summaryrefslogtreecommitdiffstats
path: root/models/auth/webauthn_test.go
diff options
context:
space:
mode:
authorLunny Xiao <xiaolunwen@gmail.com>2022-01-14 23:03:31 +0800
committerGitHub <noreply@github.com>2022-01-14 16:03:31 +0100
commit35c3553870e35b2e7cfcc599645791acda6afcef (patch)
tree0ad600c2d1cd94ef12566482832768c9efcf8a69 /models/auth/webauthn_test.go
parent8808293247bebd20482c3c625c64937174503781 (diff)
downloadgitea-35c3553870e35b2e7cfcc599645791acda6afcef.tar.gz
gitea-35c3553870e35b2e7cfcc599645791acda6afcef.zip
Support webauthn (#17957)
Migrate from U2F to Webauthn Co-authored-by: Andrew Thornton <art27@cantab.net> Co-authored-by: 6543 <6543@obermui.de> Co-authored-by: wxiaoguang <wxiaoguang@gmail.com>
Diffstat (limited to 'models/auth/webauthn_test.go')
-rw-r--r--models/auth/webauthn_test.go69
1 files changed, 69 insertions, 0 deletions
diff --git a/models/auth/webauthn_test.go b/models/auth/webauthn_test.go
new file mode 100644
index 0000000000..572636dbbf
--- /dev/null
+++ b/models/auth/webauthn_test.go
@@ -0,0 +1,69 @@
+// Copyright 2020 The Gitea Authors. All rights reserved.
+// Use of this source code is governed by a MIT-style
+// license that can be found in the LICENSE file.
+
+package auth
+
+import (
+ "encoding/base64"
+ "testing"
+
+ "code.gitea.io/gitea/models/unittest"
+
+ "github.com/duo-labs/webauthn/webauthn"
+ "github.com/stretchr/testify/assert"
+)
+
+func TestGetWebAuthnCredentialByID(t *testing.T) {
+ assert.NoError(t, unittest.PrepareTestDatabase())
+
+ res, err := GetWebAuthnCredentialByID(1)
+ assert.NoError(t, err)
+ assert.Equal(t, "WebAuthn credential", res.Name)
+
+ _, err = GetWebAuthnCredentialByID(342432)
+ assert.Error(t, err)
+ assert.True(t, IsErrWebAuthnCredentialNotExist(err))
+}
+
+func TestGetWebAuthnCredentialsByUID(t *testing.T) {
+ assert.NoError(t, unittest.PrepareTestDatabase())
+
+ res, err := GetWebAuthnCredentialsByUID(32)
+ assert.NoError(t, err)
+ assert.Len(t, res, 1)
+ assert.Equal(t, "WebAuthn credential", res[0].Name)
+}
+
+func TestWebAuthnCredential_TableName(t *testing.T) {
+ assert.Equal(t, "webauthn_credential", WebAuthnCredential{}.TableName())
+}
+
+func TestWebAuthnCredential_UpdateSignCount(t *testing.T) {
+ assert.NoError(t, unittest.PrepareTestDatabase())
+ cred := unittest.AssertExistsAndLoadBean(t, &WebAuthnCredential{ID: 1}).(*WebAuthnCredential)
+ cred.SignCount = 1
+ assert.NoError(t, cred.UpdateSignCount())
+ unittest.AssertExistsIf(t, true, &WebAuthnCredential{ID: 1, SignCount: 1})
+}
+
+func TestWebAuthnCredential_UpdateLargeCounter(t *testing.T) {
+ assert.NoError(t, unittest.PrepareTestDatabase())
+ cred := unittest.AssertExistsAndLoadBean(t, &WebAuthnCredential{ID: 1}).(*WebAuthnCredential)
+ cred.SignCount = 0xffffffff
+ assert.NoError(t, cred.UpdateSignCount())
+ unittest.AssertExistsIf(t, true, &WebAuthnCredential{ID: 1, SignCount: 0xffffffff})
+}
+
+func TestCreateCredential(t *testing.T) {
+ assert.NoError(t, unittest.PrepareTestDatabase())
+
+ res, err := CreateCredential(1, "WebAuthn Created Credential", &webauthn.Credential{ID: []byte("Test")})
+ assert.NoError(t, err)
+ assert.Equal(t, "WebAuthn Created Credential", res.Name)
+ bs, err := base64.RawStdEncoding.DecodeString(res.CredentialID)
+ assert.NoError(t, err)
+ assert.Equal(t, []byte("Test"), bs)
+
+ unittest.AssertExistsIf(t, true, &WebAuthnCredential{Name: "WebAuthn Created Credential", UserID: 1})
+}