ent/schema: explicitly defines non-null fields in schema

Reviewed By: alexsn

Differential Revision: D16791620

fbshipit-source-id: bad3ac7b2349d2f483c804eb3623c6dfa8b06313
This commit is contained in:
Ariel Mashraki
2019-08-15 03:34:02 -07:00
committed by Facebook Github Bot
parent 4ac1b595bf
commit c16d3c8e25
27 changed files with 839 additions and 186 deletions

View File

@@ -49,3 +49,43 @@ func TestColumn_ConvertibleTo(t *testing.T) {
require.False(t, c1.ConvertibleTo(&Column{Type: field.TypeUint32}))
require.False(t, c1.ConvertibleTo(&Column{Type: field.TypeString}))
}
func TestColumn_ScanDefault(t *testing.T) {
c1 := &Column{Type: field.TypeString, Size: 10}
require.NoError(t, c1.ScanDefault("Hello World"))
require.Equal(t, "Hello World", c1.Default)
require.NoError(t, c1.ScanDefault("1"))
require.Equal(t, "1", c1.Default)
c1 = &Column{Type: field.TypeInt64}
require.NoError(t, c1.ScanDefault("128"))
require.Equal(t, int64(128), c1.Default)
require.NoError(t, c1.ScanDefault("1"))
require.Equal(t, int64(1), c1.Default)
require.Error(t, c1.ScanDefault("foo"))
c1 = &Column{Type: field.TypeUint64}
require.NoError(t, c1.ScanDefault("128"))
require.Equal(t, uint64(128), c1.Default)
require.NoError(t, c1.ScanDefault("1"))
require.Equal(t, uint64(1), c1.Default)
require.Error(t, c1.ScanDefault("foo"))
c1 = &Column{Type: field.TypeFloat64}
require.NoError(t, c1.ScanDefault("128.1"))
require.Equal(t, 128.1, c1.Default)
require.NoError(t, c1.ScanDefault("1"))
require.Equal(t, float64(1), c1.Default)
require.Error(t, c1.ScanDefault("foo"))
c1 = &Column{Type: field.TypeBool}
require.NoError(t, c1.ScanDefault("1"))
require.Equal(t, true, c1.Default)
require.NoError(t, c1.ScanDefault("true"))
require.Equal(t, true, c1.Default)
require.NoError(t, c1.ScanDefault("0"))
require.Equal(t, false, c1.Default)
require.NoError(t, c1.ScanDefault("false"))
require.Equal(t, false, c1.Default)
require.Error(t, c1.ScanDefault("foo"))
}