mirror of
				https://github.com/superseriousbusiness/gotosocial.git
				synced 2025-10-30 19:42:26 -05: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
 | |
| }
 |