2021-06-03 21:59:16 +02:00
|
|
|
package app
|
|
|
|
|
|
|
|
import (
|
|
|
|
"database/sql"
|
|
|
|
"testing"
|
|
|
|
"time"
|
|
|
|
|
|
|
|
"github.com/golang/mock/gomock"
|
|
|
|
"github.com/mattermost/focalboard/server/model"
|
|
|
|
st "github.com/mattermost/focalboard/server/services/store"
|
|
|
|
"github.com/mattermost/focalboard/server/utils"
|
|
|
|
"github.com/pkg/errors"
|
|
|
|
"github.com/stretchr/testify/require"
|
|
|
|
)
|
|
|
|
|
|
|
|
func TestGetSharing(t *testing.T) {
|
2021-08-25 22:08:01 +02:00
|
|
|
th, tearDown := SetupTestHelper(t)
|
|
|
|
defer tearDown()
|
|
|
|
|
2021-06-03 21:59:16 +02:00
|
|
|
container := st.Container{
|
2021-10-05 15:52:59 +02:00
|
|
|
WorkspaceID: utils.NewID(utils.IDTypeWorkspace),
|
2021-06-03 21:59:16 +02:00
|
|
|
}
|
|
|
|
|
2021-06-21 11:21:42 +02:00
|
|
|
t.Run("should get a sharing successfully", func(t *testing.T) {
|
2021-06-03 21:59:16 +02:00
|
|
|
want := &model.Sharing{
|
2021-10-05 15:52:59 +02:00
|
|
|
ID: utils.NewID(utils.IDTypeBlock),
|
2021-06-03 21:59:16 +02:00
|
|
|
Enabled: true,
|
|
|
|
Token: "token",
|
|
|
|
ModifiedBy: "otherid",
|
|
|
|
UpdateAt: time.Now().Unix(),
|
|
|
|
}
|
|
|
|
th.Store.EXPECT().GetSharing(gomock.Eq(container), gomock.Eq("test-id")).Return(want, nil)
|
|
|
|
|
|
|
|
result, err := th.App.GetSharing(container, "test-id")
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
require.Equal(t, result, want)
|
|
|
|
require.NotNil(t, th.App)
|
|
|
|
})
|
|
|
|
|
|
|
|
t.Run("should fail to get a sharing", func(t *testing.T) {
|
|
|
|
th.Store.EXPECT().GetSharing(gomock.Eq(container), gomock.Eq("test-id")).Return(
|
|
|
|
nil,
|
|
|
|
errors.New("sharing not found"),
|
|
|
|
)
|
|
|
|
result, err := th.App.GetSharing(container, "test-id")
|
|
|
|
|
|
|
|
require.Nil(t, result)
|
|
|
|
require.Error(t, err)
|
|
|
|
require.Equal(t, "sharing not found", err.Error())
|
|
|
|
})
|
|
|
|
|
|
|
|
t.Run("should return a tuple of nil", func(t *testing.T) {
|
|
|
|
th.Store.EXPECT().GetSharing(gomock.Eq(container), gomock.Eq("test-id")).Return(
|
|
|
|
nil,
|
|
|
|
sql.ErrNoRows,
|
|
|
|
)
|
|
|
|
result, err := th.App.GetSharing(container, "test-id")
|
|
|
|
|
|
|
|
require.Nil(t, result)
|
|
|
|
require.NoError(t, err)
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestUpsertSharing(t *testing.T) {
|
2021-08-25 22:08:01 +02:00
|
|
|
th, tearDown := SetupTestHelper(t)
|
|
|
|
defer tearDown()
|
2021-06-03 21:59:16 +02:00
|
|
|
|
|
|
|
container := st.Container{
|
2021-10-05 15:52:59 +02:00
|
|
|
WorkspaceID: utils.NewID(utils.IDTypeWorkspace),
|
2021-06-03 21:59:16 +02:00
|
|
|
}
|
|
|
|
sharing := model.Sharing{
|
2021-10-05 15:52:59 +02:00
|
|
|
ID: utils.NewID(utils.IDTypeBlock),
|
2021-06-03 21:59:16 +02:00
|
|
|
Enabled: true,
|
|
|
|
Token: "token",
|
|
|
|
ModifiedBy: "otherid",
|
|
|
|
UpdateAt: time.Now().Unix(),
|
|
|
|
}
|
|
|
|
|
|
|
|
t.Run("should success to upsert sharing", func(t *testing.T) {
|
|
|
|
th.Store.EXPECT().UpsertSharing(gomock.Eq(container), gomock.Eq(sharing)).Return(nil)
|
|
|
|
err := th.App.UpsertSharing(container, sharing)
|
|
|
|
|
|
|
|
require.NoError(t, err)
|
|
|
|
})
|
|
|
|
|
|
|
|
t.Run("should fail to upsert a sharing", func(t *testing.T) {
|
|
|
|
th.Store.EXPECT().UpsertSharing(gomock.Eq(container), gomock.Eq(sharing)).Return(errors.New("sharing not found"))
|
|
|
|
err := th.App.UpsertSharing(container, sharing)
|
|
|
|
|
|
|
|
require.Error(t, err)
|
|
|
|
require.Equal(t, "sharing not found", err.Error())
|
|
|
|
})
|
|
|
|
}
|