Слияние кода завершено, страница обновится автоматически
package session_test
import (
"fmt"
"testing"
"github.com/hanchuanchuan/goInception/config"
"github.com/hanchuanchuan/goInception/session"
. "github.com/pingcap/check"
"golang.org/x/net/context"
)
var _ = Suite(&testInceptionSuite{})
type testInceptionSuite struct{}
func TestInception(t *testing.T) {
TestingT(t)
}
func (s *testInceptionSuite) SetUpSuite(c *C) {
inc := &config.GetGlobalConfig().Inc
inc.BackupHost = "127.0.0.1"
inc.BackupPort = 3306
inc.BackupUser = "test"
inc.BackupPassword = "test"
inc.Lang = "en-US"
inc.EnableFingerprint = true
inc.SqlSafeUpdates = 0
inc.EnableDropTable = true
}
func (s *testInceptionSuite) TestCheck(c *C) {
core := session.NewInception()
core.LoadOptions(session.SourceOptions{
Host: "127.0.0.1",
Port: 3306,
User: "test",
Password: "test",
})
sql := `use test_inc;
drop table if exists t1;
create table t1(id int primary key);
insert into t1 values(1);`
result, err := core.Audit(context.Background(), sql)
c.Assert(err, IsNil)
for _, row := range result {
// fmt.Println(fmt.Sprintf("%#v", row))
if row.ErrLevel == 2 {
fmt.Println(fmt.Sprintf("sql: %v, err: %v", row.Sql, row.ErrorMessage))
} else {
fmt.Println(fmt.Sprintf("[%v] sql: %v", session.StatusList[row.StageStatus], row.Sql))
}
}
}
func (s *testInceptionSuite) TestExecute(c *C) {
core := session.NewInception()
core.LoadOptions(session.SourceOptions{
Host: "127.0.0.1",
Port: 3306,
User: "test",
Password: "test",
})
sql := `use test_inc;
drop table if exists t1;
create table t1(id int primary key);
insert into t1 values(1);`
result, err := core.RunExecute(context.Background(), sql)
c.Assert(err, IsNil)
for _, row := range result {
// fmt.Println(fmt.Sprintf("%#v", row))
if row.ErrLevel == 2 {
fmt.Println(fmt.Sprintf("sql: %v, err: %v", row.Sql, row.ErrorMessage))
} else {
fmt.Println(fmt.Sprintf("[%v] sql: %v", session.StatusList[row.StageStatus], row.Sql))
}
}
}
func (s *testInceptionSuite) TestBackup(c *C) {
core := session.NewInception()
core.LoadOptions(session.SourceOptions{
Host: "127.0.0.1",
Port: 3306,
User: "test",
Password: "test",
Backup: true,
})
sql := `use test_inc;
drop table if exists t1;
create table t1(id int primary key);
insert into t1 values(1);`
result, err := core.RunExecute(context.Background(), sql)
c.Assert(err, IsNil)
for _, row := range result {
// fmt.Println(fmt.Sprintf("%#v", row))
if row.ErrLevel == 2 {
fmt.Println(fmt.Sprintf("sql: %v, err: %v", row.Sql, row.ErrorMessage))
} else {
fmt.Println(fmt.Sprintf("[%v] sql: %v", session.StatusList[row.StageStatus], row.Sql))
}
}
}
func (s *testInceptionSuite) TestDropTable(c *C) {
core := session.NewInception()
core.LoadOptions(session.SourceOptions{
Host: "127.0.0.1",
Port: 3306,
User: "test",
Password: "test",
Backup: true,
})
sql := `use test_inc;
drop table if exists t000001;
create table t000001(id int);`
result, err := core.RunExecute(context.Background(), sql)
c.Assert(err, IsNil)
for _, row := range result {
// fmt.Println(fmt.Sprintf("%#v", row))
if row.ErrLevel == 2 {
fmt.Println(fmt.Sprintf("sql: %v, err: %v", row.Sql, row.ErrorMessage))
} else {
fmt.Println(fmt.Sprintf("[%v] sql: %v", session.StatusList[row.StageStatus], row.Sql))
}
}
}
Вы можете оставить комментарий после Вход в систему
Неприемлемый контент может быть отображен здесь и не будет показан на странице. Вы можете проверить и изменить его с помощью соответствующей функции редактирования.
Если вы подтверждаете, что содержание не содержит непристойной лексики/перенаправления на рекламу/насилия/вульгарной порнографии/нарушений/пиратства/ложного/незначительного или незаконного контента, связанного с национальными законами и предписаниями, вы можете нажать «Отправить» для подачи апелляции, и мы обработаем ее как можно скорее.
Комментарий ( 0 )