From 22640d088cd5a7c5132b47e2744dc83cd5116672 Mon Sep 17 00:00:00 2001 From: mateonunez Date: Thu, 2 Mar 2023 00:17:34 +0100 Subject: [PATCH] test(drill): improve tests --- packages/drill/test/common.test.js | 209 +++++++++++++++-------------- 1 file changed, 108 insertions(+), 101 deletions(-) diff --git a/packages/drill/test/common.test.js b/packages/drill/test/common.test.js index 75168d3a..c9166a66 100644 --- a/packages/drill/test/common.test.js +++ b/packages/drill/test/common.test.js @@ -2,6 +2,7 @@ import { test } from 'tap' import setupDatabase, { killDatabase } from './../drill.js' import symbols from '../lib/symbols.js' import { logger, database } from '@mateonunez/asterism-huston' +import { allowedDatabases } from '../lib/database.js' const { mysqlOptions, postgresOptions } = database const { privateMethods } = symbols @@ -26,132 +27,138 @@ async function insertIntoTable (queryer, tableName) { }) } -test('should drop a database', ({ end }) => { - test('mysql', async ({ ok }) => { - const { db, queryer } = await setupDatabase(logger, 'mysql', mysqlOptions) - const databaseName = 'test' - await queryer[privateMethods].createDatabase(databaseName, { dropIfExists: true }) - - await queryer[privateMethods].dropDatabase(databaseName) - await killDatabase(db) - ok(db) - }) - - test('postgres', async ({ ok }) => { - const { db, queryer } = await setupDatabase(logger, 'postgres', postgresOptions) - const databaseName = 'test' - await queryer[privateMethods].createDatabase(databaseName, { dropIfExists: true }) +function getOptions (database) { + return database === 'mysql' ? mysqlOptions : database === 'postgres' ? postgresOptions : {} +} - await queryer[privateMethods].dropDatabase(databaseName) - await killDatabase(db) - ok(db) +test('should drop a database', ({ end }) => { + allowedDatabases.forEach((supportedDatabase) => { + test(supportedDatabase, async ({ equal, teardown }) => { + teardown(async () => { + await killDatabase(db) + }) + + const { db, queryer } = await setupDatabase(logger, supportedDatabase, getOptions(supportedDatabase)) + const databaseName = 'test' + await queryer[privateMethods].createDatabase(databaseName, { dropIfExists: true }) + await queryer[privateMethods].dropDatabase(databaseName) + + equal(await queryer[privateMethods].databaseExists(databaseName), false) + }) }) - end() }) test('should create a new table', ({ end }) => { - test('mysql', async ({ ok }) => { - const { db, queryer } = await setupDatabase(logger, 'mysql', mysqlOptions) - const tableName = 'common_table_test' - await createTable(queryer, tableName) - await queryer[privateMethods].dropTable(tableName) - await killDatabase(db) - - ok(db) - }) - - test('postgres', async ({ ok }) => { - const { db, queryer } = await setupDatabase(logger, 'postgres', postgresOptions) - const tableName = 'common_table_test' - await createTable(queryer, tableName) - await queryer[privateMethods].dropTable(tableName) - await killDatabase(db) - - ok(db) + allowedDatabases.forEach((supportedDatabase) => { + test(supportedDatabase, async ({ same, teardown }) => { + teardown(async () => { + await queryer[privateMethods].dropTable(tableName) + await killDatabase(db) + }) + + const { db, queryer } = await setupDatabase(logger, supportedDatabase, getOptions(supportedDatabase)) + const tableName = 'common_table_test' + await createTable(queryer, tableName) + const data = await queryer.selectData(tableName) + + same(data, []) + }) }) end() }) test('should insert data into a table', ({ end }) => { - test('mysql', async ({ ok }) => { - const { db, queryer } = await setupDatabase(logger, 'mysql', mysqlOptions) - const tableName = 'common_table_test' - await createTable(queryer, tableName) - await insertIntoTable(queryer, tableName) - await queryer[privateMethods].dropTable(tableName) - await killDatabase(db) - - ok(db) - }) - - test('postgres', async ({ ok }) => { - const { db, queryer } = await setupDatabase(logger, 'postgres', postgresOptions) - const tableName = 'common_table_test' - await createTable(queryer, tableName) - await insertIntoTable(queryer, tableName) - await queryer[privateMethods].dropTable(tableName) - await killDatabase(db) - - ok(db) + allowedDatabases.forEach((supportedDatabase) => { + test(supportedDatabase, async ({ same, teardown }) => { + teardown(async () => { + await queryer[privateMethods].dropTable(tableName) + await killDatabase(db) + }) + + const { db, queryer } = await setupDatabase(logger, supportedDatabase, getOptions(supportedDatabase)) + const tableName = 'common_table_test' + await createTable(queryer, tableName) + await insertIntoTable(queryer, tableName) + const data = await queryer.selectData(tableName) + + same(data, [{ + id: 1, + name: 'test' + }]) + }) }) end() }) test('should delete data', ({ end }) => { - test('mysql', async ({ ok }) => { - const { db, queryer } = await setupDatabase(logger, 'mysql', mysqlOptions) - const tableName = 'common_table_test' - await createTable(queryer, tableName) - await insertIntoTable(queryer, tableName) - await queryer[privateMethods].deleteData(tableName, { id: 1 }) - await queryer[privateMethods].dropTable(tableName) - await killDatabase(db) - - ok(db) - }) - - test('postgres', async ({ ok }) => { - const { db, queryer } = await setupDatabase(logger, 'postgres', postgresOptions) - const tableName = 'common_table_test' - await createTable(queryer, tableName) - await insertIntoTable(queryer, tableName) - await queryer[privateMethods].deleteData(tableName, { id: 1 }) - await queryer[privateMethods].dropTable(tableName) - await killDatabase(db) - - ok(db) + allowedDatabases.forEach((supportedDatabase) => { + test(supportedDatabase, async ({ same, teardown }) => { + teardown(async () => { + await queryer[privateMethods].dropTable(tableName) + await killDatabase(db) + }) + + const { db, queryer } = await setupDatabase(logger, supportedDatabase, getOptions(supportedDatabase)) + const tableName = 'common_table_test' + await createTable(queryer, tableName) + await insertIntoTable(queryer, tableName) + await queryer[privateMethods].deleteData(tableName, { id: 1 }) + const data = await queryer.selectData(tableName) + + same(data, []) + }) }) end() }) test('should update data', ({ end }) => { - test('mysql', async ({ ok }) => { - const { db, queryer } = await setupDatabase(logger, 'mysql', mysqlOptions) - const tableName = 'common_table_test' - await createTable(queryer, tableName) - await insertIntoTable(queryer, tableName) - await queryer[privateMethods].updateData(tableName, { id: 1 }, { name: 'test2' }) - await queryer[privateMethods].dropTable(tableName) - await killDatabase(db) - - ok(db) - }) - - test('postgres', async ({ ok }) => { - const { db, queryer } = await setupDatabase(logger, 'postgres', postgresOptions) - const tableName = 'common_table_test' - await createTable(queryer, tableName) - await insertIntoTable(queryer, tableName) - await queryer[privateMethods].updateData(tableName, { id: 1 }, { name: 'test2' }) - await queryer[privateMethods].dropTable(tableName) - await killDatabase(db) - - ok(db) + allowedDatabases.forEach((supportedDatabase) => { + test(supportedDatabase, async ({ same, teardown }) => { + teardown(async () => { + await queryer[privateMethods].dropTable(tableName) + await killDatabase(db) + }) + + const { db, queryer } = await setupDatabase(logger, supportedDatabase, getOptions(supportedDatabase)) + const tableName = 'common_table_test' + await createTable(queryer, tableName) + await insertIntoTable(queryer, tableName) + await queryer[privateMethods].updateData(tableName, { name: 'test2' }, { id: 1 }) + const data = await queryer.selectData(tableName) + + same(data, [{ + id: 1, + name: 'test2' + }]) + }) }) + // test('mysql', async ({ ok }) => { + // const { db, queryer } = await setupDatabase(logger, 'mysql', mysqlOptions) + // const tableName = 'common_table_test' + // await createTable(queryer, tableName) + // await insertIntoTable(queryer, tableName) + // await queryer[privateMethods].updateData(tableName, { id: 1 }, { name: 'test2' }) + // await queryer[privateMethods].dropTable(tableName) + // await killDatabase(db) + + // ok(db) + // }) + + // test('postgres', async ({ ok }) => { + // const { db, queryer } = await setupDatabase(logger, 'postgres', postgresOptions) + // const tableName = 'common_table_test' + // await createTable(queryer, tableName) + // await insertIntoTable(queryer, tableName) + // await queryer[privateMethods].updateData(tableName, { id: 1 }, { name: 'test2' }) + // await queryer[privateMethods].dropTable(tableName) + // await killDatabase(db) + + // ok(db) + // }) end() })