package schema import ( "encoding/json" "github.com/golang/protobuf/proto" . "github.com/seaweedfs/seaweedfs/weed/pb/schema_pb" "github.com/stretchr/testify/assert" "testing" ) func TestEnumScalarType(t *testing.T) { tests := []struct { name string enum ScalarType expected int32 }{ {"Boolean", ScalarType_BOOLEAN, 0}, {"Integer", ScalarType_INTEGER, 1}, {"Long", ScalarType_LONG, 3}, {"Float", ScalarType_FLOAT, 4}, {"Double", ScalarType_DOUBLE, 5}, {"Bytes", ScalarType_BYTES, 6}, {"String", ScalarType_STRING, 7}, } for _, tt := range tests { t.Run(tt.name, func(t *testing.T) { assert.Equal(t, tt.expected, int32(tt.enum)) }) } } func TestMapType(t *testing.T) { mt := &MapType{ Key: "key", Value: &Type{Kind: &Type_ScalarType{ScalarType: ScalarType_BOOLEAN}}, } assert.NotNil(t, mt) } func TestField(t *testing.T) { field := &Field{ Name: "field_name", Type: &Type{Kind: &Type_ScalarType{ScalarType: ScalarType_INTEGER}}, Index: 1, IsOptional: true, IsRepeated: false, } assert.NotNil(t, field) } func TestRecordType(t *testing.T) { subRecord := &RecordType{ Fields: []*Field{ { Name: "field_1", Type: &Type{Kind: &Type_ScalarType{ScalarType: ScalarType_INTEGER}}, Index: 1, IsOptional: true, IsRepeated: false, }, { Name: "field_2", Type: &Type{Kind: &Type_ScalarType{ScalarType: ScalarType_STRING}}, Index: 2, IsOptional: true, IsRepeated: false, }, }, } record := &RecordType{ Fields: []*Field{ { Name: "field_key", Type: &Type{Kind: &Type_ScalarType{ScalarType: ScalarType_INTEGER}}, Index: 1, IsOptional: true, IsRepeated: false, }, { Name: "field_record", Type: &Type{Kind: &Type_RecordType{RecordType: subRecord}}, Index: 2, IsOptional: true, IsRepeated: false, }, }, } // serialize record to protobuf text marshalling text := proto.MarshalTextString(record) println(text) bytes, _ := json.Marshal(record) println(string(bytes)) assert.NotNil(t, record) }