mirror of
https://codeberg.org/forgejo/forgejo.git
synced 2024-11-10 12:15:43 +01:00
ce563ade3d
Some checks are pending
/ release (push) Waiting to run
testing / test-remote-cacher (map[image:registry.redict.io/redict:7.3.0-scratch port:6379]) (push) Blocked by required conditions
testing / backend-checks (push) Waiting to run
testing / frontend-checks (push) Waiting to run
testing / test-unit (push) Blocked by required conditions
testing / test-remote-cacher (map[image:ghcr.io/microsoft/garnet-alpine:1.0.14 port:6379]) (push) Blocked by required conditions
testing / test-remote-cacher (map[image:redis:7.2 port:6379]) (push) Blocked by required conditions
testing / test-mysql (push) Blocked by required conditions
testing / test-pgsql (push) Blocked by required conditions
testing / test-sqlite (push) Blocked by required conditions
testing / security-check (push) Blocked by required conditions
Reviewed-on: https://codeberg.org/forgejo/forgejo/pulls/4573 Co-authored-by: TheFox0x7 <thefox0x7@gmail.com> Co-committed-by: TheFox0x7 <thefox0x7@gmail.com>
78 lines
2.6 KiB
Go
78 lines
2.6 KiB
Go
// Copyright 2023 The Forgejo Authors. All rights reserved.
|
|
// SPDX-License-Identifier: MIT
|
|
|
|
package user_test
|
|
|
|
import (
|
|
"testing"
|
|
|
|
"code.gitea.io/gitea/models/db"
|
|
"code.gitea.io/gitea/models/unittest"
|
|
user_model "code.gitea.io/gitea/models/user"
|
|
|
|
"github.com/stretchr/testify/assert"
|
|
"github.com/stretchr/testify/require"
|
|
)
|
|
|
|
func TestIsBlocked(t *testing.T) {
|
|
require.NoError(t, unittest.PrepareTestDatabase())
|
|
assert.True(t, user_model.IsBlocked(db.DefaultContext, 4, 1))
|
|
|
|
// Simple test cases to ensure the function can also respond with false.
|
|
assert.False(t, user_model.IsBlocked(db.DefaultContext, 1, 1))
|
|
assert.False(t, user_model.IsBlocked(db.DefaultContext, 3, 2))
|
|
}
|
|
|
|
func TestIsBlockedMultiple(t *testing.T) {
|
|
require.NoError(t, unittest.PrepareTestDatabase())
|
|
assert.True(t, user_model.IsBlockedMultiple(db.DefaultContext, []int64{4}, 1))
|
|
assert.True(t, user_model.IsBlockedMultiple(db.DefaultContext, []int64{4, 3, 4, 5}, 1))
|
|
|
|
// Simple test cases to ensure the function can also respond with false.
|
|
assert.False(t, user_model.IsBlockedMultiple(db.DefaultContext, []int64{1}, 1))
|
|
assert.False(t, user_model.IsBlockedMultiple(db.DefaultContext, []int64{3, 4, 1}, 2))
|
|
}
|
|
|
|
func TestUnblockUser(t *testing.T) {
|
|
require.NoError(t, unittest.PrepareTestDatabase())
|
|
assert.True(t, user_model.IsBlocked(db.DefaultContext, 4, 1))
|
|
|
|
require.NoError(t, user_model.UnblockUser(db.DefaultContext, 4, 1))
|
|
|
|
// Simple test cases to ensure the function can also respond with false.
|
|
assert.False(t, user_model.IsBlocked(db.DefaultContext, 4, 1))
|
|
}
|
|
|
|
func TestListBlockedUsers(t *testing.T) {
|
|
require.NoError(t, unittest.PrepareTestDatabase())
|
|
|
|
blockedUsers, err := user_model.ListBlockedUsers(db.DefaultContext, 4, db.ListOptions{})
|
|
require.NoError(t, err)
|
|
if assert.Len(t, blockedUsers, 1) {
|
|
assert.EqualValues(t, 1, blockedUsers[0].ID)
|
|
// The function returns the created Unix of the block, not that of the user.
|
|
assert.EqualValues(t, 1671607299, blockedUsers[0].CreatedUnix)
|
|
}
|
|
}
|
|
|
|
func TestListBlockedByUsersID(t *testing.T) {
|
|
require.NoError(t, unittest.PrepareTestDatabase())
|
|
|
|
blockedByUserIDs, err := user_model.ListBlockedByUsersID(db.DefaultContext, 1)
|
|
require.NoError(t, err)
|
|
if assert.Len(t, blockedByUserIDs, 1) {
|
|
assert.EqualValues(t, 4, blockedByUserIDs[0])
|
|
}
|
|
}
|
|
|
|
func TestCountBlockedUsers(t *testing.T) {
|
|
require.NoError(t, unittest.PrepareTestDatabase())
|
|
|
|
count, err := user_model.CountBlockedUsers(db.DefaultContext, 4)
|
|
require.NoError(t, err)
|
|
assert.EqualValues(t, 1, count)
|
|
|
|
count, err = user_model.CountBlockedUsers(db.DefaultContext, 1)
|
|
require.NoError(t, err)
|
|
assert.EqualValues(t, 0, count)
|
|
}
|