mattermost-community-enterp.../channels/store/sqlstore/schema_dump_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

117 lines
4.9 KiB
Go

// Copyright (c) 2015-present Mattermost, Inc. All Rights Reserved.
// See LICENSE.txt for license information.
package sqlstore
import (
"testing"
"github.com/stretchr/testify/assert"
"github.com/stretchr/testify/require"
"github.com/mattermost/mattermost/server/public/model"
"github.com/mattermost/mattermost/server/public/shared/request"
"github.com/mattermost/mattermost/server/v8/channels/store"
)
func TestGetSchemaDefinition(t *testing.T) {
StoreTest(t, func(t *testing.T, rctx request.CTX, ss store.Store) {
t.Run("PostgreSQL", func(t *testing.T) {
if ss.(*SqlStore).DriverName() != model.DatabaseDriverPostgres {
t.Skip("Skipping test as database is not PostgreSQL")
}
schemaInfo, err := ss.GetSchemaDefinition()
require.NoError(t, err)
require.NotNil(t, schemaInfo)
// Verify database encoding is captured
assert.Equal(t, "UTF8", schemaInfo.DatabaseEncoding, "Database encoding should be captured")
// Verify schema structure
assert.NotEmpty(t, schemaInfo.Tables)
// Verify that columns are not duplicated
for _, table := range schemaInfo.Tables {
columnNames := make(map[string]bool)
for _, column := range table.Columns {
// Assert that this column name hasn't been seen before
assert.False(t, columnNames[column.Name], "Column %s in table %s is duplicated", column.Name, table.Name)
columnNames[column.Name] = true
}
}
// Verify that common tables are present
tableNames := make([]string, 0, len(schemaInfo.Tables))
for _, table := range schemaInfo.Tables {
tableNames = append(tableNames, table.Name)
}
// Verify some core tables
expectedTables := []string{"users", "channels", "teams", "posts"}
assert.Subset(t, tableNames, expectedTables)
// Verify table structure
for _, table := range schemaInfo.Tables {
if table.Name == "users" {
// Check user table has key columns
columnNames := make([]string, 0, len(table.Columns))
for _, column := range table.Columns {
columnNames = append(columnNames, column.Name)
}
expectedColumns := []string{"id", "username", "email"}
assert.Subset(t, columnNames, expectedColumns)
break
}
}
// Verify indexes are present for tables
for _, table := range schemaInfo.Tables {
if table.Name == "channels" {
// Check that indexes are present
assert.NotEmpty(t, table.Indexes, "channels table should have indexes")
assert.Equal(t, 11, len(table.Indexes), "channels table should have 11 indexes")
// Expected index definitions
expectedIndexDefs := map[string]string{
"idx_channels_delete_at": "CREATE INDEX idx_channels_delete_at ON public.channels USING btree (deleteat)",
"idx_channels_create_at": "CREATE INDEX idx_channels_create_at ON public.channels USING btree (createat)",
"channels_pkey": "CREATE UNIQUE INDEX channels_pkey ON public.channels USING btree (id)",
"channels_name_teamid_key": "CREATE UNIQUE INDEX channels_name_teamid_key ON public.channels USING btree (name, teamid)",
"idx_channels_displayname_lower": "CREATE INDEX idx_channels_displayname_lower ON public.channels USING btree (lower((displayname)::text))",
"idx_channels_name_lower": "CREATE INDEX idx_channels_name_lower ON public.channels USING btree (lower((name)::text))",
"idx_channels_update_at": "CREATE INDEX idx_channels_update_at ON public.channels USING btree (updateat)",
"idx_channel_search_txt": "CREATE INDEX idx_channel_search_txt ON public.channels USING gin (to_tsvector('english'::regconfig, (((((name)::text || ' '::text) || (displayname)::text) || ' '::text) || (purpose)::text)))",
"idx_channels_scheme_id": "CREATE INDEX idx_channels_scheme_id ON public.channels USING btree (schemeid)",
"idx_channels_team_id_display_name": "CREATE INDEX idx_channels_team_id_display_name ON public.channels USING btree (teamid, displayname)",
"idx_channels_team_id_type": "CREATE INDEX idx_channels_team_id_type ON public.channels USING btree (teamid, type)",
}
// Verify all expected indexes are present with correct definitions
foundIndexes := make(map[string]bool)
for _, index := range table.Indexes {
foundIndexes[index.Name] = true
// Verify definition is not empty
assert.NotEmpty(t, index.Definition, "Index %s should have a definition", index.Name)
// Check if this is an expected index and verify definition
expectedDef, ok := expectedIndexDefs[index.Name]
require.Truef(t, ok, "Unexpected definition found: %s", index.Name)
assert.Equal(t, expectedDef, index.Definition, "Index %s has incorrect definition", index.Name)
}
// Verify all expected indexes were found
for expectedName := range expectedIndexDefs {
assert.True(t, foundIndexes[expectedName], "Expected index %s not found", expectedName)
}
break
}
}
})
})
}