148 lines
		
	
	
		
			4.1 KiB
		
	
	
	
		
			Go
		
	
	
	
			
		
		
	
	
			148 lines
		
	
	
		
			4.1 KiB
		
	
	
	
		
			Go
		
	
	
	
/*
 | 
						|
 * Copyright 2025 coze-dev Authors
 | 
						|
 *
 | 
						|
 * Licensed under the Apache License, Version 2.0 (the "License");
 | 
						|
 * you may not use this file except in compliance with the License.
 | 
						|
 * You may obtain a copy of the License at
 | 
						|
 *
 | 
						|
 *     http://www.apache.org/licenses/LICENSE-2.0
 | 
						|
 *
 | 
						|
 * Unless required by applicable law or agreed to in writing, software
 | 
						|
 * distributed under the License is distributed on an "AS IS" BASIS,
 | 
						|
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 | 
						|
 * See the License for the specific language governing permissions and
 | 
						|
 * limitations under the License.
 | 
						|
 */
 | 
						|
 | 
						|
package vo
 | 
						|
 | 
						|
import (
 | 
						|
	"encoding/json"
 | 
						|
	"testing"
 | 
						|
 | 
						|
	"github.com/stretchr/testify/assert"
 | 
						|
)
 | 
						|
 | 
						|
func TestTypeInfoToJSONSchema(t *testing.T) {
 | 
						|
	tests := []struct {
 | 
						|
		name     string
 | 
						|
		typeInfo map[string]*TypeInfo
 | 
						|
		validate func(t *testing.T, schema string)
 | 
						|
	}{
 | 
						|
		{
 | 
						|
			name: "Basic Data Types",
 | 
						|
			typeInfo: map[string]*TypeInfo{
 | 
						|
				"stringField": {Type: DataTypeString},
 | 
						|
				"intField":    {Type: DataTypeInteger},
 | 
						|
				"numField":    {Type: DataTypeNumber},
 | 
						|
				"boolField":   {Type: DataTypeBoolean},
 | 
						|
				"timeField":   {Type: DataTypeTime},
 | 
						|
			},
 | 
						|
			validate: func(t *testing.T, schema string) {
 | 
						|
				var schemaObj map[string]any
 | 
						|
				err := json.Unmarshal([]byte(schema), &schemaObj)
 | 
						|
				assert.NoError(t, err)
 | 
						|
 | 
						|
				props := schemaObj["properties"].(map[string]any)
 | 
						|
 | 
						|
				// Validate string field
 | 
						|
				stringProp := props["stringField"].(map[string]any)
 | 
						|
				assert.Equal(t, "string", stringProp["type"])
 | 
						|
 | 
						|
				// Validate integer fields
 | 
						|
				intProp := props["intField"].(map[string]any)
 | 
						|
				assert.Equal(t, "integer", intProp["type"])
 | 
						|
 | 
						|
				// Validate numeric field
 | 
						|
				numProp := props["numField"].(map[string]any)
 | 
						|
				assert.Equal(t, "number", numProp["type"])
 | 
						|
 | 
						|
				// Validate Boolean fields
 | 
						|
				boolProp := props["boolField"].(map[string]any)
 | 
						|
				assert.Equal(t, "boolean", boolProp["type"])
 | 
						|
 | 
						|
				// validation time field
 | 
						|
				timeProp := props["timeField"].(map[string]any)
 | 
						|
				assert.Equal(t, "string", timeProp["type"])
 | 
						|
				assert.Equal(t, "date-time", timeProp["format"])
 | 
						|
			},
 | 
						|
		},
 | 
						|
		{
 | 
						|
			name: "Complex Data Types",
 | 
						|
			typeInfo: map[string]*TypeInfo{
 | 
						|
				"objectField": {Type: DataTypeObject},
 | 
						|
				"arrayField": {
 | 
						|
					Type:         DataTypeArray,
 | 
						|
					ElemTypeInfo: &TypeInfo{Type: DataTypeString},
 | 
						|
				},
 | 
						|
				"fileField": {
 | 
						|
					Type:     DataTypeFile,
 | 
						|
					FileType: fileSubTypePtr(FileTypeImage),
 | 
						|
				},
 | 
						|
			},
 | 
						|
			validate: func(t *testing.T, schema string) {
 | 
						|
				var schemaObj map[string]any
 | 
						|
				err := json.Unmarshal([]byte(schema), &schemaObj)
 | 
						|
				assert.NoError(t, err)
 | 
						|
 | 
						|
				props := schemaObj["properties"].(map[string]any)
 | 
						|
 | 
						|
				// Validation Object Field
 | 
						|
				objProp := props["objectField"].(map[string]any)
 | 
						|
				assert.Equal(t, "object", objProp["type"])
 | 
						|
 | 
						|
				// Validate array fields
 | 
						|
				arrProp := props["arrayField"].(map[string]any)
 | 
						|
				assert.Equal(t, "array", arrProp["type"])
 | 
						|
				items := arrProp["items"].(map[string]any)
 | 
						|
				assert.Equal(t, "string", items["type"])
 | 
						|
 | 
						|
				// Validate file field
 | 
						|
				fileProp := props["fileField"].(map[string]any)
 | 
						|
				assert.Equal(t, "string", fileProp["type"])
 | 
						|
				assert.Equal(t, "image", fileProp["contentMediaType"])
 | 
						|
			},
 | 
						|
		},
 | 
						|
		{
 | 
						|
			name: "Nested Array",
 | 
						|
			typeInfo: map[string]*TypeInfo{
 | 
						|
				"nestedArray": {
 | 
						|
					Type:         DataTypeArray,
 | 
						|
					ElemTypeInfo: &TypeInfo{Type: DataTypeObject},
 | 
						|
				},
 | 
						|
			},
 | 
						|
			validate: func(t *testing.T, schema string) {
 | 
						|
				var schemaObj map[string]any
 | 
						|
				err := json.Unmarshal([]byte(schema), &schemaObj)
 | 
						|
				assert.NoError(t, err)
 | 
						|
 | 
						|
				props := schemaObj["properties"].(map[string]any)
 | 
						|
 | 
						|
				// Validate nested array fields
 | 
						|
				arrProp := props["nestedArray"].(map[string]any)
 | 
						|
				assert.Equal(t, "array", arrProp["type"])
 | 
						|
				items := arrProp["items"].(map[string]any)
 | 
						|
				assert.Equal(t, "object", items["type"])
 | 
						|
			},
 | 
						|
		},
 | 
						|
	}
 | 
						|
 | 
						|
	for _, tt := range tests {
 | 
						|
		t.Run(tt.name, func(t *testing.T) {
 | 
						|
			schema, err := TypeInfoToJSONSchema(tt.typeInfo, nil)
 | 
						|
			assert.NoError(t, err)
 | 
						|
			tt.validate(t, schema)
 | 
						|
		})
 | 
						|
	}
 | 
						|
}
 | 
						|
 | 
						|
// Helper functions for creating DataType pointers
 | 
						|
func stringPtr(dt DataType) *DataType {
 | 
						|
	return &dt
 | 
						|
}
 | 
						|
 | 
						|
// Helper function for creating a FileSubType pointer
 | 
						|
func fileSubTypePtr(fst FileSubType) *FileSubType {
 | 
						|
	return &fst
 | 
						|
}
 |