Split tests
This commit is contained in:
parent
d656edad40
commit
33988428ea
|
@ -0,0 +1,64 @@
|
||||||
|
import { GenericContainer } from "testcontainers"
|
||||||
|
import { generator } from "@budibase/backend-core/tests"
|
||||||
|
|
||||||
|
import couchdb from "../../../../packages/server/src/integrations/couchdb"
|
||||||
|
|
||||||
|
describe("datasource validators", () => {
|
||||||
|
describe("couchdb", () => {
|
||||||
|
let url: string
|
||||||
|
|
||||||
|
beforeAll(async () => {
|
||||||
|
const user = generator.first()
|
||||||
|
const password = generator.hash()
|
||||||
|
|
||||||
|
const container = await new GenericContainer("budibase/couchdb")
|
||||||
|
.withExposedPorts(5984)
|
||||||
|
.withEnv("COUCHDB_USER", user)
|
||||||
|
.withEnv("COUCHDB_PASSWORD", password)
|
||||||
|
.start()
|
||||||
|
|
||||||
|
const host = container.getContainerIpAddress()
|
||||||
|
const port = container.getMappedPort(5984)
|
||||||
|
|
||||||
|
await container.exec([
|
||||||
|
`curl`,
|
||||||
|
`-u`,
|
||||||
|
`${user}:${password}`,
|
||||||
|
`-X`,
|
||||||
|
`PUT`,
|
||||||
|
`localhost:5984/db`,
|
||||||
|
])
|
||||||
|
url = `http://${user}:${password}@${host}:${port}`
|
||||||
|
})
|
||||||
|
|
||||||
|
it("test valid connection string", async () => {
|
||||||
|
const integration = new couchdb.integration({
|
||||||
|
url,
|
||||||
|
database: "db",
|
||||||
|
})
|
||||||
|
const result = await integration.testConnection()
|
||||||
|
expect(result).toBe(true)
|
||||||
|
})
|
||||||
|
|
||||||
|
it("test invalid database", async () => {
|
||||||
|
const integration = new couchdb.integration({
|
||||||
|
url,
|
||||||
|
database: "random_db",
|
||||||
|
})
|
||||||
|
const result = await integration.testConnection()
|
||||||
|
expect(result).toBe(false)
|
||||||
|
})
|
||||||
|
|
||||||
|
it("test invalid url", async () => {
|
||||||
|
const integration = new couchdb.integration({
|
||||||
|
url: "http://invalid:123",
|
||||||
|
database: "any",
|
||||||
|
})
|
||||||
|
const result = await integration.testConnection()
|
||||||
|
expect(result).toEqual({
|
||||||
|
error:
|
||||||
|
"request to http://invalid:123/any failed, reason: getaddrinfo ENOTFOUND invalid",
|
||||||
|
})
|
||||||
|
})
|
||||||
|
})
|
||||||
|
})
|
|
@ -1,10 +1,6 @@
|
||||||
import { GenericContainer } from "testcontainers"
|
import { GenericContainer } from "testcontainers"
|
||||||
import postgres from "../../../../packages/server/src/integrations/postgres"
|
import postgres from "../../../../packages/server/src/integrations/postgres"
|
||||||
|
|
||||||
import { generator } from "@budibase/backend-core/tests"
|
|
||||||
|
|
||||||
import couchdb from "../../../../packages/server/src/integrations/couchdb"
|
|
||||||
|
|
||||||
jest.unmock("pg")
|
jest.unmock("pg")
|
||||||
|
|
||||||
describe("datasource validators", () => {
|
describe("datasource validators", () => {
|
||||||
|
@ -54,62 +50,4 @@ describe("datasource validators", () => {
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
|
||||||
describe("couchdb", () => {
|
|
||||||
let url: string
|
|
||||||
|
|
||||||
beforeAll(async () => {
|
|
||||||
const user = generator.first()
|
|
||||||
const password = generator.hash()
|
|
||||||
|
|
||||||
const container = await new GenericContainer("budibase/couchdb")
|
|
||||||
.withExposedPorts(5984)
|
|
||||||
.withEnv("COUCHDB_USER", user)
|
|
||||||
.withEnv("COUCHDB_PASSWORD", password)
|
|
||||||
.start()
|
|
||||||
|
|
||||||
const host = container.getContainerIpAddress()
|
|
||||||
const port = container.getMappedPort(5984)
|
|
||||||
|
|
||||||
await container.exec([
|
|
||||||
`curl`,
|
|
||||||
`-u`,
|
|
||||||
`${user}:${password}`,
|
|
||||||
`-X`,
|
|
||||||
`PUT`,
|
|
||||||
`localhost:5984/db`,
|
|
||||||
])
|
|
||||||
url = `http://${user}:${password}@${host}:${port}`
|
|
||||||
})
|
|
||||||
|
|
||||||
it("test valid connection string", async () => {
|
|
||||||
const integration = new couchdb.integration({
|
|
||||||
url,
|
|
||||||
database: "db",
|
|
||||||
})
|
|
||||||
const result = await integration.testConnection()
|
|
||||||
expect(result).toBe(true)
|
|
||||||
})
|
|
||||||
|
|
||||||
it("test invalid database", async () => {
|
|
||||||
const integration = new couchdb.integration({
|
|
||||||
url,
|
|
||||||
database: "random_db",
|
|
||||||
})
|
|
||||||
const result = await integration.testConnection()
|
|
||||||
expect(result).toBe(false)
|
|
||||||
})
|
|
||||||
|
|
||||||
it("test invalid url", async () => {
|
|
||||||
const integration = new couchdb.integration({
|
|
||||||
url: "http://invalid:123",
|
|
||||||
database: "any",
|
|
||||||
})
|
|
||||||
const result = await integration.testConnection()
|
|
||||||
expect(result).toEqual({
|
|
||||||
error:
|
|
||||||
"request to http://invalid:123/any failed, reason: getaddrinfo ENOTFOUND invalid",
|
|
||||||
})
|
|
||||||
})
|
|
||||||
})
|
|
||||||
})
|
})
|
||||||
|
|
Loading…
Reference in New Issue