xorm/mymysql_test.go

158 lines
3.0 KiB
Go
Raw Normal View History

package xorm
import (
_ "github.com/ziutek/mymysql/godrv"
"testing"
)
/*
CREATE DATABASE IF NOT EXISTS xorm_test CHARACTER SET
utf8 COLLATE utf8_general_ci;
*/
var showTestSql bool = true
func TestMyMysql(t *testing.T) {
2013-12-06 03:06:02 +00:00
err := mymysqlDdlImport()
2013-12-04 10:39:22 +00:00
if err != nil {
t.Error(err)
return
}
2013-11-16 16:52:43 +00:00
engine, err := NewEngine("mymysql", "xorm_test/root/")
defer engine.Close()
if err != nil {
t.Error(err)
return
}
engine.ShowSQL = showTestSql
engine.ShowErr = showTestSql
engine.ShowWarn = showTestSql
engine.ShowDebug = showTestSql
2013-12-04 10:39:22 +00:00
sqlResults, _ := engine.Import("tests/mysql_ddl.sql")
engine.LogDebug("sql results: %v", sqlResults)
2013-11-16 16:52:43 +00:00
testAll(engine, t)
testAll2(engine, t)
testAll3(engine, t)
2013-11-16 16:52:43 +00:00
}
func TestMyMysqlWithCache(t *testing.T) {
2013-12-06 03:06:02 +00:00
err := mymysqlDdlImport()
2013-12-04 10:39:22 +00:00
if err != nil {
t.Error(err)
return
}
2013-09-26 07:33:15 +00:00
engine, err := NewEngine("mymysql", "xorm_test2/root/")
defer engine.Close()
if err != nil {
t.Error(err)
return
}
2013-11-16 16:52:43 +00:00
engine.SetDefaultCacher(NewLRUCacher(NewMemoryStore(), 1000))
engine.ShowSQL = showTestSql
2013-11-16 16:52:43 +00:00
engine.ShowErr = showTestSql
engine.ShowWarn = showTestSql
engine.ShowDebug = showTestSql
2013-12-04 10:39:22 +00:00
sqlResults, _ := engine.Import("tests/mysql_ddl.sql")
engine.LogDebug("sql results: %v", sqlResults)
testAll(engine, t)
2013-09-26 07:19:39 +00:00
testAll2(engine, t)
}
2013-12-04 07:03:21 +00:00
func newMyMysqlEngine() (*Engine, error) {
return NewEngine("mymysql", "xorm_test2/root/")
}
2013-12-06 03:06:02 +00:00
func mymysqlDdlImport() error {
2013-12-04 10:39:22 +00:00
engine, err := NewEngine("mymysql", "/root/")
if err != nil {
return err
}
engine.ShowSQL = showTestSql
engine.ShowErr = showTestSql
engine.ShowWarn = showTestSql
engine.ShowDebug = showTestSql
sqlResults, _ := engine.Import("tests/mysql_ddl.sql")
engine.LogDebug("sql results: %v", sqlResults)
engine.Close()
return nil
}
2013-12-04 07:03:21 +00:00
func BenchmarkMyMysqlNoCacheInsert(t *testing.B) {
engine, err := newMyMysqlEngine()
if err != nil {
t.Error(err)
return
}
2013-12-04 12:33:43 +00:00
defer engine.Close()
2013-12-04 10:39:22 +00:00
2013-12-04 07:03:21 +00:00
doBenchInsert(engine, t)
}
func BenchmarkMyMysqlNoCacheFind(t *testing.B) {
engine, err := newMyMysqlEngine()
if err != nil {
t.Error(err)
return
}
defer engine.Close()
2013-12-04 12:33:43 +00:00
//engine.ShowSQL = true
2013-12-04 07:03:21 +00:00
doBenchFind(engine, t)
}
2013-12-04 07:03:21 +00:00
func BenchmarkMyMysqlNoCacheFindPtr(t *testing.B) {
engine, err := newMyMysqlEngine()
if err != nil {
t.Error(err)
return
}
2013-12-04 12:33:43 +00:00
defer engine.Close()
2013-12-04 07:03:21 +00:00
//engine.ShowSQL = true
doBenchFindPtr(engine, t)
}
func BenchmarkMyMysqlCacheInsert(t *testing.B) {
engine, err := newMyMysqlEngine()
if err != nil {
t.Error(err)
return
}
2013-12-04 12:33:43 +00:00
defer engine.Close()
engine.SetDefaultCacher(NewLRUCacher(NewMemoryStore(), 1000))
2013-12-04 07:03:21 +00:00
doBenchInsert(engine, t)
}
func BenchmarkMyMysqlCacheFind(t *testing.B) {
engine, err := newMyMysqlEngine()
if err != nil {
t.Error(err)
return
}
2013-12-04 10:39:22 +00:00
defer engine.Close()
2013-12-04 07:03:21 +00:00
engine.SetDefaultCacher(NewLRUCacher(NewMemoryStore(), 1000))
doBenchFind(engine, t)
}
func BenchmarkMyMysqlCacheFindPtr(t *testing.B) {
engine, err := newMyMysqlEngine()
if err != nil {
t.Error(err)
return
}
2013-12-04 12:33:43 +00:00
defer engine.Close()
2013-12-04 07:03:21 +00:00
engine.SetDefaultCacher(NewLRUCacher(NewMemoryStore(), 1000))
doBenchFindPtr(engine, t)
}