summaryrefslogtreecommitdiff
path: root/testrig/testmodels.go
diff options
context:
space:
mode:
authorLibravatar Vyr Cossont <VyrCossont@users.noreply.github.com>2024-05-31 03:55:56 -0700
committerLibravatar GitHub <noreply@github.com>2024-05-31 12:55:56 +0200
commit61a8d362557c1787d534024ed2f14e999b785cc3 (patch)
treef0ace4432170c0c88afa3233c2c327c808b7b92d /testrig/testmodels.go
parent[chore] little startup tweaks (#2941) (diff)
downloadgotosocial-61a8d362557c1787d534024ed2f14e999b785cc3.tar.xz
[feature] Implement Filter API v2 (#2936)
* Use correct entity name * We support server-side filters now * Document filter v1 methods that can throw a 409 * Validate v1 filter phrase as filter title * Always check v1 filter API status codes in tests * Document keyword minimum requirement on filter API v1 * Make it possible to specify filter keyword update columns per filter keyword * Implement v2 filter API * Fix lint and tests * Update Swagger spec * Fix filter update test * Update Swagger spec *correctly* * Update actual files Swagger spec was generated from * Remove keywords_attributes and statuses_attributes * Add test for serialization of empty filter * More helpful messages when object is owned by wrong account
Diffstat (limited to 'testrig/testmodels.go')
-rw-r--r--testrig/testmodels.go49
1 files changed, 47 insertions, 2 deletions
diff --git a/testrig/testmodels.go b/testrig/testmodels.go
index 9ebd400e4..956c898c0 100644
--- a/testrig/testmodels.go
+++ b/testrig/testmodels.go
@@ -3288,6 +3288,26 @@ func NewTestFilters() map[string]*gtsmodel.Filter {
ContextHome: util.Ptr(true),
ContextPublic: util.Ptr(true),
},
+ "local_account_1_filter_3": {
+ ID: "01HWXQDXE4QX4R9EGMG729Y76C",
+ CreatedAt: TimeMustParse("2024-01-25T12:20:03+02:00"),
+ UpdatedAt: TimeMustParse("2024-01-25T12:20:03+02:00"),
+ AccountID: "01F8MH1H7YV1Z7D2C8K2730QBF",
+ Title: "puppies",
+ Action: gtsmodel.FilterActionWarn,
+ ContextHome: util.Ptr(true),
+ ContextPublic: util.Ptr(true),
+ },
+ "local_account_1_filter_4": {
+ ID: "01HZ55WWWP82WYP2A1BKWK8Y9Q",
+ CreatedAt: TimeMustParse("2024-01-25T12:20:03+02:00"),
+ UpdatedAt: TimeMustParse("2024-01-25T12:20:03+02:00"),
+ AccountID: "01F8MH1H7YV1Z7D2C8K2730QBF",
+ Title: "empty filter with no keywords or statuses",
+ Action: gtsmodel.FilterActionWarn,
+ ContextHome: util.Ptr(true),
+ ContextPublic: util.Ptr(true),
+ },
"local_account_2_filter_1": {
ID: "01HNGFYJBED9FS0VWRVMY4TKXH",
CreatedAt: TimeMustParse("2024-01-25T12:20:03+02:00"),
@@ -3330,6 +3350,15 @@ func NewTestFilterKeywords() map[string]*gtsmodel.FilterKeyword {
Keyword: "bar",
WholeWord: util.Ptr(true),
},
+ "local_account_1_filter_2_keyword_3": {
+ ID: "01HXATJTGYT4BTG2YASE5M7GSD",
+ CreatedAt: TimeMustParse("2024-01-25T12:20:03+02:00"),
+ UpdatedAt: TimeMustParse("2024-01-25T12:20:03+02:00"),
+ AccountID: "01F8MH1H7YV1Z7D2C8K2730QBF",
+ FilterID: "01HN277FSPQAWXZXK92QPPYF79",
+ Keyword: "quux",
+ WholeWord: util.Ptr(true),
+ },
"local_account_2_filter_1_keyword_1": {
ID: "01HNGG51HV2JT67XQ5MQ7RA1WE",
CreatedAt: TimeMustParse("2024-01-25T12:20:03+02:00"),
@@ -3343,8 +3372,24 @@ func NewTestFilterKeywords() map[string]*gtsmodel.FilterKeyword {
}
func NewTestFilterStatuses() map[string]*gtsmodel.FilterStatus {
- // FUTURE: (filters v2) test filter statuses
- return map[string]*gtsmodel.FilterStatus{}
+ return map[string]*gtsmodel.FilterStatus{
+ "local_account_1_filter_3_status_1": {
+ ID: "01HWXQDY8EE182AWQKS45JV50W",
+ CreatedAt: time.Time{},
+ UpdatedAt: time.Time{},
+ AccountID: "01F8MH1H7YV1Z7D2C8K2730QBF",
+ FilterID: "01HWXQDXE4QX4R9EGMG729Y76C",
+ StatusID: "01F8MHAAY43M6RJ473VQFCVH37",
+ },
+ "local_account_2_filter_1_status_1": {
+ ID: "01HX9WXVEH05E78ABR81FZFFFY",
+ CreatedAt: time.Time{},
+ UpdatedAt: time.Time{},
+ AccountID: "01F8MH1VYJAE00TVVGMM5JNJ8X",
+ FilterID: "01HNGFYJBED9FS0VWRVMY4TKXH",
+ StatusID: "01FVW7JHQFSFK166WWKR8CBA6M",
+ },
+ }
}
// GetSignatureForActivity prepares a mock HTTP request as if it were going to deliver activity to destination signed for privkey and pubKeyID, signs the request and returns the header values.