2018-11-08 22:28:27 +00:00
|
|
|
package tests
|
|
|
|
|
|
|
|
import (
|
|
|
|
"testing"
|
|
|
|
|
|
|
|
"github.com/localhots/bocadillo/mysql"
|
|
|
|
)
|
|
|
|
|
2018-11-08 22:29:09 +00:00
|
|
|
func TestJSON(t *testing.T) {
|
|
|
|
tbl := suite.createTable(mysql.ColumnTypeJSON, "", attrNone)
|
|
|
|
defer tbl.drop(t)
|
|
|
|
|
|
|
|
exp := []byte(`{"hello": "world", "foo": [1, 2, 3.75]}`)
|
|
|
|
suite.insertAndCompare(t, tbl, exp)
|
|
|
|
}
|
|
|
|
|
2018-11-08 22:59:52 +00:00
|
|
|
func TestGeometry(t *testing.T) {
|
|
|
|
// Geometry values are tricky
|
|
|
|
// FIXME: Implement me one day
|
|
|
|
t.Skip("Not implemented")
|
|
|
|
}
|
|
|
|
|
2018-11-08 23:05:08 +00:00
|
|
|
func TestBit(t *testing.T) {
|
|
|
|
// Where to get these?
|
|
|
|
// FIXME: Implement me one day
|
|
|
|
t.Skip("Not implemented")
|
|
|
|
}
|
|
|
|
|
2018-11-08 22:28:27 +00:00
|
|
|
func TestSet(t *testing.T) {
|
|
|
|
tbl := suite.createTable(mysql.ColumnTypeSet, "'a', 'b', 'c'", attrNone)
|
|
|
|
defer tbl.drop(t)
|
|
|
|
|
|
|
|
const (
|
|
|
|
// TODO: How do I define such a bitmask properly?
|
|
|
|
bA int64 = 1
|
|
|
|
bB int64 = 2
|
|
|
|
bC int64 = 4
|
|
|
|
)
|
|
|
|
|
|
|
|
inputs := map[string]int64{
|
|
|
|
"": 0,
|
|
|
|
"a": bA,
|
|
|
|
"a,b": bA | bB,
|
|
|
|
"a,c": bA | bC,
|
|
|
|
"a,b,c": bA | bB | bC,
|
|
|
|
}
|
|
|
|
|
|
|
|
for in, exp := range inputs {
|
|
|
|
t.Run("input "+in, func(t *testing.T) {
|
|
|
|
suite.insertAndCompareExp(t, tbl, in, exp)
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
2018-11-08 23:05:19 +00:00
|
|
|
|
|
|
|
func TestEnum(t *testing.T) {
|
|
|
|
tbl := suite.createTable(mysql.ColumnTypeEnum, "'a', 'b', 'c'", attrNone)
|
|
|
|
defer tbl.drop(t)
|
|
|
|
|
|
|
|
inputs := map[string]int64{
|
|
|
|
"": 0,
|
2018-11-08 23:20:12 +00:00
|
|
|
"a": 1,
|
|
|
|
"b": 2,
|
|
|
|
"c": 3,
|
2018-11-08 23:05:19 +00:00
|
|
|
}
|
|
|
|
for in, exp := range inputs {
|
|
|
|
t.Run("input "+in, func(t *testing.T) {
|
|
|
|
suite.insertAndCompareExp(t, tbl, in, exp)
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|