1
0
Fork 0
mirror of https://github.com/Eggbertx/gochan.git synced 2025-08-18 11:46:23 -07:00
gochan/cmd/gochan-migration/internal/pre2021/sqlite3_test.go

109 lines
3.2 KiB
Go

package pre2021
import (
"path"
"testing"
"github.com/gochan-org/gochan/pkg/config"
"github.com/gochan-org/gochan/pkg/gcsql"
"github.com/gochan-org/gochan/pkg/gcutil/testutil"
"github.com/stretchr/testify/assert"
)
const (
sqlite3DBPath = "tools/gochan-pre2021.sqlite3db" // relative to gochan project root
)
func setupMigrationTest(t *testing.T, outDir string, migrateInPlace bool) *Pre2021Migrator {
dir, err := testutil.GoToGochanRoot(t)
if !assert.NoError(t, err) {
t.FailNow()
}
dbPath := path.Join(dir, sqlite3DBPath)
oldSQLConfig := config.SQLConfig{
DBtype: "sqlite3",
DBname: path.Base(dbPath),
DBhost: dbPath,
DBprefix: "gc_",
DBusername: "gochan",
DBpassword: "password",
DBTimeoutSeconds: 600,
}
migrator := &Pre2021Migrator{
config: Pre2021Config{
SQLConfig: oldSQLConfig,
},
}
db, err := gcsql.Open(&oldSQLConfig)
if !assert.NoError(t, err) {
t.FailNow()
}
migrator.db = db
migratedDBPath := path.Join(outDir, "gochan-migrated.sqlite3db")
config.SetTestDBConfig("sqlite3", migratedDBPath, path.Base(migratedDBPath), "gochan", "password", "gc_")
sqlConfig := config.GetSQLConfig()
sqlConfig.DBTimeoutSeconds = 600
if !assert.NoError(t, gcsql.ConnectToDB(&sqlConfig)) {
t.FailNow()
}
if !assert.NoError(t, gcsql.CheckAndInitializeDatabase("sqlite3", "4")) {
t.FailNow()
}
return migrator
}
func TestMigrateBoardsToNewDB(t *testing.T) {
outDir := t.TempDir()
migrator := setupMigrationTest(t, outDir, false)
assert.NoError(t, gcsql.ResetBoardSectionArrays())
numBoards := len(gcsql.AllBoards)
numSections := len(gcsql.AllSections)
assert.Equal(t, 1, numBoards, "Expected to have 1 board pre-migration (/test/ is automatically created during provisioning)")
assert.Equal(t, 1, numSections, "Expected to have 1 section pre-migration (Main is automatically created during provisioning)")
assert.NoError(t, migrator.MigrateBoards())
migratedBoards, err := gcsql.GetAllBoards(false)
if !assert.NoError(t, err) {
t.FailNow()
}
migratedSections, err := gcsql.GetAllSections(false)
if !assert.NoError(t, err) {
t.FailNow()
}
assert.Equal(t, len(migratedBoards), 2, "Expected updated boards list to have two boards")
assert.Equal(t, len(migratedSections), 2, "Expected updated sections list to have two sections")
// Test migrated sections
mainSection, err := gcsql.GetSectionFromName("Main")
if !assert.NoError(t, err) {
t.FailNow()
}
assert.Equal(t, "mainmigration", mainSection.Abbreviation, "Expected Main section to have updated abbreviation name 'mainmigration'")
// Test migrated boards
testBoard, err := gcsql.GetBoardFromDir("test")
if !assert.NoError(t, err) {
t.FailNow()
}
assert.Equal(t, "Testing Board", testBoard.Title)
assert.Equal(t, "Board for testing pre-2021 migration", testBoard.Subtitle)
testBoardSection, err := gcsql.GetSectionFromID(testBoard.SectionID)
if !assert.NoError(t, err) {
t.FailNow()
}
assert.Equal(t, "Main", testBoardSection.Name, "Expected /test/ board to be in Main section")
hiddenBoard, err := gcsql.GetBoardFromDir("hidden")
if !assert.NoError(t, err) {
t.FailNow()
}
assert.Equal(t, "Hidden Board", hiddenBoard.Title)
}