178 lines
5.6 KiB
JavaScript
178 lines
5.6 KiB
JavaScript
/* eslint-env jest */
|
|
const { ConnectionStringParser } = require("../../../utils/agents/aibitat/plugins/sql-agent/SQLConnectors/utils");
|
|
|
|
describe("ConnectionStringParser", () => {
|
|
describe("Basic Parsing", () => {
|
|
test("should parse a basic connection string without options", () => {
|
|
const parser = new ConnectionStringParser({ scheme: "mssql" });
|
|
const result = parser.parse("mssql://user:pass@localhost:1433/mydb");
|
|
|
|
expect(result).toEqual({
|
|
scheme: "mssql",
|
|
username: "user",
|
|
password: "pass",
|
|
hosts: [{ host: "localhost", port: 1433 }],
|
|
endpoint: "mydb",
|
|
options: undefined
|
|
});
|
|
});
|
|
|
|
test("should parse a connection string with options", () => {
|
|
const parser = new ConnectionStringParser({ scheme: "mssql" });
|
|
const result = parser.parse("mssql://user:pass@localhost:1433/mydb?encrypt=true&trustServerCertificate=true");
|
|
|
|
expect(result).toEqual({
|
|
scheme: "mssql",
|
|
username: "user",
|
|
password: "pass",
|
|
hosts: [{ host: "localhost", port: 1433 }],
|
|
endpoint: "mydb",
|
|
options: {
|
|
encrypt: "true",
|
|
trustServerCertificate: "true"
|
|
}
|
|
});
|
|
});
|
|
|
|
test("should handle empty passwords", () => {
|
|
const parser = new ConnectionStringParser({ scheme: "mssql" });
|
|
const result = parser.parse("mssql://user@localhost:1433/mydb");
|
|
|
|
expect(result).toEqual({
|
|
scheme: "mssql",
|
|
username: "user",
|
|
password: undefined,
|
|
hosts: [{ host: "localhost", port: 1433 }],
|
|
endpoint: "mydb",
|
|
options: undefined
|
|
});
|
|
});
|
|
});
|
|
|
|
describe("Error Handling", () => {
|
|
test("should throw error for invalid scheme", () => {
|
|
const parser = new ConnectionStringParser({ scheme: "mssql" });
|
|
expect(() => parser.parse("mysql://user:pass@localhost:3306/mydb"))
|
|
.toThrow("URI must start with 'mssql://'");
|
|
});
|
|
|
|
test("should throw error for missing scheme", () => {
|
|
const parser = new ConnectionStringParser({ scheme: "mssql" });
|
|
expect(() => parser.parse("user:pass@localhost:1433/mydb"))
|
|
.toThrow("No scheme found in URI");
|
|
});
|
|
});
|
|
|
|
describe("Special Characters", () => {
|
|
test("should handle special characters in username and password", () => {
|
|
const parser = new ConnectionStringParser({ scheme: "mssql" });
|
|
const result = parser.parse("mssql://user%40domain:p%40ssw%3Ard@localhost:1433/mydb");
|
|
|
|
expect(result).toEqual({
|
|
scheme: "mssql",
|
|
username: "user@domain",
|
|
password: "p@ssw:rd",
|
|
hosts: [{ host: "localhost", port: 1433 }],
|
|
endpoint: "mydb",
|
|
options: undefined
|
|
});
|
|
});
|
|
|
|
test("should handle special characters in database name", () => {
|
|
const parser = new ConnectionStringParser({ scheme: "mssql" });
|
|
const result = parser.parse("mssql://user:pass@localhost:1433/my%20db");
|
|
|
|
expect(result).toEqual({
|
|
scheme: "mssql",
|
|
username: "user",
|
|
password: "pass",
|
|
hosts: [{ host: "localhost", port: 1433 }],
|
|
endpoint: "my db",
|
|
options: undefined
|
|
});
|
|
});
|
|
});
|
|
|
|
describe("Multiple Hosts", () => {
|
|
test("should parse multiple hosts", () => {
|
|
const parser = new ConnectionStringParser({ scheme: "mssql" });
|
|
const result = parser.parse("mssql://user:pass@host1:1433,host2:1434/mydb");
|
|
|
|
expect(result).toEqual({
|
|
scheme: "mssql",
|
|
username: "user",
|
|
password: "pass",
|
|
hosts: [
|
|
{ host: "host1", port: 1433 },
|
|
{ host: "host2", port: 1434 }
|
|
],
|
|
endpoint: "mydb",
|
|
options: undefined
|
|
});
|
|
});
|
|
|
|
test("should handle hosts without ports", () => {
|
|
const parser = new ConnectionStringParser({ scheme: "mssql" });
|
|
const result = parser.parse("mssql://user:pass@host1,host2/mydb");
|
|
|
|
expect(result).toEqual({
|
|
scheme: "mssql",
|
|
username: "user",
|
|
password: "pass",
|
|
hosts: [
|
|
{ host: "host1" },
|
|
{ host: "host2" }
|
|
],
|
|
endpoint: "mydb",
|
|
options: undefined
|
|
});
|
|
});
|
|
});
|
|
|
|
describe("Provider-Specific Tests", () => {
|
|
test("should parse MySQL connection string", () => {
|
|
const parser = new ConnectionStringParser({ scheme: "mysql" });
|
|
const result = parser.parse("mysql://user:pass@localhost:3306/mydb?ssl=true");
|
|
|
|
expect(result).toEqual({
|
|
scheme: "mysql",
|
|
username: "user",
|
|
password: "pass",
|
|
hosts: [{ host: "localhost", port: 3306 }],
|
|
endpoint: "mydb",
|
|
options: { ssl: "true" }
|
|
});
|
|
});
|
|
|
|
test("should parse PostgreSQL connection string", () => {
|
|
const parser = new ConnectionStringParser({ scheme: "postgresql" });
|
|
const result = parser.parse("postgresql://user:pass@localhost:5432/mydb?sslmode=require");
|
|
|
|
expect(result).toEqual({
|
|
scheme: "postgresql",
|
|
username: "user",
|
|
password: "pass",
|
|
hosts: [{ host: "localhost", port: 5432 }],
|
|
endpoint: "mydb",
|
|
options: { sslmode: "require" }
|
|
});
|
|
});
|
|
|
|
test("should parse MSSQL connection string with encryption options", () => {
|
|
const parser = new ConnectionStringParser({ scheme: "mssql" });
|
|
const result = parser.parse("mssql://user:pass@localhost:1433/mydb?encrypt=true&trustServerCertificate=true");
|
|
|
|
expect(result).toEqual({
|
|
scheme: "mssql",
|
|
username: "user",
|
|
password: "pass",
|
|
hosts: [{ host: "localhost", port: 1433 }],
|
|
endpoint: "mydb",
|
|
options: {
|
|
encrypt: "true",
|
|
trustServerCertificate: "true"
|
|
}
|
|
});
|
|
});
|
|
});
|
|
}); |