Fix dump/import bug
This commit is contained in:
parent
9500b23395
commit
8a04b78ece
11
engine.go
11
engine.go
|
@ -6,7 +6,6 @@ package xorm
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"bufio"
|
"bufio"
|
||||||
"bytes"
|
|
||||||
"context"
|
"context"
|
||||||
"database/sql"
|
"database/sql"
|
||||||
"errors"
|
"errors"
|
||||||
|
@ -1174,12 +1173,18 @@ func (engine *Engine) Import(r io.Reader) ([]sql.Result, error) {
|
||||||
var lastError error
|
var lastError error
|
||||||
scanner := bufio.NewScanner(r)
|
scanner := bufio.NewScanner(r)
|
||||||
|
|
||||||
|
var inSingleQuote bool
|
||||||
semiColSpliter := func(data []byte, atEOF bool) (advance int, token []byte, err error) {
|
semiColSpliter := func(data []byte, atEOF bool) (advance int, token []byte, err error) {
|
||||||
if atEOF && len(data) == 0 {
|
if atEOF && len(data) == 0 {
|
||||||
return 0, nil, nil
|
return 0, nil, nil
|
||||||
}
|
}
|
||||||
if i := bytes.IndexByte(data, ';'); i >= 0 {
|
for i, b := range data {
|
||||||
return i + 1, data[0:i], nil
|
if b == '\'' {
|
||||||
|
inSingleQuote = !inSingleQuote
|
||||||
|
}
|
||||||
|
if !inSingleQuote && b == ';' {
|
||||||
|
return i + 1, data[0:i], nil
|
||||||
|
}
|
||||||
}
|
}
|
||||||
// If we're at EOF, we have a final, non-terminated line. Return it.
|
// If we're at EOF, we have a final, non-terminated line. Return it.
|
||||||
if atEOF {
|
if atEOF {
|
||||||
|
|
|
@ -7,6 +7,9 @@ package xorm
|
||||||
import (
|
import (
|
||||||
"context"
|
"context"
|
||||||
"fmt"
|
"fmt"
|
||||||
|
"io/ioutil"
|
||||||
|
"os"
|
||||||
|
"path/filepath"
|
||||||
"testing"
|
"testing"
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
|
@ -64,3 +67,53 @@ func TestAutoTransaction(t *testing.T) {
|
||||||
assert.NoError(t, err)
|
assert.NoError(t, err)
|
||||||
assert.EqualValues(t, false, has)
|
assert.EqualValues(t, false, has)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func TestDump(t *testing.T) {
|
||||||
|
assert.NoError(t, prepareEngine())
|
||||||
|
|
||||||
|
type TestDumpStruct struct {
|
||||||
|
Id int64
|
||||||
|
Name string
|
||||||
|
}
|
||||||
|
|
||||||
|
assertSync(t, new(TestDumpStruct))
|
||||||
|
|
||||||
|
testEngine.Insert([]TestDumpStruct{
|
||||||
|
{Name: "1"},
|
||||||
|
{Name: "2\n"},
|
||||||
|
{Name: "3;"},
|
||||||
|
{Name: "4"},
|
||||||
|
{Name: "5'"},
|
||||||
|
})
|
||||||
|
|
||||||
|
fp := testEngine.Dialect().URI().DBName + ".sql"
|
||||||
|
os.Remove(fp)
|
||||||
|
assert.NoError(t, testEngine.DumpAllToFile(fp))
|
||||||
|
|
||||||
|
assert.NoError(t, prepareEngine())
|
||||||
|
|
||||||
|
_, err := testEngine.ImportFile(fp)
|
||||||
|
assert.NoError(t, err)
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestImport(t *testing.T) {
|
||||||
|
assert.NoError(t, prepareEngine())
|
||||||
|
|
||||||
|
var sql = "/*Generated by xorm 2020-03-13 17:13:51, from sqlite3 to SQLITE3*/" +
|
||||||
|
"CREATE TABLE IF NOT EXISTS `test_dump_struct` (`id` INTEGER PRIMARY KEY AUTOINCREMENT NOT NULL, `name` TEXT NULL);" +
|
||||||
|
"INSERT INTO `test_dump_struct` (`id`, `name`) VALUES (1, '1');" +
|
||||||
|
"INSERT INTO `test_dump_struct` (`id`, `name`) VALUES (2, '2;');" +
|
||||||
|
"INSERT INTO `test_dump_struct` (`id`, `name`) VALUES (3, '3''');" +
|
||||||
|
"INSERT INTO `test_dump_struct` (`id`, `name`) VALUES (4, '4\n\n');" +
|
||||||
|
"INSERT INTO `test_dump_struct` (`id`, `name`) VALUES (5, '5\n;\n');"
|
||||||
|
|
||||||
|
f, err := ioutil.TempFile(os.TempDir(), "dump_file.sql")
|
||||||
|
assert.NoError(t, err)
|
||||||
|
_, err = f.WriteString(sql)
|
||||||
|
assert.NoError(t, err)
|
||||||
|
info, err := f.Stat()
|
||||||
|
f.Close()
|
||||||
|
assert.NoError(t, err)
|
||||||
|
_, err = testEngine.ImportFile(filepath.Join(os.TempDir(), info.Name()))
|
||||||
|
assert.NoError(t, err)
|
||||||
|
}
|
||||||
|
|
|
@ -92,6 +92,7 @@ type EngineInterface interface {
|
||||||
GetTableMapper() names.Mapper
|
GetTableMapper() names.Mapper
|
||||||
GetTZDatabase() *time.Location
|
GetTZDatabase() *time.Location
|
||||||
GetTZLocation() *time.Location
|
GetTZLocation() *time.Location
|
||||||
|
ImportFile(fp string) ([]sql.Result, error)
|
||||||
MapCacher(interface{}, caches.Cacher) error
|
MapCacher(interface{}, caches.Cacher) error
|
||||||
NewSession() *Session
|
NewSession() *Session
|
||||||
NoAutoTime() *Session
|
NoAutoTime() *Session
|
||||||
|
|
|
@ -6,7 +6,6 @@ package xorm
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"fmt"
|
"fmt"
|
||||||
"os"
|
|
||||||
"testing"
|
"testing"
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
|
@ -210,14 +209,6 @@ func TestCustomTableName(t *testing.T) {
|
||||||
assert.NoError(t, testEngine.CreateTables(c))
|
assert.NoError(t, testEngine.CreateTables(c))
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestDump(t *testing.T) {
|
|
||||||
assert.NoError(t, prepareEngine())
|
|
||||||
|
|
||||||
fp := testEngine.Dialect().URI().DBName + ".sql"
|
|
||||||
os.Remove(fp)
|
|
||||||
assert.NoError(t, testEngine.DumpAllToFile(fp))
|
|
||||||
}
|
|
||||||
|
|
||||||
type IndexOrUnique struct {
|
type IndexOrUnique struct {
|
||||||
Id int64
|
Id int64
|
||||||
Index int `xorm:"index"`
|
Index int `xorm:"index"`
|
||||||
|
|
Loading…
Reference in New Issue