feature: full-spectrum runtime Docker configuration (via #4965)
* reorganize docker things * Configurator WIP * implement Docker runtime config generator * add tests * update documentation * fix Markdown tables * Move Docker section * add note to README * move up `nodejs` install for more aggressive caching * drop exclusive test * fix missing `DISPLAY_OPERATION_ID`
This commit is contained in:
230
test/docker/translator.js
Normal file
230
test/docker/translator.js
Normal file
@@ -0,0 +1,230 @@
|
||||
const expect = require("expect")
|
||||
const translator = require("../../docker/configurator/translator")
|
||||
const dedent = require("dedent")
|
||||
|
||||
describe("docker: env translator", function() {
|
||||
it("should generate an empty baseline config", function() {
|
||||
const input = {}
|
||||
|
||||
expect(translator(input)).toEqual(``)
|
||||
})
|
||||
|
||||
it("should generate a base config including the base content", function() {
|
||||
const input = {}
|
||||
|
||||
expect(translator(input, {
|
||||
injectBaseConfig: true
|
||||
})).toEqual(dedent(`
|
||||
url: "https://petstore.swagger.io/v2/swagger.json",
|
||||
"dom_id": "#swagger-ui",
|
||||
deepLinking: true,
|
||||
presets: [
|
||||
SwaggerUIBundle.presets.apis,
|
||||
SwaggerUIStandalonePreset
|
||||
],
|
||||
plugins: [
|
||||
SwaggerUIBundle.plugins.DownloadUrl
|
||||
],
|
||||
layout: "StandaloneLayout",
|
||||
`))
|
||||
})
|
||||
|
||||
it("should ignore an unknown config", function() {
|
||||
const input = {
|
||||
ASDF1234: "wow hello"
|
||||
}
|
||||
|
||||
expect(translator(input)).toEqual(dedent(``))
|
||||
})
|
||||
|
||||
it("should generate a string config", function() {
|
||||
const input = {
|
||||
URL: "http://petstore.swagger.io/v2/swagger.json",
|
||||
FILTER: ""
|
||||
}
|
||||
|
||||
expect(translator(input)).toEqual(dedent(`
|
||||
url: "http://petstore.swagger.io/v2/swagger.json",
|
||||
filter: "",`
|
||||
).trim())
|
||||
})
|
||||
|
||||
it("should generate a boolean config", function() {
|
||||
const input = {
|
||||
DEEP_LINKING: "true",
|
||||
SHOW_EXTENSIONS: "false",
|
||||
SHOW_COMMON_EXTENSIONS: ""
|
||||
}
|
||||
|
||||
expect(translator(input)).toEqual(dedent(`
|
||||
deepLinking: true,
|
||||
showExtensions: false,
|
||||
showCommonExtensions: undefined,`
|
||||
))
|
||||
})
|
||||
|
||||
it("should generate an object config", function() {
|
||||
const input = {
|
||||
SPEC: `{ swagger: "2.0" }`
|
||||
}
|
||||
|
||||
expect(translator(input)).toEqual(dedent(`
|
||||
spec: { swagger: "2.0" },`
|
||||
).trim())
|
||||
})
|
||||
|
||||
it("should generate an array config", function() {
|
||||
const input = {
|
||||
URLS: `["/one", "/two"]`,
|
||||
SUPPORTED_SUBMIT_METHODS: ""
|
||||
}
|
||||
|
||||
expect(translator(input)).toEqual(dedent(`
|
||||
urls: ["/one", "/two"],
|
||||
supportedSubmitMethods: undefined,`
|
||||
).trim())
|
||||
})
|
||||
|
||||
it("should properly escape key names when necessary", function () {
|
||||
const input = {
|
||||
URLS: `["/one", "/two"]`,
|
||||
URLS_PRIMARY_NAME: "one",
|
||||
}
|
||||
|
||||
expect(translator(input)).toEqual(dedent(`
|
||||
urls: ["/one", "/two"],
|
||||
"urls.primaryName": "one",`
|
||||
).trim())
|
||||
})
|
||||
|
||||
it("should disregard a legacy variable in favor of a regular one", function() {
|
||||
const input = {
|
||||
// Order is important to this test... legacy vars should be
|
||||
// superseded regardless of what is fed in first.
|
||||
API_URL: "/old.json",
|
||||
URL: "/swagger.json",
|
||||
URLS: `["/one", "/two"]`,
|
||||
API_URLS: `["/three", "/four"]`,
|
||||
}
|
||||
|
||||
expect(translator(input)).toEqual(dedent(`
|
||||
url: "/swagger.json",
|
||||
urls: ["/one", "/two"],`
|
||||
).trim())
|
||||
})
|
||||
|
||||
it("should generate a full config k:v string", function() {
|
||||
const input = {
|
||||
API_URL: "/old.yaml",
|
||||
API_URLS: `["/old", "/older"]`,
|
||||
CONFIG_URL: "/wow",
|
||||
DOM_ID: "#swagger_ui",
|
||||
SPEC: `{ swagger: "2.0" }`,
|
||||
URL: "/swagger.json",
|
||||
URLS: `["/one", "/two"]`,
|
||||
URLS_PRIMARY_NAME: "one",
|
||||
LAYOUT: "BaseLayout",
|
||||
DEEP_LINKING: "false",
|
||||
DISPLAY_OPERATION_ID: "true",
|
||||
DEFAULT_MODELS_EXPAND_DEPTH: "0",
|
||||
DEFAULT_MODEL_EXPAND_DEPTH: "1",
|
||||
DEFAULT_MODEL_RENDERING: "example",
|
||||
DISPLAY_REQUEST_DURATION: "true",
|
||||
DOC_EXPANSION: "full",
|
||||
FILTER: "wowee",
|
||||
MAX_DISPLAYED_TAGS: "4",
|
||||
SHOW_EXTENSIONS: "true",
|
||||
SHOW_COMMON_EXTENSIONS: "false",
|
||||
OAUTH2_REDIRECT_URL: "http://google.com/",
|
||||
SHOW_MUTATED_REQUEST: "true",
|
||||
SUPPORTED_SUBMIT_METHODS: `["get", "post"]`,
|
||||
VALIDATOR_URL: "http://smartbear.com/"
|
||||
}
|
||||
|
||||
expect(translator(input)).toEqual(dedent(`
|
||||
configUrl: "/wow",
|
||||
"dom_id": "#swagger_ui",
|
||||
spec: { swagger: "2.0" },
|
||||
url: "/swagger.json",
|
||||
urls: ["/one", "/two"],
|
||||
"urls.primaryName": "one",
|
||||
layout: "BaseLayout",
|
||||
deepLinking: false,
|
||||
displayOperationId: true,
|
||||
defaultModelsExpandDepth: 0,
|
||||
defaultModelExpandDepth: 1,
|
||||
defaultModelRendering: "example",
|
||||
displayRequestDuration: true,
|
||||
docExpansion: "full",
|
||||
filter: "wowee",
|
||||
maxDisplayedTags: 4,
|
||||
showExtensions: true,
|
||||
showCommonExtensions: false,
|
||||
oauth2RedirectUrl: "http://google.com/",
|
||||
showMutatedRequest: true,
|
||||
supportedSubmitMethods: ["get", "post"],
|
||||
validatorUrl: "http://smartbear.com/",`
|
||||
).trim())
|
||||
})
|
||||
|
||||
it("should generate a full config k:v string including base config", function() {
|
||||
const input = {
|
||||
API_URL: "/old.yaml",
|
||||
API_URLS: `["/old", "/older"]`,
|
||||
CONFIG_URL: "/wow",
|
||||
DOM_ID: "#swagger_ui",
|
||||
SPEC: `{ swagger: "2.0" }`,
|
||||
URL: "/swagger.json",
|
||||
URLS: `["/one", "/two"]`,
|
||||
URLS_PRIMARY_NAME: "one",
|
||||
LAYOUT: "BaseLayout",
|
||||
DEEP_LINKING: "false",
|
||||
DISPLAY_OPERATION_ID: "true",
|
||||
DEFAULT_MODELS_EXPAND_DEPTH: "0",
|
||||
DEFAULT_MODEL_EXPAND_DEPTH: "1",
|
||||
DEFAULT_MODEL_RENDERING: "example",
|
||||
DISPLAY_REQUEST_DURATION: "true",
|
||||
DOC_EXPANSION: "full",
|
||||
FILTER: "wowee",
|
||||
MAX_DISPLAYED_TAGS: "4",
|
||||
SHOW_EXTENSIONS: "true",
|
||||
SHOW_COMMON_EXTENSIONS: "false",
|
||||
OAUTH2_REDIRECT_URL: "http://google.com/",
|
||||
SHOW_MUTATED_REQUEST: "true",
|
||||
SUPPORTED_SUBMIT_METHODS: `["get", "post"]`,
|
||||
VALIDATOR_URL: "http://smartbear.com/"
|
||||
}
|
||||
|
||||
expect(translator(input, { injectBaseConfig: true })).toEqual(dedent(`
|
||||
presets: [
|
||||
SwaggerUIBundle.presets.apis,
|
||||
SwaggerUIStandalonePreset
|
||||
],
|
||||
plugins: [
|
||||
SwaggerUIBundle.plugins.DownloadUrl
|
||||
],
|
||||
configUrl: "/wow",
|
||||
"dom_id": "#swagger_ui",
|
||||
spec: { swagger: "2.0" },
|
||||
url: "/swagger.json",
|
||||
urls: ["/one", "/two"],
|
||||
"urls.primaryName": "one",
|
||||
layout: "BaseLayout",
|
||||
deepLinking: false,
|
||||
displayOperationId: true,
|
||||
defaultModelsExpandDepth: 0,
|
||||
defaultModelExpandDepth: 1,
|
||||
defaultModelRendering: "example",
|
||||
displayRequestDuration: true,
|
||||
docExpansion: "full",
|
||||
filter: "wowee",
|
||||
maxDisplayedTags: 4,
|
||||
showExtensions: true,
|
||||
showCommonExtensions: false,
|
||||
oauth2RedirectUrl: "http://google.com/",
|
||||
showMutatedRequest: true,
|
||||
supportedSubmitMethods: ["get", "post"],
|
||||
validatorUrl: "http://smartbear.com/",`
|
||||
).trim())
|
||||
})
|
||||
})
|
||||
Reference in New Issue
Block a user