summaryrefslogtreecommitdiff
path: root/internal/db/bundb/filterstatus_test.go
blob: 48ddb1bed4bb1c3a11abaf84c4abc2001bfc9144 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
// GoToSocial
// Copyright (C) GoToSocial Authors admin@gotosocial.org
// SPDX-License-Identifier: AGPL-3.0-or-later
//
// This program is free software: you can redistribute it and/or modify
// it under the terms of the GNU Affero General Public License as published by
// the Free Software Foundation, either version 3 of the License, or
// (at your option) any later version.
//
// This program is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
// GNU Affero General Public License for more details.
//
// You should have received a copy of the GNU Affero General Public License
// along with this program.  If not, see <http://www.gnu.org/licenses/>.

package bundb_test

import (
	"context"
	"errors"

	"github.com/superseriousbusiness/gotosocial/internal/db"
	"github.com/superseriousbusiness/gotosocial/internal/gtsmodel"
	"github.com/superseriousbusiness/gotosocial/internal/util"
)

// TestFilterStatusCRD tests CRD (no U) and read-all operations on filter statuses.
func (suite *FilterTestSuite) TestFilterStatusCRD() {
	t := suite.T()

	// Create new filter.
	filter := &gtsmodel.Filter{
		ID:            "01HNEJNVZZVXJTRB3FX3K2B1YF",
		AccountID:     "01HNEJXCPRTJVJY9MV0VVHGD47",
		Title:         "foss jail",
		Action:        gtsmodel.FilterActionWarn,
		ContextHome:   util.Ptr(true),
		ContextPublic: util.Ptr(true),
	}

	// Create new cancellable test context.
	ctx := context.Background()
	ctx, cncl := context.WithCancel(ctx)
	defer cncl()

	// Insert the new filter into the DB.
	err := suite.db.PutFilter(ctx, filter)
	if err != nil {
		t.Fatalf("error inserting filter: %v", err)
	}

	// There should be no filter statuses yet.
	all, err := suite.db.GetFilterStatusesForAccountID(ctx, filter.AccountID)
	if err != nil {
		t.Fatalf("error fetching filter statuses: %v", err)
	}
	suite.Empty(all)

	// Add a filter status to it.
	filterStatus := &gtsmodel.FilterStatus{
		ID:        "01HNEK4RW5QEAMG9Y4ET6ST0J4",
		AccountID: filter.AccountID,
		FilterID:  filter.ID,
		StatusID:  "01HQXGMQ3QFXRT4GX9WNQ8KC0X",
	}

	// Insert the new filter status into the DB.
	err = suite.db.PutFilterStatus(ctx, filterStatus)
	if err != nil {
		t.Fatalf("error inserting filter status: %v", err)
	}

	// Try to find it again and ensure it has the fields we expect.
	check, err := suite.db.GetFilterStatusByID(ctx, filterStatus.ID)
	if err != nil {
		t.Fatalf("error fetching filter status: %v", err)
	}
	suite.Equal(filterStatus.ID, check.ID)
	suite.NotZero(check.CreatedAt)
	suite.NotZero(check.UpdatedAt)
	suite.Equal(filterStatus.AccountID, check.AccountID)
	suite.Equal(filterStatus.FilterID, check.FilterID)
	suite.Equal(filterStatus.StatusID, check.StatusID)

	// Loading filter statuses by account ID should find the one we inserted.
	all, err = suite.db.GetFilterStatusesForAccountID(ctx, filter.AccountID)
	if err != nil {
		t.Fatalf("error fetching filter statuses: %v", err)
	}
	suite.Len(all, 1)
	suite.Equal(filterStatus.ID, all[0].ID)

	// Loading filter statuses by filter ID should also find the one we inserted.
	all, err = suite.db.GetFilterStatusesForFilterID(ctx, filter.ID)
	if err != nil {
		t.Fatalf("error fetching filter statuses: %v", err)
	}
	suite.Len(all, 1)
	suite.Equal(filterStatus.ID, all[0].ID)

	// Delete the filter status from the DB.
	err = suite.db.DeleteFilterStatusByID(ctx, filter.ID)
	if err != nil {
		t.Fatalf("error deleting filter status: %v", err)
	}

	// Ensure we can't refetch it.
	check, err = suite.db.GetFilterStatusByID(ctx, filter.ID)
	if !errors.Is(err, db.ErrNoEntries) {
		t.Fatalf("fetching deleted filter status returned unexpected error: %v", err)
	}
	suite.Nil(check)

	// Ensure the filter itself is still there.
	checkFilter, err := suite.db.GetFilterByID(ctx, filter.ID)
	if err != nil {
		t.Fatalf("error fetching filter: %v", err)
	}
	suite.Equal(filter.ID, checkFilter.ID)
}