forked from mirrors/gotosocial
7d193de25f
* 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
|
|
}
|