mirror of
				https://github.com/superseriousbusiness/gotosocial.git
				synced 2025-11-03 17:42:25 -06:00 
			
		
		
		
	* only fetch status parents / children if explicity requested when dereferencing Signed-off-by: kim (grufwub) <grufwub@gmail.com> * Remove recursive DB GetStatus logic, don't fetch parent unless requested Signed-off-by: kim (grufwub) <grufwub@gmail.com> * StatusCache copies status so there are no thread-safety issues with modified status objects Signed-off-by: kim (grufwub) <grufwub@gmail.com> * remove sqlite test files Signed-off-by: kim (grufwub) <grufwub@gmail.com> * fix bugs introduced by previous commit Signed-off-by: kim (grufwub) <grufwub@gmail.com> * fix not continue on error in loop Signed-off-by: kim (grufwub) <grufwub@gmail.com> * use our own RunInTx implementation (possible fix for nested tx error) Signed-off-by: kim (grufwub) <grufwub@gmail.com> * fix cast statement to work with SQLite Signed-off-by: kim (grufwub) <grufwub@gmail.com> * be less strict about valid status in cache Signed-off-by: kim (grufwub) <grufwub@gmail.com> * add cache=shared ALWAYS for SQLite db instances Signed-off-by: kim (grufwub) <grufwub@gmail.com> * Fix EnrichRemoteAccount when updating account fails Signed-off-by: kim (grufwub) <grufwub@gmail.com> * add nolint tag Signed-off-by: kim (grufwub) <grufwub@gmail.com> * ensure file: prefixes the filename in sqlite addr Signed-off-by: kim (grufwub) <grufwub@gmail.com> * add an account cache, add status author account from db Signed-off-by: kim (grufwub) <grufwub@gmail.com> * Fix incompatible SQLite query Signed-off-by: kim (grufwub) <grufwub@gmail.com> * *actually* use the new getAccount() function in accountsDB Signed-off-by: kim (grufwub) <grufwub@gmail.com> * update cache tests to use test suite Signed-off-by: kim (grufwub) <grufwub@gmail.com> * add RelationshipTestSuite, add tests for methods with changed SQL Signed-off-by: kim (grufwub) <grufwub@gmail.com>
		
			
				
	
	
		
			63 lines
		
	
	
	
		
			1.7 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			63 lines
		
	
	
	
		
			1.7 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
package cache_test
 | 
						|
 | 
						|
import (
 | 
						|
	"testing"
 | 
						|
 | 
						|
	"github.com/stretchr/testify/suite"
 | 
						|
	"github.com/superseriousbusiness/gotosocial/internal/cache"
 | 
						|
	"github.com/superseriousbusiness/gotosocial/internal/gtsmodel"
 | 
						|
	"github.com/superseriousbusiness/gotosocial/testrig"
 | 
						|
)
 | 
						|
 | 
						|
type AccountCacheTestSuite struct {
 | 
						|
	suite.Suite
 | 
						|
	data  map[string]*gtsmodel.Account
 | 
						|
	cache *cache.AccountCache
 | 
						|
}
 | 
						|
 | 
						|
func (suite *AccountCacheTestSuite) SetupSuite() {
 | 
						|
	suite.data = testrig.NewTestAccounts()
 | 
						|
}
 | 
						|
 | 
						|
func (suite *AccountCacheTestSuite) SetupTest() {
 | 
						|
	suite.cache = cache.NewAccountCache()
 | 
						|
}
 | 
						|
 | 
						|
func (suite *AccountCacheTestSuite) TearDownTest() {
 | 
						|
	suite.data = nil
 | 
						|
	suite.cache = nil
 | 
						|
}
 | 
						|
 | 
						|
func (suite *AccountCacheTestSuite) TestAccountCache() {
 | 
						|
	for _, account := range suite.data {
 | 
						|
		// Place in the cache
 | 
						|
		suite.cache.Put(account)
 | 
						|
	}
 | 
						|
 | 
						|
	for _, account := range suite.data {
 | 
						|
		var ok bool
 | 
						|
		var check *gtsmodel.Account
 | 
						|
 | 
						|
		// Check we can retrieve
 | 
						|
		check, ok = suite.cache.GetByID(account.ID)
 | 
						|
		if !ok && !accountIs(account, check) {
 | 
						|
			suite.Fail("Failed to fetch expected account with ID: %s", account.ID)
 | 
						|
		}
 | 
						|
		check, ok = suite.cache.GetByURI(account.URI)
 | 
						|
		if account.URI != "" && !ok && !accountIs(account, check) {
 | 
						|
			suite.Fail("Failed to fetch expected account with URI: %s", account.URI)
 | 
						|
		}
 | 
						|
		check, ok = suite.cache.GetByURL(account.URL)
 | 
						|
		if account.URL != "" && !ok && !accountIs(account, check) {
 | 
						|
			suite.Fail("Failed to fetch expected account with URL: %s", account.URL)
 | 
						|
		}
 | 
						|
	}
 | 
						|
}
 | 
						|
 | 
						|
func TestAccountCache(t *testing.T) {
 | 
						|
	suite.Run(t, &AccountCacheTestSuite{})
 | 
						|
}
 | 
						|
 | 
						|
func accountIs(account1, account2 *gtsmodel.Account) bool {
 | 
						|
	return account1.ID == account2.ID && account1.URI == account2.URI && account1.URL == account2.URL
 | 
						|
}
 |