mattermost-community-enterp.../channels/app/permissions_test.go
Claude ec1f89217a Merge: Complete Mattermost Server with Community Enterprise
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>
2025-12-17 23:59:07 +09:00

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()
}