2019-08-11 16:55:18 +02:00
|
|
|
package mysql
|
|
|
|
|
|
|
|
|
|
import (
|
|
|
|
|
"github.com/go-jet/jet/internal/testutils"
|
|
|
|
|
. "github.com/go-jet/jet/mysql"
|
|
|
|
|
. "github.com/go-jet/jet/tests/.gentestdata/mysql/dvds/table"
|
2020-05-09 11:00:22 +02:00
|
|
|
"github.com/stretchr/testify/require"
|
2019-08-11 16:55:18 +02:00
|
|
|
"testing"
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
func TestLockRead(t *testing.T) {
|
|
|
|
|
query := Customer.LOCK().READ()
|
|
|
|
|
|
|
|
|
|
testutils.AssertStatementSql(t, query, `
|
|
|
|
|
LOCK TABLES dvds.customer READ;
|
|
|
|
|
`)
|
|
|
|
|
|
|
|
|
|
_, err := query.Exec(db)
|
2020-05-09 11:00:22 +02:00
|
|
|
require.NoError(t, err)
|
2019-08-11 16:55:18 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func TestLockWrite(t *testing.T) {
|
|
|
|
|
query := Customer.LOCK().WRITE()
|
|
|
|
|
|
|
|
|
|
testutils.AssertStatementSql(t, query, `
|
|
|
|
|
LOCK TABLES dvds.customer WRITE;
|
|
|
|
|
`)
|
|
|
|
|
|
|
|
|
|
_, err := query.Exec(db)
|
2020-05-09 11:00:22 +02:00
|
|
|
require.NoError(t, err)
|
2019-08-11 16:55:18 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func TestUnlockTables(t *testing.T) {
|
|
|
|
|
query := UNLOCK_TABLES()
|
|
|
|
|
|
|
|
|
|
testutils.AssertStatementSql(t, query, `
|
|
|
|
|
UNLOCK TABLES;
|
|
|
|
|
`)
|
|
|
|
|
|
|
|
|
|
_, err := query.Exec(db)
|
2020-05-09 11:00:22 +02:00
|
|
|
require.NoError(t, err)
|
2019-08-11 16:55:18 +02:00
|
|
|
}
|