@jakub.knejzlik/ts-query
Version:
TypeScript implementation of SQL builder
63 lines (53 loc) • 2.45 kB
text/typescript
import { Cond } from "./Condition";
import { Q } from "./Query";
import { MySQLFlavor } from "./flavors/mysql";
import { MetadataOperationType } from "./interfaces";
describe("CreateViewAsSelect", () => {
const initialSelectQuery = Q.select()
.from("users", "u")
.where(Cond.equal("u.id", 1));
const viewName = "user_view";
it("should clone itself correctly", () => {
const cvas = Q.createOrReplaceViewAs(viewName, initialSelectQuery);
const clone = cvas.clone();
expect(clone).not.toBe(cvas);
expect(clone.toSQL(new MySQLFlavor())).toBe(cvas.toSQL(new MySQLFlavor()));
});
it("should generate the correct SQL with OR REPLACE", () => {
const cvas = Q.createOrReplaceViewAs(viewName, initialSelectQuery);
const expectedSQL = `CREATE OR REPLACE VIEW \`${viewName}\` AS SELECT * FROM \`users\` AS \`u\` WHERE \`u\`.\`id\` = 1`;
expect(cvas.toSQL(new MySQLFlavor())).toBe(expectedSQL);
});
it("should generate the correct SQL without OR REPLACE", () => {
const cvas = Q.createViewAs(viewName, initialSelectQuery);
const expectedSQL = `CREATE VIEW \`${viewName}\` AS SELECT * FROM \`users\` AS \`u\` WHERE \`u\`.\`id\` = 1`;
expect(cvas.toSQL(new MySQLFlavor())).toBe(expectedSQL);
});
it("should serialize and deserialize correctly", () => {
const cvas = Q.createViewAs(viewName, initialSelectQuery);
const cvasReplace = Q.createOrReplaceViewAs(viewName, initialSelectQuery);
const serialized = cvas.serialize();
const deserialized = Q.deserialize(serialized);
expect(deserialized.toSQL(new MySQLFlavor())).toEqual(
cvas.toSQL(new MySQLFlavor())
);
expect(
Q.deserialize(cvasReplace.serialize()).toSQL(new MySQLFlavor())
).toEqual(cvasReplace.toSQL(new MySQLFlavor()));
});
it("should fetch table names correctly", () => {
const cvas = Q.createViewAs(viewName, initialSelectQuery);
expect(cvas.getTableNames()).toEqual([viewName, "users"]);
});
it("should return correct operation type", () => {
const cvas = Q.createViewAs(viewName, initialSelectQuery);
expect(cvas.getOperationType()).toEqual(
MetadataOperationType.CREATE_VIEW_AS
);
});
it("should return correct values from accessorts", () => {
const cvas = Q.createViewAs(viewName, initialSelectQuery);
expect(cvas.getViewName()).toEqual(viewName);
expect(cvas.getSelect().toSQL()).toEqual(initialSelectQuery.toSQL());
});
});