Merge branch 'master' into bug/oauth2-authorization-interceptor
This commit is contained in:
@@ -183,7 +183,7 @@ export class Select extends React.Component {
|
|||||||
{ allowEmptyValue ? <option value="">--</option> : null }
|
{ allowEmptyValue ? <option value="">--</option> : null }
|
||||||
{
|
{
|
||||||
allowedValues.map(function (item, key) {
|
allowedValues.map(function (item, key) {
|
||||||
return <option key={ key } value={ String(item) }>{ item }</option>
|
return <option key={ key } value={ String(item) }>{ String(item) }</option>
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
</select>
|
</select>
|
||||||
|
|||||||
@@ -57,9 +57,6 @@ export default class ResponseBody extends React.Component {
|
|||||||
(headers["Content-Description"] && (/File Transfer/i).test(headers["Content-Description"])) ||
|
(headers["Content-Description"] && (/File Transfer/i).test(headers["Content-Description"])) ||
|
||||||
(headers["content-description"] && (/File Transfer/i).test(headers["content-description"]))) {
|
(headers["content-description"] && (/File Transfer/i).test(headers["content-description"]))) {
|
||||||
|
|
||||||
let contentLength = headers["content-length"] || headers["Content-Length"]
|
|
||||||
if ( !(+contentLength) ) return null
|
|
||||||
|
|
||||||
const isSafari = /^((?!chrome|android).)*safari/i.test(navigator.userAgent)
|
const isSafari = /^((?!chrome|android).)*safari/i.test(navigator.userAgent)
|
||||||
|
|
||||||
if (!isSafari && "Blob" in window) {
|
if (!isSafari && "Blob" in window) {
|
||||||
|
|||||||
@@ -36,7 +36,7 @@ export class JsonSchemaForm extends Component {
|
|||||||
|
|
||||||
let { type, format="" } = schema
|
let { type, format="" } = schema
|
||||||
|
|
||||||
let Comp = getComponent(`JsonSchema_${type}_${format}`) || getComponent(`JsonSchema_${type}`) || getComponent("JsonSchema_string")
|
let Comp = (format ? getComponent(`JsonSchema_${type}_${format}`) : getComponent(`JsonSchema_${type}`)) || getComponent("JsonSchema_string")
|
||||||
return <Comp { ...this.props } fn={fn} getComponent={getComponent} value={value} onChange={onChange} schema={schema}/>
|
return <Comp { ...this.props } fn={fn} getComponent={getComponent} value={value} onChange={onChange} schema={schema}/>
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -189,8 +189,8 @@ export class JsonSchema_boolean extends Component {
|
|||||||
return (<Select className={ errors.length ? "invalid" : ""}
|
return (<Select className={ errors.length ? "invalid" : ""}
|
||||||
title={ errors.length ? errors : ""}
|
title={ errors.length ? errors : ""}
|
||||||
value={ String(value) }
|
value={ String(value) }
|
||||||
allowedValues={ fromJS(["true", "false"]) }
|
allowedValues={ fromJS(schema.enum || ["true", "false"]) }
|
||||||
allowEmptyValue={ true }
|
allowEmptyValue={ !this.props.required }
|
||||||
onChange={ this.onEnumChange }/>)
|
onChange={ this.onEnumChange }/>)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -473,6 +473,9 @@ export const validateParam = (param, isXml, isOAS3 = false) => {
|
|||||||
let required = param.get("required")
|
let required = param.get("required")
|
||||||
|
|
||||||
let paramDetails = isOAS3 ? param.get("schema") : param
|
let paramDetails = isOAS3 ? param.get("schema") : param
|
||||||
|
|
||||||
|
if(!paramDetails) return errors
|
||||||
|
|
||||||
let maximum = paramDetails.get("maximum")
|
let maximum = paramDetails.get("maximum")
|
||||||
let minimum = paramDetails.get("minimum")
|
let minimum = paramDetails.get("minimum")
|
||||||
let type = paramDetails.get("type")
|
let type = paramDetails.get("type")
|
||||||
|
|||||||
154
test/components/json-schema-form.js
Normal file
154
test/components/json-schema-form.js
Normal file
@@ -0,0 +1,154 @@
|
|||||||
|
/* eslint-env mocha */
|
||||||
|
import React from "react"
|
||||||
|
import expect, { createSpy } from "expect"
|
||||||
|
import { Select, Input } from "components/layout-utils"
|
||||||
|
import { render } from "enzyme"
|
||||||
|
import * as JsonSchemaComponents from "core/json-schema-components"
|
||||||
|
import { JsonSchemaForm } from "core/json-schema-components"
|
||||||
|
|
||||||
|
const components = {...JsonSchemaComponents, Select, Input}
|
||||||
|
|
||||||
|
const getComponentStub = (name) => {
|
||||||
|
if(components[name]) return components[name]
|
||||||
|
|
||||||
|
return null
|
||||||
|
}
|
||||||
|
|
||||||
|
describe("<JsonSchemaForm/>", function(){
|
||||||
|
describe("strings", function() {
|
||||||
|
it("should render the correct options for a string enum parameter", function(){
|
||||||
|
|
||||||
|
let props = {
|
||||||
|
getComponent: getComponentStub,
|
||||||
|
value: "",
|
||||||
|
onChange: () => {},
|
||||||
|
keyName: "",
|
||||||
|
fn: {},
|
||||||
|
schema: {
|
||||||
|
type: "string",
|
||||||
|
enum: ["one", "two"]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
let wrapper = render(<JsonSchemaForm {...props}/>)
|
||||||
|
|
||||||
|
expect(wrapper.find("select").length).toEqual(1)
|
||||||
|
expect(wrapper.find("select option").length).toEqual(3)
|
||||||
|
expect(wrapper.find("select option").eq(0).text()).toEqual("--")
|
||||||
|
expect(wrapper.find("select option").eq(1).text()).toEqual("one")
|
||||||
|
expect(wrapper.find("select option").eq(2).text()).toEqual("two")
|
||||||
|
})
|
||||||
|
|
||||||
|
it("should render the correct options for a required string enum parameter", function(){
|
||||||
|
|
||||||
|
let props = {
|
||||||
|
getComponent: getComponentStub,
|
||||||
|
value: "",
|
||||||
|
onChange: () => {},
|
||||||
|
keyName: "",
|
||||||
|
fn: {},
|
||||||
|
required: true,
|
||||||
|
schema: {
|
||||||
|
type: "string",
|
||||||
|
enum: ["one", "two"]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
let wrapper = render(<JsonSchemaForm {...props}/>)
|
||||||
|
|
||||||
|
expect(wrapper.find("select").length).toEqual(1)
|
||||||
|
expect(wrapper.find("select option").length).toEqual(2)
|
||||||
|
expect(wrapper.find("select option").eq(0).text()).toEqual("one")
|
||||||
|
expect(wrapper.find("select option").eq(1).text()).toEqual("two")
|
||||||
|
})
|
||||||
|
})
|
||||||
|
describe("booleans", function() {
|
||||||
|
it("should render the correct options for a boolean parameter", function(){
|
||||||
|
|
||||||
|
let props = {
|
||||||
|
getComponent: getComponentStub,
|
||||||
|
value: "",
|
||||||
|
onChange: () => {},
|
||||||
|
keyName: "",
|
||||||
|
fn: {},
|
||||||
|
schema: {
|
||||||
|
type: "boolean"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
let wrapper = render(<JsonSchemaForm {...props}/>)
|
||||||
|
|
||||||
|
expect(wrapper.find("select").length).toEqual(1)
|
||||||
|
expect(wrapper.find("select option").length).toEqual(3)
|
||||||
|
expect(wrapper.find("select option").eq(0).text()).toEqual("--")
|
||||||
|
expect(wrapper.find("select option").eq(1).text()).toEqual("true")
|
||||||
|
expect(wrapper.find("select option").eq(2).text()).toEqual("false")
|
||||||
|
})
|
||||||
|
|
||||||
|
it("should render the correct options for a required enum boolean parameter", function(){
|
||||||
|
|
||||||
|
let props = {
|
||||||
|
getComponent: getComponentStub,
|
||||||
|
value: "",
|
||||||
|
onChange: () => {},
|
||||||
|
keyName: "",
|
||||||
|
fn: {},
|
||||||
|
required: true,
|
||||||
|
schema: {
|
||||||
|
type: "boolean",
|
||||||
|
enum: ["true"]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
let wrapper = render(<JsonSchemaForm {...props}/>)
|
||||||
|
|
||||||
|
expect(wrapper.find("select").length).toEqual(1)
|
||||||
|
expect(wrapper.find("select option").length).toEqual(1)
|
||||||
|
expect(wrapper.find("select option").first().text()).toEqual("true")
|
||||||
|
})
|
||||||
|
})
|
||||||
|
describe("unknown types", function() {
|
||||||
|
it("should render unknown types as strings", function(){
|
||||||
|
|
||||||
|
let props = {
|
||||||
|
getComponent: getComponentStub,
|
||||||
|
value: "yo",
|
||||||
|
onChange: () => {},
|
||||||
|
keyName: "",
|
||||||
|
fn: {},
|
||||||
|
schema: {
|
||||||
|
type: "NotARealType"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
let wrapper = render(<JsonSchemaForm {...props}/>)
|
||||||
|
|
||||||
|
expect(wrapper.find("input").length).toEqual(1)
|
||||||
|
// expect(wrapper.find("select input").length).toEqual(1)
|
||||||
|
// expect(wrapper.find("select option").first().text()).toEqual("true")
|
||||||
|
})
|
||||||
|
|
||||||
|
it("should render unknown types as strings when a format is passed", function(){
|
||||||
|
|
||||||
|
let props = {
|
||||||
|
getComponent: getComponentStub,
|
||||||
|
value: "yo",
|
||||||
|
onChange: () => {},
|
||||||
|
keyName: "",
|
||||||
|
fn: {},
|
||||||
|
schema: {
|
||||||
|
type: "NotARealType",
|
||||||
|
format: "NotARealFormat"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
let wrapper = render(<JsonSchemaForm {...props}/>)
|
||||||
|
|
||||||
|
expect(wrapper.find("input").length).toEqual(1)
|
||||||
|
// expect(wrapper.find("select input").length).toEqual(1)
|
||||||
|
// expect(wrapper.find("select option").first().text()).toEqual("true")
|
||||||
|
})
|
||||||
|
})
|
||||||
|
})
|
||||||
@@ -321,14 +321,11 @@ describe("utils", function() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
it("should check the isOAS3 flag when validating parameters", function() {
|
it("should check the isOAS3 flag when validating parameters", function() {
|
||||||
// This should "skip" validation because there is no `schema.type` property
|
// This should "skip" validation because there is no `schema` property
|
||||||
// and we are telling `validateParam` this is an OAS3 spec
|
// and we are telling `validateParam` this is an OAS3 spec
|
||||||
param = fromJS({
|
param = fromJS({
|
||||||
value: "",
|
value: "",
|
||||||
required: true,
|
required: true
|
||||||
schema: {
|
|
||||||
notTheTypeProperty: "string"
|
|
||||||
}
|
|
||||||
})
|
})
|
||||||
result = validateParam( param, false, true )
|
result = validateParam( param, false, true )
|
||||||
expect( result ).toEqual( [] )
|
expect( result ).toEqual( [] )
|
||||||
|
|||||||
Reference in New Issue
Block a user