2019-02-05 15:13:34 +03:00
|
|
|
package sqlite
|
2019-01-08 18:33:49 +03:00
|
|
|
|
|
|
|
import (
|
2019-01-10 19:50:31 +03:00
|
|
|
"io/ioutil"
|
|
|
|
"mapserver/coords"
|
2019-01-13 18:37:03 +03:00
|
|
|
"mapserver/testutils"
|
2019-01-10 19:50:31 +03:00
|
|
|
"os"
|
|
|
|
"testing"
|
2019-02-15 19:53:32 +03:00
|
|
|
|
2022-02-01 16:59:29 +03:00
|
|
|
_ "modernc.org/sqlite"
|
2019-01-08 18:33:49 +03:00
|
|
|
)
|
|
|
|
|
2019-01-10 19:50:31 +03:00
|
|
|
func TestMigrateEmpty(t *testing.T) {
|
|
|
|
tmpfile, err := ioutil.TempFile("", "TestMigrateEmpty.*.sqlite")
|
|
|
|
if err != nil {
|
|
|
|
panic(err)
|
|
|
|
}
|
|
|
|
defer os.Remove(tmpfile.Name())
|
|
|
|
|
2019-01-11 12:24:10 +03:00
|
|
|
testutils.CreateEmptyDatabase(tmpfile.Name())
|
2019-02-05 15:13:34 +03:00
|
|
|
a, err := New(tmpfile.Name())
|
2019-01-10 19:50:31 +03:00
|
|
|
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
|
|
|
|
2019-01-10 19:50:31 +03:00
|
|
|
func TestMigrate(t *testing.T) {
|
|
|
|
tmpfile, err := ioutil.TempFile("", "TestMigrate.*.sqlite")
|
|
|
|
if err != nil {
|
|
|
|
panic(err)
|
|
|
|
}
|
|
|
|
defer os.Remove(tmpfile.Name())
|
|
|
|
|
2019-01-11 12:24:10 +03:00
|
|
|
testutils.CreateEmptyDatabase(tmpfile.Name())
|
2019-02-05 15:13:34 +03:00
|
|
|
a, err := New(tmpfile.Name())
|
2019-01-10 19:50:31 +03:00
|
|
|
if err != nil {
|
|
|
|
panic(err)
|
|
|
|
}
|
|
|
|
err = a.Migrate()
|
|
|
|
if err != nil {
|
|
|
|
panic(err)
|
|
|
|
}
|
2019-01-09 11:56:36 +03:00
|
|
|
}
|
2019-01-09 12:16:22 +03:00
|
|
|
|
2019-01-10 19:50:31 +03:00
|
|
|
func TestMigrateAndQuery(t *testing.T) {
|
|
|
|
tmpfile, err := ioutil.TempFile("", "TestMigrateAndQuery.*.sqlite")
|
|
|
|
if err != nil {
|
|
|
|
panic(err)
|
|
|
|
}
|
|
|
|
defer os.Remove(tmpfile.Name())
|
|
|
|
|
2019-01-11 12:24:10 +03:00
|
|
|
testutils.CreateTestDatabase(tmpfile.Name())
|
2019-02-05 15:13:34 +03:00
|
|
|
a, err := New(tmpfile.Name())
|
2019-01-10 19:50:31 +03:00
|
|
|
if err != nil {
|
|
|
|
panic(err)
|
|
|
|
}
|
2019-01-11 12:24:10 +03:00
|
|
|
|
2019-01-10 19:50:31 +03:00
|
|
|
err = a.Migrate()
|
|
|
|
if err != nil {
|
|
|
|
panic(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
block, err := a.GetBlock(coords.NewMapBlockCoords(0, 0, 0))
|
|
|
|
|
|
|
|
if err != nil {
|
|
|
|
panic(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
if block == nil {
|
|
|
|
t.Fatal("no data")
|
|
|
|
}
|
2019-01-09 12:16:22 +03:00
|
|
|
|
|
|
|
}
|
2019-01-17 16:42:02 +03:00
|
|
|
|
2019-01-23 14:46:45 +03:00
|
|
|
func TestMigrateAndQueryCount(t *testing.T) {
|
2019-01-17 16:42:02 +03:00
|
|
|
tmpfile, err := ioutil.TempFile("", "TestMigrateAndQueryStride.*.sqlite")
|
|
|
|
if err != nil {
|
|
|
|
panic(err)
|
|
|
|
}
|
|
|
|
defer os.Remove(tmpfile.Name())
|
|
|
|
|
|
|
|
testutils.CreateTestDatabase(tmpfile.Name())
|
2019-02-05 15:13:34 +03:00
|
|
|
a, err := New(tmpfile.Name())
|
2019-01-17 16:42:02 +03:00
|
|
|
if err != nil {
|
|
|
|
panic(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
err = a.Migrate()
|
|
|
|
if err != nil {
|
|
|
|
panic(err)
|
|
|
|
}
|
|
|
|
|
2019-02-15 19:53:32 +03:00
|
|
|
count, err := a.CountBlocks()
|
2019-01-17 16:42:02 +03:00
|
|
|
if err != nil {
|
|
|
|
panic(err)
|
|
|
|
}
|
|
|
|
|
2019-01-23 14:46:45 +03:00
|
|
|
if count <= 0 {
|
|
|
|
t.Fatal("zero count")
|
2019-01-17 16:42:02 +03:00
|
|
|
}
|
|
|
|
}
|
2019-04-03 09:15:32 +03:00
|
|
|
|
|
|
|
func TestMigrateAndQueryTimestamp(t *testing.T) {
|
|
|
|
tmpfile, err := ioutil.TempFile("", "TestMigrateAndQueryStride.*.sqlite")
|
|
|
|
if err != nil {
|
|
|
|
panic(err)
|
|
|
|
}
|
|
|
|
defer os.Remove(tmpfile.Name())
|
|
|
|
|
|
|
|
testutils.CreateTestDatabase(tmpfile.Name())
|
|
|
|
a, err := New(tmpfile.Name())
|
|
|
|
if err != nil {
|
|
|
|
panic(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
err = a.Migrate()
|
|
|
|
if err != nil {
|
|
|
|
panic(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
count, err := a.GetTimestamp()
|
|
|
|
if err != nil {
|
|
|
|
panic(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
if count <= 0 {
|
|
|
|
t.Fatal("zero count")
|
|
|
|
}
|
|
|
|
}
|