Show user OpenID URIs in their profile (#1314)
parent
e1586898b2
commit
9182a35f18
@ -0,0 +1,17 @@
|
|||||||
|
-
|
||||||
|
id: 1
|
||||||
|
uid: 1
|
||||||
|
uri: https://user1.domain1.tld/
|
||||||
|
show: false
|
||||||
|
|
||||||
|
-
|
||||||
|
id: 2
|
||||||
|
uid: 1
|
||||||
|
uri: http://user1.domain2.tld/
|
||||||
|
show: true
|
||||||
|
|
||||||
|
-
|
||||||
|
id: 3
|
||||||
|
uid: 2
|
||||||
|
uri: https://domain1.tld/user2/
|
||||||
|
show: true
|
@ -0,0 +1,18 @@
|
|||||||
|
// Copyright 2017 Gitea. All rights reserved.
|
||||||
|
// Use of this source code is governed by a MIT-style
|
||||||
|
// license that can be found in the LICENSE file.
|
||||||
|
|
||||||
|
package migrations
|
||||||
|
|
||||||
|
import (
|
||||||
|
"fmt"
|
||||||
|
|
||||||
|
"github.com/go-xorm/xorm"
|
||||||
|
)
|
||||||
|
|
||||||
|
func addUserOpenIDShow(x *xorm.Engine) error {
|
||||||
|
if err := x.Sync2(new(UserOpenID)); err != nil {
|
||||||
|
return fmt.Errorf("Sync2: %v", err)
|
||||||
|
}
|
||||||
|
return nil
|
||||||
|
}
|
@ -0,0 +1,82 @@
|
|||||||
|
// Copyright 2017 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 models
|
||||||
|
|
||||||
|
import (
|
||||||
|
"testing"
|
||||||
|
|
||||||
|
"github.com/stretchr/testify/assert"
|
||||||
|
)
|
||||||
|
|
||||||
|
func TestGetUserOpenIDs(t *testing.T) {
|
||||||
|
assert.NoError(t, PrepareTestDatabase())
|
||||||
|
|
||||||
|
oids, err := GetUserOpenIDs(int64(1))
|
||||||
|
if assert.NoError(t, err) {
|
||||||
|
assert.Len(t, oids, 2)
|
||||||
|
assert.Equal(t, oids[0].URI, "https://user1.domain1.tld/")
|
||||||
|
assert.False(t, oids[0].Show)
|
||||||
|
assert.Equal(t, oids[1].URI, "http://user1.domain2.tld/")
|
||||||
|
assert.True(t, oids[1].Show)
|
||||||
|
}
|
||||||
|
|
||||||
|
oids, err = GetUserOpenIDs(int64(2))
|
||||||
|
if assert.NoError(t, err) {
|
||||||
|
assert.Len(t, oids, 1)
|
||||||
|
assert.Equal(t, oids[0].URI, "https://domain1.tld/user2/")
|
||||||
|
assert.True(t, oids[0].Show)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestGetUserByOpenID(t *testing.T) {
|
||||||
|
assert.NoError(t, PrepareTestDatabase())
|
||||||
|
|
||||||
|
user, err := GetUserByOpenID("https://unknown")
|
||||||
|
if assert.Error(t, err) {
|
||||||
|
assert.True(t, IsErrUserNotExist(err))
|
||||||
|
}
|
||||||
|
|
||||||
|
user, err = GetUserByOpenID("https://user1.domain1.tld")
|
||||||
|
if assert.NoError(t, err) {
|
||||||
|
assert.Equal(t, user.ID, int64(1))
|
||||||
|
}
|
||||||
|
|
||||||
|
user, err = GetUserByOpenID("https://domain1.tld/user2/")
|
||||||
|
if assert.NoError(t, err) {
|
||||||
|
assert.Equal(t, user.ID, int64(2))
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestToggleUserOpenIDVisibility(t *testing.T) {
|
||||||
|
assert.NoError(t, PrepareTestDatabase())
|
||||||
|
oids, err := GetUserOpenIDs(int64(2))
|
||||||
|
if ! assert.NoError(t, err) {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
assert.Len(t, oids, 1)
|
||||||
|
assert.True(t, oids[0].Show)
|
||||||
|
|
||||||
|
err = ToggleUserOpenIDVisibility(oids[0].ID)
|
||||||
|
if ! assert.NoError(t, err) {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
oids, err = GetUserOpenIDs(int64(2))
|
||||||
|
if assert.NoError(t, err) {
|
||||||
|
assert.Len(t, oids, 1)
|
||||||
|
assert.False(t, oids[0].Show)
|
||||||
|
}
|
||||||
|
err = ToggleUserOpenIDVisibility(oids[0].ID)
|
||||||
|
if ! assert.NoError(t, err) {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
oids, err = GetUserOpenIDs(int64(2))
|
||||||
|
if ! assert.NoError(t, err) {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
assert.Len(t, oids, 1)
|
||||||
|
assert.True(t, oids[0].Show)
|
||||||
|
}
|
Loading…
Reference in new issue