jet/tests/mysql/lock_test.go

46 lines
883 B
Go
Raw Normal View History

package mysql
import (
2020-06-27 18:48:19 +02:00
"github.com/go-jet/jet/v2/internal/testutils"
. "github.com/go-jet/jet/v2/mysql"
. "github.com/go-jet/jet/v2/tests/.gentestdata/mysql/dvds/table"
"github.com/stretchr/testify/require"
"testing"
)
func TestLockRead(t *testing.T) {
query := Customer.LOCK().READ()
testutils.AssertStatementSql(t, query, `
LOCK TABLES dvds.customer READ;
`)
_, err := query.Exec(db)
require.NoError(t, err)
requireLogged(t, query)
}
func TestLockWrite(t *testing.T) {
query := Customer.LOCK().WRITE()
testutils.AssertStatementSql(t, query, `
LOCK TABLES dvds.customer WRITE;
`)
_, err := query.Exec(db)
require.NoError(t, err)
requireLogged(t, query)
}
func TestUnlockTables(t *testing.T) {
query := UNLOCK_TABLES()
testutils.AssertStatementSql(t, query, `
UNLOCK TABLES;
`)
_, err := query.Exec(db)
require.NoError(t, err)
requireLogged(t, query)
}