func (sg *schemaGenContext) buildArray() error { tpe, err := sg.TypeResolver.ResolveSchema(sg.Schema.Items.Schema, true) if err != nil { return err } // check if the element is a complex object, if so generate a new type for it if tpe.IsComplexObject && tpe.IsAnonymous { pg := sg.makeNewStruct(sg.Name+" items"+strconv.Itoa(sg.Index), *sg.Schema.Items.Schema) if err := pg.makeGenSchema(); err != nil { return err } sg.MergeResult(pg) sg.ExtraSchemas[pg.Name] = pg.GenSchema sg.Schema.Items.Schema = spec.RefProperty("#/definitions/" + pg.Name) if err := sg.makeGenSchema(); err != nil { return err } return nil } elProp := sg.NewSliceBranch(sg.Schema.Items.Schema) if err := elProp.makeGenSchema(); err != nil { return err } sg.MergeResult(elProp) sg.GenSchema.ItemsEnum = elProp.GenSchema.Enum elProp.GenSchema.Suffix = "Items" sg.GenSchema.GoType = "[]" + elProp.GenSchema.GoType sg.GenSchema.Items = &elProp.GenSchema return nil }
func newMapStack(context *schemaGenContext) (first, last *mapStack, err error) { ms := &mapStack{ Type: &context.Schema, Context: context, } l := ms for l.HasMore() { tpe, err := l.Context.TypeResolver.ResolveSchema(l.Type.AdditionalProperties.Schema, true) if err != nil { return nil, nil, err } if !tpe.IsMap { if tpe.IsComplexObject && tpe.IsAnonymous { nw := l.Context.makeNewStruct(l.Context.Name+" Anon", *l.Type.AdditionalProperties.Schema) sch := spec.RefProperty("#/definitions/" + nw.Name) l.NewObj = nw l.Type.AdditionalProperties.Schema = sch l.ValueRef = l.Context.NewAdditionalProperty(*sch) } break } l.Next = &mapStack{ Previous: l, Type: l.Type.AdditionalProperties.Schema, Context: l.Context.NewAdditionalProperty(*l.Type.AdditionalProperties.Schema), } l = l.Next } return ms, l, nil }
func (sg *schemaGenContext) buildAdditionalItems() error { wantsAdditionalItems := sg.Schema.AdditionalItems != nil && (sg.Schema.AdditionalItems.Allows || sg.Schema.AdditionalItems.Schema != nil) sg.GenSchema.HasAdditionalItems = wantsAdditionalItems if wantsAdditionalItems { // check if the element is a complex object, if so generate a new type for it tpe, err := sg.TypeResolver.ResolveSchema(sg.Schema.AdditionalItems.Schema, true) if err != nil { return err } if tpe.IsComplexObject && tpe.IsAnonymous { pg := sg.makeNewStruct(sg.Name+" Items", *sg.Schema.AdditionalItems.Schema) if err := pg.makeGenSchema(); err != nil { return err } sg.Schema.AdditionalItems.Schema = spec.RefProperty("#/definitions/" + pg.Name) pg.GenSchema.HasValidations = true sg.MergeResult(pg) sg.ExtraSchemas[pg.Name] = pg.GenSchema } it := sg.NewAdditionalItems(sg.Schema.AdditionalItems.Schema) if tpe.IsInterface { it.Untyped = true } if err := it.makeGenSchema(); err != nil { return err } sg.MergeResult(it) sg.GenSchema.AdditionalItems = &it.GenSchema } return nil }
func TestValidateParameters(t *testing.T) { doc, api := petstore.NewAPI(t) validator := NewSpecValidator(spec.MustLoadSwagger20Schema(), api.Formats()) validator.spec = doc res := validator.validateParameters() assert.Empty(t, res.Errors) sw := doc.Spec() sw.Paths.Paths["/pets"].Get.Parameters = append(sw.Paths.Paths["/pets"].Get.Parameters, *spec.QueryParam("limit").Typed("string", "")) res = validator.validateParameters() assert.NotEmpty(t, res.Errors) doc, api = petstore.NewAPI(t) sw = doc.Spec() sw.Paths.Paths["/pets"].Post.Parameters = append(sw.Paths.Paths["/pets"].Post.Parameters, *spec.BodyParam("fake", spec.RefProperty("#/definitions/Pet"))) validator = NewSpecValidator(spec.MustLoadSwagger20Schema(), api.Formats()) validator.spec = doc res = validator.validateParameters() assert.NotEmpty(t, res.Errors) assert.Len(t, res.Errors, 1) assert.Contains(t, res.Errors[0].Error(), "has more than 1 body param") doc, api = petstore.NewAPI(t) sw = doc.Spec() pp := sw.Paths.Paths["/pets/{id}"] pp.Delete = nil var nameParams []spec.Parameter for _, p := range pp.Parameters { if p.Name == "id" { p.Name = "name" nameParams = append(nameParams, p) } } pp.Parameters = nameParams sw.Paths.Paths["/pets/{name}"] = pp doc.Reload() validator = NewSpecValidator(spec.MustLoadSwagger20Schema(), api.Formats()) validator.spec = doc res = validator.validateParameters() assert.NotEmpty(t, res.Errors) assert.Len(t, res.Errors, 1) assert.Contains(t, res.Errors[0].Error(), "overlaps with") doc, api = petstore.NewAPI(t) validator = NewSpecValidator(spec.MustLoadSwagger20Schema(), api.Formats()) validator.spec = doc sw = doc.Spec() pp = sw.Paths.Paths["/pets/{id}"] pp.Delete = nil pp.Get.Parameters = nameParams pp.Parameters = nil sw.Paths.Paths["/pets/{id}"] = pp doc.Reload() res = validator.validateParameters() assert.NotEmpty(t, res.Errors) assert.Len(t, res.Errors, 2) assert.Contains(t, res.Errors[1].Error(), "is not present in path \"/pets/{id}\"") assert.Contains(t, res.Errors[0].Error(), "has no parameter definition") }