two_factors_test.go 2.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596
  1. // Copyright 2020 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. "time"
  9. "github.com/stretchr/testify/assert"
  10. "github.com/stretchr/testify/require"
  11. "gogs.io/gogs/internal/errutil"
  12. )
  13. func TestTwoFactors(t *testing.T) {
  14. if testing.Short() {
  15. t.Skip()
  16. }
  17. t.Parallel()
  18. tables := []interface{}{new(TwoFactor), new(TwoFactorRecoveryCode)}
  19. db := &twoFactors{
  20. DB: initTestDB(t, "twoFactors", tables...),
  21. }
  22. for _, tc := range []struct {
  23. name string
  24. test func(*testing.T, *twoFactors)
  25. }{
  26. {"Create", twoFactorsCreate},
  27. {"GetByUserID", twoFactorsGetByUserID},
  28. {"IsUserEnabled", twoFactorsIsUserEnabled},
  29. } {
  30. t.Run(tc.name, func(t *testing.T) {
  31. t.Cleanup(func() {
  32. err := clearTables(t, db.DB, tables...)
  33. require.NoError(t, err)
  34. })
  35. tc.test(t, db)
  36. })
  37. if t.Failed() {
  38. break
  39. }
  40. }
  41. }
  42. func twoFactorsCreate(t *testing.T, db *twoFactors) {
  43. ctx := context.Background()
  44. // Create a 2FA token
  45. err := db.Create(ctx, 1, "secure-key", "secure-secret")
  46. require.NoError(t, err)
  47. // Get it back and check the Created field
  48. tf, err := db.GetByUserID(ctx, 1)
  49. require.NoError(t, err)
  50. assert.Equal(t, db.NowFunc().Format(time.RFC3339), tf.Created.UTC().Format(time.RFC3339))
  51. // Verify there are 10 recover codes generated
  52. var count int64
  53. err = db.Model(new(TwoFactorRecoveryCode)).Count(&count).Error
  54. require.NoError(t, err)
  55. assert.Equal(t, int64(10), count)
  56. }
  57. func twoFactorsGetByUserID(t *testing.T, db *twoFactors) {
  58. ctx := context.Background()
  59. // Create a 2FA token for user 1
  60. err := db.Create(ctx, 1, "secure-key", "secure-secret")
  61. require.NoError(t, err)
  62. // We should be able to get it back
  63. _, err = db.GetByUserID(ctx, 1)
  64. require.NoError(t, err)
  65. // Try to get a non-existent 2FA token
  66. _, err = db.GetByUserID(ctx, 2)
  67. wantErr := ErrTwoFactorNotFound{args: errutil.Args{"userID": int64(2)}}
  68. assert.Equal(t, wantErr, err)
  69. }
  70. func twoFactorsIsUserEnabled(t *testing.T, db *twoFactors) {
  71. ctx := context.Background()
  72. // Create a 2FA token for user 1
  73. err := db.Create(ctx, 1, "secure-key", "secure-secret")
  74. require.NoError(t, err)
  75. assert.True(t, db.IsUserEnabled(ctx, 1))
  76. assert.False(t, db.IsUserEnabled(ctx, 2))
  77. }