1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61
|
//go:build !nosqlite
package database
import (
"database/sql"
"testing"
)
// SQLite version 0 schema. DO NOT EDIT.
const sqliteV0Schema = `
CREATE TABLE User (
username VARCHAR(255) NOT NULL UNIQUE,
password VARCHAR(255)
);
CREATE TABLE Network (
id INTEGER PRIMARY KEY,
name VARCHAR(255),
user VARCHAR(255) NOT NULL,
addr VARCHAR(255) NOT NULL,
nick VARCHAR(255) NOT NULL,
username VARCHAR(255),
realname VARCHAR(255),
pass VARCHAR(255),
sasl_mechanism VARCHAR(255),
sasl_plain_username VARCHAR(255),
sasl_plain_password VARCHAR(255),
UNIQUE(user, addr, nick),
UNIQUE(user, name)
);
CREATE TABLE Channel (
id INTEGER PRIMARY KEY,
network INTEGER NOT NULL,
name VARCHAR(255) NOT NULL,
key VARCHAR(255),
FOREIGN KEY(network) REFERENCES Network(id),
UNIQUE(network, name)
);
PRAGMA user_version = 1;
`
func TestSqliteMigrations(t *testing.T) {
sqlDB, err := sql.Open(sqliteDriver, ":memory:")
if err != nil {
t.Fatalf("failed to create temporary SQLite database: %v", err)
}
if _, err := sqlDB.Exec(sqliteV0Schema); err != nil {
t.Fatalf("DB.Exec() failed for v0 schema: %v", err)
}
db := &SqliteDB{db: sqlDB}
defer db.Close()
if err := db.upgrade(); err != nil {
t.Fatalf("SqliteDB.Upgrade() failed: %v", err)
}
}
|