1727 lines
48 KiB
JavaScript
Raw Normal View History

const { expect } = require('chai');
let tableSql;
const sinon = require('sinon');
2019-07-10 22:48:43 +01:00
const PG_Client = require('../../../lib/dialects/postgres');
const client = new PG_Client({ client: 'pg' });
const knex = require('../../../knex');
const equal = require('chai').assert.equal;
2020-04-19 00:40:23 +02:00
describe('PostgreSQL Config', function () {
let knexInstance;
let version;
const config = {
client: 'pg',
connection: {
user: 'postgres',
password: '',
host: '127.0.0.1',
database: 'knex_test',
},
};
2020-04-19 00:40:23 +02:00
describe('check version', function () {
describe('check version < 9.2', function () {
beforeEach(function () {
version = '7.2';
config.version = version;
knexInstance = knex(config);
});
2020-04-19 00:40:23 +02:00
it('client.version', function () {
expect(knexInstance.client.version).to.equal(version);
});
2020-04-19 00:40:23 +02:00
it('json', function () {
tableSql = knexInstance.schema
2020-04-19 00:40:23 +02:00
.table('public', function (t) {
t.json('test_name');
})
.toSQL();
equal(1, tableSql.length);
expect(tableSql[0].sql).to.equal(
'alter table "public" add column "test_name" text'
);
});
2020-04-19 00:40:23 +02:00
it('jsonb', function () {
tableSql = knexInstance.schema
2020-04-19 00:40:23 +02:00
.table('public', function (t) {
t.jsonb('test_name');
})
.toSQL();
equal(1, tableSql.length);
expect(tableSql[0].sql).to.equal(
'alter table "public" add column "test_name" text'
);
});
});
2020-04-19 00:40:23 +02:00
describe('check version >= 9.2', function () {
beforeEach(function () {
version = '9.5';
config.version = version;
knexInstance = knex(config);
});
2020-04-19 00:40:23 +02:00
it('client.version', function () {
expect(knexInstance.client.version).to.equal(version);
});
2020-04-19 00:40:23 +02:00
it('json', function () {
tableSql = knexInstance.schema
2020-04-19 00:40:23 +02:00
.table('public', function (t) {
t.json('test_name');
})
.toSQL();
equal(1, tableSql.length);
expect(tableSql[0].sql).to.equal(
'alter table "public" add column "test_name" json'
);
});
2020-04-19 00:40:23 +02:00
it('jsonb', function () {
tableSql = knexInstance.schema
2020-04-19 00:40:23 +02:00
.table('public', function (t) {
t.jsonb('test_name');
})
.toSQL();
equal(1, tableSql.length);
expect(tableSql[0].sql).to.equal(
'alter table "public" add column "test_name" jsonb'
);
});
});
});
});
2020-04-19 00:40:23 +02:00
describe('PostgreSQL SchemaBuilder', function () {
it('fixes memoization regression', function () {
tableSql = client
.schemaBuilder()
2020-04-19 00:40:23 +02:00
.createTable('users', function (table) {
table.uuid('key');
table.increments('id');
table.string('email');
})
.toSQL();
equal(1, tableSql.length);
expect(tableSql[0].sql).to.equal(
'create table "users" ("key" uuid, "id" serial primary key, "email" varchar(255))'
);
});
it('create table like another', function () {
tableSql = client
.schemaBuilder()
.createTableLike('users_like', 'users')
.toSQL();
equal(1, tableSql.length);
expect(tableSql[0].sql).to.equal(
'create table "users_like" (like "users" including all)'
);
});
2020-04-19 00:40:23 +02:00
it('basic alter table', function () {
tableSql = client
.schemaBuilder()
2020-04-19 00:40:23 +02:00
.table('users', function (table) {
table.increments('id');
table.string('email');
})
.toSQL();
equal(1, tableSql.length);
expect(tableSql[0].sql).to.equal(
'alter table "users" add column "id" serial primary key, add column "email" varchar(255)'
);
});
2020-04-19 00:40:23 +02:00
it('should alter columns with the alter flag', function () {
tableSql = client
.schemaBuilder()
2020-04-19 00:40:23 +02:00
.table('users', function () {
this.string('foo').notNullable().default('foo').alter();
this.integer('bar').alter();
})
.toSQL();
equal(8, tableSql.length);
expect(tableSql[0].sql).to.equal(
'alter table "users" alter column "foo" drop default'
);
expect(tableSql[1].sql).to.equal(
'alter table "users" alter column "foo" drop not null'
);
expect(tableSql[2].sql).to.equal(
'alter table "users" alter column "foo" type varchar(255) using ("foo"::varchar(255))'
);
expect(tableSql[3].sql).to.equal(
'alter table "users" alter column "foo" set default \'foo\''
);
expect(tableSql[4].sql).to.equal(
'alter table "users" alter column "foo" set not null'
);
expect(tableSql[5].sql).to.equal(
'alter table "users" alter column "bar" drop default'
);
expect(tableSql[6].sql).to.equal(
'alter table "users" alter column "bar" drop not null'
);
expect(tableSql[7].sql).to.equal(
'alter table "users" alter column "bar" type integer using ("bar"::integer)'
);
});
2020-04-19 00:40:23 +02:00
it('alter table with schema', function () {
tableSql = client
.schemaBuilder()
.withSchema('myschema')
2020-04-19 00:40:23 +02:00
.table('users', function (table) {
table.increments('id');
})
.toSQL();
2015-08-09 22:24:55 -03:00
equal(1, tableSql.length);
expect(tableSql[0].sql).to.equal(
'alter table "myschema"."users" add column "id" serial primary key'
);
2015-08-09 22:24:55 -03:00
});
2020-04-19 00:40:23 +02:00
it('drop table', function () {
tableSql = client.schemaBuilder().dropTable('users').toSQL();
equal(1, tableSql.length);
expect(tableSql[0].sql).to.equal('drop table "users"');
});
2020-04-19 00:40:23 +02:00
it('drop table with schema', function () {
tableSql = client
.schemaBuilder()
.withSchema('myschema')
.dropTable('users')
.toSQL();
2015-08-09 22:24:55 -03:00
equal(1, tableSql.length);
expect(tableSql[0].sql).to.equal('drop table "myschema"."users"');
});
2020-04-19 00:40:23 +02:00
it('drop table if exists', function () {
tableSql = client.schemaBuilder().dropTableIfExists('users').toSQL();
equal(1, tableSql.length);
expect(tableSql[0].sql).to.equal('drop table if exists "users"');
});
2020-04-19 00:40:23 +02:00
it('drop table if exists with schema', function () {
tableSql = client
.schemaBuilder()
.withSchema('myschema')
.dropTableIfExists('users')
.toSQL();
2015-08-09 22:24:55 -03:00
equal(1, tableSql.length);
expect(tableSql[0].sql).to.equal('drop table if exists "myschema"."users"');
});
2020-04-19 00:40:23 +02:00
it('drop column', function () {
tableSql = client
.schemaBuilder()
2020-04-19 00:40:23 +02:00
.table('users', function (table) {
table.dropColumn('foo');
})
.toSQL();
equal(1, tableSql.length);
expect(tableSql[0].sql).to.equal('alter table "users" drop column "foo"');
});
2020-04-19 00:40:23 +02:00
it('drop multiple columns', function () {
tableSql = client
.schemaBuilder()
2020-04-19 00:40:23 +02:00
.table('users', function (table) {
table.dropColumn(['foo', 'bar']);
})
.toSQL();
equal(1, tableSql.length);
expect(tableSql[0].sql).to.equal(
'alter table "users" drop column "foo", drop column "bar"'
);
});
2020-04-19 00:40:23 +02:00
it('drop multiple columns with arguments', function () {
tableSql = client
.schemaBuilder()
2020-04-19 00:40:23 +02:00
.table('users', function (table) {
table.dropColumn('foo', 'bar');
})
.toSQL();
equal(1, tableSql.length);
expect(tableSql[0].sql).to.equal(
'alter table "users" drop column "foo", drop column "bar"'
);
});
2020-04-19 00:40:23 +02:00
it('drop primary', function () {
tableSql = client
.schemaBuilder()
2020-04-19 00:40:23 +02:00
.table('users', function (table) {
table.dropPrimary();
})
.toSQL();
equal(1, tableSql.length);
expect(tableSql[0].sql).to.equal(
'alter table "users" drop constraint "users_pkey"'
);
});
2020-04-19 00:40:23 +02:00
it('drop unique', function () {
tableSql = client
.schemaBuilder()
2020-04-19 00:40:23 +02:00
.table('users', function (table) {
table.dropUnique('foo');
})
.toSQL();
equal(1, tableSql.length);
expect(tableSql[0].sql).to.equal(
'alter table "users" drop constraint "users_foo_unique"'
);
});
2020-04-19 00:40:23 +02:00
it('drop unique, custom', function () {
tableSql = client
.schemaBuilder()
2020-04-19 00:40:23 +02:00
.table('users', function (table) {
table.dropUnique(null, 'foo');
})
.toSQL();
equal(1, tableSql.length);
expect(tableSql[0].sql).to.equal(
'alter table "users" drop constraint "foo"'
);
});
2020-04-19 00:40:23 +02:00
it('drop index', function () {
tableSql = client
.schemaBuilder()
2020-04-19 00:40:23 +02:00
.table('users', function (table) {
table.dropIndex('foo');
})
.toSQL();
equal(1, tableSql.length);
2015-07-15 23:16:30 -03:00
expect(tableSql[0].sql).to.equal('drop index "users_foo_index"');
});
2020-04-19 00:40:23 +02:00
it('drop index, custom', function () {
tableSql = client
.schemaBuilder()
2020-04-19 00:40:23 +02:00
.table('users', function (table) {
table.dropIndex(null, 'foo');
})
.toSQL();
equal(1, tableSql.length);
2015-07-15 23:16:30 -03:00
expect(tableSql[0].sql).to.equal('drop index "foo"');
});
2020-04-19 00:40:23 +02:00
it('drop index, with schema', function () {
tableSql = client
.schemaBuilder()
.withSchema('mySchema')
2020-04-19 00:40:23 +02:00
.table('users', function (table) {
table.dropIndex('foo');
})
.toSQL();
equal(1, tableSql.length);
expect(tableSql[0].sql).to.equal('drop index "mySchema"."users_foo_index"');
});
2020-04-19 00:40:23 +02:00
it('drop foreign', function () {
tableSql = client
.schemaBuilder()
2020-04-19 00:40:23 +02:00
.table('users', function (table) {
table.dropForeign('foo');
})
.toSQL();
equal(1, tableSql.length);
expect(tableSql[0].sql).to.equal(
'alter table "users" drop constraint "users_foo_foreign"'
);
});
2020-04-19 00:40:23 +02:00
it('drop foreign', function () {
tableSql = client
.schemaBuilder()
2020-04-19 00:40:23 +02:00
.table('users', function (table) {
table.dropForeign(null, 'foo');
})
.toSQL();
equal(1, tableSql.length);
expect(tableSql[0].sql).to.equal(
'alter table "users" drop constraint "foo"'
);
});
2020-04-19 00:40:23 +02:00
it('drop timestamps', function () {
tableSql = client
.schemaBuilder()
2020-04-19 00:40:23 +02:00
.table('users', function (table) {
table.dropTimestamps();
})
.toSQL();
equal(1, tableSql.length);
expect(tableSql[0].sql).to.equal(
'alter table "users" drop column "created_at", drop column "updated_at"'
);
});
it('adds foreign key with deferrable initially immediate', function () {
tableSql = client
.schemaBuilder()
.createTable('person', function (table) {
table
.integer('user_id')
.notNull()
.references('users.id')
.deferrable('immediate');
})
.toSQL();
equal(2, tableSql.length);
expect(tableSql[1].sql).to.equal(
'alter table "person" add constraint "person_user_id_foreign" foreign key ("user_id") references "users" ("id") deferrable initially immediate '
);
});
it('adds unique constraint with deferrable initially immediate', function () {
tableSql = client
.schemaBuilder()
.createTable('person', function (table) {
table
.integer('user_id')
.unique({ indexName: 'user_id_index', deferrable: 'immediate' });
})
.toSQL();
equal(2, tableSql.length);
expect(tableSql[1].sql).to.equal(
'alter table "person" add constraint "user_id_index" unique ("user_id") deferrable initially immediate'
);
});
it('adds primary constraint with deferrable initially immediate', function () {
tableSql = client
.schemaBuilder()
.createTable('person', function (table) {
table.integer('user_id').primary({
constraintName: 'user_id_primary',
deferrable: 'immediate',
});
})
.toSQL();
equal(2, tableSql.length);
expect(tableSql[1].sql).to.equal(
'alter table "person" add constraint "user_id_primary" primary key ("user_id") deferrable initially immediate'
);
});
2020-04-19 00:40:23 +02:00
it('rename table', function () {
tableSql = client.schemaBuilder().renameTable('users', 'foo').toSQL();
equal(1, tableSql.length);
expect(tableSql[0].sql).to.equal('alter table "users" rename to "foo"');
});
2020-04-19 00:40:23 +02:00
it('rename column', function () {
tableSql = client
.schemaBuilder()
2020-04-19 00:40:23 +02:00
.table('users', function (table) {
table.renameColumn('foo', 'bar');
})
.toSQL();
equal(1, tableSql.length);
expect(tableSql[0].sql).to.equal(
'alter table "users" rename "foo" to "bar"'
);
});
2020-04-19 00:40:23 +02:00
it('adding primary key', function () {
tableSql = client
.schemaBuilder()
2020-04-19 00:40:23 +02:00
.table('users', function (table) {
table.primary('foo');
})
.toSQL();
equal(1, tableSql.length);
expect(tableSql[0].sql).to.equal(
'alter table "users" add constraint "users_pkey" primary key ("foo")'
);
});
2020-04-19 00:40:23 +02:00
it('adding primary key fluently', function () {
tableSql = client
.schemaBuilder()
2020-04-19 00:40:23 +02:00
.createTable('users', function (table) {
table.string('name').primary();
})
.toSQL();
equal(2, tableSql.length);
expect(tableSql[0].sql).to.equal(
'create table "users" ("name" varchar(255))'
);
expect(tableSql[1].sql).to.equal(
'alter table "users" add constraint "users_pkey" primary key ("name")'
);
});
2020-04-19 00:40:23 +02:00
it('adding foreign key', function () {
tableSql = client
.schemaBuilder()
2020-04-19 00:40:23 +02:00
.table('users', function () {
this.foreign('foo_id').references('id').on('orders');
})
.toSQL();
equal(1, tableSql.length);
expect(tableSql[0].sql).to.equal(
'alter table "users" add constraint "users_foo_id_foreign" foreign key ("foo_id") references "orders" ("id")'
);
tableSql = client
.schemaBuilder()
2020-04-19 00:40:23 +02:00
.table('users', function () {
this.integer('foo_id').references('id').on('orders');
})
.toSQL();
equal(2, tableSql.length);
expect(tableSql[0].sql).to.equal(
'alter table "users" add column "foo_id" integer'
);
expect(tableSql[1].sql).to.equal(
'alter table "users" add constraint "users_foo_id_foreign" foreign key ("foo_id") references "orders" ("id")'
);
});
2020-04-19 00:40:23 +02:00
it('adding foreign key with specific identifier', function () {
tableSql = client
.schemaBuilder()
2020-04-19 00:40:23 +02:00
.table('users', function () {
this.foreign('foo_id', 'fk_foo').references('id').on('orders');
})
.toSQL();
equal(1, tableSql.length);
expect(tableSql[0].sql).to.equal(
'alter table "users" add constraint "fk_foo" foreign key ("foo_id") references "orders" ("id")'
);
tableSql = client
.schemaBuilder()
2020-04-19 00:40:23 +02:00
.table('users', function () {
this.integer('foo_id')
.references('id')
.on('orders')
.withKeyName('fk_foo');
})
.toSQL();
equal(2, tableSql.length);
expect(tableSql[0].sql).to.equal(
'alter table "users" add column "foo_id" integer'
);
expect(tableSql[1].sql).to.equal(
'alter table "users" add constraint "fk_foo" foreign key ("foo_id") references "orders" ("id")'
);
});
2020-04-19 00:40:23 +02:00
it('adds foreign key with onUpdate and onDelete', function () {
tableSql = client
.schemaBuilder()
2020-04-19 00:40:23 +02:00
.createTable('person', function (table) {
table
.integer('user_id')
.notNull()
.references('users.id')
.onDelete('SET NULL');
table
.integer('account_id')
.notNull()
.references('id')
.inTable('accounts')
.onUpdate('cascade');
})
.toSQL();
equal(3, tableSql.length);
expect(tableSql[1].sql).to.equal(
'alter table "person" add constraint "person_user_id_foreign" foreign key ("user_id") references "users" ("id") on delete SET NULL'
);
expect(tableSql[2].sql).to.equal(
'alter table "person" add constraint "person_account_id_foreign" foreign key ("account_id") references "accounts" ("id") on update cascade'
);
});
2020-04-19 00:40:23 +02:00
it('adding unique key', function () {
tableSql = client
.schemaBuilder()
2020-04-19 00:40:23 +02:00
.table('users', function (table) {
table.unique('foo', 'bar');
})
.toSQL();
equal(1, tableSql.length);
expect(tableSql[0].sql).to.equal(
'alter table "users" add constraint "bar" unique ("foo")'
);
});
2020-04-19 00:40:23 +02:00
it('adding unique key fluently', function () {
tableSql = client
.schemaBuilder()
2020-04-19 00:40:23 +02:00
.createTable('users', function (table) {
table.string('email').unique();
})
.toSQL();
equal(2, tableSql.length);
expect(tableSql[0].sql).to.equal(
'create table "users" ("email" varchar(255))'
);
expect(tableSql[1].sql).to.equal(
'alter table "users" add constraint "users_email_unique" unique ("email")'
);
});
2020-04-19 00:40:23 +02:00
it('adding index without value', function () {
tableSql = client
.schemaBuilder()
2020-04-19 00:40:23 +02:00
.table('users', function (table) {
table.index(['foo', 'bar']);
})
.toSQL();
equal(1, tableSql.length);
expect(tableSql[0].sql).to.equal(
'create index "users_foo_bar_index" on "users" ("foo", "bar")'
);
});
2020-04-19 00:40:23 +02:00
it('adding index', function () {
tableSql = client
.schemaBuilder()
2020-04-19 00:40:23 +02:00
.table('users', function (table) {
table.index(['foo', 'bar'], 'baz');
})
.toSQL();
equal(1, tableSql.length);
expect(tableSql[0].sql).to.equal(
'create index "baz" on "users" ("foo", "bar")'
);
});
2020-04-19 00:40:23 +02:00
it('adding index fluently', function () {
tableSql = client
.schemaBuilder()
2020-04-19 00:40:23 +02:00
.table('users', function (table) {
table.string('name').index();
})
.toSQL();
equal(2, tableSql.length);
expect(tableSql[0].sql).to.equal(
'alter table "users" add column "name" varchar(255)'
);
expect(tableSql[1].sql).to.equal(
'create index "users_name_index" on "users" ("name")'
);
});
2020-04-19 00:40:23 +02:00
it('adding index with an index type', function () {
tableSql = client
.schemaBuilder()
2020-04-19 00:40:23 +02:00
.table('users', function (table) {
table.index(['foo', 'bar'], 'baz', 'gist');
})
.toSQL();
equal(1, tableSql.length);
expect(tableSql[0].sql).to.equal(
'create index "baz" on "users" using gist ("foo", "bar")'
);
});
2020-04-19 00:40:23 +02:00
it('adding index with an index type fluently', function () {
tableSql = client
.schemaBuilder()
2020-04-19 00:40:23 +02:00
.table('users', function (table) {
table.string('name').index('baz', 'gist');
})
.toSQL();
equal(2, tableSql.length);
expect(tableSql[0].sql).to.equal(
'alter table "users" add column "name" varchar(255)'
);
expect(tableSql[1].sql).to.equal(
'create index "baz" on "users" using gist ("name")'
);
});
2020-04-19 00:40:23 +02:00
it('adding index with an index type and default name fluently', function () {
tableSql = client
.schemaBuilder()
2020-04-19 00:40:23 +02:00
.table('users', function (table) {
table.string('name').index(null, 'gist');
})
.toSQL();
equal(2, tableSql.length);
expect(tableSql[0].sql).to.equal(
'alter table "users" add column "name" varchar(255)'
);
expect(tableSql[1].sql).to.equal(
'create index "users_name_index" on "users" using gist ("name")'
);
});
2020-04-19 00:40:23 +02:00
it('adding incrementing id', function () {
tableSql = client
.schemaBuilder()
2020-04-19 00:40:23 +02:00
.table('users', function (table) {
table.increments('id');
})
.toSQL();
equal(1, tableSql.length);
expect(tableSql[0].sql).to.equal(
'alter table "users" add column "id" serial primary key'
);
});
2021-02-03 13:47:32 +01:00
it('adding incrementing id without primary key', function () {
tableSql = client
.schemaBuilder()
.table('users', function (table) {
table.increments('id', { primaryKey: false });
})
.toSQL();
equal(1, tableSql.length);
expect(tableSql[0].sql).to.equal(
'alter table "users" add column "id" serial'
);
});
2020-04-19 00:40:23 +02:00
it('adding big incrementing id', function () {
tableSql = client
.schemaBuilder()
2020-04-19 00:40:23 +02:00
.table('users', function (table) {
table.bigIncrements('id');
})
.toSQL();
equal(1, tableSql.length);
expect(tableSql[0].sql).to.equal(
'alter table "users" add column "id" bigserial primary key'
);
});
2021-02-03 13:47:32 +01:00
it('adding big incrementing id without primary key', function () {
tableSql = client
.schemaBuilder()
.table('users', function (table) {
table.bigIncrements('id', { primaryKey: false });
})
.toSQL();
equal(1, tableSql.length);
expect(tableSql[0].sql).to.equal(
'alter table "users" add column "id" bigserial'
);
});
2020-04-19 00:40:23 +02:00
it('adding string', function () {
tableSql = client
.schemaBuilder()
2020-04-19 00:40:23 +02:00
.table('users', function (table) {
table.string('foo');
})
.toSQL();
equal(1, tableSql.length);
expect(tableSql[0].sql).to.equal(
'alter table "users" add column "foo" varchar(255)'
);
});
2020-04-19 00:40:23 +02:00
it('adding varchar with length', function () {
tableSql = client
.schemaBuilder()
2020-04-19 00:40:23 +02:00
.table('users', function (table) {
table.string('foo', 100);
})
.toSQL();
equal(1, tableSql.length);
expect(tableSql[0].sql).to.equal(
'alter table "users" add column "foo" varchar(100)'
);
});
2020-04-19 00:40:23 +02:00
it('adding a string with a default', function () {
tableSql = client
.schemaBuilder()
2020-04-19 00:40:23 +02:00
.table('users', function (table) {
table.string('foo', 100).defaultTo('bar');
})
.toSQL();
equal(1, tableSql.length);
expect(tableSql[0].sql).to.equal(
'alter table "users" add column "foo" varchar(100) default \'bar\''
);
});
2020-04-19 00:40:23 +02:00
it('adding text', function () {
tableSql = client
.schemaBuilder()
2020-04-19 00:40:23 +02:00
.table('users', function (table) {
table.text('foo');
})
.toSQL();
equal(1, tableSql.length);
expect(tableSql[0].sql).to.equal(
'alter table "users" add column "foo" text'
);
});
2020-04-19 00:40:23 +02:00
it('adding big integer', function () {
tableSql = client
.schemaBuilder()
2020-04-19 00:40:23 +02:00
.table('users', function (table) {
table.bigInteger('foo');
})
.toSQL();
equal(1, tableSql.length);
expect(tableSql[0].sql).to.equal(
'alter table "users" add column "foo" bigint'
);
});
2020-04-19 00:40:23 +02:00
it('tests a big integer as the primary autoincrement key', function () {
tableSql = client
.schemaBuilder()
2020-04-19 00:40:23 +02:00
.table('users', function (table) {
table.bigIncrements('foo');
})
.toSQL();
equal(1, tableSql.length);
expect(tableSql[0].sql).to.equal(
'alter table "users" add column "foo" bigserial primary key'
);
});
2020-04-19 00:40:23 +02:00
it('adding integer', function () {
tableSql = client
.schemaBuilder()
2020-04-19 00:40:23 +02:00
.table('users', function (table) {
table.integer('foo');
})
.toSQL();
equal(1, tableSql.length);
expect(tableSql[0].sql).to.equal(
'alter table "users" add column "foo" integer'
);
});
2020-04-19 00:40:23 +02:00
it('adding autoincrement integer', function () {
tableSql = client
.schemaBuilder()
2020-04-19 00:40:23 +02:00
.table('users', function (table) {
table.increments('foo');
})
.toSQL();
equal(1, tableSql.length);
expect(tableSql[0].sql).to.equal(
'alter table "users" add column "foo" serial primary key'
);
});
2020-04-19 00:40:23 +02:00
it('adding medium integer', function () {
tableSql = client
.schemaBuilder()
2020-04-19 00:40:23 +02:00
.table('users', function (table) {
table.mediumint('foo');
})
.toSQL();
equal(1, tableSql.length);
expect(tableSql[0].sql).to.equal(
'alter table "users" add column "foo" integer'
);
});
2020-04-19 00:40:23 +02:00
it('adding tiny integer', function () {
tableSql = client
.schemaBuilder()
2020-04-19 00:40:23 +02:00
.table('users', function (table) {
table.tinyint('foo');
})
.toSQL();
equal(1, tableSql.length);
expect(tableSql[0].sql).to.equal(
'alter table "users" add column "foo" smallint'
);
});
2020-04-19 00:40:23 +02:00
it('adding small integer', function () {
tableSql = client
.schemaBuilder()
2020-04-19 00:40:23 +02:00
.table('users', function (table) {
table.smallint('foo');
})
.toSQL();
equal(1, tableSql.length);
expect(tableSql[0].sql).to.equal(
'alter table "users" add column "foo" smallint'
);
});
2020-04-19 00:40:23 +02:00
it('adding float', function () {
tableSql = client
.schemaBuilder()
2020-04-19 00:40:23 +02:00
.table('users', function (table) {
table.float('foo', 5, 2);
})
.toSQL();
equal(1, tableSql.length);
expect(tableSql[0].sql).to.equal(
'alter table "users" add column "foo" real'
);
});
2020-04-19 00:40:23 +02:00
it('adding double', function () {
tableSql = client
.schemaBuilder()
2020-04-19 00:40:23 +02:00
.table('users', function (table) {
table.double('foo', 15, 8);
})
.toSQL();
equal(1, tableSql.length);
expect(tableSql[0].sql).to.equal(
'alter table "users" add column "foo" double precision'
);
});
2020-04-19 00:40:23 +02:00
it('adding decimal', function () {
tableSql = client
.schemaBuilder()
2020-04-19 00:40:23 +02:00
.table('users', function (table) {
table.decimal('foo', 5, 2);
})
.toSQL();
equal(1, tableSql.length);
expect(tableSql[0].sql).to.equal(
'alter table "users" add column "foo" decimal(5, 2)'
);
});
2020-04-19 00:40:23 +02:00
it('adding decimal, variable precision', function () {
tableSql = client
.schemaBuilder()
2020-04-19 00:40:23 +02:00
.table('users', function (table) {
table.decimal('foo', null);
})
.toSQL();
equal(1, tableSql.length);
expect(tableSql[0].sql).to.equal(
'alter table "users" add column "foo" decimal'
);
});
2020-04-19 00:40:23 +02:00
it('adding boolean', function () {
tableSql = client
.schemaBuilder()
2020-04-19 00:40:23 +02:00
.table('users', function (table) {
table.boolean('foo').defaultTo(false);
})
.toSQL();
equal(1, tableSql.length);
expect(tableSql[0].sql).to.equal(
'alter table "users" add column "foo" boolean default \'0\''
);
});
2020-04-19 00:40:23 +02:00
it('adding enum', function () {
tableSql = client
.schemaBuilder()
2020-04-19 00:40:23 +02:00
.table('users', function (table) {
table.enum('foo', ['bar', 'baz']);
})
.toSQL();
equal(1, tableSql.length);
expect(tableSql[0].sql).to.equal(
'alter table "users" add column "foo" text check ("foo" in (\'bar\', \'baz\'))'
);
});
2020-04-19 00:40:23 +02:00
it('adding enum with useNative', function () {
tableSql = client
.schemaBuilder()
2020-04-19 00:40:23 +02:00
.table('users', function (table) {
table
.enu('foo', ['bar', 'baz'], {
useNative: true,
enumName: 'foo_type',
})
.notNullable();
})
.toSQL();
equal(2, tableSql.length);
expect(tableSql[0].sql).to.equal(
"create type \"foo_type\" as enum ('bar', 'baz')"
);
expect(tableSql[1].sql).to.equal(
'alter table "users" add column "foo" "foo_type" not null'
);
});
2020-04-19 00:40:23 +02:00
it('adding enum with useNative and withSchema', function () {
const schema = 'test';
const enumName = 'foo_type';
tableSql = client
.schemaBuilder()
.withSchema(schema)
2020-04-19 00:40:23 +02:00
.table('users', function (table) {
table
.enu('foo', ['bar', 'baz'], {
useNative: true,
schema: true,
enumName,
})
.notNullable();
})
.toSQL();
equal(2, tableSql.length);
expect(tableSql[0].sql).to.equal(
`create type "${schema}"."${enumName}" as enum ('bar', 'baz')`
);
expect(tableSql[1].sql).to.equal(
`alter table "${schema}"."users" add column "foo" "${schema}"."${enumName}" not null`
);
});
2020-04-19 00:40:23 +02:00
it('adding enum with useNative and existingType', function () {
tableSql = client
.schemaBuilder()
.raw("create type \"foo_type\" as enum ('bar', 'baz')")
2020-04-19 00:40:23 +02:00
.table('users', function (table) {
table
.enu('foo', ['bar', 'baz'], {
useNative: true,
existingType: true,
enumName: 'foo_type',
})
.notNullable();
})
.toSQL();
equal(2, tableSql.length);
expect(tableSql[0].sql).to.equal(
"create type \"foo_type\" as enum ('bar', 'baz')"
);
expect(tableSql[1].sql).to.equal(
'alter table "users" add column "foo" "foo_type" not null'
);
});
2020-04-19 00:40:23 +02:00
it('adding enum with useNative and existingType works without enum values', function () {
tableSql = client
.schemaBuilder()
.raw("create type \"foo_type\" as enum ('bar', 'baz')")
2020-04-19 00:40:23 +02:00
.table('users', function (table) {
table
.enu('foo', undefined, {
useNative: true,
existingType: true,
enumName: 'foo_type',
})
.notNullable();
})
.toSQL();
equal(2, tableSql.length);
expect(tableSql[0].sql).to.equal(
"create type \"foo_type\" as enum ('bar', 'baz')"
);
expect(tableSql[1].sql).to.equal(
'alter table "users" add column "foo" "foo_type" not null'
);
});
2020-04-19 00:40:23 +02:00
it('adding enum with useNative, from manually defined schema and withSchema', function () {
const tableSchema = 'table_schema';
const tableName = 'table_name';
const typeSchema = 'type_schema';
const typeName = 'type_name';
const columnName = 'column_name';
tableSql = client
.schemaBuilder()
.withSchema(tableSchema)
2020-04-19 00:40:23 +02:00
.table(tableName, function (table) {
table.enu(columnName, ['foo', 'bar', 'baz'], {
useNative: true,
schemaName: typeSchema,
enumName: typeName,
});
})
.toSQL();
equal(2, tableSql.length);
expect(tableSql[0].sql).to.equal(
`create type "${typeSchema}"."${typeName}" as enum ('foo', 'bar', 'baz')`
);
expect(tableSql[1].sql).to.equal(
`alter table "${tableSchema}"."${tableName}" add column "${columnName}" "${typeSchema}"."${typeName}"`
);
});
2020-04-19 00:40:23 +02:00
it('adding enum with useNative and existingType, from manually defined schema and withSchema', function () {
const tableSchema = 'table_schema';
const tableName = 'table_name';
const typeSchema = 'type_schema';
const typeName = 'type_name';
const columnName = 'column_name';
tableSql = client
.schemaBuilder()
.withSchema(tableSchema)
2020-04-19 00:40:23 +02:00
.table(tableName, function (table) {
table.enu(columnName, null, {
useNative: true,
schemaName: typeSchema,
enumName: typeName,
existingType: true,
});
})
.toSQL();
equal(1, tableSql.length);
expect(tableSql[0].sql).to.equal(
`alter table "${tableSchema}"."${tableName}" add column "${columnName}" "${typeSchema}"."${typeName}"`
);
});
it('adding enum with useNative and alter', function () {
tableSql = client
.schemaBuilder()
.table('users', function (table) {
table
.enu('foo', ['bar', 'baz'], {
useNative: true,
enumName: 'foo_type',
})
.notNullable()
.alter();
})
.toSQL();
equal(5, tableSql.length);
const expectedSql = [
"create type \"foo_type\" as enum ('bar', 'baz')",
'alter table "users" alter column "foo" drop default',
'alter table "users" alter column "foo" drop not null',
'alter table "users" alter column "foo" type "foo_type" using ("foo"::text::"foo_type")',
'alter table "users" alter column "foo" set not null',
];
for (let i = 0; i < tableSql.length; i++) {
expect(tableSql[i].sql).to.equal(expectedSql[i]);
}
});
it('adding multiple useNative enums with some alters', function () {
tableSql = client
.schemaBuilder()
.table('users', function (table) {
table
.enu('foo', ['bar', 'baz'], {
useNative: true,
enumName: 'foo_type',
})
.notNullable()
.alter();
table.enu('bar', ['foo', 'baz'], {
useNative: true,
enumName: 'bar_type',
});
table
.enu('baz', ['foo', 'bar'], {
useNative: true,
enumName: 'baz_type',
})
.defaultTo('foo')
.alter();
})
.toSQL();
equal(12, tableSql.length);
const expectedSql = [
"create type \"baz_type\" as enum ('foo', 'bar')",
"create type \"foo_type\" as enum ('bar', 'baz')",
"create type \"bar_type\" as enum ('foo', 'baz')",
'alter table "users" add column "bar" "bar_type"',
'alter table "users" alter column "foo" drop default',
'alter table "users" alter column "foo" drop not null',
'alter table "users" alter column "foo" type "foo_type" using ("foo"::text::"foo_type")',
'alter table "users" alter column "foo" set not null',
'alter table "users" alter column "baz" drop default',
'alter table "users" alter column "baz" drop not null',
'alter table "users" alter column "baz" type "baz_type" using ("baz"::text::"baz_type")',
'alter table "users" alter column "baz" set default \'foo\'',
];
for (let i = 0; i < tableSql.length; i++) {
expect(tableSql[i].sql).to.equal(expectedSql[i]);
}
});
2020-04-19 00:40:23 +02:00
it('adding date', function () {
tableSql = client
.schemaBuilder()
2020-04-19 00:40:23 +02:00
.table('users', function (table) {
table.date('foo');
})
.toSQL();
equal(1, tableSql.length);
expect(tableSql[0].sql).to.equal(
'alter table "users" add column "foo" date'
);
});
it('adding date time', () => {
tableSql = client
.schemaBuilder()
.table('users', (table) => {
table.dateTime('foo');
})
.toSQL();
equal(1, tableSql.length);
expect(tableSql[0].sql).to.equal(
'alter table "users" add column "foo" timestamptz'
);
});
it('adding time', () => {
tableSql = client
.schemaBuilder()
.table('users', (table) => {
table.time('foo');
})
.toSQL();
equal(1, tableSql.length);
expect(tableSql[0].sql).to.equal(
'alter table "users" add column "foo" time'
);
});
it('adding default timestamp', () => {
tableSql = client
.schemaBuilder()
.table('users', (table) => {
table.timestamp('foo');
})
.toSQL();
equal(1, tableSql.length);
expect(tableSql[0].sql).to.equal(
'alter table "users" add column "foo" timestamptz'
);
});
it('adding default datetime', () => {
tableSql = client
.schemaBuilder()
.table('users', (table) => {
table.datetime('foo');
})
.toSQL();
equal(1, tableSql.length);
expect(tableSql[0].sql).to.equal(
'alter table "users" add column "foo" timestamptz'
);
});
it('adding timestamp with timezone', () => {
tableSql = client
.schemaBuilder()
.table('users', (table) => {
table.timestamp('foo', false);
})
.toSQL();
equal(1, tableSql.length);
expect(tableSql[0].sql).to.equal(
'alter table "users" add column "foo" timestamptz'
);
});
it('adding datetime with timezone', () => {
tableSql = client
.schemaBuilder()
.table('users', (table) => {
table.datetime('foo', false);
})
.toSQL();
equal(1, tableSql.length);
expect(tableSql[0].sql).to.equal(
'alter table "users" add column "foo" timestamptz'
);
});
it('adding timestamp without timezone', () => {
tableSql = client
.schemaBuilder()
.table('users', (table) => {
table.timestamp('foo', true);
})
.toSQL();
equal(1, tableSql.length);
expect(tableSql[0].sql).to.equal(
'alter table "users" add column "foo" timestamp'
);
});
it('adding datetime without timezone', () => {
tableSql = client
.schemaBuilder()
.table('users', (table) => {
table.datetime('foo', true);
})
.toSQL();
equal(1, tableSql.length);
expect(tableSql[0].sql).to.equal(
'alter table "users" add column "foo" timestamp'
);
});
it('adding timestamp with precision', () => {
tableSql = client
.schemaBuilder()
.table('users', (table) => {
table.timestamp('foo', undefined, 2);
})
.toSQL();
equal(1, tableSql.length);
expect(tableSql[0].sql).to.equal(
'alter table "users" add column "foo" timestamptz(2)'
);
});
it('adding datetime with precision', () => {
tableSql = client
.schemaBuilder()
.table('users', (table) => {
table.datetime('foo', undefined, 3);
})
.toSQL();
equal(1, tableSql.length);
expect(tableSql[0].sql).to.equal(
'alter table "users" add column "foo" timestamptz(3)'
);
});
it('adding timestamp with options object', () => {
tableSql = client
.schemaBuilder()
.table('users', (table) => {
table.timestamp('foo', { useTz: false, precision: 3 });
})
.toSQL();
equal(1, tableSql.length);
expect(tableSql[0].sql).to.equal(
'alter table "users" add column "foo" timestamp(3)'
);
});
it('adding timestamp with options object but no timestamp', () => {
tableSql = client
.schemaBuilder()
.table('users', (table) => {
table.timestamp('foo', { precision: 3 });
})
.toSQL();
equal(1, tableSql.length);
expect(tableSql[0].sql).to.equal(
'alter table "users" add column "foo" timestamptz(3)'
);
});
it('adding timestamp with empty options object', () => {
tableSql = client
.schemaBuilder()
.table('users', (table) => {
table.timestamp('foo', {});
})
.toSQL();
equal(1, tableSql.length);
expect(tableSql[0].sql).to.equal(
'alter table "users" add column "foo" timestamptz'
);
});
it('adding datetime with options object', () => {
tableSql = client
.schemaBuilder()
.table('users', (table) => {
table.datetime('foo', { useTz: false, precision: 3 });
})
.toSQL();
equal(1, tableSql.length);
expect(tableSql[0].sql).to.equal(
'alter table "users" add column "foo" timestamp(3)'
);
});
it('adding datetime with options object but no timestamp', () => {
tableSql = client
.schemaBuilder()
.table('users', (table) => {
table.datetime('foo', { precision: 3 });
})
.toSQL();
equal(1, tableSql.length);
expect(tableSql[0].sql).to.equal(
'alter table "users" add column "foo" timestamptz(3)'
);
});
it('adding datetime with empty options object', () => {
tableSql = client
.schemaBuilder()
.table('users', (table) => {
table.datetime('foo', {});
})
.toSQL();
equal(1, tableSql.length);
expect(tableSql[0].sql).to.equal(
'alter table "users" add column "foo" timestamptz'
);
});
it('adding timestamps', () => {
tableSql = client
.schemaBuilder()
.table('users', (table) => {
table.timestamps();
})
.toSQL();
equal(1, tableSql.length);
expect(tableSql[0].sql).to.equal(
'alter table "users" add column "created_at" timestamptz, add column "updated_at" timestamptz'
);
});
it('adding timestamps with defaults', () => {
tableSql = client
.schemaBuilder()
.table('users', (table) => {
table.timestamps(false, true);
})
.toSQL();
equal(1, tableSql.length);
expect(tableSql[0].sql).to.equal(
'alter table "users" add column "created_at" timestamptz not null default CURRENT_TIMESTAMP, add column "updated_at" timestamptz not null default CURRENT_TIMESTAMP'
);
});
2020-04-19 00:40:23 +02:00
it('adding binary', function () {
tableSql = client
.schemaBuilder()
2020-04-19 00:40:23 +02:00
.table('users', function (table) {
table.binary('foo');
})
.toSQL();
equal(1, tableSql.length);
expect(tableSql[0].sql).to.equal(
'alter table "users" add column "foo" bytea'
);
});
2020-04-19 00:40:23 +02:00
it('adding jsonb', function () {
tableSql = client
.schemaBuilder()
2020-04-19 00:40:23 +02:00
.table('user', function (t) {
t.jsonb('preferences');
})
.toSQL();
expect(tableSql[0].sql).to.equal(
'alter table "user" add column "preferences" jsonb'
);
});
2020-04-19 00:40:23 +02:00
it('set comment', function () {
tableSql = client
.schemaBuilder()
2020-04-19 00:40:23 +02:00
.table('user', function (t) {
t.comment('Custom comment');
})
.toSQL();
equal(1, tableSql.length);
expect(tableSql[0].sql).to.equal(
'comment on table "user" is \'Custom comment\''
);
});
2020-04-19 00:40:23 +02:00
it('set empty comment', function () {
tableSql = client
.schemaBuilder()
2020-04-19 00:40:23 +02:00
.table('user', function (t) {
t.comment('');
})
.toSQL();
equal(1, tableSql.length);
expect(tableSql[0].sql).to.equal('comment on table "user" is \'\'');
});
it('test column comment with quotes', function () {
tableSql = client
.schemaBuilder()
.createTable('test', (t) => {
t.text('column1').comment("The table's first column and it's escaped");
})
.toSQL();
equal(tableSql.length, 2);
expect(tableSql[1].sql).to.equal(
"comment on column \"test\".\"column1\" is 'The table''s first column and it''s escaped'"
);
});
it('test column comment with pre-escaped quotes', function () {
tableSql = client
.schemaBuilder()
.createTable('test', (t) => {
t.text('column1').comment(
"The table''s first column and it''s escaped"
);
})
.toSQL();
equal(tableSql.length, 2);
expect(tableSql[1].sql).to.equal(
"comment on column \"test\".\"column1\" is 'The table''s first column and it''s escaped'"
);
});
2020-04-19 00:40:23 +02:00
it('set comment to undefined', function () {
expect(function () {
client
.schemaBuilder()
2020-04-19 00:40:23 +02:00
.table('user', function (t) {
t.comment();
})
.toSQL();
}).to.throw(TypeError);
});
2020-04-19 00:40:23 +02:00
it('set comment to null', function () {
expect(function () {
client
.schemaBuilder()
2020-04-19 00:40:23 +02:00
.table('user', function (t) {
t.comment(null);
})
.toSQL();
}).to.throw(TypeError);
});
2020-04-19 00:40:23 +02:00
it('allows adding default json objects when the column is json', function () {
tableSql = client
.schemaBuilder()
2020-04-19 00:40:23 +02:00
.table('user', function (t) {
t.json('preferences').defaultTo({}).notNullable();
})
.toSQL();
expect(tableSql[0].sql).to.equal(
'alter table "user" add column "preferences" json not null default \'{}\''
);
});
2020-04-19 00:40:23 +02:00
it('allows adding default jsonb objects when the column is json', function () {
tableSql = client
.schemaBuilder()
2020-04-19 00:40:23 +02:00
.table('user', function (t) {
t.jsonb('preferences').defaultTo({}).notNullable();
})
.toSQL();
expect(tableSql[0].sql).to.equal(
'alter table "user" add column "preferences" jsonb not null default \'{}\''
);
});
2020-04-19 00:40:23 +02:00
it('sets specificType correctly', function () {
tableSql = client
.schemaBuilder()
2020-04-19 00:40:23 +02:00
.table('user', function (t) {
t.specificType('email', 'CITEXT').unique().notNullable();
})
.toSQL();
expect(tableSql[0].sql).to.equal(
'alter table "user" add column "email" CITEXT not null'
);
});
2020-04-19 00:40:23 +02:00
it('allows creating an extension', function () {
const sql = client.schemaBuilder().createExtension('test').toSQL();
expect(sql[0].sql).to.equal('create extension "test"');
});
2020-04-19 00:40:23 +02:00
it('allows dropping an extension', function () {
const sql = client.schemaBuilder().dropExtension('test').toSQL();
expect(sql[0].sql).to.equal('drop extension "test"');
});
2020-04-19 00:40:23 +02:00
it("allows creating an extension only if it doesn't exist", function () {
const sql = client
.schemaBuilder()
.createExtensionIfNotExists('test')
.toSQL();
expect(sql[0].sql).to.equal('create extension if not exists "test"');
});
2020-04-19 00:40:23 +02:00
it('allows dropping an extension only if it exists', function () {
const sql = client.schemaBuilder().dropExtensionIfExists('test').toSQL();
expect(sql[0].sql).to.equal('drop extension if exists "test"');
});
2020-04-19 00:40:23 +02:00
it('table inherits another table', function () {
tableSql = client
.schemaBuilder()
2020-04-19 00:40:23 +02:00
.createTable('inheriteeTable', function (t) {
t.string('username');
t.inherits('inheritedTable');
})
.toSQL();
expect(tableSql[0].sql).to.equal(
'create table "inheriteeTable" ("username" varchar(255)) inherits ("inheritedTable")'
);
});
2020-04-19 00:40:23 +02:00
it('should warn on disallowed method', function () {
expect(() => {
tableSql = client
.schemaBuilder()
2020-04-19 00:40:23 +02:00
.createTable('users', function (t) {
t.string('username');
t.engine('myISAM');
})
.toSQL();
}).to.throw('Knex only supports engine statement with mysql');
});
2020-04-19 00:40:23 +02:00
it('#1430 - .primary & .dropPrimary takes columns and constraintName', function () {
tableSql = client
.schemaBuilder()
2020-04-19 00:40:23 +02:00
.table('users', function (t) {
t.primary(['test1', 'test2'], 'testconstraintname');
})
.toSQL();
expect(tableSql[0].sql).to.equal(
'alter table "users" add constraint "testconstraintname" primary key ("test1", "test2")'
);
tableSql = client
.schemaBuilder()
2020-04-19 00:40:23 +02:00
.createTable('users', function (t) {
t.string('test').primary('testconstraintname');
})
.toSQL();
expect(tableSql[1].sql).to.equal(
'alter table "users" add constraint "testconstraintname" primary key ("test")'
);
});
2020-04-19 00:40:23 +02:00
describe('queryContext', function () {
Add queryContext to schema and query builders (#2314) * feat(query-builder): add hookContext for wrapIdentifier * refactor: use isUndefined * test(transaction): test passing of hookContext * feat(runnner): pass context to postProcessResponse * test(runner): test postProcessResponse for raw responses * test(raw): test passing of hookContext * feat: add hookContext to Raw and SchemaBuilder * test(transaction): fix test for hookContext * chore: fix lint error * fix: check for hookContext before calling it * test(transaction): fix hookContext test * chore: remove whitespace * test(hookContext): test cloning of context object * refactor: hookContext -> queryContext * minor: use more descriptive variable name i.e. refactor: `context` => `queryContext` * fix: remove unnecessary checks for query builder * fix(Raw): pass query builder to formatter * fix(SchemaCompiler): pass schema builder to formatter * refactor: add addQueryContext helper * feat: add queryContext to TableBuilder and ColumnBuilder * fix(TableCompiler): pass table builder to formatter * fix(ColumnCompiler): pass column builder to formatter * fix(pushQuery): fix passing builder to formatter * test(Schema|Table|ColumnCompiler): test passing queryContext * fix(SchemaCompiler): pass queryContext to TableCompiler * fix(TableCompiler): pass queryContext to ColumnCompiler * test: add queryContext tests for all schema dialects * test(TableCompiler): test overwriting queryContext from SchemaCompiler * test(Raw): test passing queryContext to wrapIdentifier * tests: run all the tests
2018-02-01 23:41:01 +01:00
let spy;
let originalWrapIdentifier;
2020-04-19 00:40:23 +02:00
before(function () {
Add queryContext to schema and query builders (#2314) * feat(query-builder): add hookContext for wrapIdentifier * refactor: use isUndefined * test(transaction): test passing of hookContext * feat(runnner): pass context to postProcessResponse * test(runner): test postProcessResponse for raw responses * test(raw): test passing of hookContext * feat: add hookContext to Raw and SchemaBuilder * test(transaction): fix test for hookContext * chore: fix lint error * fix: check for hookContext before calling it * test(transaction): fix hookContext test * chore: remove whitespace * test(hookContext): test cloning of context object * refactor: hookContext -> queryContext * minor: use more descriptive variable name i.e. refactor: `context` => `queryContext` * fix: remove unnecessary checks for query builder * fix(Raw): pass query builder to formatter * fix(SchemaCompiler): pass schema builder to formatter * refactor: add addQueryContext helper * feat: add queryContext to TableBuilder and ColumnBuilder * fix(TableCompiler): pass table builder to formatter * fix(ColumnCompiler): pass column builder to formatter * fix(pushQuery): fix passing builder to formatter * test(Schema|Table|ColumnCompiler): test passing queryContext * fix(SchemaCompiler): pass queryContext to TableCompiler * fix(TableCompiler): pass queryContext to ColumnCompiler * test: add queryContext tests for all schema dialects * test(TableCompiler): test overwriting queryContext from SchemaCompiler * test(Raw): test passing queryContext to wrapIdentifier * tests: run all the tests
2018-02-01 23:41:01 +01:00
spy = sinon.spy();
originalWrapIdentifier = client.config.wrapIdentifier;
2020-04-19 00:40:23 +02:00
client.config.wrapIdentifier = function (value, wrap, queryContext) {
Add queryContext to schema and query builders (#2314) * feat(query-builder): add hookContext for wrapIdentifier * refactor: use isUndefined * test(transaction): test passing of hookContext * feat(runnner): pass context to postProcessResponse * test(runner): test postProcessResponse for raw responses * test(raw): test passing of hookContext * feat: add hookContext to Raw and SchemaBuilder * test(transaction): fix test for hookContext * chore: fix lint error * fix: check for hookContext before calling it * test(transaction): fix hookContext test * chore: remove whitespace * test(hookContext): test cloning of context object * refactor: hookContext -> queryContext * minor: use more descriptive variable name i.e. refactor: `context` => `queryContext` * fix: remove unnecessary checks for query builder * fix(Raw): pass query builder to formatter * fix(SchemaCompiler): pass schema builder to formatter * refactor: add addQueryContext helper * feat: add queryContext to TableBuilder and ColumnBuilder * fix(TableCompiler): pass table builder to formatter * fix(ColumnCompiler): pass column builder to formatter * fix(pushQuery): fix passing builder to formatter * test(Schema|Table|ColumnCompiler): test passing queryContext * fix(SchemaCompiler): pass queryContext to TableCompiler * fix(TableCompiler): pass queryContext to ColumnCompiler * test: add queryContext tests for all schema dialects * test(TableCompiler): test overwriting queryContext from SchemaCompiler * test(Raw): test passing queryContext to wrapIdentifier * tests: run all the tests
2018-02-01 23:41:01 +01:00
spy(value, queryContext);
return wrap(value);
};
});
2020-04-19 00:40:23 +02:00
beforeEach(function () {
spy.resetHistory();
Add queryContext to schema and query builders (#2314) * feat(query-builder): add hookContext for wrapIdentifier * refactor: use isUndefined * test(transaction): test passing of hookContext * feat(runnner): pass context to postProcessResponse * test(runner): test postProcessResponse for raw responses * test(raw): test passing of hookContext * feat: add hookContext to Raw and SchemaBuilder * test(transaction): fix test for hookContext * chore: fix lint error * fix: check for hookContext before calling it * test(transaction): fix hookContext test * chore: remove whitespace * test(hookContext): test cloning of context object * refactor: hookContext -> queryContext * minor: use more descriptive variable name i.e. refactor: `context` => `queryContext` * fix: remove unnecessary checks for query builder * fix(Raw): pass query builder to formatter * fix(SchemaCompiler): pass schema builder to formatter * refactor: add addQueryContext helper * feat: add queryContext to TableBuilder and ColumnBuilder * fix(TableCompiler): pass table builder to formatter * fix(ColumnCompiler): pass column builder to formatter * fix(pushQuery): fix passing builder to formatter * test(Schema|Table|ColumnCompiler): test passing queryContext * fix(SchemaCompiler): pass queryContext to TableCompiler * fix(TableCompiler): pass queryContext to ColumnCompiler * test: add queryContext tests for all schema dialects * test(TableCompiler): test overwriting queryContext from SchemaCompiler * test(Raw): test passing queryContext to wrapIdentifier * tests: run all the tests
2018-02-01 23:41:01 +01:00
});
2020-04-19 00:40:23 +02:00
after(function () {
Add queryContext to schema and query builders (#2314) * feat(query-builder): add hookContext for wrapIdentifier * refactor: use isUndefined * test(transaction): test passing of hookContext * feat(runnner): pass context to postProcessResponse * test(runner): test postProcessResponse for raw responses * test(raw): test passing of hookContext * feat: add hookContext to Raw and SchemaBuilder * test(transaction): fix test for hookContext * chore: fix lint error * fix: check for hookContext before calling it * test(transaction): fix hookContext test * chore: remove whitespace * test(hookContext): test cloning of context object * refactor: hookContext -> queryContext * minor: use more descriptive variable name i.e. refactor: `context` => `queryContext` * fix: remove unnecessary checks for query builder * fix(Raw): pass query builder to formatter * fix(SchemaCompiler): pass schema builder to formatter * refactor: add addQueryContext helper * feat: add queryContext to TableBuilder and ColumnBuilder * fix(TableCompiler): pass table builder to formatter * fix(ColumnCompiler): pass column builder to formatter * fix(pushQuery): fix passing builder to formatter * test(Schema|Table|ColumnCompiler): test passing queryContext * fix(SchemaCompiler): pass queryContext to TableCompiler * fix(TableCompiler): pass queryContext to ColumnCompiler * test: add queryContext tests for all schema dialects * test(TableCompiler): test overwriting queryContext from SchemaCompiler * test(Raw): test passing queryContext to wrapIdentifier * tests: run all the tests
2018-02-01 23:41:01 +01:00
client.config.wrapIdentifier = originalWrapIdentifier;
});
2020-04-19 00:40:23 +02:00
it('SchemaCompiler passes queryContext to wrapIdentifier via TableCompiler', function () {
Add queryContext to schema and query builders (#2314) * feat(query-builder): add hookContext for wrapIdentifier * refactor: use isUndefined * test(transaction): test passing of hookContext * feat(runnner): pass context to postProcessResponse * test(runner): test postProcessResponse for raw responses * test(raw): test passing of hookContext * feat: add hookContext to Raw and SchemaBuilder * test(transaction): fix test for hookContext * chore: fix lint error * fix: check for hookContext before calling it * test(transaction): fix hookContext test * chore: remove whitespace * test(hookContext): test cloning of context object * refactor: hookContext -> queryContext * minor: use more descriptive variable name i.e. refactor: `context` => `queryContext` * fix: remove unnecessary checks for query builder * fix(Raw): pass query builder to formatter * fix(SchemaCompiler): pass schema builder to formatter * refactor: add addQueryContext helper * feat: add queryContext to TableBuilder and ColumnBuilder * fix(TableCompiler): pass table builder to formatter * fix(ColumnCompiler): pass column builder to formatter * fix(pushQuery): fix passing builder to formatter * test(Schema|Table|ColumnCompiler): test passing queryContext * fix(SchemaCompiler): pass queryContext to TableCompiler * fix(TableCompiler): pass queryContext to ColumnCompiler * test: add queryContext tests for all schema dialects * test(TableCompiler): test overwriting queryContext from SchemaCompiler * test(Raw): test passing queryContext to wrapIdentifier * tests: run all the tests
2018-02-01 23:41:01 +01:00
client
.schemaBuilder()
.queryContext('table context')
2020-04-19 00:40:23 +02:00
.createTable('users', function (table) {
Add queryContext to schema and query builders (#2314) * feat(query-builder): add hookContext for wrapIdentifier * refactor: use isUndefined * test(transaction): test passing of hookContext * feat(runnner): pass context to postProcessResponse * test(runner): test postProcessResponse for raw responses * test(raw): test passing of hookContext * feat: add hookContext to Raw and SchemaBuilder * test(transaction): fix test for hookContext * chore: fix lint error * fix: check for hookContext before calling it * test(transaction): fix hookContext test * chore: remove whitespace * test(hookContext): test cloning of context object * refactor: hookContext -> queryContext * minor: use more descriptive variable name i.e. refactor: `context` => `queryContext` * fix: remove unnecessary checks for query builder * fix(Raw): pass query builder to formatter * fix(SchemaCompiler): pass schema builder to formatter * refactor: add addQueryContext helper * feat: add queryContext to TableBuilder and ColumnBuilder * fix(TableCompiler): pass table builder to formatter * fix(ColumnCompiler): pass column builder to formatter * fix(pushQuery): fix passing builder to formatter * test(Schema|Table|ColumnCompiler): test passing queryContext * fix(SchemaCompiler): pass queryContext to TableCompiler * fix(TableCompiler): pass queryContext to ColumnCompiler * test: add queryContext tests for all schema dialects * test(TableCompiler): test overwriting queryContext from SchemaCompiler * test(Raw): test passing queryContext to wrapIdentifier * tests: run all the tests
2018-02-01 23:41:01 +01:00
table.increments('id');
table.string('email');
})
.toSQL();
expect(spy.callCount).to.equal(3);
expect(spy.firstCall.args).to.deep.equal(['id', 'table context']);
expect(spy.secondCall.args).to.deep.equal(['email', 'table context']);
expect(spy.thirdCall.args).to.deep.equal(['users', 'table context']);
});
2020-04-19 00:40:23 +02:00
it('TableCompiler passes queryContext to wrapIdentifier', function () {
Add queryContext to schema and query builders (#2314) * feat(query-builder): add hookContext for wrapIdentifier * refactor: use isUndefined * test(transaction): test passing of hookContext * feat(runnner): pass context to postProcessResponse * test(runner): test postProcessResponse for raw responses * test(raw): test passing of hookContext * feat: add hookContext to Raw and SchemaBuilder * test(transaction): fix test for hookContext * chore: fix lint error * fix: check for hookContext before calling it * test(transaction): fix hookContext test * chore: remove whitespace * test(hookContext): test cloning of context object * refactor: hookContext -> queryContext * minor: use more descriptive variable name i.e. refactor: `context` => `queryContext` * fix: remove unnecessary checks for query builder * fix(Raw): pass query builder to formatter * fix(SchemaCompiler): pass schema builder to formatter * refactor: add addQueryContext helper * feat: add queryContext to TableBuilder and ColumnBuilder * fix(TableCompiler): pass table builder to formatter * fix(ColumnCompiler): pass column builder to formatter * fix(pushQuery): fix passing builder to formatter * test(Schema|Table|ColumnCompiler): test passing queryContext * fix(SchemaCompiler): pass queryContext to TableCompiler * fix(TableCompiler): pass queryContext to ColumnCompiler * test: add queryContext tests for all schema dialects * test(TableCompiler): test overwriting queryContext from SchemaCompiler * test(Raw): test passing queryContext to wrapIdentifier * tests: run all the tests
2018-02-01 23:41:01 +01:00
client
.schemaBuilder()
2020-04-19 00:40:23 +02:00
.createTable('users', function (table) {
Add queryContext to schema and query builders (#2314) * feat(query-builder): add hookContext for wrapIdentifier * refactor: use isUndefined * test(transaction): test passing of hookContext * feat(runnner): pass context to postProcessResponse * test(runner): test postProcessResponse for raw responses * test(raw): test passing of hookContext * feat: add hookContext to Raw and SchemaBuilder * test(transaction): fix test for hookContext * chore: fix lint error * fix: check for hookContext before calling it * test(transaction): fix hookContext test * chore: remove whitespace * test(hookContext): test cloning of context object * refactor: hookContext -> queryContext * minor: use more descriptive variable name i.e. refactor: `context` => `queryContext` * fix: remove unnecessary checks for query builder * fix(Raw): pass query builder to formatter * fix(SchemaCompiler): pass schema builder to formatter * refactor: add addQueryContext helper * feat: add queryContext to TableBuilder and ColumnBuilder * fix(TableCompiler): pass table builder to formatter * fix(ColumnCompiler): pass column builder to formatter * fix(pushQuery): fix passing builder to formatter * test(Schema|Table|ColumnCompiler): test passing queryContext * fix(SchemaCompiler): pass queryContext to TableCompiler * fix(TableCompiler): pass queryContext to ColumnCompiler * test: add queryContext tests for all schema dialects * test(TableCompiler): test overwriting queryContext from SchemaCompiler * test(Raw): test passing queryContext to wrapIdentifier * tests: run all the tests
2018-02-01 23:41:01 +01:00
table.increments('id').queryContext('id context');
table.string('email').queryContext('email context');
})
.toSQL();
expect(spy.callCount).to.equal(3);
expect(spy.firstCall.args).to.deep.equal(['id', 'id context']);
expect(spy.secondCall.args).to.deep.equal(['email', 'email context']);
expect(spy.thirdCall.args).to.deep.equal(['users', undefined]);
});
2020-04-19 00:40:23 +02:00
it('TableCompiler allows overwriting queryContext from SchemaCompiler', function () {
Add queryContext to schema and query builders (#2314) * feat(query-builder): add hookContext for wrapIdentifier * refactor: use isUndefined * test(transaction): test passing of hookContext * feat(runnner): pass context to postProcessResponse * test(runner): test postProcessResponse for raw responses * test(raw): test passing of hookContext * feat: add hookContext to Raw and SchemaBuilder * test(transaction): fix test for hookContext * chore: fix lint error * fix: check for hookContext before calling it * test(transaction): fix hookContext test * chore: remove whitespace * test(hookContext): test cloning of context object * refactor: hookContext -> queryContext * minor: use more descriptive variable name i.e. refactor: `context` => `queryContext` * fix: remove unnecessary checks for query builder * fix(Raw): pass query builder to formatter * fix(SchemaCompiler): pass schema builder to formatter * refactor: add addQueryContext helper * feat: add queryContext to TableBuilder and ColumnBuilder * fix(TableCompiler): pass table builder to formatter * fix(ColumnCompiler): pass column builder to formatter * fix(pushQuery): fix passing builder to formatter * test(Schema|Table|ColumnCompiler): test passing queryContext * fix(SchemaCompiler): pass queryContext to TableCompiler * fix(TableCompiler): pass queryContext to ColumnCompiler * test: add queryContext tests for all schema dialects * test(TableCompiler): test overwriting queryContext from SchemaCompiler * test(Raw): test passing queryContext to wrapIdentifier * tests: run all the tests
2018-02-01 23:41:01 +01:00
client
.schemaBuilder()
.queryContext('schema context')
2020-04-19 00:40:23 +02:00
.createTable('users', function (table) {
Add queryContext to schema and query builders (#2314) * feat(query-builder): add hookContext for wrapIdentifier * refactor: use isUndefined * test(transaction): test passing of hookContext * feat(runnner): pass context to postProcessResponse * test(runner): test postProcessResponse for raw responses * test(raw): test passing of hookContext * feat: add hookContext to Raw and SchemaBuilder * test(transaction): fix test for hookContext * chore: fix lint error * fix: check for hookContext before calling it * test(transaction): fix hookContext test * chore: remove whitespace * test(hookContext): test cloning of context object * refactor: hookContext -> queryContext * minor: use more descriptive variable name i.e. refactor: `context` => `queryContext` * fix: remove unnecessary checks for query builder * fix(Raw): pass query builder to formatter * fix(SchemaCompiler): pass schema builder to formatter * refactor: add addQueryContext helper * feat: add queryContext to TableBuilder and ColumnBuilder * fix(TableCompiler): pass table builder to formatter * fix(ColumnCompiler): pass column builder to formatter * fix(pushQuery): fix passing builder to formatter * test(Schema|Table|ColumnCompiler): test passing queryContext * fix(SchemaCompiler): pass queryContext to TableCompiler * fix(TableCompiler): pass queryContext to ColumnCompiler * test: add queryContext tests for all schema dialects * test(TableCompiler): test overwriting queryContext from SchemaCompiler * test(Raw): test passing queryContext to wrapIdentifier * tests: run all the tests
2018-02-01 23:41:01 +01:00
table.queryContext('table context');
table.increments('id');
table.string('email');
})
.toSQL();
expect(spy.callCount).to.equal(3);
expect(spy.firstCall.args).to.deep.equal(['id', 'table context']);
expect(spy.secondCall.args).to.deep.equal(['email', 'table context']);
expect(spy.thirdCall.args).to.deep.equal(['users', 'table context']);
});
2020-04-19 00:40:23 +02:00
it('ColumnCompiler allows overwriting queryContext from TableCompiler', function () {
Add queryContext to schema and query builders (#2314) * feat(query-builder): add hookContext for wrapIdentifier * refactor: use isUndefined * test(transaction): test passing of hookContext * feat(runnner): pass context to postProcessResponse * test(runner): test postProcessResponse for raw responses * test(raw): test passing of hookContext * feat: add hookContext to Raw and SchemaBuilder * test(transaction): fix test for hookContext * chore: fix lint error * fix: check for hookContext before calling it * test(transaction): fix hookContext test * chore: remove whitespace * test(hookContext): test cloning of context object * refactor: hookContext -> queryContext * minor: use more descriptive variable name i.e. refactor: `context` => `queryContext` * fix: remove unnecessary checks for query builder * fix(Raw): pass query builder to formatter * fix(SchemaCompiler): pass schema builder to formatter * refactor: add addQueryContext helper * feat: add queryContext to TableBuilder and ColumnBuilder * fix(TableCompiler): pass table builder to formatter * fix(ColumnCompiler): pass column builder to formatter * fix(pushQuery): fix passing builder to formatter * test(Schema|Table|ColumnCompiler): test passing queryContext * fix(SchemaCompiler): pass queryContext to TableCompiler * fix(TableCompiler): pass queryContext to ColumnCompiler * test: add queryContext tests for all schema dialects * test(TableCompiler): test overwriting queryContext from SchemaCompiler * test(Raw): test passing queryContext to wrapIdentifier * tests: run all the tests
2018-02-01 23:41:01 +01:00
client
.schemaBuilder()
.queryContext('schema context')
2020-04-19 00:40:23 +02:00
.createTable('users', function (table) {
Add queryContext to schema and query builders (#2314) * feat(query-builder): add hookContext for wrapIdentifier * refactor: use isUndefined * test(transaction): test passing of hookContext * feat(runnner): pass context to postProcessResponse * test(runner): test postProcessResponse for raw responses * test(raw): test passing of hookContext * feat: add hookContext to Raw and SchemaBuilder * test(transaction): fix test for hookContext * chore: fix lint error * fix: check for hookContext before calling it * test(transaction): fix hookContext test * chore: remove whitespace * test(hookContext): test cloning of context object * refactor: hookContext -> queryContext * minor: use more descriptive variable name i.e. refactor: `context` => `queryContext` * fix: remove unnecessary checks for query builder * fix(Raw): pass query builder to formatter * fix(SchemaCompiler): pass schema builder to formatter * refactor: add addQueryContext helper * feat: add queryContext to TableBuilder and ColumnBuilder * fix(TableCompiler): pass table builder to formatter * fix(ColumnCompiler): pass column builder to formatter * fix(pushQuery): fix passing builder to formatter * test(Schema|Table|ColumnCompiler): test passing queryContext * fix(SchemaCompiler): pass queryContext to TableCompiler * fix(TableCompiler): pass queryContext to ColumnCompiler * test: add queryContext tests for all schema dialects * test(TableCompiler): test overwriting queryContext from SchemaCompiler * test(Raw): test passing queryContext to wrapIdentifier * tests: run all the tests
2018-02-01 23:41:01 +01:00
table.queryContext('table context');
table.increments('id').queryContext('id context');
table.string('email').queryContext('email context');
})
.toSQL();
expect(spy.callCount).to.equal(3);
expect(spy.firstCall.args).to.deep.equal(['id', 'id context']);
expect(spy.secondCall.args).to.deep.equal(['email', 'email context']);
expect(spy.thirdCall.args).to.deep.equal(['users', 'table context']);
});
2020-04-19 00:40:23 +02:00
it('TableCompiler calls wrapIdentifier when altering column', function () {
client
.schemaBuilder()
2020-04-19 00:40:23 +02:00
.table('users', function (table) {
table.queryContext('table context');
table
.string('email')
.notNull()
.alter()
.queryContext('email alter context');
})
.toSQL();
expect(spy.callCount).to.equal(3);
expect(spy.thirdCall.args).to.deep.equal([
'email',
'email alter context',
]);
});
Add queryContext to schema and query builders (#2314) * feat(query-builder): add hookContext for wrapIdentifier * refactor: use isUndefined * test(transaction): test passing of hookContext * feat(runnner): pass context to postProcessResponse * test(runner): test postProcessResponse for raw responses * test(raw): test passing of hookContext * feat: add hookContext to Raw and SchemaBuilder * test(transaction): fix test for hookContext * chore: fix lint error * fix: check for hookContext before calling it * test(transaction): fix hookContext test * chore: remove whitespace * test(hookContext): test cloning of context object * refactor: hookContext -> queryContext * minor: use more descriptive variable name i.e. refactor: `context` => `queryContext` * fix: remove unnecessary checks for query builder * fix(Raw): pass query builder to formatter * fix(SchemaCompiler): pass schema builder to formatter * refactor: add addQueryContext helper * feat: add queryContext to TableBuilder and ColumnBuilder * fix(TableCompiler): pass table builder to formatter * fix(ColumnCompiler): pass column builder to formatter * fix(pushQuery): fix passing builder to formatter * test(Schema|Table|ColumnCompiler): test passing queryContext * fix(SchemaCompiler): pass queryContext to TableCompiler * fix(TableCompiler): pass queryContext to ColumnCompiler * test: add queryContext tests for all schema dialects * test(TableCompiler): test overwriting queryContext from SchemaCompiler * test(Raw): test passing queryContext to wrapIdentifier * tests: run all the tests
2018-02-01 23:41:01 +01:00
});
2015-11-04 13:34:18 +02:00
});