2022-01-21 13:43:27 +01:00
|
|
|
import filterTests from "../support/filterTests"
|
2022-08-23 12:40:15 +02:00
|
|
|
const interact = require("../support/interact")
|
2022-01-21 13:43:27 +01:00
|
|
|
|
2022-02-25 17:24:36 +01:00
|
|
|
filterTests(["smoke", "all"], () => {
|
2022-02-17 15:06:17 +01:00
|
|
|
context("Query Level Transformers", () => {
|
2022-01-21 13:43:27 +01:00
|
|
|
before(() => {
|
|
|
|
cy.login()
|
2022-04-01 12:31:18 +02:00
|
|
|
cy.createTestApp()
|
2022-01-21 13:43:27 +01:00
|
|
|
})
|
2022-02-25 17:24:36 +01:00
|
|
|
|
2022-01-21 13:43:27 +01:00
|
|
|
it("should write a transformer function", () => {
|
2022-02-25 17:24:36 +01:00
|
|
|
// Add REST datasource - contains API for breweries
|
|
|
|
const datasource = "REST"
|
|
|
|
const restUrl = "https://api.openbrewerydb.org/breweries"
|
|
|
|
cy.selectExternalDatasource(datasource)
|
2023-01-11 12:11:36 +01:00
|
|
|
cy.createRestQuery("GET", restUrl, "breweries")
|
2022-12-21 15:01:44 +01:00
|
|
|
cy.reload()
|
2023-01-11 12:11:36 +01:00
|
|
|
cy.contains(".nav-item-content", "breweries", { timeout: 20000 }).click()
|
2022-12-21 15:01:44 +01:00
|
|
|
cy.contains(interact.SPECTRUM_TABS_ITEM, "Transformer", { timeout: 5000 }).click({ force: true })
|
2022-02-25 17:24:36 +01:00
|
|
|
// Get Transformer Function from file
|
|
|
|
cy.readFile("cypress/support/queryLevelTransformerFunction.js").then(
|
|
|
|
transformerFunction => {
|
2022-12-21 15:01:44 +01:00
|
|
|
cy.get(interact.CODEMIRROR_TEXTAREA, { timeout: 5000 })
|
2022-02-25 17:24:36 +01:00
|
|
|
// Highlight current text and overwrite with file contents
|
|
|
|
.type(Cypress.platform === "darwin" ? "{cmd}a" : "{ctrl}a", {
|
|
|
|
force: true,
|
|
|
|
})
|
|
|
|
.type(transformerFunction, { parseSpecialCharSequences: false })
|
|
|
|
}
|
|
|
|
)
|
|
|
|
// Send Query
|
|
|
|
cy.intercept("**/queries/preview").as("query")
|
2022-12-21 15:01:44 +01:00
|
|
|
cy.get(interact.SPECTRUM_BUTTON).contains("Save").click({ force: true })
|
2022-06-13 10:28:36 +02:00
|
|
|
cy.get(interact.SPECTRUM_BUTTON).contains("Send").click({ force: true })
|
2022-02-25 17:24:36 +01:00
|
|
|
cy.wait("@query")
|
|
|
|
// Assert against Status Code, body, & body rows
|
|
|
|
cy.get("@query").its("response.statusCode").should("eq", 200)
|
|
|
|
cy.get("@query").its("response.body").should("not.be.empty")
|
|
|
|
cy.get("@query").its("response.body.rows").should("not.be.empty")
|
|
|
|
})
|
|
|
|
|
2022-01-21 13:43:27 +01:00
|
|
|
it("should add data to the previous query", () => {
|
2021-11-15 16:25:58 +01:00
|
|
|
// Add REST datasource - contains API for breweries
|
|
|
|
const datasource = "REST"
|
|
|
|
const restUrl = "https://api.openbrewerydb.org/breweries"
|
|
|
|
cy.selectExternalDatasource(datasource)
|
2023-01-11 12:11:36 +01:00
|
|
|
cy.createRestQuery("GET", restUrl, "breweries")
|
2022-12-21 15:01:44 +01:00
|
|
|
cy.reload()
|
2023-01-11 12:11:36 +01:00
|
|
|
cy.contains(".nav-item-content", "breweries", { timeout: 2000 }).click()
|
2022-12-21 15:01:44 +01:00
|
|
|
cy.contains(interact.SPECTRUM_TABS_ITEM, "Transformer", { timeout: 5000 }).click({ force: true })
|
2022-01-21 13:43:27 +01:00
|
|
|
// Get Transformer Function with Data from file
|
2022-02-25 17:24:36 +01:00
|
|
|
cy.readFile(
|
|
|
|
"cypress/support/queryLevelTransformerFunctionWithData.js"
|
|
|
|
).then(transformerFunction => {
|
2022-01-21 13:43:27 +01:00
|
|
|
//console.log(transformerFunction[1])
|
2022-06-13 10:28:36 +02:00
|
|
|
cy.get(interact.CODEMIRROR_TEXTAREA)
|
2022-02-25 17:24:36 +01:00
|
|
|
// Highlight current text and overwrite with file contents
|
|
|
|
.type(Cypress.platform === "darwin" ? "{cmd}a" : "{ctrl}a", {
|
|
|
|
force: true,
|
|
|
|
})
|
|
|
|
.type(transformerFunction, { parseSpecialCharSequences: false })
|
2021-11-18 14:47:41 +01:00
|
|
|
})
|
2021-12-24 11:38:03 +01:00
|
|
|
// Send Query
|
2022-02-25 17:24:36 +01:00
|
|
|
cy.intercept("**/queries/preview").as("query")
|
2022-06-13 10:28:36 +02:00
|
|
|
cy.get(interact.SPECTRUM_BUTTON).contains("Send").click({ force: true })
|
2021-12-24 11:38:03 +01:00
|
|
|
cy.wait("@query")
|
|
|
|
// Assert against Status Code, body, & body rows
|
2022-02-25 17:24:36 +01:00
|
|
|
cy.get("@query").its("response.statusCode").should("eq", 200)
|
|
|
|
cy.get("@query").its("response.body").should("not.be.empty")
|
|
|
|
cy.get("@query").its("response.body.rows").should("not.be.empty")
|
2021-11-15 16:25:58 +01:00
|
|
|
})
|
2022-02-25 17:24:36 +01:00
|
|
|
|
2022-01-21 13:43:27 +01:00
|
|
|
it("should run an invalid query within the transformer section", () => {
|
|
|
|
// Add REST datasource - contains API for breweries
|
|
|
|
const datasource = "REST"
|
|
|
|
const restUrl = "https://api.openbrewerydb.org/breweries"
|
|
|
|
cy.selectExternalDatasource(datasource)
|
2023-01-11 12:11:36 +01:00
|
|
|
cy.createRestQuery("GET", restUrl, "breweries")
|
2022-12-21 15:01:44 +01:00
|
|
|
cy.reload()
|
2023-01-11 12:11:36 +01:00
|
|
|
cy.contains(".nav-item-content", "breweries", { timeout: 2000 }).click()
|
2022-12-21 15:01:44 +01:00
|
|
|
cy.contains(interact.SPECTRUM_TABS_ITEM, "Transformer", { timeout: 5000 }).click({ force: true })
|
2022-01-21 13:43:27 +01:00
|
|
|
// Clear the code box and add "test"
|
2022-06-13 10:28:36 +02:00
|
|
|
cy.get(interact.CODEMIRROR_TEXTAREA)
|
2022-02-25 17:24:36 +01:00
|
|
|
.type(Cypress.platform === "darwin" ? "{cmd}a" : "{ctrl}a", {
|
|
|
|
force: true,
|
|
|
|
})
|
|
|
|
.type("test")
|
2022-01-21 13:43:27 +01:00
|
|
|
// Run Query and intercept
|
2022-02-25 17:24:36 +01:00
|
|
|
cy.intercept("**/preview").as("queryError")
|
2022-06-13 10:28:36 +02:00
|
|
|
cy.get(interact.SPECTRUM_BUTTON).contains("Send").click({ force: true })
|
2022-01-21 13:43:27 +01:00
|
|
|
cy.wait("@queryError")
|
|
|
|
cy.wait(500)
|
|
|
|
// Assert against message and status for the query error
|
2022-02-25 17:24:36 +01:00
|
|
|
cy.get("@queryError")
|
|
|
|
.its("response.body")
|
|
|
|
.should("have.property", "message", "test is not defined")
|
|
|
|
cy.get("@queryError")
|
|
|
|
.its("response.body")
|
|
|
|
.should("have.property", "status", 400)
|
2021-11-18 14:47:41 +01:00
|
|
|
})
|
2022-02-25 17:24:36 +01:00
|
|
|
|
2022-02-18 18:59:33 +01:00
|
|
|
xit("should run an invalid query via POST request", () => {
|
2022-01-21 13:43:27 +01:00
|
|
|
// POST request with transformer as null
|
2022-02-25 17:24:36 +01:00
|
|
|
cy.request({
|
|
|
|
method: "POST",
|
|
|
|
url: `${Cypress.config().baseUrl}/api/queries/`,
|
|
|
|
body: {
|
|
|
|
fields: { headers: {}, queryString: null, path: null },
|
|
|
|
parameters: [],
|
|
|
|
schema: {},
|
|
|
|
name: "test",
|
|
|
|
queryVerb: "read",
|
|
|
|
transformer: null,
|
|
|
|
datasourceId: "test",
|
|
|
|
},
|
|
|
|
// Expected 400 error - Transformer must be a string
|
|
|
|
failOnStatusCode: false,
|
|
|
|
}).then(response => {
|
2022-01-21 13:43:27 +01:00
|
|
|
expect(response.status).to.equal(400)
|
2022-02-25 17:24:36 +01:00
|
|
|
expect(response.body.message).to.include(
|
|
|
|
'Invalid body - "transformer" must be a string'
|
|
|
|
)
|
2022-01-21 13:43:27 +01:00
|
|
|
})
|
2021-11-15 16:25:58 +01:00
|
|
|
})
|
2022-02-25 17:24:36 +01:00
|
|
|
|
2022-02-18 18:59:33 +01:00
|
|
|
xit("should run an empty query", () => {
|
2022-01-21 13:43:27 +01:00
|
|
|
// POST request with Transformer as an empty string
|
2022-02-25 17:24:36 +01:00
|
|
|
cy.request({
|
|
|
|
method: "POST",
|
|
|
|
url: `${Cypress.config().baseUrl}/api/queries/preview`,
|
|
|
|
body: {
|
|
|
|
fields: { headers: {}, queryString: null, path: null },
|
|
|
|
queryVerb: "read",
|
|
|
|
transformer: "",
|
|
|
|
datasourceId: "test",
|
|
|
|
},
|
|
|
|
// Expected 400 error - Transformer is not allowed to be empty
|
|
|
|
failOnStatusCode: false,
|
|
|
|
}).then(response => {
|
2022-01-21 13:43:27 +01:00
|
|
|
expect(response.status).to.equal(400)
|
2022-02-25 17:24:36 +01:00
|
|
|
expect(response.body.message).to.include(
|
|
|
|
'Invalid body - "transformer" is not allowed to be empty'
|
|
|
|
)
|
2022-01-21 13:43:27 +01:00
|
|
|
})
|
2021-11-18 14:47:41 +01:00
|
|
|
})
|
2021-11-15 16:25:58 +01:00
|
|
|
})
|
|
|
|
})
|