1
0
forked from MTSR/mapserver
mapserver/db/sqlite_test.go

93 lines
1.5 KiB
Go
Raw Normal View History

2019-01-08 18:33:49 +03:00
package db
import (
2019-01-09 11:56:36 +03:00
"os"
"io"
2019-01-08 18:33:49 +03:00
"fmt"
"testing"
"io/ioutil"
"database/sql"
_ "github.com/mattn/go-sqlite3"
)
const emptyBlocksScript = `
create table blocks (
pos int,
data blob
);
`
2019-01-09 11:56:36 +03:00
const testDatabase = "./testdata/map.sqlite"
2019-01-08 18:33:49 +03:00
func createEmptyDatabase(filename string){
db, err := sql.Open("sqlite3", filename)
if err != nil {
panic(err)
}
rows, err := db.Query(emptyBlocksScript)
if err != nil {
panic(err)
}
rows.Next()
fmt.Println(rows)
db.Close()
}
2019-01-09 11:56:36 +03:00
func copy(src, dst string) error {
in, err := os.Open(src)
if err != nil {
return err
}
defer in.Close()
out, err := os.Create(dst)
if err != nil {
return err
}
defer out.Close()
_, err = io.Copy(out, in)
if err != nil {
return err
}
return out.Close()
}
func createTestDatabase(filename string) error {
return copy(testDatabase, filename)
}
func TestMigrateEmpty(t *testing.T){
2019-01-08 18:33:49 +03:00
tmpfile, err := ioutil.TempFile("", "example")
if err != nil {
panic(err)
}
createEmptyDatabase(tmpfile.Name())
2019-01-09 10:44:14 +03:00
a, err := NewSqliteAccessor(tmpfile.Name())
if err != nil {
panic(err)
}
err = a.Migrate()
if err != nil {
panic(err)
}
2019-01-08 18:33:49 +03:00
}
2019-01-09 11:56:36 +03:00
func TestMigrate(t *testing.T){
tmpfile, err := ioutil.TempFile("", "example")
if err != nil {
panic(err)
}
createTestDatabase(tmpfile.Name())
a, err := NewSqliteAccessor(tmpfile.Name())
if err != nil {
panic(err)
}
err = a.Migrate()
if err != nil {
panic(err)
}
}