builder/sqlfiddle_test.go
2022-05-31 09:54:58 +08:00

114 lines
2.4 KiB
Go

// Copyright 2018 The Xorm Authors. All rights reserved.
// Use of this source code is governed by a BSD-style
// license that can be found in the LICENSE file.
//go:build sqlfiddle
// +build sqlfiddle
package builder
import (
"fmt"
"io/ioutil"
"os"
"testing"
"gitea.com/xorm/sqlfiddle"
"github.com/stretchr/testify/assert"
)
type fiddler struct {
sessionCode string
dbType int
f *sqlfiddle.Fiddle
}
func readPreparationSQLFromFile(path string) (string, error) {
file, err := os.Open(path)
defer file.Close()
if err != nil {
return "", err
}
data, err := ioutil.ReadAll(file)
if err != nil {
return "", err
}
return string(data), nil
}
func newFiddler(fiddleServerAddr, dbDialect, preparationSQL string) (*fiddler, error) {
var dbType int
switch dbDialect {
case MYSQL:
dbType = sqlfiddle.Mysql5_6
case MSSQL:
dbType = sqlfiddle.MSSQL2017
case POSTGRES:
dbType = sqlfiddle.PostgreSQL96
case ORACLE:
dbType = sqlfiddle.Oracle11gR2
case SQLITE:
dbType = sqlfiddle.SQLite_WebSQL
default:
return nil, ErrNotSupportDialectType
}
f := sqlfiddle.NewFiddle(fiddleServerAddr)
response, err := f.CreateSchema(dbType, preparationSQL)
if err != nil {
return nil, err
}
return &fiddler{sessionCode: response.Code, f: f, dbType: dbType}, nil
}
func (f *fiddler) executableCheck(obj interface{}) error {
var sql string
var err error
switch obj.(type) {
case *Builder:
sql, err = obj.(*Builder).ToBoundSQL()
if err != nil {
return err
}
case string:
sql = obj.(string)
}
_, err = f.f.RunSQL(f.dbType, f.sessionCode, sql)
if err != nil {
return err
}
return nil
}
func TestReadPreparationSQLFromFile(t *testing.T) {
sqlFromFile, err := readPreparationSQLFromFile("testdata/mysql_fiddle_data.sql")
assert.NoError(t, err)
fmt.Println(sqlFromFile)
}
func TestNewFiddler(t *testing.T) {
sqlFromFile, err := readPreparationSQLFromFile("testdata/mysql_fiddle_data.sql")
assert.NoError(t, err)
f, err := newFiddler("", MYSQL, sqlFromFile)
assert.NoError(t, err)
assert.NotEmpty(t, f.sessionCode)
}
func TestExecutableCheck(t *testing.T) {
sqlFromFile, err := readPreparationSQLFromFile("testdata/mysql_fiddle_data.sql")
assert.NoError(t, err)
f, err := newFiddler("", MYSQL, sqlFromFile)
assert.NoError(t, err)
assert.NotEmpty(t, f.sessionCode)
assert.NoError(t, f.executableCheck("SELECT * FROM table1"))
err = f.executableCheck("SELECT * FROM table3")
assert.Error(t, err)
}