From 61a2b91f454a6eb0dd383fc8614fee154654fa08 Mon Sep 17 00:00:00 2001 From: Vyr Cossont Date: Wed, 6 Mar 2024 02:15:58 -0800 Subject: [feature] Filters v1 (#2594) * Implement client-side v1 filters * Exclude linter false positives * Update test/envparsing.sh * Fix minor Swagger, style, and Bun usage issues * Regenerate Swagger * De-generify filter keywords * Remove updating filter statuses This is an operation that the Mastodon v2 filter API doesn't actually have, because filter statuses, unlike keywords, don't have options: the only info they contain is the status ID to be filtered. * Add a test for filter statuses specifically * De-generify filter statuses * Inline FilterEntry * Use vertical style for Bun operations consistently * Add comment on Filter DB interface * Remove GoLand linter control comments Our existing linters should catch these, or they don't matter very much * Reduce memory ratio for filters --- testrig/db.go | 21 +++++++++++++++++++++ 1 file changed, 21 insertions(+) (limited to 'testrig/db.go') diff --git a/testrig/db.go b/testrig/db.go index 17c8f83b0..a83d93b16 100644 --- a/testrig/db.go +++ b/testrig/db.go @@ -37,6 +37,9 @@ var testModels = []interface{}{ >smodel.Block{}, >smodel.DomainBlock{}, >smodel.EmailDomainBlock{}, + >smodel.Filter{}, + >smodel.FilterKeyword{}, + >smodel.FilterStatus{}, >smodel.Follow{}, >smodel.FollowRequest{}, >smodel.List{}, @@ -329,6 +332,24 @@ func StandardDBSetup(db db.DB, accounts map[string]*gtsmodel.Account) { } } + for _, v := range NewTestFilters() { + if err := db.Put(ctx, v); err != nil { + log.Panic(nil, err) + } + } + + for _, v := range NewTestFilterKeywords() { + if err := db.Put(ctx, v); err != nil { + log.Panic(nil, err) + } + } + + for _, v := range NewTestFilterStatuses() { + if err := db.Put(ctx, v); err != nil { + log.Panic(nil, err) + } + } + if err := db.CreateInstanceAccount(ctx); err != nil { log.Panic(nil, err) } -- cgit v1.2.3