mirror of
https://github.com/superseriousbusiness/gotosocial.git
synced 2025-10-29 06:42:25 -05:00
[performance] cache mute check results (#4202)
This separates our the user mute handling from the typeconverter code, and creates a new "mutes" filter type (in a similar vein to the visibility filter) subpkg with its own result cache. This is a heavy mix of both chore given that mute calculation shouldn't have been handled in the conversion to frontend API types, and a performance bonus since we don't need to load and calculate so many things each time, just the single result each time with all necessary invalidation handled by database cache hooks. Reviewed-on: https://codeberg.org/superseriousbusiness/gotosocial/pulls/4202 Co-authored-by: kim <grufwub@gmail.com> Co-committed-by: kim <grufwub@gmail.com>
This commit is contained in:
parent
a82d574acc
commit
faed35c938
65 changed files with 1645 additions and 766 deletions
|
|
@ -24,6 +24,7 @@ import (
|
|||
"testing"
|
||||
|
||||
apimodel "code.superseriousbusiness.org/gotosocial/internal/api/model"
|
||||
"code.superseriousbusiness.org/gotosocial/internal/filter/mutes"
|
||||
"code.superseriousbusiness.org/gotosocial/internal/filter/visibility"
|
||||
"code.superseriousbusiness.org/gotosocial/internal/gtserror"
|
||||
"code.superseriousbusiness.org/gotosocial/internal/gtsmodel"
|
||||
|
|
@ -38,9 +39,10 @@ import (
|
|||
|
||||
type PollTestSuite struct {
|
||||
suite.Suite
|
||||
state state.State
|
||||
filter *visibility.Filter
|
||||
polls polls.Processor
|
||||
state state.State
|
||||
visFilter *visibility.Filter
|
||||
muteFilter *mutes.Filter
|
||||
polls polls.Processor
|
||||
|
||||
testAccounts map[string]*gtsmodel.Account
|
||||
testPolls map[string]*gtsmodel.Poll
|
||||
|
|
@ -56,8 +58,9 @@ func (suite *PollTestSuite) SetupTest() {
|
|||
controller := testrig.NewTestTransportController(&suite.state, nil)
|
||||
mediaMgr := media.NewManager(&suite.state)
|
||||
federator := testrig.NewTestFederator(&suite.state, controller, mediaMgr)
|
||||
suite.filter = visibility.NewFilter(&suite.state)
|
||||
common := common.New(&suite.state, mediaMgr, converter, federator, suite.filter)
|
||||
suite.visFilter = visibility.NewFilter(&suite.state)
|
||||
suite.muteFilter = mutes.NewFilter(&suite.state)
|
||||
common := common.New(&suite.state, mediaMgr, converter, federator, suite.visFilter, suite.muteFilter)
|
||||
suite.polls = polls.New(&common, &suite.state, converter)
|
||||
}
|
||||
|
||||
|
|
@ -88,7 +91,7 @@ func (suite *PollTestSuite) testPollGet(ctx context.Context, requester *gtsmodel
|
|||
var check func(*apimodel.Poll, gtserror.WithCode) bool
|
||||
|
||||
switch {
|
||||
case !pollIsVisible(suite.filter, ctx, requester, poll):
|
||||
case !pollIsVisible(suite.visFilter, ctx, requester, poll):
|
||||
// Poll should not be visible to requester, this should
|
||||
// return an error code 404 (to prevent info leak).
|
||||
check = func(poll *apimodel.Poll, err gtserror.WithCode) bool {
|
||||
|
|
@ -188,7 +191,7 @@ func (suite *PollTestSuite) testPollVote(ctx context.Context, requester *gtsmode
|
|||
return poll == nil && err.Code() == http.StatusUnprocessableEntity
|
||||
}
|
||||
|
||||
case !pollIsVisible(suite.filter, ctx, requester, poll):
|
||||
case !pollIsVisible(suite.visFilter, ctx, requester, poll):
|
||||
// Poll should not be visible to requester, this should
|
||||
// return an error code 404 (to prevent info leak).
|
||||
check = func(poll *apimodel.Poll, err gtserror.WithCode) bool {
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue