mirror of
https://github.com/unmojang/drasl.git
synced 2025-09-07 14:14:46 -04:00
Test player name in use as another user's username
This commit is contained in:
parent
43f9d3d815
commit
00a56daac1
32
api_test.go
32
api_test.go
@ -3,6 +3,7 @@ package main
|
|||||||
import (
|
import (
|
||||||
"encoding/json"
|
"encoding/json"
|
||||||
"github.com/stretchr/testify/assert"
|
"github.com/stretchr/testify/assert"
|
||||||
|
"gorm.io/gorm"
|
||||||
"net/http"
|
"net/http"
|
||||||
"net/http/httptest"
|
"net/http/httptest"
|
||||||
"net/url"
|
"net/url"
|
||||||
@ -347,7 +348,10 @@ func (ts *TestSuite) testAPIGetPlayer(t *testing.T) {
|
|||||||
|
|
||||||
func (ts *TestSuite) testAPICreatePlayer(t *testing.T) {
|
func (ts *TestSuite) testAPICreatePlayer(t *testing.T) {
|
||||||
adminUsername := "admin"
|
adminUsername := "admin"
|
||||||
|
adminPlayerName := "AdminPlayer"
|
||||||
admin, _ := ts.CreateTestUser(t, ts.App, ts.Server, adminUsername)
|
admin, _ := ts.CreateTestUser(t, ts.App, ts.Server, adminUsername)
|
||||||
|
admin.Players[0].Name = adminPlayerName
|
||||||
|
assert.Nil(t, ts.App.DB.Session(&gorm.Session{FullSaveAssociations: true}).Save(&admin).Error)
|
||||||
|
|
||||||
username := "user"
|
username := "user"
|
||||||
user, _ := ts.CreateTestUser(t, ts.App, ts.Server, username)
|
user, _ := ts.CreateTestUser(t, ts.App, ts.Server, username)
|
||||||
@ -357,6 +361,7 @@ func (ts *TestSuite) testAPICreatePlayer(t *testing.T) {
|
|||||||
|
|
||||||
newName := "newPlayer"
|
newName := "newPlayer"
|
||||||
|
|
||||||
|
{
|
||||||
payload := APICreatePlayerRequest{
|
payload := APICreatePlayerRequest{
|
||||||
Name: newName,
|
Name: newName,
|
||||||
UserUUID: Ptr(user.UUID),
|
UserUUID: Ptr(user.UUID),
|
||||||
@ -386,6 +391,33 @@ func (ts *TestSuite) testAPICreatePlayer(t *testing.T) {
|
|||||||
var player Player
|
var player Player
|
||||||
assert.Nil(t, ts.App.DB.First(&player, "uuid = ?", createdAPIPlayer.UUID).Error)
|
assert.Nil(t, ts.App.DB.First(&player, "uuid = ?", createdAPIPlayer.UUID).Error)
|
||||||
assert.Equal(t, newName, player.Name)
|
assert.Equal(t, newName, player.Name)
|
||||||
|
}
|
||||||
|
{
|
||||||
|
// Player name is already in use by another player
|
||||||
|
payload := APICreatePlayerRequest{
|
||||||
|
Name: adminPlayerName,
|
||||||
|
UserUUID: Ptr(user.UUID),
|
||||||
|
}
|
||||||
|
|
||||||
|
rec := ts.PostJSON(t, ts.Server, DRASL_API_PREFIX+"/players", payload, nil, &admin.APIToken)
|
||||||
|
assert.Equal(t, http.StatusBadRequest, rec.Code)
|
||||||
|
var apiError APIError
|
||||||
|
assert.Nil(t, json.NewDecoder(rec.Body).Decode(&apiError))
|
||||||
|
assert.Equal(t, "That player name is taken.", apiError.Message)
|
||||||
|
}
|
||||||
|
{
|
||||||
|
// Player name is already in use as another user's username
|
||||||
|
payload := APICreatePlayerRequest{
|
||||||
|
Name: adminUsername,
|
||||||
|
UserUUID: Ptr(user.UUID),
|
||||||
|
}
|
||||||
|
|
||||||
|
rec := ts.PostJSON(t, ts.Server, DRASL_API_PREFIX+"/players", payload, nil, &admin.APIToken)
|
||||||
|
assert.Equal(t, http.StatusBadRequest, rec.Code)
|
||||||
|
var apiError APIError
|
||||||
|
assert.Nil(t, json.NewDecoder(rec.Body).Decode(&apiError))
|
||||||
|
assert.Equal(t, "That player name is in use as another user's username.", apiError.Message)
|
||||||
|
}
|
||||||
|
|
||||||
assert.Nil(t, ts.App.DeleteUser(&GOD, user))
|
assert.Nil(t, ts.App.DeleteUser(&GOD, user))
|
||||||
assert.Nil(t, ts.App.DeleteUser(&GOD, admin))
|
assert.Nil(t, ts.App.DeleteUser(&GOD, admin))
|
||||||
|
Loading…
x
Reference in New Issue
Block a user