mirror of
https://github.com/superseriousbusiness/gotosocial
synced 2025-01-08 14:31:31 +01:00
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>
64 lines
1.6 KiB
Go
64 lines
1.6 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 StatusCacheTestSuite struct {
|
|
suite.Suite
|
|
data map[string]*gtsmodel.Status
|
|
cache *cache.StatusCache
|
|
}
|
|
|
|
func (suite *StatusCacheTestSuite) SetupSuite() {
|
|
suite.data = testrig.NewTestStatuses()
|
|
}
|
|
|
|
func (suite *StatusCacheTestSuite) SetupTest() {
|
|
suite.cache = cache.NewStatusCache()
|
|
}
|
|
|
|
func (suite *StatusCacheTestSuite) TearDownTest() {
|
|
suite.data = nil
|
|
suite.cache = nil
|
|
}
|
|
|
|
func (suite *StatusCacheTestSuite) TestStatusCache() {
|
|
for _, status := range suite.data {
|
|
// Place in the cache
|
|
suite.cache.Put(status)
|
|
}
|
|
|
|
for _, status := range suite.data {
|
|
var ok bool
|
|
var check *gtsmodel.Status
|
|
|
|
// Check we can retrieve
|
|
check, ok = suite.cache.GetByID(status.ID)
|
|
if !ok && !statusIs(status, check) {
|
|
suite.Fail("Failed to fetch expected account with ID: %s", status.ID)
|
|
}
|
|
check, ok = suite.cache.GetByURI(status.URI)
|
|
if status.URI != "" && !ok && !statusIs(status, check) {
|
|
suite.Fail("Failed to fetch expected account with URI: %s", status.URI)
|
|
}
|
|
check, ok = suite.cache.GetByURL(status.URL)
|
|
if status.URL != "" && !ok && !statusIs(status, check) {
|
|
suite.Fail("Failed to fetch expected account with URL: %s", status.URL)
|
|
}
|
|
}
|
|
}
|
|
|
|
func TestStatusCache(t *testing.T) {
|
|
suite.Run(t, &StatusCacheTestSuite{})
|
|
}
|
|
|
|
func statusIs(status1, status2 *gtsmodel.Status) bool {
|
|
return status1.ID == status2.ID && status1.URI == status2.URI && status1.URL == status2.URL
|
|
}
|