2021-08-10 04:57:45 +02:00
|
|
|
package integrationtests
|
|
|
|
|
|
|
|
import (
|
|
|
|
"bytes"
|
|
|
|
"crypto/rand"
|
|
|
|
"testing"
|
|
|
|
|
2022-03-22 16:24:34 +02:00
|
|
|
"github.com/mattermost/focalboard/server/model"
|
2021-08-10 04:57:45 +02:00
|
|
|
"github.com/mattermost/focalboard/server/utils"
|
|
|
|
"github.com/stretchr/testify/require"
|
|
|
|
)
|
|
|
|
|
|
|
|
const (
|
|
|
|
fakeUsername = "fakeUsername"
|
|
|
|
fakeEmail = "mock@test.com"
|
|
|
|
)
|
|
|
|
|
|
|
|
func TestUserRegister(t *testing.T) {
|
2022-03-22 16:24:34 +02:00
|
|
|
th := SetupTestHelper(t).Start()
|
2021-08-10 04:57:45 +02:00
|
|
|
defer th.TearDown()
|
|
|
|
|
|
|
|
// register
|
2022-08-10 14:20:42 +02:00
|
|
|
registerRequest := &model.RegisterRequest{
|
2021-08-10 04:57:45 +02:00
|
|
|
Username: fakeUsername,
|
|
|
|
Email: fakeEmail,
|
2021-10-05 15:52:59 +02:00
|
|
|
Password: utils.NewID(utils.IDTypeNone),
|
2021-08-10 04:57:45 +02:00
|
|
|
}
|
|
|
|
success, resp := th.Client.Register(registerRequest)
|
|
|
|
require.NoError(t, resp.Error)
|
|
|
|
require.True(t, success)
|
|
|
|
|
2022-03-22 16:24:34 +02:00
|
|
|
// register again will fail
|
2021-08-10 04:57:45 +02:00
|
|
|
success, resp = th.Client.Register(registerRequest)
|
|
|
|
require.Error(t, resp.Error)
|
|
|
|
require.False(t, success)
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestUserLogin(t *testing.T) {
|
2022-03-22 16:24:34 +02:00
|
|
|
th := SetupTestHelper(t).Start()
|
2021-08-10 04:57:45 +02:00
|
|
|
defer th.TearDown()
|
|
|
|
|
|
|
|
t.Run("with nonexist user", func(t *testing.T) {
|
2022-08-10 14:20:42 +02:00
|
|
|
loginRequest := &model.LoginRequest{
|
2021-08-10 04:57:45 +02:00
|
|
|
Type: "normal",
|
|
|
|
Username: "nonexistuser",
|
|
|
|
Email: "",
|
2021-10-05 15:52:59 +02:00
|
|
|
Password: utils.NewID(utils.IDTypeNone),
|
2021-08-10 04:57:45 +02:00
|
|
|
}
|
|
|
|
data, resp := th.Client.Login(loginRequest)
|
|
|
|
require.Error(t, resp.Error)
|
|
|
|
require.Nil(t, data)
|
|
|
|
})
|
|
|
|
|
|
|
|
t.Run("with registered user", func(t *testing.T) {
|
2021-10-05 15:52:59 +02:00
|
|
|
password := utils.NewID(utils.IDTypeNone)
|
2021-08-10 04:57:45 +02:00
|
|
|
// register
|
2022-08-10 14:20:42 +02:00
|
|
|
registerRequest := &model.RegisterRequest{
|
2021-08-10 04:57:45 +02:00
|
|
|
Username: fakeUsername,
|
|
|
|
Email: fakeEmail,
|
|
|
|
Password: password,
|
|
|
|
}
|
|
|
|
success, resp := th.Client.Register(registerRequest)
|
|
|
|
require.NoError(t, resp.Error)
|
|
|
|
require.True(t, success)
|
|
|
|
|
|
|
|
// login
|
2022-08-10 14:20:42 +02:00
|
|
|
loginRequest := &model.LoginRequest{
|
2021-08-10 04:57:45 +02:00
|
|
|
Type: "normal",
|
|
|
|
Username: fakeUsername,
|
|
|
|
Email: fakeEmail,
|
|
|
|
Password: password,
|
|
|
|
}
|
|
|
|
data, resp := th.Client.Login(loginRequest)
|
|
|
|
require.NoError(t, resp.Error)
|
|
|
|
require.NotNil(t, data)
|
|
|
|
require.NotNil(t, data.Token)
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestGetMe(t *testing.T) {
|
2022-03-22 16:24:34 +02:00
|
|
|
th := SetupTestHelper(t).Start()
|
2021-08-10 04:57:45 +02:00
|
|
|
defer th.TearDown()
|
|
|
|
|
|
|
|
t.Run("not login yet", func(t *testing.T) {
|
|
|
|
me, resp := th.Client.GetMe()
|
|
|
|
require.Error(t, resp.Error)
|
|
|
|
require.Nil(t, me)
|
|
|
|
})
|
|
|
|
|
|
|
|
t.Run("logged in", func(t *testing.T) {
|
|
|
|
// register
|
2021-10-05 15:52:59 +02:00
|
|
|
password := utils.NewID(utils.IDTypeNone)
|
2022-08-10 14:20:42 +02:00
|
|
|
registerRequest := &model.RegisterRequest{
|
2021-08-10 04:57:45 +02:00
|
|
|
Username: fakeUsername,
|
|
|
|
Email: fakeEmail,
|
|
|
|
Password: password,
|
|
|
|
}
|
|
|
|
success, resp := th.Client.Register(registerRequest)
|
|
|
|
require.NoError(t, resp.Error)
|
|
|
|
require.True(t, success)
|
|
|
|
// login
|
2022-08-10 14:20:42 +02:00
|
|
|
loginRequest := &model.LoginRequest{
|
2021-08-10 04:57:45 +02:00
|
|
|
Type: "normal",
|
|
|
|
Username: fakeUsername,
|
|
|
|
Email: fakeEmail,
|
|
|
|
Password: password,
|
|
|
|
}
|
|
|
|
data, resp := th.Client.Login(loginRequest)
|
|
|
|
require.NoError(t, resp.Error)
|
|
|
|
require.NotNil(t, data)
|
|
|
|
require.NotNil(t, data.Token)
|
|
|
|
|
|
|
|
// get user me
|
|
|
|
me, resp := th.Client.GetMe()
|
|
|
|
require.NoError(t, resp.Error)
|
|
|
|
require.NotNil(t, me)
|
2021-12-08 21:47:47 +02:00
|
|
|
require.Equal(t, "", me.Email)
|
2021-08-10 04:57:45 +02:00
|
|
|
require.Equal(t, registerRequest.Username, me.Username)
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestGetUser(t *testing.T) {
|
2022-03-22 16:24:34 +02:00
|
|
|
th := SetupTestHelper(t).Start()
|
2021-08-10 04:57:45 +02:00
|
|
|
defer th.TearDown()
|
|
|
|
|
|
|
|
// register
|
2021-10-05 15:52:59 +02:00
|
|
|
password := utils.NewID(utils.IDTypeNone)
|
2022-08-10 14:20:42 +02:00
|
|
|
registerRequest := &model.RegisterRequest{
|
2021-08-10 04:57:45 +02:00
|
|
|
Username: fakeUsername,
|
|
|
|
Email: fakeEmail,
|
|
|
|
Password: password,
|
|
|
|
}
|
|
|
|
success, resp := th.Client.Register(registerRequest)
|
|
|
|
require.NoError(t, resp.Error)
|
|
|
|
require.True(t, success)
|
|
|
|
// login
|
2022-08-10 14:20:42 +02:00
|
|
|
loginRequest := &model.LoginRequest{
|
2021-08-10 04:57:45 +02:00
|
|
|
Type: "normal",
|
|
|
|
Username: fakeUsername,
|
|
|
|
Email: fakeEmail,
|
|
|
|
Password: password,
|
|
|
|
}
|
|
|
|
data, resp := th.Client.Login(loginRequest)
|
|
|
|
require.NoError(t, resp.Error)
|
|
|
|
require.NotNil(t, data)
|
|
|
|
require.NotNil(t, data.Token)
|
|
|
|
|
|
|
|
me, resp := th.Client.GetMe()
|
|
|
|
require.NoError(t, resp.Error)
|
|
|
|
require.NotNil(t, me)
|
|
|
|
|
|
|
|
t.Run("me's id", func(t *testing.T) {
|
|
|
|
user, resp := th.Client.GetUser(me.ID)
|
|
|
|
require.NoError(t, resp.Error)
|
|
|
|
require.NotNil(t, user)
|
|
|
|
require.Equal(t, me.ID, user.ID)
|
|
|
|
require.Equal(t, me.Username, user.Username)
|
|
|
|
})
|
|
|
|
|
|
|
|
t.Run("nonexist user", func(t *testing.T) {
|
|
|
|
user, resp := th.Client.GetUser("nonexistid")
|
|
|
|
require.Error(t, resp.Error)
|
|
|
|
require.Nil(t, user)
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestUserChangePassword(t *testing.T) {
|
2022-03-22 16:24:34 +02:00
|
|
|
th := SetupTestHelper(t).Start()
|
2021-08-10 04:57:45 +02:00
|
|
|
defer th.TearDown()
|
|
|
|
|
|
|
|
// register
|
2021-10-05 15:52:59 +02:00
|
|
|
password := utils.NewID(utils.IDTypeNone)
|
2022-08-10 14:20:42 +02:00
|
|
|
registerRequest := &model.RegisterRequest{
|
2021-08-10 04:57:45 +02:00
|
|
|
Username: fakeUsername,
|
|
|
|
Email: fakeEmail,
|
|
|
|
Password: password,
|
|
|
|
}
|
|
|
|
success, resp := th.Client.Register(registerRequest)
|
|
|
|
require.NoError(t, resp.Error)
|
|
|
|
require.True(t, success)
|
|
|
|
// login
|
2022-08-10 14:20:42 +02:00
|
|
|
loginRequest := &model.LoginRequest{
|
2021-08-10 04:57:45 +02:00
|
|
|
Type: "normal",
|
|
|
|
Username: fakeUsername,
|
|
|
|
Email: fakeEmail,
|
|
|
|
Password: password,
|
|
|
|
}
|
|
|
|
data, resp := th.Client.Login(loginRequest)
|
|
|
|
require.NoError(t, resp.Error)
|
|
|
|
require.NotNil(t, data)
|
|
|
|
require.NotNil(t, data.Token)
|
|
|
|
|
|
|
|
originalMe, resp := th.Client.GetMe()
|
|
|
|
require.NoError(t, resp.Error)
|
|
|
|
require.NotNil(t, originalMe)
|
|
|
|
|
|
|
|
// change password
|
2022-08-10 14:20:42 +02:00
|
|
|
success, resp = th.Client.UserChangePassword(originalMe.ID, &model.ChangePasswordRequest{
|
2021-08-10 04:57:45 +02:00
|
|
|
OldPassword: password,
|
2021-10-05 15:52:59 +02:00
|
|
|
NewPassword: utils.NewID(utils.IDTypeNone),
|
2021-08-10 04:57:45 +02:00
|
|
|
})
|
|
|
|
require.NoError(t, resp.Error)
|
|
|
|
require.True(t, success)
|
|
|
|
}
|
|
|
|
|
|
|
|
func randomBytes(t *testing.T, n int) []byte {
|
|
|
|
bb := make([]byte, n)
|
|
|
|
_, err := rand.Read(bb)
|
|
|
|
require.NoError(t, err)
|
|
|
|
return bb
|
|
|
|
}
|
|
|
|
|
2022-03-22 16:24:34 +02:00
|
|
|
func TestTeamUploadFile(t *testing.T) {
|
2021-08-10 04:57:45 +02:00
|
|
|
t.Run("no permission", func(t *testing.T) { // native auth, but not login
|
2022-03-22 16:24:34 +02:00
|
|
|
th := SetupTestHelper(t).InitBasic()
|
2021-08-10 04:57:45 +02:00
|
|
|
defer th.TearDown()
|
|
|
|
|
2022-03-22 16:24:34 +02:00
|
|
|
teamID := "0"
|
|
|
|
boardID := utils.NewID(utils.IDTypeBoard)
|
2021-08-10 04:57:45 +02:00
|
|
|
data := randomBytes(t, 1024)
|
2022-03-22 16:24:34 +02:00
|
|
|
result, resp := th.Client.TeamUploadFile(teamID, boardID, bytes.NewReader(data))
|
2021-08-10 04:57:45 +02:00
|
|
|
require.Error(t, resp.Error)
|
|
|
|
require.Nil(t, result)
|
|
|
|
})
|
|
|
|
|
2022-03-22 16:24:34 +02:00
|
|
|
t.Run("a board admin should be able to update a file", func(t *testing.T) { // single token auth
|
|
|
|
th := SetupTestHelper(t).InitBasic()
|
2021-08-10 04:57:45 +02:00
|
|
|
defer th.TearDown()
|
|
|
|
|
2022-03-22 16:24:34 +02:00
|
|
|
teamID := "0"
|
|
|
|
newBoard := &model.Board{
|
|
|
|
Type: model.BoardTypeOpen,
|
|
|
|
TeamID: teamID,
|
|
|
|
}
|
|
|
|
board, resp := th.Client.CreateBoard(newBoard)
|
|
|
|
th.CheckOK(resp)
|
|
|
|
require.NotNil(t, board)
|
|
|
|
|
2021-08-10 04:57:45 +02:00
|
|
|
data := randomBytes(t, 1024)
|
2022-03-22 16:24:34 +02:00
|
|
|
result, resp := th.Client.TeamUploadFile(teamID, board.ID, bytes.NewReader(data))
|
|
|
|
th.CheckOK(resp)
|
2021-08-10 04:57:45 +02:00
|
|
|
require.NotNil(t, result)
|
|
|
|
require.NotEmpty(t, result.FileID)
|
|
|
|
// TODO get the uploaded file
|
|
|
|
})
|
2022-03-22 16:24:34 +02:00
|
|
|
|
|
|
|
t.Run("user that doesn't belong to the board should not be able to upload a file", func(t *testing.T) {
|
|
|
|
th := SetupTestHelper(t).InitBasic()
|
|
|
|
defer th.TearDown()
|
|
|
|
|
|
|
|
teamID := "0"
|
|
|
|
newBoard := &model.Board{
|
|
|
|
Type: model.BoardTypeOpen,
|
|
|
|
TeamID: teamID,
|
|
|
|
}
|
|
|
|
board, resp := th.Client.CreateBoard(newBoard)
|
|
|
|
th.CheckOK(resp)
|
|
|
|
require.NotNil(t, board)
|
|
|
|
|
|
|
|
data := randomBytes(t, 1024)
|
|
|
|
|
|
|
|
// a user that doesn't belong to the board tries to upload the file
|
|
|
|
result, resp := th.Client2.TeamUploadFile(teamID, board.ID, bytes.NewReader(data))
|
|
|
|
th.CheckForbidden(resp)
|
|
|
|
require.Nil(t, result)
|
|
|
|
})
|
2021-08-10 04:57:45 +02:00
|
|
|
}
|