mirror of
https://github.com/mattermost/mattermost.git
synced 2025-02-25 18:55:24 -06:00
* Replacing require.nil in api layer * Fixing some tests * Fixing tests * Addressing PR review comments Co-authored-by: Mattermod <mattermod@users.noreply.github.com>
107 lines
2.8 KiB
Go
107 lines
2.8 KiB
Go
// Copyright (c) 2015-present Mattermost, Inc. All Rights Reserved.
|
|
// See LICENSE.txt for license information.
|
|
|
|
package api4
|
|
|
|
import (
|
|
"os"
|
|
"path/filepath"
|
|
"testing"
|
|
|
|
"github.com/stretchr/testify/require"
|
|
|
|
"github.com/mattermost/mattermost-server/v5/model"
|
|
"github.com/mattermost/mattermost-server/v5/utils/fileutils"
|
|
)
|
|
|
|
func TestListImports(t *testing.T) {
|
|
th := Setup(t)
|
|
defer th.TearDown()
|
|
|
|
testsDir, _ := fileutils.FindDir("tests")
|
|
require.NotEmpty(t, testsDir)
|
|
|
|
uploadNewImport := func(c *model.Client4, t *testing.T) string {
|
|
file, err := os.Open(testsDir + "/import_test.zip")
|
|
require.NoError(t, err)
|
|
|
|
info, err := file.Stat()
|
|
require.NoError(t, err)
|
|
|
|
us := &model.UploadSession{
|
|
Filename: info.Name(),
|
|
FileSize: info.Size(),
|
|
Type: model.UploadTypeImport,
|
|
}
|
|
|
|
if c == th.LocalClient {
|
|
us.UserId = model.UploadNoUserID
|
|
}
|
|
|
|
u, resp := c.CreateUpload(us)
|
|
require.Nil(t, resp.Error)
|
|
require.NotNil(t, u)
|
|
|
|
finfo, resp := c.UploadData(u.Id, file)
|
|
require.Nil(t, resp.Error)
|
|
require.NotNil(t, finfo)
|
|
|
|
return u.Id
|
|
}
|
|
|
|
t.Run("no permissions", func(t *testing.T) {
|
|
imports, resp := th.Client.ListImports()
|
|
require.NotNil(t, resp.Error)
|
|
require.Equal(t, "api.context.permissions.app_error", resp.Error.Id)
|
|
require.Nil(t, imports)
|
|
})
|
|
|
|
dataDir, found := fileutils.FindDir("data")
|
|
require.True(t, found)
|
|
|
|
th.TestForSystemAdminAndLocal(t, func(t *testing.T, c *model.Client4) {
|
|
imports, resp := c.ListImports()
|
|
require.Nil(t, resp.Error)
|
|
require.Empty(t, imports)
|
|
}, "no imports")
|
|
|
|
th.TestForSystemAdminAndLocal(t, func(t *testing.T, c *model.Client4) {
|
|
id := uploadNewImport(c, t)
|
|
id2 := uploadNewImport(c, t)
|
|
|
|
importDir := filepath.Join(dataDir, "import")
|
|
f, err := os.Create(filepath.Join(importDir, "import.zip.tmp"))
|
|
require.NoError(t, err)
|
|
f.Close()
|
|
|
|
imports, resp := c.ListImports()
|
|
require.Nil(t, resp.Error)
|
|
require.NotEmpty(t, imports)
|
|
require.Len(t, imports, 2)
|
|
require.Contains(t, imports, id+"_import_test.zip")
|
|
require.Contains(t, imports, id2+"_import_test.zip")
|
|
|
|
require.NoError(t, os.RemoveAll(importDir))
|
|
}, "expected imports")
|
|
|
|
th.TestForSystemAdminAndLocal(t, func(t *testing.T, c *model.Client4) {
|
|
th.App.UpdateConfig(func(cfg *model.Config) { *cfg.ImportSettings.Directory = "import_new" })
|
|
defer th.App.UpdateConfig(func(cfg *model.Config) { *cfg.ImportSettings.Directory = "import" })
|
|
|
|
importDir := filepath.Join(dataDir, "import_new")
|
|
|
|
imports, resp := c.ListImports()
|
|
require.Nil(t, resp.Error)
|
|
require.Empty(t, imports)
|
|
|
|
id := uploadNewImport(c, t)
|
|
imports, resp = c.ListImports()
|
|
require.Nil(t, resp.Error)
|
|
require.NotEmpty(t, imports)
|
|
require.Len(t, imports, 1)
|
|
require.Equal(t, id+"_import_test.zip", imports[0])
|
|
|
|
require.NoError(t, os.RemoveAll(importDir))
|
|
}, "change import directory")
|
|
}
|