Merge pull request #10553 from Budibase/budi-6932/verify_mssql

Implement MSSQL connection verification
This commit is contained in:
Michael Drury 2023-05-15 17:12:05 +01:00 committed by GitHub
commit 3ef204cf7b
2 changed files with 73 additions and 0 deletions

View File

@ -123,6 +123,15 @@ class SqlServerIntegration extends Sql implements DatasourcePlus {
} }
} }
async testConnection() {
try {
await this.connect()
return true
} catch (e: any) {
return { error: e.message as string }
}
}
getBindingIdentifier(): string { getBindingIdentifier(): string {
return `@p${this.index++}` return `@p${this.index++}`
} }

View File

@ -0,0 +1,64 @@
import { GenericContainer, Wait } from "testcontainers"
import { Duration, TemporalUnit } from "node-duration"
import mssql from "../../../../packages/server/src/integrations/microsoftSqlServer"
jest.unmock("mssql")
describe("datasource validators", () => {
describe("mssql", () => {
let host: string, port: number
const password = "Str0Ng_p@ssW0rd!"
beforeAll(async () => {
const container = await new GenericContainer(
"mcr.microsoft.com/mssql/server"
)
.withExposedPorts(1433)
.withEnv("ACCEPT_EULA", "Y")
.withEnv("MSSQL_SA_PASSWORD", password)
.withEnv("MSSQL_PID", "Developer")
.withWaitStrategy(Wait.forHealthCheck())
.withHealthCheck({
test: `/opt/mssql-tools/bin/sqlcmd -S localhost -U sa -P "${password}" -Q "SELECT 1" -b -o /dev/null`,
interval: new Duration(1000, TemporalUnit.MILLISECONDS),
timeout: new Duration(3, TemporalUnit.SECONDS),
retries: 20,
startPeriod: new Duration(100, TemporalUnit.MILLISECONDS),
})
.start()
host = container.getContainerIpAddress()
port = container.getMappedPort(1433)
})
it("test valid connection string", async () => {
const integration = new mssql.integration({
user: "sa",
password,
server: host,
port: port,
database: "master",
schema: "dbo",
})
const result = await integration.testConnection()
expect(result).toBe(true)
})
it("test invalid password", async () => {
const integration = new mssql.integration({
user: "sa",
password: "wrong_pwd",
server: host,
port: port,
database: "master",
schema: "dbo",
})
const result = await integration.testConnection()
expect(result).toEqual({
error: "ConnectionError: Login failed for user 'sa'.",
})
})
})
})