Full Mattermost server source with integrated Community Enterprise features. Includes vendor directory for offline/air-gapped builds. Structure: - enterprise-impl/: Enterprise feature implementations - enterprise-community/: Init files that register implementations - enterprise/: Bridge imports (community_imports.go) - vendor/: All dependencies for offline builds Build (online): go build ./cmd/mattermost Build (offline/air-gapped): go build -mod=vendor ./cmd/mattermost 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
126 lines
3.8 KiB
Go
126 lines
3.8 KiB
Go
// Copyright (c) 2015-present Mattermost, Inc. All Rights Reserved.
|
|
// See LICENSE.txt for license information.
|
|
|
|
package app
|
|
|
|
import (
|
|
"encoding/json"
|
|
"testing"
|
|
|
|
"github.com/stretchr/testify/assert"
|
|
"github.com/stretchr/testify/require"
|
|
|
|
"github.com/mattermost/mattermost/server/public/model"
|
|
)
|
|
|
|
type testWriter struct {
|
|
write func(p []byte) (int, error)
|
|
}
|
|
|
|
func (tw testWriter) Write(p []byte) (int, error) {
|
|
return tw.write(p)
|
|
}
|
|
|
|
func TestExportPermissions(t *testing.T) {
|
|
mainHelper.Parallel(t)
|
|
th := Setup(t)
|
|
defer th.TearDown()
|
|
|
|
var scheme *model.Scheme
|
|
var roles []*model.Role
|
|
withMigrationMarkedComplete(t, th, func() {
|
|
scheme, roles = th.CreateScheme()
|
|
})
|
|
|
|
results := [][]byte{}
|
|
|
|
tw := testWriter{
|
|
write: func(p []byte) (int, error) {
|
|
results = append(results, p)
|
|
return len(p), nil
|
|
},
|
|
}
|
|
|
|
err := th.App.ExportPermissions(th.Context, tw)
|
|
require.NoError(t, err)
|
|
|
|
if len(results) == 0 {
|
|
t.Error("Expected export to have returned something.")
|
|
}
|
|
|
|
firstResult := results[0]
|
|
|
|
var row map[string]any
|
|
err = json.Unmarshal(firstResult, &row)
|
|
if err != nil {
|
|
t.Error(err)
|
|
}
|
|
|
|
getRoleByName := func(name string) string {
|
|
for _, role := range roles {
|
|
if role.Name == name {
|
|
return role.Name
|
|
}
|
|
}
|
|
return ""
|
|
}
|
|
|
|
expectations := map[string]func(str string) string{
|
|
scheme.DisplayName: func(_ string) string { return row["display_name"].(string) },
|
|
scheme.Name: func(_ string) string { return row["name"].(string) },
|
|
scheme.Description: func(_ string) string { return row["description"].(string) },
|
|
scheme.Scope: func(_ string) string { return row["scope"].(string) },
|
|
scheme.DefaultTeamAdminRole: func(str string) string { return getRoleByName(str) },
|
|
scheme.DefaultTeamUserRole: func(str string) string { return getRoleByName(str) },
|
|
scheme.DefaultTeamGuestRole: func(str string) string { return getRoleByName(str) },
|
|
scheme.DefaultChannelAdminRole: func(str string) string { return getRoleByName(str) },
|
|
scheme.DefaultChannelUserRole: func(str string) string { return getRoleByName(str) },
|
|
scheme.DefaultChannelGuestRole: func(str string) string { return getRoleByName(str) },
|
|
}
|
|
|
|
for key, valF := range expectations {
|
|
expected := key
|
|
actual := valF(key)
|
|
if actual != expected {
|
|
t.Errorf("Expected %v but got %v.", expected, actual)
|
|
}
|
|
}
|
|
}
|
|
|
|
func TestMigration(t *testing.T) {
|
|
mainHelper.Parallel(t)
|
|
th := Setup(t)
|
|
defer th.TearDown()
|
|
|
|
role, err := th.App.GetRoleByName(th.Context, model.SystemAdminRoleId)
|
|
require.Nil(t, err)
|
|
assert.Contains(t, role.Permissions, model.PermissionCreateEmojis.Id)
|
|
assert.Contains(t, role.Permissions, model.PermissionDeleteEmojis.Id)
|
|
assert.Contains(t, role.Permissions, model.PermissionDeleteOthersEmojis.Id)
|
|
assert.Contains(t, role.Permissions, model.PermissionUseGroupMentions.Id)
|
|
|
|
appErr := th.App.ResetPermissionsSystem()
|
|
require.Nil(t, appErr)
|
|
|
|
role, err = th.App.GetRoleByName(th.Context, model.SystemAdminRoleId)
|
|
require.Nil(t, err)
|
|
assert.Contains(t, role.Permissions, model.PermissionCreateEmojis.Id)
|
|
assert.Contains(t, role.Permissions, model.PermissionDeleteEmojis.Id)
|
|
assert.Contains(t, role.Permissions, model.PermissionDeleteOthersEmojis.Id)
|
|
assert.Contains(t, role.Permissions, model.PermissionUseGroupMentions.Id)
|
|
}
|
|
|
|
func withMigrationMarkedComplete(t *testing.T, th *TestHelper, f func()) {
|
|
// Mark the migration as done.
|
|
_, err := th.App.Srv().Store().System().PermanentDeleteByName(model.MigrationKeyAdvancedPermissionsPhase2)
|
|
require.NoError(t, err)
|
|
err = th.App.Srv().Store().System().Save(&model.System{Name: model.MigrationKeyAdvancedPermissionsPhase2, Value: "true"})
|
|
require.NoError(t, err)
|
|
// Un-mark the migration at the end of the test.
|
|
defer func() {
|
|
_, err := th.App.Srv().Store().System().PermanentDeleteByName(model.MigrationKeyAdvancedPermissionsPhase2)
|
|
require.NoError(t, err)
|
|
}()
|
|
f()
|
|
}
|