80 lines
1.6 KiB
Go

package driver
import (
"flag"
"fmt"
"testing"
"github.com/jmoiron/sqlx"
. "github.com/pingcap/check"
)
// Use docker mysql to test, mysql is 3306
var testHost = flag.String("host", "127.0.0.1", "MySQL master host")
// possible choices for different MySQL versions are: 5561,5641,3306,5722,8003,8012
var testPort = flag.Int("port", 3306, "MySQL server port")
var testUser = flag.String("user", "root", "MySQL user")
var testPassword = flag.String("pass", "", "MySQL password")
var testDB = flag.String("db", "test", "MySQL test database")
func TestDriver(t *testing.T) {
TestingT(t)
}
type testDriverSuite struct {
db *sqlx.DB
}
var _ = Suite(&testDriverSuite{})
func (s *testDriverSuite) SetUpSuite(c *C) {
addr := fmt.Sprintf("%s:%d", *testHost, *testPort)
dsn := fmt.Sprintf("%s:%s@%s?%s", *testUser, *testPassword, addr, *testDB)
var err error
s.db, err = sqlx.Open("mysql", dsn)
c.Assert(err, IsNil)
}
func (s *testDriverSuite) TearDownSuite(c *C) {
if s.db != nil {
s.db.Close()
}
}
func (s *testDriverSuite) TestConn(c *C) {
var n int
err := s.db.Get(&n, "SELECT 1")
c.Assert(err, IsNil)
c.Assert(n, Equals, 1)
_, err = s.db.Exec("USE test")
c.Assert(err, IsNil)
}
func (s *testDriverSuite) TestStmt(c *C) {
stmt, err := s.db.Preparex("SELECT ? + ?")
c.Assert(err, IsNil)
var n int
err = stmt.Get(&n, 1, 1)
c.Assert(err, IsNil)
c.Assert(n, Equals, 2)
err = stmt.Close()
c.Assert(err, IsNil)
}
func (s *testDriverSuite) TestTransaction(c *C) {
tx, err := s.db.Beginx()
c.Assert(err, IsNil)
var n int
err = tx.Get(&n, "SELECT 1")
c.Assert(err, IsNil)
c.Assert(n, Equals, 1)
err = tx.Commit()
c.Assert(err, IsNil)
}