org_users_test.go 1.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263
  1. // Copyright 2022 The Gogs Authors. All rights reserved.
  2. // Use of this source code is governed by a MIT-style
  3. // license that can be found in the LICENSE file.
  4. package db
  5. import (
  6. "context"
  7. "testing"
  8. "github.com/stretchr/testify/assert"
  9. "github.com/stretchr/testify/require"
  10. "gogs.io/gogs/internal/dbtest"
  11. )
  12. func TestOrgUsers(t *testing.T) {
  13. if testing.Short() {
  14. t.Skip()
  15. }
  16. t.Parallel()
  17. tables := []any{new(OrgUser)}
  18. db := &orgUsers{
  19. DB: dbtest.NewDB(t, "orgUsers", tables...),
  20. }
  21. for _, tc := range []struct {
  22. name string
  23. test func(t *testing.T, db *orgUsers)
  24. }{
  25. {"CountByUser", orgUsersCountByUser},
  26. } {
  27. t.Run(tc.name, func(t *testing.T) {
  28. t.Cleanup(func() {
  29. err := clearTables(t, db.DB, tables...)
  30. require.NoError(t, err)
  31. })
  32. tc.test(t, db)
  33. })
  34. if t.Failed() {
  35. break
  36. }
  37. }
  38. }
  39. func orgUsersCountByUser(t *testing.T, db *orgUsers) {
  40. ctx := context.Background()
  41. // TODO: Use OrgUsers.Join to replace SQL hack when the method is available.
  42. err := db.Exec(`INSERT INTO org_user (uid, org_id) VALUES (?, ?)`, 1, 1).Error
  43. require.NoError(t, err)
  44. err = db.Exec(`INSERT INTO org_user (uid, org_id) VALUES (?, ?)`, 2, 1).Error
  45. require.NoError(t, err)
  46. got, err := db.CountByUser(ctx, 1)
  47. require.NoError(t, err)
  48. assert.Equal(t, int64(1), got)
  49. got, err = db.CountByUser(ctx, 404)
  50. require.NoError(t, err)
  51. assert.Equal(t, int64(0), got)
  52. }