diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml index 23a4abdff..0711b3f36 100644 --- a/.github/workflows/ci.yml +++ b/.github/workflows/ci.yml @@ -9,4 +9,4 @@ jobs: - name: Run tests run: | cp ./ormconfig.gh-actions.json ./ormconfig.json - deno run --allow-read --allow-write --config ./tsconfig.json ./test.ts + deno run --allow-read --allow-write --allow-env --config ./tsconfig.json ./test.ts diff --git a/ormconfig.gh-actions.json b/ormconfig.gh-actions.json index b13d5ac7d..95ee2b59d 100644 --- a/ormconfig.gh-actions.json +++ b/ormconfig.gh-actions.json @@ -3,7 +3,7 @@ "skip": false, "name": "sqlite", "type": "sqlite", - "database": "temp/sqlitedb.db", - "logging": true + "database": ":memory:", + "logging": false } ] diff --git a/src/connection/ConnectionOptionsReader.ts b/src/connection/ConnectionOptionsReader.ts index 649b35a68..5235821dd 100644 --- a/src/connection/ConnectionOptionsReader.ts +++ b/src/connection/ConnectionOptionsReader.ts @@ -108,10 +108,12 @@ export class ConnectionOptionsReader { connectionOptions = new ConnectionOptionsEnvReader().read(); } else if (foundFileFormat === "js") { - connectionOptions = await PlatformTools.load(configFile); + const mod = await import(configFile); + connectionOptions = await mod.default; } else if (foundFileFormat === "ts") { - connectionOptions = await PlatformTools.load(configFile); + const mod = await import(configFile); + connectionOptions = await mod.default; } else if (foundFileFormat === "json") { connectionOptions = PlatformTools.load(configFile); @@ -197,10 +199,12 @@ export class ConnectionOptionsReader { * Gets directory where configuration file should be located. */ protected get baseDirectory(): string { - if (this.options && this.options.root) - return this.options.root; - - return PlatformTools.load("app-root-path").path; + const baseDirectory = this.options && this.options.root + ? this.options.root + : PlatformTools.load("app-root-path").path; + return baseDirectory.endsWith('/') + ? baseDirectory.slice(0, -1) + : baseDirectory; } /** diff --git a/src/driver/sqlite/SqliteQueryRunner.ts b/src/driver/sqlite/SqliteQueryRunner.ts index 343dd45a0..c0d814499 100644 --- a/src/driver/sqlite/SqliteQueryRunner.ts +++ b/src/driver/sqlite/SqliteQueryRunner.ts @@ -70,7 +70,6 @@ export class SqliteQueryRunner extends AbstractSqliteQueryRunner { await this.saveDatabaseToFileIfNeeded(databaseConnection, query); return result; } catch (err) { - console.error(err) connection.logger.logQueryError(err, query, parameters, this); throw new QueryFailedError(query, parameters, err); } diff --git a/src/driver/types/ColumnTypes.ts b/src/driver/types/ColumnTypes.ts index 3569bedda..5572e6c00 100644 --- a/src/driver/types/ColumnTypes.ts +++ b/src/driver/types/ColumnTypes.ts @@ -206,4 +206,5 @@ export type ColumnType = WithPrecisionColumnType |BooleanConstructor |DateConstructor |NumberConstructor - |StringConstructor; + |StringConstructor + |Uint8ArrayConstructor; // TODO(uki001) This type is not fully tested yet. diff --git a/src/platform/PlatformTools.ts b/src/platform/PlatformTools.ts index 53d46ea91..6f02b15a5 100644 --- a/src/platform/PlatformTools.ts +++ b/src/platform/PlatformTools.ts @@ -106,6 +106,14 @@ export class PlatformTools { return Deno.env()[name]; } + static encodeToBase64(string: string): string { + return window.btoa(string); + } + + static decodeFromBase64(base64: string): string { + return window.atob(base64); + } + // TODO(uki00a) implement this method. /** * Highlights sql string to be print in the console. diff --git a/test.ts b/test.ts index a36c30be3..7190ae4e4 100644 --- a/test.ts +++ b/test.ts @@ -1,4 +1,256 @@ import {runTests} from "./test/deps/mocha.ts"; + import "./test/integration/sample1-simple-entity.ts"; +import "./test/functional/cascades/cascade-insert-from-both-sides/cascade-insert-from-both-sides.ts"; +import "./test/functional/columns/embedded-columns/columns-embedded-columns.ts"; +import "./test/functional/columns/getters-setters/columns-getters-setters.ts"; +import "./test/functional/columns/no-select/columns-no-select.ts"; +import "./test/functional/columns/readonly/columns-readonly.ts"; +import "./test/functional/columns/update-insert/columns-update-insert.ts"; +import "./test/functional/columns/value-transformer/value-transformer.ts"; +import "./test/functional/connection/connection.ts"; +import "./test/functional/connection-manager/connection-manager.ts"; +import "./test/functional/connection-options-reader/connection-options-reader.ts"; +import "./test/functional/cube/postgres/cube-postgres.ts"; +import "./test/functional/database-schema/column-collation/cockroach/column-collation-cockroach.ts"; +import "./test/functional/database-schema/column-collation/mssql/column-collation-mssql.ts"; +import "./test/functional/database-schema/column-collation/mysql/column-collation-mysql.ts"; +import "./test/functional/database-schema/column-collation/postgres/column-collation-postgres.ts"; +import "./test/functional/database-schema/column-collation/sqlite/column-collation-sqlite.ts"; +import "./test/functional/database-schema/column-length/mssql/column-length-mssql.ts"; +import "./test/functional/database-schema/column-length/mysql/column-length-mysql.ts"; +import "./test/functional/database-schema/column-length/postgres/column-length-postgres.ts"; +import "./test/functional/database-schema/column-length/sap/column-length-sap.ts"; +import "./test/functional/database-schema/column-length/sqlite/column-length-sqlite.ts"; +import "./test/functional/database-schema/column-types/cockroachdb/column-types-cockroach.ts"; +import "./test/functional/database-schema/column-types/mssql/column-types-mssql.ts"; +import "./test/functional/database-schema/column-types/mysql/column-types-mysql.ts"; +import "./test/functional/database-schema/column-types/oracle/column-types-oracle.ts"; +import "./test/functional/database-schema/column-types/postgres/column-types-postgres.ts"; +import "./test/functional/database-schema/column-types/postgres-enum/postgres-enum.ts"; +import "./test/functional/database-schema/column-types/sap/column-types-sap.ts"; +import "./test/functional/database-schema/column-types/sqlite/column-types-sqlite.ts"; +import "./test/functional/database-schema/column-width/mysql/column-width.ts"; +import "./test/functional/database-schema/enums/enums.ts"; +import "./test/functional/database-schema/enums-array/enums-array.ts"; +import "./test/functional/database-schema/indices/indices-create-modify.ts"; +import "./test/functional/database-schema/mssql-parameters/mssql-parameters.ts"; +import "./test/functional/database-schema/rowid-column/rowid-column.ts"; +import "./test/functional/database-schema/sequences/sequence-create-test.ts"; +import "./test/functional/database-schema/simple-enums/enums.ts"; +import "./test/functional/database-schema/simple-enums-array/enums-array.ts"; +import "./test/functional/decorators/embedded/query-builder-embedded.ts"; +import "./test/functional/decorators/relation-count/relation-count-many-to-many/relation-count-decorator-many-to-many.ts"; +import "./test/functional/decorators/relation-count/relation-count-one-to-many/relation-count-decorator-one-to-many.ts"; +import "./test/functional/decorators/relation-id/relation-id-many-to-many/relation-id-decorator-many-to-many.ts"; +import "./test/functional/decorators/relation-id/relation-id-many-to-one/relation-id-decorator-many-to-one.ts"; +import "./test/functional/decorators/relation-id/relation-id-one-to-many/relation-id-decorator-one-to-many.ts"; +import "./test/functional/decorators/relation-id/relation-id-one-to-one/relation-id-decorator-one-to-one.ts"; +import "./test/functional/deferrable/deferrable.ts"; +import "./test/functional/driver/convert-to-entity/convert-to-entity.ts"; +import "./test/functional/embedded/basic-functionality/basic-functionality.ts"; +import "./test/functional/embedded/embedded-listeners/embedded-listeners.ts"; +import "./test/functional/embedded/embedded-many-to-many-case1/embedded-many-to-many-case1.ts"; +import "./test/functional/embedded/embedded-many-to-many-case2/embedded-many-to-many-case2.ts"; +import "./test/functional/embedded/embedded-many-to-many-case3/embedded-many-to-many-case3.ts"; +import "./test/functional/embedded/embedded-many-to-many-case4/embedded-many-to-many-case4.ts"; +import "./test/functional/embedded/embedded-many-to-many-case5/embedded-many-to-many-case5.ts"; +import "./test/functional/embedded/embedded-many-to-one-case1/embedded-many-to-one-case1.ts"; +import "./test/functional/embedded/embedded-many-to-one-case2/embedded-many-to-one-case2.ts"; +import "./test/functional/embedded/embedded-many-to-one-case3/embedded-many-to-one-case3.ts"; +import "./test/functional/embedded/embedded-many-to-one-case4/embedded-many-to-one-case4.ts"; +import "./test/functional/embedded/embedded-many-to-one-case5/embedded-many-to-one-case5.ts"; +import "./test/functional/embedded/embedded-one-to-one/embedded-one-to-one.ts"; +import "./test/functional/embedded/embedded-with-special-columns/embedded-with-special-columns.ts"; +import "./test/functional/embedded/multiple-primary-columns/multiple-primary-columns.ts"; +import "./test/functional/embedded/multiple-primary-columns-with-nested-embed/multiple-primary-columns-with-nested-embed.ts"; +import "./test/functional/embedded/optional-embedded-listeners/optional-embedded-listeners.ts"; +import "./test/functional/embedded/outer-primary-column/outer-primary-column.ts"; +import "./test/functional/embedded/prefix/embedded-prefix.ts"; +import "./test/functional/entity-listeners/entity-listeners.ts"; +import "./test/functional/entity-metadata-validator/basic/entity-metadata-validator.ts"; +import "./test/functional/entity-metadata-validator/initialized-relations/validator-intialized-relations.ts"; +import "./test/functional/entity-model/entity-model.ts"; +import "./test/functional/entity-schema/basic/entity-schema-basic.ts"; +import "./test/functional/entity-schema/checks/checks-basic.ts"; +import "./test/functional/entity-schema/columns/mysql/columns-mysql.ts"; +import "./test/functional/entity-schema/exclusions/exclusions-basic.ts"; +import "./test/functional/entity-schema/indices/basic/indices-basic.ts"; +import "./test/functional/entity-schema/indices/mysql/indices-mysql.ts"; +import "./test/functional/entity-schema/target/entity-schema-target.ts"; +import "./test/functional/entity-schema/uniques/uniques-basic.ts"; +import "./test/functional/indices/basic-unique-index-test/basic-unique-index-test.ts"; +import "./test/functional/indices/conditional-index/conditional-index.ts"; +import "./test/functional/indices/embeddeds-index-test/embeddeds-unique-index-test.ts"; +import "./test/functional/json/jsonb.ts"; +import "./test/functional/metadata-builder/column-metadata/column-metadata.ts"; +import "./test/functional/metadata-builder/metadata-args-storage/metadata-args-storage.ts"; +import "./test/functional/migrations/show-command/command.ts"; +import "./test/functional/mongodb/basic/array-columns/mongodb-array-columns.ts"; +import "./test/functional/mongodb/basic/embedded-columns/mongodb-embedded-columns.ts"; +import "./test/functional/mongodb/basic/embedded-columns-listeners/mongodb-embedded-columns-listeners.ts"; +import "./test/functional/mongodb/basic/mongo-embeddeds-index/mongo-embeddeds-index.ts"; +import "./test/functional/mongodb/basic/mongo-index/mongo-index.ts"; +import "./test/functional/mongodb/basic/mongo-repository/mongo-repository.ts"; +import "./test/functional/mongodb/basic/object-id/mongodb-object-id.ts"; +import "./test/functional/mongodb/basic/repository-actions/mongodb-repository-actions.ts"; +import "./test/functional/mongodb/basic/timestampable-columns/timestampable-columns.ts"; +import "./test/functional/multi-schema-and-database/custom-junction-database/custom-junction-database.ts"; +import "./test/functional/multi-schema-and-database/custom-junction-schema/custom-junction-schema.ts"; +import "./test/functional/multi-schema-and-database/multi-schema-and-database-basic-functionality/multi-schema-and-database-basic-functionality.ts"; +import "./test/functional/persistence/basic-functionality/persistence-basic-functionality.ts"; +import "./test/functional/persistence/bulk-insert-remove-optimization/bulk-insert-remove-optimization.ts"; +import "./test/functional/persistence/cascades/cascades-example1/cascades-example1.ts"; +import "./test/functional/persistence/cascades/cascades-example2/cascades-example2.ts"; +import "./test/functional/persistence/cascades/cascades-remove/cascades-remove.ts"; +import "./test/functional/persistence/custom-column-name-pk/custom-column-name-pk.ts"; +import "./test/functional/persistence/custom-column-names/persistence-custom-column-names.ts"; +import "./test/functional/persistence/entity-updation/persistence-entity-updation.ts"; +import "./test/functional/persistence/insert/update-relation-columns-after-insertion/update-relation-columns-after-insertion.ts"; +import "./test/functional/persistence/many-to-many/persistence-many-to-many.ts"; +import "./test/functional/persistence/many-to-one-bi-directional/persistence-many-to-one-bi-directional.ts"; +import "./test/functional/persistence/many-to-one-uni-directional/persistence-many-to-one-uni-directional.ts"; +import "./test/functional/persistence/multi-primary-key/multi-primary-key.ts"; +import "./test/functional/persistence/multi-primary-key-on-both-sides/multi-primary-key.ts"; +import "./test/functional/persistence/null-and-default-behaviour/null-and-default-behaviour.ts"; +import "./test/functional/persistence/one-to-many/persistence-one-to-many.ts"; +import "./test/functional/persistence/one-to-one/persistence-one-to-one.ts"; +import "./test/functional/persistence/partial-persist/partial-persist.ts"; +import "./test/functional/persistence/persistence-options/chunks/persistence-options-chunks.ts"; +import "./test/functional/persistence/persistence-options/listeners/persistence-options-listeners.ts"; +import "./test/functional/persistence/persistence-options/transaction/persistence-options-transaction.ts"; +import "./test/functional/persistence/persistence-order/persistence-order.ts"; +import "./test/functional/persistence/remove-topological-order/remove-topolotical-order.ts"; +import "./test/functional/query-builder/brackets/query-builder-brackets.ts"; +import "./test/functional/query-builder/cache/query-builder-cache.ts"; +import "./test/functional/query-builder/delete/query-builder-delete.ts"; +import "./test/functional/query-builder/distinct-on/query-builder-distinct-on.ts"; +import "./test/functional/query-builder/enabling-transaction/enabling-transaction.ts"; +import "./test/functional/query-builder/entity-updation/entity-updation.ts"; +import "./test/functional/query-builder/insert/query-builder-insert.ts"; +import "./test/functional/query-builder/insert-on-conflict/query-builder-insert-on-conflict.ts"; +import "./test/functional/query-builder/join/query-builder-joins.ts"; +import "./test/functional/query-builder/locking/query-builder-locking.ts"; +import "./test/functional/query-builder/order-by/query-builder-order-by.ts"; +import "./test/functional/query-builder/relation-count/relation-count-many-to-many/load-relation-count-and-map-many-to-many.ts"; +import "./test/functional/query-builder/relation-count/relation-count-one-to-many/load-relation-count-and-map-one-to-many.ts"; +import "./test/functional/query-builder/relation-id/many-to-many/basic-functionality/basic-functionality.ts"; +import "./test/functional/query-builder/relation-id/many-to-many/embedded/embedded.ts"; +import "./test/functional/query-builder/relation-id/many-to-many/embedded-with-multiple-pk/embedded-with-multiple-pk.ts"; +import "./test/functional/query-builder/relation-id/many-to-many/multiple-pk/multiple-pk.ts"; +import "./test/functional/query-builder/relation-id/many-to-one/basic-functionality/basic-functionality.ts"; +import "./test/functional/query-builder/relation-id/many-to-one/embedded/embedded.ts"; +import "./test/functional/query-builder/relation-id/many-to-one/embedded-with-multiple-pk/embedded-with-multiple-pk.ts"; +import "./test/functional/query-builder/relation-id/many-to-many/multiple-pk/multiple-pk.ts"; +import "./test/functional/query-builder/relation-id/one-to-many/basic-functionality/basic-functionality.ts"; +import "./test/functional/query-builder/relation-id/one-to-many/embedded/embedded.ts"; +import "./test/functional/query-builder/relation-id/one-to-many/embedded-with-multiple-pk/embedded-with-multiple-pk.ts"; +import "./test/functional/query-builder/relation-id/one-to-many/multiple-pk/multiple-pk.ts"; +import "./test/functional/query-builder/relation-id/one-to-one/basic-functionality/basic-functionality.ts"; +import "./test/functional/query-builder/relation-id/one-to-one/embedded/embedded.ts"; +import "./test/functional/query-builder/relation-id/one-to-one/embedded-with-multiple-pk/embedded-with-multiple-pk.ts"; +import "./test/functional/query-builder/relation-id/one-to-one/multiple-pk/multiple-pk.ts"; +import "./test/functional/query-builder/relational/with-many/query-builder-relational-add-remove-many-to-many-inverse.ts"; +import "./test/functional/query-builder/relational/with-many/query-builder-relational-add-remove-many-to-many.ts"; +import "./test/functional/query-builder/relational/with-many/query-builder-relational-add-remove-one-to-many.ts"; +import "./test/functional/query-builder/relational/with-many/query-builder-relational-load-many.ts"; +import "./test/functional/query-builder/relational/with-one/query-builder-relational-load-one.ts"; +import "./test/functional/query-builder/relational/with-one/query-builder-relational-set-many-to-one.ts"; +import "./test/functional/query-builder/relational/with-one/query-builder-relational-set-one-to-one-inverse.ts"; +import "./test/functional/query-builder/relational/with-one/query-builder-relational-set-one-to-one.ts"; +import "./test/functional/query-builder/select/query-builder-select.ts"; +import "./test/functional/query-builder/subquery/query-builder-subquery.ts"; +import "./test/functional/query-builder/update/query-builder-update.ts"; +import "./test/functional/query-runner/add-column.ts"; +import "./test/functional/query-runner/change-column.ts"; +import "./test/functional/query-runner/create-and-drop-database.ts"; +import "./test/functional/query-runner/create-and-drop-schema.ts"; +import "./test/functional/query-runner/create-check-constraint.ts"; +import "./test/functional/query-runner/create-exclusion-constraint.ts"; +import "./test/functional/query-runner/create-foreign-key.ts"; +import "./test/functional/query-runner/create-index.ts"; +import "./test/functional/query-runner/create-primary-key.ts"; +import "./test/functional/query-runner/create-table.ts"; +import "./test/functional/query-runner/create-unique-constraint.ts"; +import "./test/functional/query-runner/drop-check-constraint.ts"; +import "./test/functional/query-runner/drop-column.ts"; +import "./test/functional/query-runner/drop-exclusion-constraint.ts"; +import "./test/functional/query-runner/drop-foreign-key.ts"; +import "./test/functional/query-runner/drop-index.ts"; +import "./test/functional/query-runner/drop-primary-key.ts"; +import "./test/functional/query-runner/drop-table.ts"; +import "./test/functional/query-runner/drop-unique-constraint.ts"; +import "./test/functional/query-runner/rename-column.ts"; +import "./test/functional/query-runner/rename-table.ts"; +import "./test/functional/relations/custom-referenced-column-name/custom-referenced-column-name.ts"; +import "./test/functional/relations/eager-relations/basic-eager-relations/basic-eager-relations.ts"; +import "./test/functional/relations/eager-relations/circular-eager-relations/circular-eager-relations.ts"; +import "./test/functional/relations/lazy-relations/basic-lazy-relation/basic-lazy-relations.ts"; +import "./test/functional/relations/lazy-relations/named-columns/named-columns-lazy-relations.ts"; +import "./test/functional/relations/lazy-relations/named-tables/named-tables-lazy-relations.ts"; +import "./test/functional/relations/lazy-relations/named-tables-and-columns/named-tables-and-columns-lazy-relations.ts"; +import "./test/functional/relations/multiple-primary-keys/multiple-primary-keys-many-to-many/multiple-primary-keys-many-to-many.ts"; +import "./test/functional/relations/multiple-primary-keys/multiple-primary-keys-many-to-one/multiple-primary-keys-many-to-one.ts"; +import "./test/functional/relations/multiple-primary-keys/multiple-primary-keys-one-to-one/multiple-primary-keys-one-to-one.ts"; +import "./test/functional/relations/multiple-primary-keys/multiple-primary-keys-other-cases/multiple-primary-keys-other-cases.ts"; +import "./test/functional/relations/relation-mapped-to-different-name-column/relation-mapped-to-different-name-column.ts"; +import "./test/functional/relations/relation-with-primary-key/relation-with-primary-key.ts"; +import "./test/functional/repository/basic-methods/repository-basic-methods.ts"; +import "./test/functional/repository/clear/repository-clear.ts"; +import "./test/functional/repository/decrement/repository-decrement.ts"; +import "./test/functional/repository/delete-by-id-and-ids/repository-remove-by-id-and-ids.ts"; +import "./test/functional/repository/find-methods/repostiory-find-methods.ts"; +import "./test/functional/repository/find-options/repository-find-options.ts"; +import "./test/functional/repository/find-options-locking/find-options-locking.ts"; +import "./test/functional/repository/find-options-operators/repository-find-operators.ts"; +import "./test/functional/repository/find-options-relations/repository-find-options-relations.ts"; +import "./test/functional/repository/increment/repository-increment.ts"; +import "./test/functional/repository/set-add-remove-relations/repository-set-add-remove-relations.ts"; +import "./test/functional/schema-builder/add-column.ts"; +import "./test/functional/schema-builder/change-check-constraint.ts"; +import "./test/functional/schema-builder/change-column.ts"; +import "./test/functional/schema-builder/change-exclusion-constraint.ts"; +import "./test/functional/schema-builder/change-index.ts"; +import "./test/functional/schema-builder/change-unique-constraint.ts"; +import "./test/functional/schema-builder/create-foreign-key.ts"; +import "./test/functional/schema-builder/create-table.ts"; +import "./test/functional/schema-builder/custom-db-and-schema-sync.ts"; +import "./test/functional/schema-builder/drop-column.ts"; +import "./test/functional/schema-builder/update-primary-keys.ts"; +import "./test/functional/spatial/postgres/spatial-postgres.ts"; +import "./test/functional/sqljs/auto-save.ts"; +import "./test/functional/sqljs/load.ts"; +import "./test/functional/sqljs/save.ts"; +import "./test/functional/sqljs/startup.ts"; +import "./test/functional/table-inheritance/extending/extending-inheritance.ts"; +import "./test/functional/table-inheritance/single-table/basic-functionality/basic-functionality.ts"; +import "./test/functional/table-inheritance/single-table/database-option-inherited/database-option-inherited.ts"; +import "./test/functional/table-inheritance/single-table/non-virtual-discriminator-column/non-virtual-discriminator-column.ts"; +import "./test/functional/table-inheritance/single-table/relations/many-to-many/many-to-many.ts"; +import "./test/functional/table-inheritance/single-table/relations/one-to-many/one-to-many.ts"; +import "./test/functional/transaction/database-specific-isolation/full-isolation-support.ts"; +import "./test/functional/transaction/database-specific-isolation/oracle-isolation.ts"; +import "./test/functional/transaction/database-specific-isolation/sqlite-isolation.ts"; +import "./test/functional/transaction/return-data-from-transaction/return-data-from-transaction.ts"; +import "./test/functional/transaction/single-query-runner/single-query-runner.ts"; +import "./test/functional/transaction/transaction-decorator/transaction-decorator.ts"; +import "./test/functional/transaction/transaction-in-entity-manager/transaction-in-entity-manager.ts"; +import "./test/functional/tree-tables/closure-table/closure-table.ts"; +import "./test/functional/tree-tables/materialized-path/materialized-path.ts"; +import "./test/functional/tree-tables/nested-set/nested-set.ts"; +import "./test/functional/uuid/cockroach/uuid-cockroach.ts"; +import "./test/functional/uuid/mssql/uuid-mssql.ts"; +import "./test/functional/uuid/mysql/uuid-mysql.ts"; +import "./test/functional/uuid/oracle/uuid-oracle.ts"; +import "./test/functional/uuid/postgres/pgcrypto.ts"; +import "./test/functional/uuid/postgres/uuid-ossp.ts"; +import "./test/functional/uuid/sap/uuid-sap.ts"; +import "./test/functional/uuid/sqlite/uuid-sqlite.ts"; +import "./test/functional/view-entity/general/view-entity-general.ts"; +import "./test/functional/view-entity/mssql/view-entity-mssql.ts"; +import "./test/functional/view-entity/mysql/view-entity-mysql.ts"; +import "./test/functional/view-entity/oracle/view-entity-oracle.ts"; +import "./test/functional/view-entity/postgres/view-entity-postgres.ts"; +import "./test/functional/view-entity/sqlite/view-entity-sqlite.ts"; runTests(); diff --git a/test/deps/mocha.ts b/test/deps/mocha.ts index 6fb2109c4..bcc52ea77 100644 --- a/test/deps/mocha.ts +++ b/test/deps/mocha.ts @@ -3,11 +3,21 @@ import "https://unpkg.com/mocha@7.0.0/mocha.js"; mocha.setup({ ui: 'bdd', reporter: 'spec' }); export function runTests(): void { - mocha.run(); + mocha.run(onCompleted); } export function runIfMain(meta: ImportMeta): void { if (meta.main) { - mocha.run(); + mocha.run(onCompleted); + } +} + +mocha.timeout(60000); + +function onCompleted(failures: number): void { + if (failures > 0) { + Deno.exit(1); + } else { + Deno.exit(0); } } diff --git a/test/functional/cascades/cascade-insert-from-both-sides/cascade-insert-from-both-sides.ts b/test/functional/cascades/cascade-insert-from-both-sides/cascade-insert-from-both-sides.ts index c67cb1f06..444f4b6d0 100644 --- a/test/functional/cascades/cascade-insert-from-both-sides/cascade-insert-from-both-sides.ts +++ b/test/functional/cascades/cascade-insert-from-both-sides/cascade-insert-from-both-sides.ts @@ -1,14 +1,17 @@ -import "reflect-metadata"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils"; -import {Connection} from "../../../../src/connection/Connection"; -import {Post} from "./entity/Post"; -import {PostDetails} from "./entity/PostDetails"; +import {runIfMain} from "../../../deps/mocha.ts"; +import {expect} from "../../../deps/chai.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils.ts"; +import {Connection} from "../../../../src/connection/Connection.ts"; +import {Post} from "./entity/Post.ts"; +import {PostDetails} from "./entity/PostDetails.ts"; +import {join} from "../../../../vendor/https/deno.land/std/path/mod.ts" describe("cascades > should insert by cascades from both sides (#57)", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [join(__dirname, "/entity/*.ts")] })); beforeEach(() => reloadTestingDatabases(connections)); after(() => closeTestingConnections(connections)); @@ -35,7 +38,7 @@ describe("cascades > should insert by cascades from both sides (#57)", () => { } }); - posts.should.be.eql([{ + expect(posts).to.eql([{ key: post1.key, title: post1.title, details: { @@ -46,3 +49,5 @@ describe("cascades > should insert by cascades from both sides (#57)", () => { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/cascades/cascade-insert-from-both-sides/entity/Post.ts b/test/functional/cascades/cascade-insert-from-both-sides/entity/Post.ts index a755bbd4f..e314bbba0 100644 --- a/test/functional/cascades/cascade-insert-from-both-sides/entity/Post.ts +++ b/test/functional/cascades/cascade-insert-from-both-sides/entity/Post.ts @@ -1,9 +1,9 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {PostDetails} from "./PostDetails"; -import {OneToOne} from "../../../../../src/decorator/relations/OneToOne"; -import {JoinColumn} from "../../../../../src/decorator/relations/JoinColumn"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {PostDetails} from "./PostDetails.ts"; +import {OneToOne} from "../../../../../src/decorator/relations/OneToOne.ts"; +import {JoinColumn} from "../../../../../src/decorator/relations/JoinColumn.ts"; @Entity() export class Post { @@ -17,7 +17,7 @@ export class Post { @JoinColumn() details: PostDetails; - @Column() + @Column({ type: String }) title: string; -} \ No newline at end of file +} diff --git a/test/functional/cascades/cascade-insert-from-both-sides/entity/PostDetails.ts b/test/functional/cascades/cascade-insert-from-both-sides/entity/PostDetails.ts index 395dc9953..b85d0f0ec 100644 --- a/test/functional/cascades/cascade-insert-from-both-sides/entity/PostDetails.ts +++ b/test/functional/cascades/cascade-insert-from-both-sides/entity/PostDetails.ts @@ -1,12 +1,12 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn"; -import {Post} from "./Post"; -import {OneToOne} from "../../../../../src/decorator/relations/OneToOne"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn.ts"; +import {Post} from "./Post.ts"; +import {OneToOne} from "../../../../../src/decorator/relations/OneToOne.ts"; @Entity() export class PostDetails { - @PrimaryColumn() + @PrimaryColumn({ type: String }) keyword: string; @OneToOne(type => Post, post => post.details, { @@ -14,4 +14,4 @@ export class PostDetails { }) post: Post; -} \ No newline at end of file +} diff --git a/test/functional/columns/embedded-columns/columns-embedded-columns.ts b/test/functional/columns/embedded-columns/columns-embedded-columns.ts index 4aa470f30..9d4e117e1 100644 --- a/test/functional/columns/embedded-columns/columns-embedded-columns.ts +++ b/test/functional/columns/embedded-columns/columns-embedded-columns.ts @@ -1,17 +1,19 @@ -import "reflect-metadata"; -import {expect} from "chai"; -import {Connection} from "../../../../src/connection/Connection"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils"; -import {SimplePost} from "./entity/SimplePost"; -import {SimpleCounters} from "./entity/SimpleCounters"; -import {Information} from "./entity/Information"; -import {Post} from "./entity/Post"; +import {expect} from "../../../deps/chai.ts"; +import {runIfMain} from "../../../deps/mocha.ts"; +import {Connection} from "../../../../src/connection/Connection.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils.ts"; +import {join as joinPaths} from "../../../../vendor/https/deno.land/std/path/mod.ts"; +import {SimplePost} from "./entity/SimplePost.ts"; +import {SimpleCounters} from "./entity/SimpleCounters.ts"; +import {Information} from "./entity/Information.ts"; +import {Post} from "./entity/Post.ts"; describe("columns > embedded columns", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], })); beforeEach(() => reloadTestingDatabases(connections)); after(() => closeTestingConnections(connections)); @@ -132,3 +134,5 @@ describe("columns > embedded columns", () => { ]); }))); }); + +runIfMain(import.meta); diff --git a/test/functional/columns/embedded-columns/entity/Counters.ts b/test/functional/columns/embedded-columns/entity/Counters.ts index 9ed2a3302..e3d423569 100644 --- a/test/functional/columns/embedded-columns/entity/Counters.ts +++ b/test/functional/columns/embedded-columns/entity/Counters.ts @@ -1,14 +1,14 @@ -import { Column } from "../../../../../src/decorator/columns/Column"; -import { Information } from "./Information"; +import { Column } from "../../../../../src/decorator/columns/Column.ts"; +import { Information } from "./Information.ts"; export class Counters { - @Column() + @Column({ type: Number }) likes: number; - @Column() + @Column({ type: Number }) comments: number; - @Column() + @Column({ type: Number }) favorites: number; @Column(type => Information, { prefix: "info" }) diff --git a/test/functional/columns/embedded-columns/entity/Information.ts b/test/functional/columns/embedded-columns/entity/Information.ts index 340689c7a..53d3a72ff 100644 --- a/test/functional/columns/embedded-columns/entity/Information.ts +++ b/test/functional/columns/embedded-columns/entity/Information.ts @@ -1,7 +1,7 @@ -import { Column } from "../../../../../src/decorator/columns/Column"; +import { Column } from "../../../../../src/decorator/columns/Column.ts"; export class Information { - @Column({ name: "descr" }) + @Column({ name: "descr", type: String }) description: string; } diff --git a/test/functional/columns/embedded-columns/entity/Post.ts b/test/functional/columns/embedded-columns/entity/Post.ts index 6f31401d3..4520a82c3 100644 --- a/test/functional/columns/embedded-columns/entity/Post.ts +++ b/test/functional/columns/embedded-columns/entity/Post.ts @@ -1,7 +1,7 @@ -import { Entity } from "../../../../../src/decorator/entity/Entity"; -import { Column } from "../../../../../src/decorator/columns/Column"; -import { PrimaryGeneratedColumn } from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import { Counters } from "./Counters"; +import { Entity } from "../../../../../src/decorator/entity/Entity.ts"; +import { Column } from "../../../../../src/decorator/columns/Column.ts"; +import { PrimaryGeneratedColumn } from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import { Counters } from "./Counters.ts"; @Entity() export class Post { @@ -9,10 +9,10 @@ export class Post { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) title: string; - @Column() + @Column({ type: String }) text: string; @Column(type => Counters) diff --git a/test/functional/columns/embedded-columns/entity/SimpleCounters.ts b/test/functional/columns/embedded-columns/entity/SimpleCounters.ts index b691b7172..71e4919e6 100644 --- a/test/functional/columns/embedded-columns/entity/SimpleCounters.ts +++ b/test/functional/columns/embedded-columns/entity/SimpleCounters.ts @@ -1,15 +1,15 @@ -import { Column } from "../../../../../src/decorator/columns/Column"; -import { Information } from "./Information"; +import { Column } from "../../../../../src/decorator/columns/Column.ts"; +import { Information } from "./Information.ts"; export class SimpleCounters { - @Column() + @Column({ type: Number }) likes: number; - @Column() + @Column({ type: Number }) comments: number; - @Column() + @Column({ type: Number }) favorites: number; @Column(type => Information, { prefix: "info" }) diff --git a/test/functional/columns/embedded-columns/entity/SimplePost.ts b/test/functional/columns/embedded-columns/entity/SimplePost.ts index 41a257414..895ce018f 100644 --- a/test/functional/columns/embedded-columns/entity/SimplePost.ts +++ b/test/functional/columns/embedded-columns/entity/SimplePost.ts @@ -1,7 +1,7 @@ -import { Entity } from "../../../../../src/decorator/entity/Entity"; -import { Column } from "../../../../../src/decorator/columns/Column"; -import { PrimaryGeneratedColumn } from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import { SimpleCounters } from "./SimpleCounters"; +import { Entity } from "../../../../../src/decorator/entity/Entity.ts"; +import { Column } from "../../../../../src/decorator/columns/Column.ts"; +import { PrimaryGeneratedColumn } from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import { SimpleCounters } from "./SimpleCounters.ts"; @Entity() export class SimplePost { @@ -9,10 +9,10 @@ export class SimplePost { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) title: string; - @Column() + @Column({ type: String }) text: string; @Column(type => SimpleCounters) diff --git a/test/functional/columns/getters-setters/columns-getters-setters.ts b/test/functional/columns/getters-setters/columns-getters-setters.ts index 2c477e721..506c11bc6 100644 --- a/test/functional/columns/getters-setters/columns-getters-setters.ts +++ b/test/functional/columns/getters-setters/columns-getters-setters.ts @@ -1,8 +1,8 @@ -import "reflect-metadata"; -import {expect} from "chai"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils"; -import {Connection} from "../../../../src/connection/Connection"; -import {Post} from "./entity/Post"; +import {runIfMain} from "../../../deps/mocha.ts"; +import {expect} from "../../../deps/chai.ts"; +import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils.ts"; +import {Connection} from "../../../../src/connection/Connection.ts"; +import {Post} from "./entity/Post.ts"; describe("columns > getters and setters", () => { @@ -34,3 +34,5 @@ describe("columns > getters and setters", () => { }); + +runIfMain(import.meta); diff --git a/test/functional/columns/getters-setters/entity/Post.ts b/test/functional/columns/getters-setters/entity/Post.ts index df050a2e0..ffb4532ef 100644 --- a/test/functional/columns/getters-setters/entity/Post.ts +++ b/test/functional/columns/getters-setters/entity/Post.ts @@ -1,6 +1,6 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; @Entity() export class Post { @@ -19,9 +19,9 @@ export class Post { } } - @Column() + @Column({ type: String }) get title(): string { return this._title; } -} \ No newline at end of file +} diff --git a/test/functional/columns/no-select/columns-no-select.ts b/test/functional/columns/no-select/columns-no-select.ts index 24058d219..9dbd9242b 100644 --- a/test/functional/columns/no-select/columns-no-select.ts +++ b/test/functional/columns/no-select/columns-no-select.ts @@ -1,8 +1,8 @@ -import "reflect-metadata"; -import {expect} from "chai"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils"; -import {Connection} from "../../../../src/connection/Connection"; -import {Post} from "./entity/Post"; +import {runIfMain} from "../../../deps/mocha.ts"; +import {expect} from "../../../deps/chai.ts"; +import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils.ts"; +import {Connection} from "../../../../src/connection/Connection.ts"; +import {Post} from "./entity/Post.ts"; describe("columns > no-selection functionality", () => { @@ -72,3 +72,5 @@ describe("columns > no-selection functionality", () => { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/columns/no-select/entity/Post.ts b/test/functional/columns/no-select/entity/Post.ts index 32e73d8bf..1a0db0a58 100644 --- a/test/functional/columns/no-select/entity/Post.ts +++ b/test/functional/columns/no-select/entity/Post.ts @@ -1,6 +1,6 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; @Entity() export class Post { @@ -8,13 +8,13 @@ export class Post { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) title: string; - @Column() + @Column({ type: String }) text: string; - @Column({ select: false }) + @Column({ type: String, select: false }) authorName: string; -} \ No newline at end of file +} diff --git a/test/functional/columns/readonly/columns-readonly.ts b/test/functional/columns/readonly/columns-readonly.ts index 73de9bf9d..c63e1ac6a 100644 --- a/test/functional/columns/readonly/columns-readonly.ts +++ b/test/functional/columns/readonly/columns-readonly.ts @@ -1,8 +1,8 @@ -import {expect} from "chai"; -import "reflect-metadata"; -import {Connection} from "../../../../src"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils"; -import {Post} from "./entity/Post"; +import {runIfMain} from "../../../deps/mocha.ts"; +import {expect} from "../../../deps/chai.ts"; +import {Connection} from "../../../../src/index.ts"; +import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils.ts"; +import {Post} from "./entity/Post.ts"; describe("columns > readonly functionality", () => { @@ -40,3 +40,5 @@ describe("columns > readonly functionality", () => { }); + +runIfMain(import.meta); diff --git a/test/functional/columns/readonly/entity/Post.ts b/test/functional/columns/readonly/entity/Post.ts index bf886c752..876dfa3f2 100644 --- a/test/functional/columns/readonly/entity/Post.ts +++ b/test/functional/columns/readonly/entity/Post.ts @@ -1,6 +1,6 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; @Entity() export class Post { @@ -8,13 +8,13 @@ export class Post { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) title: string; - @Column() + @Column({ type: String }) text: string; - @Column({ readonly: true }) + @Column({ readonly: true, type: String }) authorName: string; -} \ No newline at end of file +} diff --git a/test/functional/columns/update-insert/columns-update-insert.ts b/test/functional/columns/update-insert/columns-update-insert.ts index 556a9e55a..da560d4cd 100644 --- a/test/functional/columns/update-insert/columns-update-insert.ts +++ b/test/functional/columns/update-insert/columns-update-insert.ts @@ -1,8 +1,8 @@ -import "reflect-metadata"; -import {expect} from "chai"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils"; -import {Connection} from "../../../../src/connection/Connection"; -import {Post} from "./entity/Post"; +import {runIfMain} from "../../../deps/mocha.ts"; +import {expect} from "../../../deps/chai.ts"; +import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils.ts"; +import {Connection} from "../../../../src/connection/Connection.ts"; +import {Post} from "./entity/Post.ts"; describe("columns > update and insert control", () => { @@ -51,3 +51,5 @@ describe("columns > update and insert control", () => { expect(loadedPost!.authorLastName).to.be.equal("Default"); // update blocked }))); }); + +runIfMain(import.meta); diff --git a/test/functional/columns/update-insert/entity/Post.ts b/test/functional/columns/update-insert/entity/Post.ts index 9dce58286..0c272d318 100644 --- a/test/functional/columns/update-insert/entity/Post.ts +++ b/test/functional/columns/update-insert/entity/Post.ts @@ -1,6 +1,6 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; @Entity() export class Post { @@ -8,18 +8,18 @@ export class Post { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) title: string; - @Column() + @Column({ type: String }) text: string; - @Column({ update: false, default: "Default" }) + @Column({ type: String, update: false, default: "Default" }) authorFirstName: string; - @Column({ insert: false, default: "Default" }) + @Column({ type: String, insert: false, default: "Default" }) authorMiddleName: string; - @Column({ insert: false, update: false, default: "Default" }) + @Column({ type: String, insert: false, update: false, default: "Default" }) authorLastName: string; } diff --git a/test/functional/columns/value-transformer/entity/Category.ts b/test/functional/columns/value-transformer/entity/Category.ts index 3e63a29db..b0121f83a 100644 --- a/test/functional/columns/value-transformer/entity/Category.ts +++ b/test/functional/columns/value-transformer/entity/Category.ts @@ -1,7 +1,7 @@ -import { Column, ValueTransformer, Entity, PrimaryGeneratedColumn } from "../../../../../src"; -import { lowercase, encrypt } from "./User"; +import { Column, ValueTransformer, Entity, PrimaryGeneratedColumn } from "../../../../../src/index.ts"; +import { lowercase, encrypt } from "./User.ts"; -const trim: ValueTransformer = { +const trim: ValueTransformer = { to: (entityValue: string) => { return entityValue.trim(); }, @@ -15,6 +15,6 @@ export class Category { @PrimaryGeneratedColumn("uuid") id: string; - @Column({transformer: [lowercase, trim, encrypt]}) + @Column({type: String, transformer: [lowercase, trim, encrypt]}) description: string; -} \ No newline at end of file +} diff --git a/test/functional/columns/value-transformer/entity/PhoneBook.ts b/test/functional/columns/value-transformer/entity/PhoneBook.ts index 6bb248214..099bda853 100644 --- a/test/functional/columns/value-transformer/entity/PhoneBook.ts +++ b/test/functional/columns/value-transformer/entity/PhoneBook.ts @@ -1,7 +1,7 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {ValueTransformer} from "../../../../../src/decorator/options/ValueTransformer"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {ValueTransformer} from "../../../../../src/decorator/options/ValueTransformer.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; class PhonesTransformer implements ValueTransformer { @@ -22,10 +22,10 @@ export class PhoneBook { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) name: string; @Column({ type: String, transformer: new PhonesTransformer() }) phones: Map; -} \ No newline at end of file +} diff --git a/test/functional/columns/value-transformer/entity/Post.ts b/test/functional/columns/value-transformer/entity/Post.ts index 5077452d6..ae69be2a3 100644 --- a/test/functional/columns/value-transformer/entity/Post.ts +++ b/test/functional/columns/value-transformer/entity/Post.ts @@ -1,7 +1,7 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {ValueTransformer} from "../../../../../src/decorator/options/ValueTransformer"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {ValueTransformer} from "../../../../../src/decorator/options/ValueTransformer.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; class TagTransformer implements ValueTransformer { @@ -21,7 +21,7 @@ export class Post { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) title: string; @Column({ type: String, transformer: new TagTransformer() }) diff --git a/test/functional/columns/value-transformer/entity/User.ts b/test/functional/columns/value-transformer/entity/User.ts index 9d448a8b7..f625bbaea 100644 --- a/test/functional/columns/value-transformer/entity/User.ts +++ b/test/functional/columns/value-transformer/entity/User.ts @@ -1,4 +1,5 @@ -import { Column, ValueTransformer, Entity, PrimaryGeneratedColumn } from "../../../../../src"; +import { Column, ValueTransformer, Entity, PrimaryGeneratedColumn } from "../../../../../src/index.ts"; +import { PlatformTools } from "../../../../../src/platform/PlatformTools.ts"; const encode: ValueTransformer = { to: (entityValue: string) => { @@ -11,10 +12,10 @@ const encode: ValueTransformer = { export const encrypt: ValueTransformer = { to: (entityValue: string) => { - return Buffer.from(entityValue).toString("base64"); + return PlatformTools.encodeToBase64(entityValue); }, from: (databaseValue: string) => { - return Buffer.from(databaseValue, "base64").toString(); + return PlatformTools.decodeFromBase64(databaseValue); }, }; @@ -33,6 +34,6 @@ export class User { @PrimaryGeneratedColumn("uuid") id: string; - @Column({transformer: [lowercase, encode, encrypt]}) + @Column({type: String, transformer: [lowercase, encode, encrypt]}) email: string; -} \ No newline at end of file +} diff --git a/test/functional/columns/value-transformer/entity/View.ts b/test/functional/columns/value-transformer/entity/View.ts index 9ed51baf2..0003200a2 100644 --- a/test/functional/columns/value-transformer/entity/View.ts +++ b/test/functional/columns/value-transformer/entity/View.ts @@ -1,10 +1,10 @@ -import { Entity, PrimaryGeneratedColumn, Column } from "../../../../../src"; +import { Entity, PrimaryGeneratedColumn, Column } from "../../../../../src/index.ts"; @Entity() export class View { @PrimaryGeneratedColumn("uuid") id: string; - @Column({transformer: []}) + @Column({type: String, transformer: []}) title: string; -} \ No newline at end of file +} diff --git a/test/functional/columns/value-transformer/value-transformer.ts b/test/functional/columns/value-transformer/value-transformer.ts index 02f5d49bc..ed29a248b 100644 --- a/test/functional/columns/value-transformer/value-transformer.ts +++ b/test/functional/columns/value-transformer/value-transformer.ts @@ -1,14 +1,12 @@ -import "reflect-metadata"; - -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils"; - -import {Connection} from "../../../../src/connection/Connection"; -import {PhoneBook} from "./entity/PhoneBook"; -import {Post} from "./entity/Post"; -import {User} from "./entity/User"; -importĀ {Category} from "./entity/Category"; -import {View} from "./entity/View"; -import {expect} from "chai"; +import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils.ts"; +import {Connection} from "../../../../src/connection/Connection.ts"; +import {PhoneBook} from "./entity/PhoneBook.ts"; +import {Post} from "./entity/Post.ts"; +import {User} from "./entity/User.ts"; +importĀ {Category} from "./entity/Category.ts"; +import {View} from "./entity/View.ts"; +import {expect} from "../../../deps/chai.ts"; +import {runIfMain} from "../../../deps/mocha.ts"; describe("columns > value-transformer functionality", () => { @@ -96,3 +94,5 @@ describe("columns > value-transformer functionality", () => { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/connection-manager/connection-manager.ts b/test/functional/connection-manager/connection-manager.ts index 6cd86c9d4..36f45d7bc 100644 --- a/test/functional/connection-manager/connection-manager.ts +++ b/test/functional/connection-manager/connection-manager.ts @@ -1,11 +1,11 @@ -import "reflect-metadata"; -import {expect} from "chai"; -import {setupSingleTestingConnection} from "../../utils/test-utils"; -import {ConnectionManager} from "../../../src/connection/ConnectionManager"; -import {MysqlDriver} from "../../../src/driver/mysql/MysqlDriver"; -import {PrimaryGeneratedColumn} from "../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../src/decorator/columns/Column"; -import {Entity} from "../../../src/decorator/entity/Entity"; +import {runIfMain} from "../../deps/mocha.ts"; +import {expect} from "../../deps/chai.ts"; +import {setupSingleTestingConnection} from "../../utils/test-utils.ts"; +import {ConnectionManager} from "../../../src/connection/ConnectionManager.ts"; +import {MysqlDriver} from "../../../src/driver/mysql/MysqlDriver.ts"; +import {PrimaryGeneratedColumn} from "../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../src/decorator/columns/Column.ts"; +import {Entity} from "../../../src/decorator/entity/Entity.ts"; describe("ConnectionManager", () => { @@ -15,7 +15,7 @@ describe("ConnectionManager", () => { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) title: string; constructor(id: number, title: string) { @@ -215,3 +215,5 @@ describe("ConnectionManager", () => { }); }); + +runIfMain(import.meta); diff --git a/test/functional/connection-options-reader/configs/class-entities.ts b/test/functional/connection-options-reader/configs/class-entities.ts index ce86873e9..103ad44a0 100644 --- a/test/functional/connection-options-reader/configs/class-entities.ts +++ b/test/functional/connection-options-reader/configs/class-entities.ts @@ -1,6 +1,6 @@ -import {PrimaryGeneratedColumn} from "../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../src/decorator/columns/Column"; -import {Entity} from "../../../../src/decorator/entity/Entity"; +import {PrimaryGeneratedColumn} from "../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../src/decorator/columns/Column.ts"; +import {Entity} from "../../../../src/decorator/entity/Entity.ts"; @Entity() export class Post { @@ -8,7 +8,7 @@ export class Post { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) title: string; constructor(id: number, title: string) { @@ -17,7 +17,7 @@ export class Post { } } -module.exports = { +export default { type: "mysql", name: "test-conn", host: "localhost", @@ -27,4 +27,4 @@ module.exports = { database: "test", logging: false, entities: [Post], -}; \ No newline at end of file +}; diff --git a/test/functional/connection-options-reader/configs/sqlite-memory.ts b/test/functional/connection-options-reader/configs/sqlite-memory.ts index 243dd45ce..048ee4619 100644 --- a/test/functional/connection-options-reader/configs/sqlite-memory.ts +++ b/test/functional/connection-options-reader/configs/sqlite-memory.ts @@ -1,4 +1,4 @@ -module.exports = [{ +export default [{ type: "sqlite", name: "file", database: "test" @@ -6,4 +6,4 @@ module.exports = [{ type: "sqlite", name: "memory", database: ":memory:", -}]; \ No newline at end of file +}]; diff --git a/test/functional/connection-options-reader/configs/test-path-config-async.ts b/test/functional/connection-options-reader/configs/test-path-config-async.js similarity index 62% rename from test/functional/connection-options-reader/configs/test-path-config-async.ts rename to test/functional/connection-options-reader/configs/test-path-config-async.js index 423bf9fab..36aa9fb9f 100644 --- a/test/functional/connection-options-reader/configs/test-path-config-async.ts +++ b/test/functional/connection-options-reader/configs/test-path-config-async.js @@ -1,5 +1,5 @@ -module.exports = Promise.resolve({ +export default Promise.resolve({ type: "sqlite", name: "file", database: "test-js-async" -}); \ No newline at end of file +}); diff --git a/test/functional/connection-options-reader/configs/test-path-config.ts b/test/functional/connection-options-reader/configs/test-path-config.js similarity index 70% rename from test/functional/connection-options-reader/configs/test-path-config.ts rename to test/functional/connection-options-reader/configs/test-path-config.js index fa93cc8b9..27495c202 100644 --- a/test/functional/connection-options-reader/configs/test-path-config.ts +++ b/test/functional/connection-options-reader/configs/test-path-config.js @@ -1,5 +1,5 @@ -module.exports = [{ +export default [{ type: "sqlite", name: "file", database: "test-js" -}]; \ No newline at end of file +}]; diff --git a/test/functional/connection-options-reader/connection-options-reader.ts b/test/functional/connection-options-reader/connection-options-reader.ts index fae1bf881..435309b93 100644 --- a/test/functional/connection-options-reader/connection-options-reader.ts +++ b/test/functional/connection-options-reader/connection-options-reader.ts @@ -1,14 +1,17 @@ -import {expect} from "chai"; -import {ConnectionOptions} from "../../../src/connection/ConnectionOptions"; -import {ConnectionOptionsReader} from "../../../src/connection/ConnectionOptionsReader"; +import {runIfMain} from "../../deps/mocha.ts"; +import {expect} from "../../deps/chai.ts"; +import {getDirnameOfCurrentModule} from "../../utils/test-utils.ts"; +import {ConnectionOptions} from "../../../src/connection/ConnectionOptions.ts"; +import {ConnectionOptionsReader} from "../../../src/connection/ConnectionOptionsReader.ts"; describe("ConnectionOptionsReader", () => { + const __dirname = getDirnameOfCurrentModule(import.meta); after(() => { - delete process.env.TYPEORM_CONNECTION; - delete process.env.TYPEORM_DATABASE; + delete Deno.env().TYPEORM_CONNECTION; + delete Deno.env().TYPEORM_DATABASE; }); - it("properly loads config with entities specified", async () => { + it("properly loads config with entities specified", async function() { type EntititesList = Function[] | string[]; const connectionOptionsReader = new ConnectionOptionsReader({ root: __dirname, configName: "configs/class-entities" }); const options: ConnectionOptions = await connectionOptionsReader.get("test-conn"); @@ -42,6 +45,8 @@ describe("ConnectionOptionsReader", () => { const connectionOptionsReader = new ConnectionOptionsReader({ root: __dirname, configName: "configs/.env" }); const [ fileOptions ]: ConnectionOptions[] = await connectionOptionsReader.all(); expect(fileOptions.database).to.have.string("test-js"); - expect(process.env.TYPEORM_DATABASE).to.equal("test-js"); + expect(Deno.env().TYPEORM_DATABASE).to.equal("test-js"); }); }); + +runIfMain(import.meta); diff --git a/test/functional/connection/connection.ts b/test/functional/connection/connection.ts index 3f03b099a..2d059eebd 100644 --- a/test/functional/connection/connection.ts +++ b/test/functional/connection/connection.ts @@ -1,23 +1,23 @@ -import "reflect-metadata"; -import {expect} from "chai"; -import {Post} from "./entity/Post"; -import {Guest as GuestV1} from "./entity/v1/Guest"; -import {Comment as CommentV1} from "./entity/v1/Comment"; -import {Guest as GuestV2} from "./entity/v2/Guest"; -import {Comment as CommentV2} from "./entity/v2/Comment"; -import {View} from "./entity/View"; -import {Category} from "./entity/Category"; -import {closeTestingConnections, createTestingConnections, setupSingleTestingConnection} from "../../utils/test-utils"; -import {Connection} from "../../../src/connection/Connection"; -import {Repository} from "../../../src/repository/Repository"; -import {TreeRepository} from "../../../src/repository/TreeRepository"; -import {getConnectionManager} from "../../../src/index"; -import {NoConnectionForRepositoryError} from "../../../src/error/NoConnectionForRepositoryError"; -import {EntityManager} from "../../../src/entity-manager/EntityManager"; -import {CannotGetEntityManagerNotConnectedError} from "../../../src/error/CannotGetEntityManagerNotConnectedError"; -import {ConnectionOptions} from "../../../src/connection/ConnectionOptions"; -import {PostgresConnectionOptions} from "../../../src/driver/postgres/PostgresConnectionOptions"; -import {PromiseUtils} from "../../../src/util/PromiseUtils"; +import {runIfMain} from "../../deps/mocha.ts"; +import {expect} from "../../deps/chai.ts"; +import {Post} from "./entity/Post.ts"; +import {Guest as GuestV1} from "./entity/v1/Guest.ts"; +import {Comment as CommentV1} from "./entity/v1/Comment.ts"; +import {Guest as GuestV2} from "./entity/v2/Guest.ts"; +import {Comment as CommentV2} from "./entity/v2/Comment.ts"; +import {View} from "./entity/View.ts"; +import {Category} from "./entity/Category.ts"; +import {closeTestingConnections, createTestingConnections, setupSingleTestingConnection} from "../../utils/test-utils.ts"; +import {Connection} from "../../../src/connection/Connection.ts"; +import {Repository} from "../../../src/repository/Repository.ts"; +import {TreeRepository} from "../../../src/repository/TreeRepository.ts"; +import {getConnectionManager} from "../../../src/index.ts"; +import {NoConnectionForRepositoryError} from "../../../src/error/NoConnectionForRepositoryError.ts"; +import {EntityManager} from "../../../src/entity-manager/EntityManager.ts"; +import {CannotGetEntityManagerNotConnectedError} from "../../../src/error/CannotGetEntityManagerNotConnectedError.ts"; +import {ConnectionOptions} from "../../../src/connection/ConnectionOptions.ts"; +// import {PostgresConnectionOptions} from "../../../src/driver/postgres/PostgresConnectionOptions.ts"; +import {PromiseUtils} from "../../../src/util/PromiseUtils.ts"; describe("Connection", () => { // const resourceDir = __dirname + "/../../../../../test/functional/connection/"; @@ -68,16 +68,26 @@ describe("Connection", () => { ]); });*/ - it("should not be able to close", () => { + it("should not be able to close", async () => { if (!connection) return; - return connection.close().should.be.rejected; // CannotCloseNotConnectedError + try { + await connection.close(); // CannotCloseNotConnectedError + expect.fail("an error to be thrown"); + } catch (err) { + expect(err.message).not.to.be.equal("an error to be thrown"); + } }); - it("should not be able to sync a schema", () => { + it("should not be able to sync a schema", async () => { if (!connection) return; - return connection.synchronize().should.be.rejected; // CannotCloseNotConnectedError + try { + await connection.synchronize(); // CannotCloseNotConnectedError + expect.fail("an error to be thrown"); + } catch (err) { + expect(err.message).not.to.equal("an error to be thrown"); + } }); it.skip("should not be able to use repositories", () => { @@ -90,10 +100,10 @@ describe("Connection", () => { // expect(() => connection.getReactiveTreeRepository(Category)).to.throw(NoConnectionForRepositoryError); }); - it("should be able to connect", () => { + it("should be able to connect", async () => { if (!connection) return; - return connection.connect().should.be.fulfilled; + await connection.connect(); }); }); @@ -130,8 +140,13 @@ describe("Connection", () => { // expect(connection.reactiveEntityManager).to.be.instanceOf(ReactiveEntityManager); })); - it("should not be able to connect again", () => connections.forEach(connection => { - return connection.connect().should.be.rejected; // CannotConnectAlreadyConnectedError + it("should not be able to connect again", () => connections.forEach(async connection => { + try { + await connection.connect(); // CannotConnectAlreadyConnectedError + expect.fail("an error to be thrown"); + } catch (err) { + expect(err.message).not.to.equal("an error to be thrown"); + } })); it("should be able to close a connection", async () => Promise.all(connections.map(connection => { @@ -226,8 +241,13 @@ describe("Connection", () => { return Promise.all(connections.map(connection => connection.close())); })); - it("should not be able to close already closed connection", () => connections.forEach(connection => { - return connection.close().should.be.rejected; // CannotCloseNotConnectedError + it("should not be able to close already closed connection", () => connections.forEach(async connection => { + try { + await connection.close(); // CannotCloseNotConnectedError + expect.fail("an error to be thrown"); + } catch (err) { + expect(err.message).not.to.equal("an error to be thrown"); + } })); it("connection.isConnected should be false", () => connections.forEach(connection => { @@ -320,7 +340,8 @@ describe("Connection", () => { it("schema name can be set", () => { return Promise.all(connections.map(async connection => { await connection.synchronize(true); - const schemaName = (connection.options as PostgresConnectionOptions).schema; + // TODO(uki00a) remove `any` when `PostgresDriver` is implemented. + const schemaName = (connection.options as /*PostgresConnectionOptions*/any).schema; const comment = new CommentV1(); comment.title = "Change SchemaName"; comment.context = `To ${schemaName}`; @@ -339,3 +360,5 @@ describe("Connection", () => { }); }); + +runIfMain(import.meta); diff --git a/test/functional/connection/entity/Category.ts b/test/functional/connection/entity/Category.ts index 92cd1843b..a57759e7b 100644 --- a/test/functional/connection/entity/Category.ts +++ b/test/functional/connection/entity/Category.ts @@ -1,10 +1,10 @@ -import {PrimaryGeneratedColumn} from "../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../src/decorator/columns/Column"; -import {TreeParent} from "../../../../src/decorator/tree/TreeParent"; -import {TreeChildren} from "../../../../src/decorator/tree/TreeChildren"; -import {TreeLevelColumn} from "../../../../src/decorator/tree/TreeLevelColumn"; -import {Entity} from "../../../../src/decorator/entity/Entity"; -import {Tree} from "../../../../src/decorator/tree/Tree"; +import {PrimaryGeneratedColumn} from "../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../src/decorator/columns/Column.ts"; +import {TreeParent} from "../../../../src/decorator/tree/TreeParent.ts"; +import {TreeChildren} from "../../../../src/decorator/tree/TreeChildren.ts"; +import {TreeLevelColumn} from "../../../../src/decorator/tree/TreeLevelColumn.ts"; +import {Entity} from "../../../../src/decorator/entity/Entity.ts"; +import {Tree} from "../../../../src/decorator/tree/Tree.ts"; @Entity("CaTeGoRy") @Tree("closure-table") @@ -13,9 +13,9 @@ export class Category { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) name: string; - + @TreeParent() parentCategory: Category; @@ -25,4 +25,4 @@ export class Category { @TreeLevelColumn() level: number; -} \ No newline at end of file +} diff --git a/test/functional/connection/entity/Post.ts b/test/functional/connection/entity/Post.ts index 220070f27..9b0f4a6fd 100644 --- a/test/functional/connection/entity/Post.ts +++ b/test/functional/connection/entity/Post.ts @@ -1,6 +1,6 @@ -import {Entity} from "../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../src/decorator/columns/Column"; +import {Entity} from "../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../src/decorator/columns/Column.ts"; @Entity() export class Post { @@ -8,7 +8,7 @@ export class Post { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) title: string; -} \ No newline at end of file +} diff --git a/test/functional/connection/entity/View.ts b/test/functional/connection/entity/View.ts index 34b3bb4bd..56507f283 100644 --- a/test/functional/connection/entity/View.ts +++ b/test/functional/connection/entity/View.ts @@ -1,14 +1,14 @@ -import {Entity} from "../../../../src/decorator/entity/Entity"; -import {PrimaryColumn} from "../../../../src/decorator/columns/PrimaryColumn"; -import {Column} from "../../../../src/decorator/columns/Column"; +import {Entity} from "../../../../src/decorator/entity/Entity.ts"; +import {PrimaryColumn} from "../../../../src/decorator/columns/PrimaryColumn.ts"; +import {Column} from "../../../../src/decorator/columns/Column.ts"; @Entity("view", { synchronize: false }) export class View { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; - @Column() + @Column({ type: String }) title: string; -} \ No newline at end of file +} diff --git a/test/functional/connection/entity/v1/Comment.ts b/test/functional/connection/entity/v1/Comment.ts index d2136ac74..e4a4f9fb8 100644 --- a/test/functional/connection/entity/v1/Comment.ts +++ b/test/functional/connection/entity/v1/Comment.ts @@ -1,10 +1,10 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {ManyToOne} from "../../../../../src/decorator/relations/ManyToOne"; -import {OneToMany} from "../../../../../src/decorator/relations/OneToMany"; -import {Index} from "../../../../../src/decorator/Index"; -import {Guest} from "./Guest"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {ManyToOne} from "../../../../../src/decorator/relations/ManyToOne.ts"; +import {OneToMany} from "../../../../../src/decorator/relations/OneToMany.ts"; +import {Index} from "../../../../../src/decorator/Index.ts"; +import {Guest} from "./Guest.ts"; @Entity() @Index("author_and_title_unique", ["author", "title"], { unique: true }) @@ -13,11 +13,11 @@ export class Comment { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) @Index() title: string; - @Column() + @Column({ type: String }) context: string; @OneToMany(type => Comment, comment => comment.relay) @@ -28,4 +28,4 @@ export class Comment { @ManyToOne(type => Guest, guest => guest.comments) author: Guest; -} \ No newline at end of file +} diff --git a/test/functional/connection/entity/v1/Guest.ts b/test/functional/connection/entity/v1/Guest.ts index da3debacd..f256f3a8c 100644 --- a/test/functional/connection/entity/v1/Guest.ts +++ b/test/functional/connection/entity/v1/Guest.ts @@ -1,8 +1,8 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {OneToMany} from "../../../../../src/decorator/relations/OneToMany"; -import {Comment} from "./Comment"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {OneToMany} from "../../../../../src/decorator/relations/OneToMany.ts"; +import {Comment} from "./Comment.ts"; @Entity() export class Guest { @@ -10,9 +10,9 @@ export class Guest { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) username: string; @OneToMany(type => Comment, comment => comment.author) comments: Comment[]; -} \ No newline at end of file +} diff --git a/test/functional/connection/entity/v2/Comment.ts b/test/functional/connection/entity/v2/Comment.ts index c2a755a03..0311e8d34 100644 --- a/test/functional/connection/entity/v2/Comment.ts +++ b/test/functional/connection/entity/v2/Comment.ts @@ -1,9 +1,9 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {ManyToOne} from "../../../../../src/decorator/relations/ManyToOne"; -import {Index} from "../../../../../src/decorator/Index"; -import {Guest} from "./Guest"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {ManyToOne} from "../../../../../src/decorator/relations/ManyToOne.ts"; +import {Index} from "../../../../../src/decorator/Index.ts"; +import {Guest} from "./Guest.ts"; @Entity() @Index("author_and_title_unique_rename", ["author", "title", "context"], { unique: true }) @@ -12,13 +12,13 @@ export class Comment { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) @Index() title: string; - @Column() + @Column({ type: String }) context: string; @ManyToOne(type => Guest, guest => guest.comments) author: Guest; -} \ No newline at end of file +} diff --git a/test/functional/connection/entity/v2/Guest.ts b/test/functional/connection/entity/v2/Guest.ts index da3debacd..f256f3a8c 100644 --- a/test/functional/connection/entity/v2/Guest.ts +++ b/test/functional/connection/entity/v2/Guest.ts @@ -1,8 +1,8 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {OneToMany} from "../../../../../src/decorator/relations/OneToMany"; -import {Comment} from "./Comment"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {OneToMany} from "../../../../../src/decorator/relations/OneToMany.ts"; +import {Comment} from "./Comment.ts"; @Entity() export class Guest { @@ -10,9 +10,9 @@ export class Guest { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) username: string; @OneToMany(type => Comment, comment => comment.author) comments: Comment[]; -} \ No newline at end of file +} diff --git a/test/functional/connection/modules/blog/entity/Blog.ts b/test/functional/connection/modules/blog/entity/Blog.ts index 5dc03829c..884cc903e 100644 --- a/test/functional/connection/modules/blog/entity/Blog.ts +++ b/test/functional/connection/modules/blog/entity/Blog.ts @@ -1,6 +1,6 @@ -import {Entity} from "../../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../../src/decorator/columns/Column"; +import {Entity} from "../../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../../src/decorator/columns/Column.ts"; @Entity() export class Blog { @@ -8,7 +8,7 @@ export class Blog { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) name: string; -} \ No newline at end of file +} diff --git a/test/functional/connection/modules/blog/subscriber/TestBlogSubscriber.ts b/test/functional/connection/modules/blog/subscriber/TestBlogSubscriber.ts index f6a40b238..2cb48ad6c 100644 --- a/test/functional/connection/modules/blog/subscriber/TestBlogSubscriber.ts +++ b/test/functional/connection/modules/blog/subscriber/TestBlogSubscriber.ts @@ -1,10 +1,10 @@ -import {EventSubscriber} from "../../../../../../src/decorator/listeners/EventSubscriber"; -import {EntitySubscriberInterface} from "../../../../../../src/subscriber/EntitySubscriberInterface"; -import {InsertEvent} from "../../../../../../src/subscriber/event/InsertEvent"; +import {EventSubscriber} from "../../../../../../src/decorator/listeners/EventSubscriber.ts"; +import {EntitySubscriberInterface} from "../../../../../../src/subscriber/EntitySubscriberInterface.ts"; +import {InsertEvent} from "../../../../../../src/subscriber/event/InsertEvent.ts"; @EventSubscriber() export class TestBlogSubscriber implements EntitySubscriberInterface { - + /** * Called after entity insertion. */ @@ -12,4 +12,4 @@ export class TestBlogSubscriber implements EntitySubscriberInterface { console.log(`BEFORE ENTITY INSERTED: `, event.entity); } -} \ No newline at end of file +} diff --git a/test/functional/connection/modules/question/entity/Question.ts b/test/functional/connection/modules/question/entity/Question.ts index 7228209b8..1040db1be 100644 --- a/test/functional/connection/modules/question/entity/Question.ts +++ b/test/functional/connection/modules/question/entity/Question.ts @@ -1,6 +1,6 @@ -import {Entity} from "../../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../../src/decorator/columns/Column"; +import {Entity} from "../../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../../src/decorator/columns/Column.ts"; @Entity() export class Question { @@ -8,7 +8,7 @@ export class Question { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) name: string; -} \ No newline at end of file +} diff --git a/test/functional/connection/modules/question/subscriber/TestQuestionSubscriber.ts b/test/functional/connection/modules/question/subscriber/TestQuestionSubscriber.ts index d22940cbd..19703d067 100644 --- a/test/functional/connection/modules/question/subscriber/TestQuestionSubscriber.ts +++ b/test/functional/connection/modules/question/subscriber/TestQuestionSubscriber.ts @@ -1,10 +1,10 @@ -import {EventSubscriber} from "../../../../../../src/decorator/listeners/EventSubscriber"; -import {EntitySubscriberInterface} from "../../../../../../src/subscriber/EntitySubscriberInterface"; -import {InsertEvent} from "../../../../../../src/subscriber/event/InsertEvent"; +import {EventSubscriber} from "../../../../../../src/decorator/listeners/EventSubscriber.ts"; +import {EntitySubscriberInterface} from "../../../../../../src/subscriber/EntitySubscriberInterface.ts"; +import {InsertEvent} from "../../../../../../src/subscriber/event/InsertEvent.ts"; @EventSubscriber() export class TestQuestionSubscriber implements EntitySubscriberInterface { - + /** * Called before entity insertion. */ @@ -12,4 +12,4 @@ export class TestQuestionSubscriber implements EntitySubscriberInterface { console.log(`BEFORE ENTITY INSERTED: `, event.entity); } -} \ No newline at end of file +} diff --git a/test/functional/connection/modules/video/entity/Video.ts b/test/functional/connection/modules/video/entity/Video.ts index 8215f46f6..72f687593 100644 --- a/test/functional/connection/modules/video/entity/Video.ts +++ b/test/functional/connection/modules/video/entity/Video.ts @@ -1,6 +1,6 @@ -import {Entity} from "../../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../../src/decorator/columns/Column"; +import {Entity} from "../../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../../src/decorator/columns/Column.ts"; @Entity() export class Video { @@ -8,7 +8,7 @@ export class Video { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) name: string; -} \ No newline at end of file +} diff --git a/test/functional/connection/modules/video/subscriber/TestVideoSubscriber.ts b/test/functional/connection/modules/video/subscriber/TestVideoSubscriber.ts index 58f66b5eb..b89bc7163 100644 --- a/test/functional/connection/modules/video/subscriber/TestVideoSubscriber.ts +++ b/test/functional/connection/modules/video/subscriber/TestVideoSubscriber.ts @@ -1,10 +1,10 @@ -import {EventSubscriber} from "../../../../../../src/decorator/listeners/EventSubscriber"; -import {EntitySubscriberInterface} from "../../../../../../src/subscriber/EntitySubscriberInterface"; -import {InsertEvent} from "../../../../../../src/subscriber/event/InsertEvent"; +import {EventSubscriber} from "../../../../../../src/decorator/listeners/EventSubscriber.ts"; +import {EntitySubscriberInterface} from "../../../../../../src/subscriber/EntitySubscriberInterface.ts"; +import {InsertEvent} from "../../../../../../src/subscriber/event/InsertEvent.ts"; @EventSubscriber() export class TestVideoSubscriber implements EntitySubscriberInterface { - + /** * Called after entity insertion. */ @@ -12,4 +12,4 @@ export class TestVideoSubscriber implements EntitySubscriberInterface { console.log(`BEFORE ENTITY INSERTED: `, event.entity); } -} \ No newline at end of file +} diff --git a/test/functional/connection/naming-strategy/FirstCustomNamingStrategy.ts b/test/functional/connection/naming-strategy/FirstCustomNamingStrategy.ts index cee9e2109..76ce18b04 100644 --- a/test/functional/connection/naming-strategy/FirstCustomNamingStrategy.ts +++ b/test/functional/connection/naming-strategy/FirstCustomNamingStrategy.ts @@ -1,10 +1,10 @@ -import {DefaultNamingStrategy} from "../../../../src/naming-strategy/DefaultNamingStrategy"; -import {NamingStrategyInterface} from "../../../../src/naming-strategy/NamingStrategyInterface"; +import {DefaultNamingStrategy} from "../../../../src/naming-strategy/DefaultNamingStrategy.ts"; +import {NamingStrategyInterface} from "../../../../src/naming-strategy/NamingStrategyInterface.ts"; export class FirstCustomNamingStrategy extends DefaultNamingStrategy implements NamingStrategyInterface { tableName(className: string, customName: string): string { return customName ? customName.toUpperCase() : className.toUpperCase(); } - -} \ No newline at end of file + +} diff --git a/test/functional/connection/naming-strategy/SecondCustomNamingStrategy.ts b/test/functional/connection/naming-strategy/SecondCustomNamingStrategy.ts index 697b28e7f..f6fbd89a4 100644 --- a/test/functional/connection/naming-strategy/SecondCustomNamingStrategy.ts +++ b/test/functional/connection/naming-strategy/SecondCustomNamingStrategy.ts @@ -1,10 +1,10 @@ -import {DefaultNamingStrategy} from "../../../../src/naming-strategy/DefaultNamingStrategy"; -import {NamingStrategyInterface} from "../../../../src/naming-strategy/NamingStrategyInterface"; +import {DefaultNamingStrategy} from "../../../../src/naming-strategy/DefaultNamingStrategy.ts"; +import {NamingStrategyInterface} from "../../../../src/naming-strategy/NamingStrategyInterface.ts"; export class SecondCustomNamingStrategy extends DefaultNamingStrategy implements NamingStrategyInterface { tableName(className: string, customName: string): string { return customName ? customName.toLowerCase() : className.toLowerCase(); } - -} \ No newline at end of file + +} diff --git a/test/functional/connection/subscriber/FirstConnectionSubscriber.ts b/test/functional/connection/subscriber/FirstConnectionSubscriber.ts index 2aefd8274..72364ba22 100644 --- a/test/functional/connection/subscriber/FirstConnectionSubscriber.ts +++ b/test/functional/connection/subscriber/FirstConnectionSubscriber.ts @@ -1,10 +1,10 @@ -import {EntitySubscriberInterface} from "../../../../src/subscriber/EntitySubscriberInterface"; -import {EventSubscriber} from "../../../../src/decorator/listeners/EventSubscriber"; -import {InsertEvent} from "../../../../src/subscriber/event/InsertEvent"; +import {EntitySubscriberInterface} from "../../../../src/subscriber/EntitySubscriberInterface.ts"; +import {EventSubscriber} from "../../../../src/decorator/listeners/EventSubscriber.ts"; +import {InsertEvent} from "../../../../src/subscriber/event/InsertEvent.ts"; @EventSubscriber() export class FirstConnectionSubscriber implements EntitySubscriberInterface { - + /** * Called after entity insertion. */ @@ -12,4 +12,4 @@ export class FirstConnectionSubscriber implements EntitySubscriberInterface { console.log(`BEFORE ENTITY INSERTED: `, event.entity); } -} \ No newline at end of file +} diff --git a/test/functional/connection/subscriber/SecondConnectionSubscriber.ts b/test/functional/connection/subscriber/SecondConnectionSubscriber.ts index 2ef4427b3..0b242d542 100644 --- a/test/functional/connection/subscriber/SecondConnectionSubscriber.ts +++ b/test/functional/connection/subscriber/SecondConnectionSubscriber.ts @@ -1,10 +1,10 @@ -import {EntitySubscriberInterface} from "../../../../src/subscriber/EntitySubscriberInterface"; -import {EventSubscriber} from "../../../../src/decorator/listeners/EventSubscriber"; -import {InsertEvent} from "../../../../src/subscriber/event/InsertEvent"; +import {EntitySubscriberInterface} from "../../../../src/subscriber/EntitySubscriberInterface.ts"; +import {EventSubscriber} from "../../../../src/decorator/listeners/EventSubscriber.ts"; +import {InsertEvent} from "../../../../src/subscriber/event/InsertEvent.ts"; @EventSubscriber() export class SecondConnectionSubscriber implements EntitySubscriberInterface { - + /** * Called after entity insertion. */ @@ -12,4 +12,4 @@ export class SecondConnectionSubscriber implements EntitySubscriberInterface { console.log(`BEFORE ENTITY INSERTED: `, event.entity); } -} \ No newline at end of file +} diff --git a/test/functional/cube/postgres/cube-postgres.ts b/test/functional/cube/postgres/cube-postgres.ts index 5e3c2efcd..cadab76f9 100644 --- a/test/functional/cube/postgres/cube-postgres.ts +++ b/test/functional/cube/postgres/cube-postgres.ts @@ -1,18 +1,21 @@ -import "reflect-metadata"; -import { expect } from "chai"; -import { Connection } from "../../../../src/connection/Connection"; +import { join as joinPaths } from "../../../../vendor/https/deno.land/std/path/mod.ts"; +import { runIfMain } from "../../../deps/mocha.ts"; +import { expect } from "../../../deps/chai.ts"; +import { Connection } from "../../../../src/connection/Connection.ts"; import { + getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases -} from "../../../utils/test-utils"; -import { Post } from "./entity/Post"; +} from "../../../utils/test-utils.ts"; +import { Post } from "./entity/Post.ts"; describe("cube-postgres", () => { + const __dirname = getDirnameOfCurrentModule(import.meta); let connections: Connection[]; before(async () => { connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], enabledDrivers: ["postgres"] }); }); @@ -161,3 +164,5 @@ describe("cube-postgres", () => { }) )); }); + +runIfMain(import.meta); diff --git a/test/functional/cube/postgres/entity/Post.ts b/test/functional/cube/postgres/entity/Post.ts index ab767b358..54a06c183 100644 --- a/test/functional/cube/postgres/entity/Post.ts +++ b/test/functional/cube/postgres/entity/Post.ts @@ -1,6 +1,6 @@ -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../../src/decorator/columns/Column"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; @Entity() export class Post { diff --git a/test/functional/database-schema/column-collation/cockroach/column-collation-cockroach.ts b/test/functional/database-schema/column-collation/cockroach/column-collation-cockroach.ts index 520462d93..a62e1bf1b 100644 --- a/test/functional/database-schema/column-collation/cockroach/column-collation-cockroach.ts +++ b/test/functional/database-schema/column-collation/cockroach/column-collation-cockroach.ts @@ -1,14 +1,17 @@ -import "reflect-metadata"; -import {Post} from "./entity/Post"; -import {Connection} from "../../../../../src/connection/Connection"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils"; +import {join as joinPaths} from "../../../../../vendor/https/deno.land/std/path/mod.ts"; +import "../../../../deps/chai.ts"; +import {runIfMain} from "../../../../deps/mocha.ts"; +import {Post} from "./entity/Post.ts"; +import {Connection} from "../../../../../src/connection/Connection.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils.ts"; describe("database schema > column collation > cockroach", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => { connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], enabledDrivers: ["cockroachdb"], }); }); @@ -31,3 +34,5 @@ describe("database schema > column collation > cockroach", () => { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/database-schema/column-collation/cockroach/entity/Post.ts b/test/functional/database-schema/column-collation/cockroach/entity/Post.ts index e6be6cffd..48de1bee8 100644 --- a/test/functional/database-schema/column-collation/cockroach/entity/Post.ts +++ b/test/functional/database-schema/column-collation/cockroach/entity/Post.ts @@ -1,14 +1,14 @@ -import {Entity} from "../../../../../../src/decorator/entity/Entity"; -import {PrimaryColumn} from "../../../../../../src/decorator/columns/PrimaryColumn"; -import {Column} from "../../../../../../src/decorator/columns/Column"; +import {Entity} from "../../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryColumn} from "../../../../../../src/decorator/columns/PrimaryColumn.ts"; +import {Column} from "../../../../../../src/decorator/columns/Column.ts"; @Entity() export class Post { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; - @Column({ collation: "en_US" }) + @Column({ collation: "en_US", type: String }) name: string; } diff --git a/test/functional/database-schema/column-collation/mssql/column-collation-mssql.ts b/test/functional/database-schema/column-collation/mssql/column-collation-mssql.ts index d542bfccc..762ddd71a 100644 --- a/test/functional/database-schema/column-collation/mssql/column-collation-mssql.ts +++ b/test/functional/database-schema/column-collation/mssql/column-collation-mssql.ts @@ -1,14 +1,17 @@ -import "reflect-metadata"; -import {Post} from "./entity/Post"; -import {Connection} from "../../../../../src/connection/Connection"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils"; +import {join as joinPaths} from "../../../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../../../deps/mocha.ts"; +import "../../../../deps/chai.ts"; +import {Post} from "./entity/Post.ts"; +import {Connection} from "../../../../../src/connection/Connection.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils.ts"; describe("database schema > column collation > mssql", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => { connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], enabledDrivers: ["mssql"], }); }); @@ -32,3 +35,5 @@ describe("database schema > column collation > mssql", () => { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/database-schema/column-collation/mssql/entity/Post.ts b/test/functional/database-schema/column-collation/mssql/entity/Post.ts index 8db95f455..19e215906 100644 --- a/test/functional/database-schema/column-collation/mssql/entity/Post.ts +++ b/test/functional/database-schema/column-collation/mssql/entity/Post.ts @@ -1,14 +1,14 @@ -import {Entity} from "../../../../../../src/decorator/entity/Entity"; -import {PrimaryColumn} from "../../../../../../src/decorator/columns/PrimaryColumn"; -import {Column} from "../../../../../../src/decorator/columns/Column"; +import {Entity} from "../../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryColumn} from "../../../../../../src/decorator/columns/PrimaryColumn.ts"; +import {Column} from "../../../../../../src/decorator/columns/Column.ts"; @Entity() export class Post { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; - @Column({ collation: "French_CI_AS" }) + @Column({ collation: "French_CI_AS", type: String }) name: string; -} \ No newline at end of file +} diff --git a/test/functional/database-schema/column-collation/mysql/column-collation-mysql.ts b/test/functional/database-schema/column-collation/mysql/column-collation-mysql.ts index 40d243932..0e7b203d4 100644 --- a/test/functional/database-schema/column-collation/mysql/column-collation-mysql.ts +++ b/test/functional/database-schema/column-collation/mysql/column-collation-mysql.ts @@ -1,14 +1,17 @@ -import "reflect-metadata"; -import {Post} from "./entity/Post"; -import {Connection} from "../../../../../src/connection/Connection"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils"; +import {join as joinPaths} from "../../../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../../../deps/mocha.ts"; +import "../../../../deps/chai.ts"; +import {Post} from "./entity/Post.ts"; +import {Connection} from "../../../../../src/connection/Connection.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils.ts"; describe("database schema > column collation > mysql", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => { connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], enabledDrivers: ["mysql"], }); }); @@ -39,3 +42,5 @@ describe("database schema > column collation > mysql", () => { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/database-schema/column-collation/mysql/entity/Post.ts b/test/functional/database-schema/column-collation/mysql/entity/Post.ts index 76e3fe19c..22101acc6 100644 --- a/test/functional/database-schema/column-collation/mysql/entity/Post.ts +++ b/test/functional/database-schema/column-collation/mysql/entity/Post.ts @@ -1,20 +1,20 @@ -import {Entity} from "../../../../../../src/decorator/entity/Entity"; -import {PrimaryColumn} from "../../../../../../src/decorator/columns/PrimaryColumn"; -import {Column} from "../../../../../../src/decorator/columns/Column"; +import {Entity} from "../../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryColumn} from "../../../../../../src/decorator/columns/PrimaryColumn.ts"; +import {Column} from "../../../../../../src/decorator/columns/Column.ts"; @Entity() export class Post { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; - @Column({ collation: "ascii_general_ci" }) + @Column({ collation: "ascii_general_ci", type: String }) name: string; - @Column({ charset: "utf8" }) + @Column({ charset: "utf8", type: String }) title: string; - @Column({ charset: "cp852", collation: "cp852_general_ci" }) + @Column({ charset: "cp852", collation: "cp852_general_ci", type: String }) description: string; -} \ No newline at end of file +} diff --git a/test/functional/database-schema/column-collation/postgres/column-collation-postgres.ts b/test/functional/database-schema/column-collation/postgres/column-collation-postgres.ts index d79fd2709..ed95cd777 100644 --- a/test/functional/database-schema/column-collation/postgres/column-collation-postgres.ts +++ b/test/functional/database-schema/column-collation/postgres/column-collation-postgres.ts @@ -1,14 +1,17 @@ -import "reflect-metadata"; -import {Post} from "./entity/Post"; -import {Connection} from "../../../../../src/connection/Connection"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils"; +import {join as joinPaths} from "../../../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../../../deps/mocha.ts"; +import "../../../../deps/chai.ts"; +import {Post} from "./entity/Post.ts"; +import {Connection} from "../../../../../src/connection/Connection.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils.ts"; describe("database schema > column collation > postgres", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => { connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], enabledDrivers: ["postgres"], }); }); @@ -32,3 +35,5 @@ describe("database schema > column collation > postgres", () => { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/database-schema/column-collation/postgres/entity/Post.ts b/test/functional/database-schema/column-collation/postgres/entity/Post.ts index dcabd293c..48de1bee8 100644 --- a/test/functional/database-schema/column-collation/postgres/entity/Post.ts +++ b/test/functional/database-schema/column-collation/postgres/entity/Post.ts @@ -1,14 +1,14 @@ -import {Entity} from "../../../../../../src/decorator/entity/Entity"; -import {PrimaryColumn} from "../../../../../../src/decorator/columns/PrimaryColumn"; -import {Column} from "../../../../../../src/decorator/columns/Column"; +import {Entity} from "../../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryColumn} from "../../../../../../src/decorator/columns/PrimaryColumn.ts"; +import {Column} from "../../../../../../src/decorator/columns/Column.ts"; @Entity() export class Post { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; - @Column({ collation: "en_US" }) + @Column({ collation: "en_US", type: String }) name: string; -} \ No newline at end of file +} diff --git a/test/functional/database-schema/column-collation/sqlite/column-collation-sqlite.ts b/test/functional/database-schema/column-collation/sqlite/column-collation-sqlite.ts index cfd415258..c17f882fa 100644 --- a/test/functional/database-schema/column-collation/sqlite/column-collation-sqlite.ts +++ b/test/functional/database-schema/column-collation/sqlite/column-collation-sqlite.ts @@ -1,15 +1,18 @@ -import "reflect-metadata"; -import {Post} from "./entity/Post"; -import {Connection} from "../../../../../src/connection/Connection"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils"; +import {join as joinPaths} from "../../../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../../../deps/mocha.ts"; +import "../../../../deps/chai.ts"; +import {Post} from "./entity/Post.ts"; +import {Connection} from "../../../../../src/connection/Connection.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils.ts"; // skipped because there is no way to get column collation from SQLite table schema describe.skip("database schema > column collation > sqlite", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => { connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], enabledDrivers: ["sqlite"], }); }); @@ -33,3 +36,5 @@ describe.skip("database schema > column collation > sqlite", () => { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/database-schema/column-collation/sqlite/entity/Post.ts b/test/functional/database-schema/column-collation/sqlite/entity/Post.ts index e1f81c694..143bdb983 100644 --- a/test/functional/database-schema/column-collation/sqlite/entity/Post.ts +++ b/test/functional/database-schema/column-collation/sqlite/entity/Post.ts @@ -1,14 +1,14 @@ -import {Entity} from "../../../../../../src/decorator/entity/Entity"; -import {PrimaryColumn} from "../../../../../../src/decorator/columns/PrimaryColumn"; -import {Column} from "../../../../../../src/decorator/columns/Column"; +import {Entity} from "../../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryColumn} from "../../../../../../src/decorator/columns/PrimaryColumn.ts"; +import {Column} from "../../../../../../src/decorator/columns/Column.ts"; @Entity() export class Post { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; - @Column({ collation: "RTRIM" }) + @Column({ collation: "RTRIM", type: String }) name: string; -} \ No newline at end of file +} diff --git a/test/functional/database-schema/column-length/mssql/column-length-mssql.ts b/test/functional/database-schema/column-length/mssql/column-length-mssql.ts index dce7134ca..6fce1a8c0 100644 --- a/test/functional/database-schema/column-length/mssql/column-length-mssql.ts +++ b/test/functional/database-schema/column-length/mssql/column-length-mssql.ts @@ -1,8 +1,8 @@ -import "reflect-metadata"; -import {expect} from "chai"; -import {Post} from "./entity/Post"; -import {Connection} from "../../../../../src/connection/Connection"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils"; +import {runIfMain} from "../../../../deps/mocha.ts"; +import {expect} from "../../../../deps/chai.ts"; +import {Post} from "./entity/Post.ts"; +import {Connection} from "../../../../../src/connection/Connection.ts"; +import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils.ts"; describe("database schema > column length > mssql", () => { @@ -28,11 +28,11 @@ describe("database schema > column length > mssql", () => { expect(table!.findColumnByName("nvarchar")!.length).to.be.equal("50"); expect(table!.findColumnByName("binary")!.length).to.be.equal("50"); expect(table!.findColumnByName("varbinary")!.length).to.be.equal("50"); - + }))); it("all types should update their size", () => Promise.all(connections.map(async connection => { - + let metadata = connection.getMetadata(Post); metadata.findColumnWithPropertyName("char")!.length = "100"; metadata.findColumnWithPropertyName("varchar")!.length = "100"; @@ -53,11 +53,11 @@ describe("database schema > column length > mssql", () => { expect(table!.findColumnByName("nvarchar")!.length).to.be.equal("100"); expect(table!.findColumnByName("binary")!.length).to.be.equal("100"); expect(table!.findColumnByName("varbinary")!.length).to.be.equal("100"); - + }))); it("all relevant types should update their size to max", () => Promise.all(connections.map(async connection => { - + let metadata = connection.getMetadata(Post); metadata.findColumnWithPropertyName("varchar")!.length = "MAX"; metadata.findColumnWithPropertyName("nvarchar")!.length = "MAX"; @@ -72,7 +72,9 @@ describe("database schema > column length > mssql", () => { expect(table!.findColumnByName("varchar")!.length).to.be.equal("MAX"); expect(table!.findColumnByName("nvarchar")!.length).to.be.equal("MAX"); expect(table!.findColumnByName("varbinary")!.length).to.be.equal("MAX"); - + }))); - + }); + +runIfMain(import.meta); diff --git a/test/functional/database-schema/column-length/mssql/entity/Post.ts b/test/functional/database-schema/column-length/mssql/entity/Post.ts index cc7f6826e..5dbfe27de 100644 --- a/test/functional/database-schema/column-length/mssql/entity/Post.ts +++ b/test/functional/database-schema/column-length/mssql/entity/Post.ts @@ -1,11 +1,11 @@ -import {Entity} from "../../../../../../src/decorator/entity/Entity"; -import {PrimaryColumn} from "../../../../../../src/decorator/columns/PrimaryColumn"; -import {Column} from "../../../../../../src/decorator/columns/Column"; +import {Entity} from "../../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryColumn} from "../../../../../../src/decorator/columns/PrimaryColumn.ts"; +import {Column} from "../../../../../../src/decorator/columns/Column.ts"; @Entity() export class Post { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; @Column("char", { @@ -31,11 +31,11 @@ export class Post { @Column("binary", { length: 50 }) - binary: Buffer; + binary: Uint8Array;/* Buffer; */ @Column("varbinary", { length: 50 }) - varbinary: Buffer; + varbinary: Uint8Array;/* Buffer; */ -} \ No newline at end of file +} diff --git a/test/functional/database-schema/column-length/mysql/column-length-mysql.ts b/test/functional/database-schema/column-length/mysql/column-length-mysql.ts index 38147d1fa..cfd6b1db7 100644 --- a/test/functional/database-schema/column-length/mysql/column-length-mysql.ts +++ b/test/functional/database-schema/column-length/mysql/column-length-mysql.ts @@ -1,8 +1,8 @@ -import "reflect-metadata"; -import {expect} from "chai"; -import {Post} from "./entity/Post"; -import {Connection} from "../../../../../src/connection/Connection"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils"; +import {runIfMain} from "../../../../deps/mocha.ts"; +import {expect} from "../../../../deps/chai.ts"; +import {Post} from "./entity/Post.ts"; +import {Connection} from "../../../../../src/connection/Connection.ts"; +import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils.ts"; describe("database schema > column length > mysql", () => { @@ -24,16 +24,16 @@ describe("database schema > column length > mysql", () => { expect(table!.findColumnByName("char")!.length).to.be.equal("50"); expect(table!.findColumnByName("varchar")!.length).to.be.equal("50"); - + }))); it("all types should update their length", () => Promise.all(connections.map(async connection => { - + let metadata = connection.getMetadata(Post); metadata.findColumnWithPropertyName("char")!.length = "100"; metadata.findColumnWithPropertyName("varchar")!.length = "100"; - - await connection.synchronize(false); + + await connection.synchronize(false); const queryRunner = connection.createQueryRunner(); const table = await queryRunner.getTable("post"); @@ -41,7 +41,9 @@ describe("database schema > column length > mysql", () => { expect(table!.findColumnByName("char")!.length).to.be.equal("100"); expect(table!.findColumnByName("varchar")!.length).to.be.equal("100"); - + }))); }); + +runIfMain(import.meta); diff --git a/test/functional/database-schema/column-length/mysql/entity/Post.ts b/test/functional/database-schema/column-length/mysql/entity/Post.ts index 9863c3cd7..85b590356 100644 --- a/test/functional/database-schema/column-length/mysql/entity/Post.ts +++ b/test/functional/database-schema/column-length/mysql/entity/Post.ts @@ -1,11 +1,11 @@ -import {Entity} from "../../../../../../src/decorator/entity/Entity"; -import {PrimaryColumn} from "../../../../../../src/decorator/columns/PrimaryColumn"; -import {Column} from "../../../../../../src/decorator/columns/Column"; +import {Entity} from "../../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryColumn} from "../../../../../../src/decorator/columns/PrimaryColumn.ts"; +import {Column} from "../../../../../../src/decorator/columns/Column.ts"; @Entity() export class Post { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; @Column("char", { @@ -18,4 +18,4 @@ export class Post { }) varchar: string; -} \ No newline at end of file +} diff --git a/test/functional/database-schema/column-length/postgres/column-length-postgres.ts b/test/functional/database-schema/column-length/postgres/column-length-postgres.ts index c7b6952da..df1a87cf9 100644 --- a/test/functional/database-schema/column-length/postgres/column-length-postgres.ts +++ b/test/functional/database-schema/column-length/postgres/column-length-postgres.ts @@ -1,8 +1,8 @@ -import "reflect-metadata"; -import {expect} from "chai"; -import {Post} from "./entity/Post"; -import {Connection} from "../../../../../src/connection/Connection"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils"; +import {runIfMain} from "../../../../deps/mocha.ts"; +import {expect} from "../../../../deps/chai.ts"; +import {Post} from "./entity/Post.ts"; +import {Connection} from "../../../../../src/connection/Connection.ts"; +import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils.ts"; describe("database schema > column length > postgres", () => { @@ -26,18 +26,18 @@ describe("database schema > column length > postgres", () => { expect(table!.findColumnByName("varchar")!.length).to.be.equal("50"); expect(table!.findColumnByName("character")!.length).to.be.equal("50"); expect(table!.findColumnByName("char")!.length).to.be.equal("50"); - + }))); it("all types should update their size", () => Promise.all(connections.map(async connection => { - + let metadata = connection.getMetadata(Post); metadata.findColumnWithPropertyName("characterVarying")!.length = "100"; metadata.findColumnWithPropertyName("varchar")!.length = "100"; metadata.findColumnWithPropertyName("character")!.length = "100"; metadata.findColumnWithPropertyName("char")!.length = "100"; - await connection.synchronize(false); + await connection.synchronize(false); const queryRunner = connection.createQueryRunner(); const table = await queryRunner.getTable("post"); @@ -47,7 +47,9 @@ describe("database schema > column length > postgres", () => { expect(table!.findColumnByName("varchar")!.length).to.be.equal("100"); expect(table!.findColumnByName("character")!.length).to.be.equal("100"); expect(table!.findColumnByName("char")!.length).to.be.equal("100"); - + }))); - + }); + +runIfMain(import.meta); diff --git a/test/functional/database-schema/column-length/postgres/entity/Post.ts b/test/functional/database-schema/column-length/postgres/entity/Post.ts index 4393c9f90..7d83e5cc1 100644 --- a/test/functional/database-schema/column-length/postgres/entity/Post.ts +++ b/test/functional/database-schema/column-length/postgres/entity/Post.ts @@ -1,11 +1,11 @@ -import {Entity} from "../../../../../../src/decorator/entity/Entity"; -import {PrimaryColumn} from "../../../../../../src/decorator/columns/PrimaryColumn"; -import {Column} from "../../../../../../src/decorator/columns/Column"; +import {Entity} from "../../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryColumn} from "../../../../../../src/decorator/columns/PrimaryColumn.ts"; +import {Column} from "../../../../../../src/decorator/columns/Column.ts"; @Entity() export class Post { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; @Column("character varying", { @@ -28,4 +28,4 @@ export class Post { }) char: string; -} \ No newline at end of file +} diff --git a/test/functional/database-schema/column-length/sap/column-length-sap.ts b/test/functional/database-schema/column-length/sap/column-length-sap.ts index 542f078bb..72747e135 100644 --- a/test/functional/database-schema/column-length/sap/column-length-sap.ts +++ b/test/functional/database-schema/column-length/sap/column-length-sap.ts @@ -1,8 +1,8 @@ -import "reflect-metadata"; -import {expect} from "chai"; -import {Post} from "./entity/Post"; -import {Connection} from "../../../../../src"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils"; +import {runIfMain} from "../../../../deps/mocha.ts"; +import {expect} from "../../../../deps/chai.ts"; +import {Post} from "./entity/Post.ts"; +import {Connection} from "../../../../../src/index.ts"; +import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils.ts"; describe("database schema > column length > sap", () => { @@ -54,3 +54,5 @@ describe("database schema > column length > sap", () => { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/database-schema/column-length/sap/entity/Post.ts b/test/functional/database-schema/column-length/sap/entity/Post.ts index 289c34138..8cbd89e3c 100644 --- a/test/functional/database-schema/column-length/sap/entity/Post.ts +++ b/test/functional/database-schema/column-length/sap/entity/Post.ts @@ -1,11 +1,11 @@ -import {Entity} from "../../../../../../src"; -import {PrimaryColumn} from "../../../../../../src"; -import {Column} from "../../../../../../src"; +import {Entity} from "../../../../../../src/index.ts"; +import {PrimaryColumn} from "../../../../../../src/index.ts"; +import {Column} from "../../../../../../src/index.ts"; @Entity() export class Post { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; @Column("varchar", { @@ -31,6 +31,6 @@ export class Post { @Column("varbinary", { length: 50 }) - varbinary: Buffer; + varbinary: Uint8Array;/*Buffer;*/ } diff --git a/test/functional/database-schema/column-length/sqlite/column-length-sqlite..ts b/test/functional/database-schema/column-length/sqlite/column-length-sqlite.ts similarity index 91% rename from test/functional/database-schema/column-length/sqlite/column-length-sqlite..ts rename to test/functional/database-schema/column-length/sqlite/column-length-sqlite.ts index deffdbd3a..c9c6c72e2 100644 --- a/test/functional/database-schema/column-length/sqlite/column-length-sqlite..ts +++ b/test/functional/database-schema/column-length/sqlite/column-length-sqlite.ts @@ -1,8 +1,8 @@ -import "reflect-metadata"; -import {expect} from "chai"; -import {Post} from "./entity/Post"; -import {Connection} from "../../../../../src/connection/Connection"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils"; +import {runIfMain} from "../../../../deps/mocha.ts"; +import {expect} from "../../../../deps/chai.ts"; +import {Post} from "./entity/Post.ts"; +import {Connection} from "../../../../../src/connection/Connection.ts"; +import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils.ts"; describe("database schema > column length > sqlite", () => { @@ -32,7 +32,7 @@ describe("database schema > column length > sqlite", () => { }))); it("all types should update their size", () => Promise.all(connections.map(async connection => { - + let metadata = connection.getMetadata(Post); metadata.findColumnWithPropertyName("character")!.length = "100"; metadata.findColumnWithPropertyName("varchar")!.length = "100"; @@ -57,5 +57,7 @@ describe("database schema > column length > sqlite", () => { await connection.synchronize(false); }))); - + }); + +runIfMain(import.meta); diff --git a/test/functional/database-schema/column-length/sqlite/entity/Post.ts b/test/functional/database-schema/column-length/sqlite/entity/Post.ts index 1f93951a6..abc324143 100644 --- a/test/functional/database-schema/column-length/sqlite/entity/Post.ts +++ b/test/functional/database-schema/column-length/sqlite/entity/Post.ts @@ -1,6 +1,6 @@ -import {Entity} from "../../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../../src/decorator/columns/Column"; +import {Entity} from "../../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../../src/decorator/columns/Column.ts"; @Entity() export class Post { @@ -38,4 +38,4 @@ export class Post { }) nvarchar: string; -} \ No newline at end of file +} diff --git a/test/functional/database-schema/column-types/cockroachdb/column-types-cockroach.ts b/test/functional/database-schema/column-types/cockroachdb/column-types-cockroach.ts index 452aba30d..4015984a1 100644 --- a/test/functional/database-schema/column-types/cockroachdb/column-types-cockroach.ts +++ b/test/functional/database-schema/column-types/cockroachdb/column-types-cockroach.ts @@ -1,16 +1,20 @@ -import "reflect-metadata"; -import {Connection} from "../../../../../src"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils"; -import {Post} from "./entity/Post"; -import {PostWithOptions} from "./entity/PostWithOptions"; -import {PostWithoutTypes} from "./entity/PostWithoutTypes"; +import {join as joinPaths} from "../../../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../../../deps/mocha.ts" +import "../../../../deps/chai.ts" +import {Connection} from "../../../../../src/index.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils.ts"; +import {Post} from "./entity/Post.ts"; +import {PostWithOptions} from "./entity/PostWithOptions.ts"; +import {PostWithoutTypes} from "./entity/PostWithoutTypes.ts"; describe("database schema > column types > cockroachdb", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); + const encoder = new TextEncoder(); before(async () => { connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], enabledDrivers: ["cockroachdb"], }); }); @@ -49,9 +53,10 @@ describe("database schema > column types > cockroachdb", () => { post.characterVarying = "This is character varying"; post.text = "This is text"; post.string = "This is string"; - post.bytes = Buffer.alloc(13, "This is bytes"); - post.bytea = Buffer.alloc(13, "This is bytea"); - post.blob = Buffer.alloc(12, "This is blob"); + // TODO(uki00a) not fully tested yet. + post.bytes = encoder.encode("This is bytes");/* Buffer.alloc(13, "This is bytes"); */ + post.bytea = encoder.encode("This is bytea");/* Buffer.alloc(13, "This is bytea"); */ + post.blob = encoder.encode("This is blob");/* Buffer.alloc(12, "This is blob"); */ post.date = "2017-06-21"; post.interval = "1 year 2 months 3 days 4 hours 5 minutes 6 seconds"; post.time = "05:40:00.000001"; @@ -261,3 +266,5 @@ describe("database schema > column types > cockroachdb", () => { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/database-schema/column-types/cockroachdb/entity/Post.ts b/test/functional/database-schema/column-types/cockroachdb/entity/Post.ts index 93e504bdb..45fd4492e 100644 --- a/test/functional/database-schema/column-types/cockroachdb/entity/Post.ts +++ b/test/functional/database-schema/column-types/cockroachdb/entity/Post.ts @@ -1,14 +1,14 @@ -import {Entity} from "../../../../../../src"; -import {PrimaryColumn} from "../../../../../../src"; -import {Column} from "../../../../../../src"; +import {Entity} from "../../../../../../src/index.ts"; +import {PrimaryColumn} from "../../../../../../src/index.ts"; +import {Column} from "../../../../../../src/index.ts"; @Entity() export class Post { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; - @Column() + @Column({ type: String }) name: string; // ------------------------------------------------------------------------- @@ -90,13 +90,13 @@ export class Post { // ------------------------------------------------------------------------- @Column("bytes") - bytes: Buffer; + bytes: Uint8Array;/* Buffer; */ @Column("bytea") - bytea: Buffer; + bytea: Uint8Array;/* Buffer; */ @Column("blob") - blob: Buffer; + blob: Uint8Array;/* Buffer; */ // ------------------------------------------------------------------------- // Date/Time Types diff --git a/test/functional/database-schema/column-types/cockroachdb/entity/PostWithOptions.ts b/test/functional/database-schema/column-types/cockroachdb/entity/PostWithOptions.ts index f8311ba48..48440b472 100644 --- a/test/functional/database-schema/column-types/cockroachdb/entity/PostWithOptions.ts +++ b/test/functional/database-schema/column-types/cockroachdb/entity/PostWithOptions.ts @@ -1,11 +1,11 @@ -import {Entity} from "../../../../../../src"; -import {PrimaryColumn} from "../../../../../../src"; -import {Column} from "../../../../../../src"; +import {Entity} from "../../../../../../src/index.ts"; +import {PrimaryColumn} from "../../../../../../src/index.ts"; +import {Column} from "../../../../../../src/index.ts"; @Entity() export class PostWithOptions { - @PrimaryColumn() + @PrimaryColumn({ type: String }) id: number; // ------------------------------------------------------------------------- diff --git a/test/functional/database-schema/column-types/cockroachdb/entity/PostWithoutTypes.ts b/test/functional/database-schema/column-types/cockroachdb/entity/PostWithoutTypes.ts index b6e7f4aaa..76c84f441 100644 --- a/test/functional/database-schema/column-types/cockroachdb/entity/PostWithoutTypes.ts +++ b/test/functional/database-schema/column-types/cockroachdb/entity/PostWithoutTypes.ts @@ -1,20 +1,20 @@ -import {Entity} from "../../../../../../src"; -import {PrimaryColumn} from "../../../../../../src"; -import {Column} from "../../../../../../src"; +import {Entity} from "../../../../../../src/index.ts"; +import {PrimaryColumn} from "../../../../../../src/index.ts"; +import {Column} from "../../../../../../src/index.ts"; @Entity() export class PostWithoutTypes { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; - @Column() + @Column({ type: String }) name: string; - @Column() + @Column({ type: Boolean }) boolean: boolean; - @Column() + @Column({ type: Date }) datetime: Date; } diff --git a/test/functional/database-schema/column-types/mssql/column-types-mssql.ts b/test/functional/database-schema/column-types/mssql/column-types-mssql.ts index b7afa047d..490b2460a 100644 --- a/test/functional/database-schema/column-types/mssql/column-types-mssql.ts +++ b/test/functional/database-schema/column-types/mssql/column-types-mssql.ts @@ -1,18 +1,22 @@ -import "reflect-metadata"; -import {Post} from "./entity/Post"; -import {Connection} from "../../../../../src/connection/Connection"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils"; -import {PostWithOptions} from "./entity/PostWithOptions"; -import {PostWithoutTypes} from "./entity/PostWithoutTypes"; -import {DateUtils} from "../../../../../src/util/DateUtils"; -import {FruitEnum} from "./enum/FruitEnum"; +import {join as joinPaths} from "../../../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../../../deps/mocha.ts"; +import "../../../../deps/chai.ts"; +import {Post} from "./entity/Post.ts"; +import {Connection} from "../../../../../src/connection/Connection.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils.ts"; +import {PostWithOptions} from "./entity/PostWithOptions.ts"; +import {PostWithoutTypes} from "./entity/PostWithoutTypes.ts"; +import {DateUtils} from "../../../../../src/util/DateUtils.ts"; +import {FruitEnum} from "./enum/FruitEnum.ts"; describe("database schema > column types > mssql", () => { // https://github.com/tediousjs/tedious/issues/722 let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); + const encoder = new TextEncoder(); before(async () => { connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], enabledDrivers: ["mssql"], }); }); @@ -48,9 +52,10 @@ describe("database schema > column types > mssql", () => { // https://github.com post.nchar = "A"; post.nvarchar = "This is nvarchar"; post.ntext = "This is ntext"; - post.binary = new Buffer("A"); - post.varbinary = new Buffer("B"); - post.image = new Buffer("This is image"); + // TODO(uki00a) not fully tested yet. + post.binary = encoder.encode("A");/* new Buffer("A"); */ + post.varbinary = encoder.encode("B");/* new Buffer("B"); */ + post.image = encoder.encode("This is image");/* new Buffer("This is image"); */ post.dateObj = new Date(); post.date = "2017-06-21"; post.datetime = new Date(); @@ -182,8 +187,9 @@ describe("database schema > column types > mssql", () => { // https://github.com post.varchar = "This is varchar"; post.nchar = "AAA"; post.nvarchar = "This is nvarchar"; - post.binary = new Buffer("AAAAA"); - post.varbinary = new Buffer("BBBBB"); + // TODO(uki00a) not fully tested yet. + post.binary = encoder.encode("AAAAA");/*new Buffer("AAAAA");*/ + post.varbinary = encoder.encode("BBBBB");/*new Buffer("BBBBB");*/ post.datetime2 = new Date(); post.time = new Date(); post.datetimeoffset = new Date(); @@ -252,7 +258,7 @@ describe("database schema > column types > mssql", () => { // https://github.com post.id = 1; post.name = "Post"; post.bit = true; - post.binary = new Buffer("A"); + post.binary = encoder.encode("A");/* new Buffer("A"); */ post.datetime = new Date(); post.datetime.setMilliseconds(0); // set milliseconds to zero because the SQL Server datetime type only has a 1/300 ms (~3.33Ģ… ms) resolution await postRepository.save(post); @@ -273,3 +279,5 @@ describe("database schema > column types > mssql", () => { // https://github.com }))); }); + +runIfMain(import.meta); diff --git a/test/functional/database-schema/column-types/mssql/entity/Post.ts b/test/functional/database-schema/column-types/mssql/entity/Post.ts index bdfb8e909..dadf4c5a8 100644 --- a/test/functional/database-schema/column-types/mssql/entity/Post.ts +++ b/test/functional/database-schema/column-types/mssql/entity/Post.ts @@ -1,15 +1,15 @@ -import {Entity} from "../../../../../../src/decorator/entity/Entity"; -import {PrimaryColumn} from "../../../../../../src/decorator/columns/PrimaryColumn"; -import {Column} from "../../../../../../src/decorator/columns/Column"; -import {FruitEnum} from "../enum/FruitEnum"; +import {Entity} from "../../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryColumn} from "../../../../../../src/decorator/columns/PrimaryColumn.ts"; +import {Column} from "../../../../../../src/decorator/columns/Column.ts"; +import {FruitEnum} from "../enum/FruitEnum.ts"; @Entity() export class Post { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; - @Column() + @Column({ type: String }) name: string; // ------------------------------------------------------------------------- @@ -78,16 +78,16 @@ export class Post { ntext: string; @Column("binary") - binary: Buffer; + binary: Uint8Array;/* Buffer; */ @Column("varbinary") - varbinary: Buffer; + varbinary: Uint8Array; /* Buffer; */ @Column("image") - image: Buffer; + image: Uint8Array; /* Buffer; */ @Column("rowversion") - rowversion: Buffer; + rowversion: Uint8Array; /* Buffer; */ // ------------------------------------------------------------------------- // Date Types @@ -145,4 +145,4 @@ export class Post { @Column("simple-enum", { enum: FruitEnum }) simpleClassEnum1: FruitEnum; -} \ No newline at end of file +} diff --git a/test/functional/database-schema/column-types/mssql/entity/PostWithOptions.ts b/test/functional/database-schema/column-types/mssql/entity/PostWithOptions.ts index d70b7a9ec..6f0752f3d 100644 --- a/test/functional/database-schema/column-types/mssql/entity/PostWithOptions.ts +++ b/test/functional/database-schema/column-types/mssql/entity/PostWithOptions.ts @@ -1,11 +1,11 @@ -import {Entity} from "../../../../../../src/decorator/entity/Entity"; -import {PrimaryColumn} from "../../../../../../src/decorator/columns/PrimaryColumn"; -import {Column} from "../../../../../../src/decorator/columns/Column"; +import {Entity} from "../../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryColumn} from "../../../../../../src/decorator/columns/PrimaryColumn.ts"; +import {Column} from "../../../../../../src/decorator/columns/Column.ts"; @Entity() export class PostWithOptions { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; // ------------------------------------------------------------------------- @@ -38,10 +38,10 @@ export class PostWithOptions { nvarchar: string; @Column("binary", { length: 5 }) - binary: Buffer; + binary: Uint8Array; /* Buffer; */ @Column("varbinary", { length: 5 }) - varbinary: Buffer; + varbinary: Uint8Array; /* Buffer; */ // ------------------------------------------------------------------------- // Date Types @@ -56,4 +56,4 @@ export class PostWithOptions { @Column("datetimeoffset", { precision: 6 }) datetimeoffset: Date; -} \ No newline at end of file +} diff --git a/test/functional/database-schema/column-types/mssql/entity/PostWithoutTypes.ts b/test/functional/database-schema/column-types/mssql/entity/PostWithoutTypes.ts index b16118a0e..c3a4fba04 100644 --- a/test/functional/database-schema/column-types/mssql/entity/PostWithoutTypes.ts +++ b/test/functional/database-schema/column-types/mssql/entity/PostWithoutTypes.ts @@ -1,23 +1,23 @@ -import {Entity} from "../../../../../../src/decorator/entity/Entity"; -import {PrimaryColumn} from "../../../../../../src/decorator/columns/PrimaryColumn"; -import {Column} from "../../../../../../src/decorator/columns/Column"; +import {Entity} from "../../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryColumn} from "../../../../../../src/decorator/columns/PrimaryColumn.ts"; +import {Column} from "../../../../../../src/decorator/columns/Column.ts"; @Entity() export class PostWithoutTypes { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; - @Column() + @Column({ type: String }) name: string; - @Column() + @Column({ type: Boolean }) bit: boolean; - @Column() - binary: Buffer; + @Column({ type: Uint8Array }) + binary: Uint8Array; /* Buffer; */ - @Column() + @Column({ type: Date }) datetime: Date; -} \ No newline at end of file +} diff --git a/test/functional/database-schema/column-types/mysql/column-types-mysql.ts b/test/functional/database-schema/column-types/mysql/column-types-mysql.ts index 287a81b40..3ee57182d 100644 --- a/test/functional/database-schema/column-types/mysql/column-types-mysql.ts +++ b/test/functional/database-schema/column-types/mysql/column-types-mysql.ts @@ -1,17 +1,21 @@ -import "reflect-metadata"; -import {Post} from "./entity/Post"; -import {Connection} from "../../../../../src/connection/Connection"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils"; -import {PostWithOptions} from "./entity/PostWithOptions"; -import {PostWithoutTypes} from "./entity/PostWithoutTypes"; -import {FruitEnum} from "./enum/FruitEnum"; +import {join as joinPaths} from "../../../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../../../deps/mocha.ts"; +import "../../../../deps/chai.ts"; +import {Post} from "./entity/Post.ts"; +import {Connection} from "../../../../../src/connection/Connection.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils.ts"; +import {PostWithOptions} from "./entity/PostWithOptions.ts"; +import {PostWithoutTypes} from "./entity/PostWithoutTypes.ts"; +import {FruitEnum} from "./enum/FruitEnum.ts"; describe("database schema > column types > mysql", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); + const encoder = new TextEncoder(); before(async () => { connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], enabledDrivers: ["mysql"], }); }); @@ -27,7 +31,8 @@ describe("database schema > column types > mysql", () => { const post = new Post(); post.id = 1; - post.bit = Buffer.from([0]); + // TODO(uki00a) not fully tested yet. + post.bit = new Uint8Array([0]);/* Buffer.from([0]); */ post.int = 2147483647; post.integer = 2147483647; post.tinyint = 127; @@ -61,12 +66,13 @@ describe("database schema > column types > mysql", () => { post.timestamp.setMilliseconds(0); // set milliseconds to zero, because if datetime type specified without precision, milliseconds won't save in database post.time = "15:30:00"; post.year = 2017; - post.binary = new Buffer("A"); - post.varbinary = new Buffer("B"); - post.blob = new Buffer("This is blob"); - post.tinyblob = new Buffer("This is tinyblob"); - post.mediumblob = new Buffer("This is mediumblob"); - post.longblob = new Buffer("This is longblob"); + // TODO(uki00a) not fully tested yet. + post.binary = encoder.encode("A");/* new Buffer("A"); */ + post.varbinary = encoder.encode("B");/* new Buffer("B"); */ + post.blob = encoder.encode("This is blob");/* new Buffer("This is blob"); */ + post.tinyblob = encoder.encode("This is tinyblob");/* new Buffer("This is tinyblob"); */ + post.mediumblob = encoder.encode("This is mediumblob");/* new Buffer("This is mediumblob"); */ + post.longblob = encoder.encode("This is longblob");/* new Buffer("This is longblob"); */ post.geometry = "POINT(1 1)"; post.point = "POINT(1 1)"; post.linestring = "LINESTRING(0 0,1 1,2 2)"; @@ -278,7 +284,8 @@ describe("database schema > column types > mysql", () => { post.id = 1; post.name = "Post"; post.boolean = true; - post.blob = new Buffer("A"); + // TODO(uki00a) not fully tested yet. + post.blob = encoder.encode("A");/* new Buffer("A"); */ post.datetime = new Date(); post.datetime.setMilliseconds(0); // set milliseconds to zero, because if datetime type specified without precision, milliseconds won't save in database await postRepository.save(post); @@ -299,3 +306,5 @@ describe("database schema > column types > mysql", () => { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/database-schema/column-types/mysql/entity/Post.ts b/test/functional/database-schema/column-types/mysql/entity/Post.ts index cde433a07..b017e0c20 100644 --- a/test/functional/database-schema/column-types/mysql/entity/Post.ts +++ b/test/functional/database-schema/column-types/mysql/entity/Post.ts @@ -1,7 +1,7 @@ -import {Entity} from "../../../../../../src/decorator/entity/Entity"; -import {PrimaryColumn} from "../../../../../../src/decorator/columns/PrimaryColumn"; -import {Column} from "../../../../../../src/decorator/columns/Column"; -import {FruitEnum} from "../enum/FruitEnum"; +import {Entity} from "../../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryColumn} from "../../../../../../src/decorator/columns/PrimaryColumn.ts"; +import {Column} from "../../../../../../src/decorator/columns/Column.ts"; +import {FruitEnum} from "../enum/FruitEnum.ts"; @Entity() export class Post { @@ -10,11 +10,11 @@ export class Post { // Numeric Types // ------------------------------------------------------------------------- - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; @Column("bit") - bit: Buffer; + bit: Uint8Array; /* Buffer; */ @Column("int") int: number; @@ -106,26 +106,26 @@ export class Post { // Binary Types // ------------------------------------------------------------------------- @Column("binary") - binary: Buffer; + binary: Uint8Array; /* Buffer; */ @Column("varbinary") - varbinary: Buffer; + varbinary: Uint8Array; /* Buffer; */ // ------------------------------------------------------------------------- // LOB Types // ------------------------------------------------------------------------- @Column("blob") - blob: Buffer; + blob: Uint8Array; /* Buffer; */ @Column("tinyblob") - tinyblob: Buffer; + tinyblob: Uint8Array; /* Buffer; */ @Column("mediumblob") - mediumblob: Buffer; + mediumblob: Uint8Array; /* Buffer; */ @Column("longblob") - longblob: Buffer; + longblob: Uint8Array; /* Buffer; */ // ------------------------------------------------------------------------- // Date Types diff --git a/test/functional/database-schema/column-types/mysql/entity/PostWithOptions.ts b/test/functional/database-schema/column-types/mysql/entity/PostWithOptions.ts index e6c0aed10..b9004cc22 100644 --- a/test/functional/database-schema/column-types/mysql/entity/PostWithOptions.ts +++ b/test/functional/database-schema/column-types/mysql/entity/PostWithOptions.ts @@ -1,14 +1,14 @@ -import {Entity} from "../../../../../../src/decorator/entity/Entity"; -import {PrimaryColumn} from "../../../../../../src/decorator/columns/PrimaryColumn"; -import {Column} from "../../../../../../src/decorator/columns/Column"; +import {Entity} from "../../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryColumn} from "../../../../../../src/decorator/columns/PrimaryColumn.ts"; +import {Column} from "../../../../../../src/decorator/columns/Column.ts"; @Entity() export class PostWithOptions { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; - @Column({ length: 10 }) + @Column({ length: 10, type: String }) name: string; @Column("float", { precision: 5, scale: 2 }) @@ -35,4 +35,4 @@ export class PostWithOptions { @Column("time", { precision: 3 }) time: string; -} \ No newline at end of file +} diff --git a/test/functional/database-schema/column-types/mysql/entity/PostWithoutTypes.ts b/test/functional/database-schema/column-types/mysql/entity/PostWithoutTypes.ts index d666f1244..d8a8df2cf 100644 --- a/test/functional/database-schema/column-types/mysql/entity/PostWithoutTypes.ts +++ b/test/functional/database-schema/column-types/mysql/entity/PostWithoutTypes.ts @@ -1,23 +1,23 @@ -import {Entity} from "../../../../../../src/decorator/entity/Entity"; -import {PrimaryColumn} from "../../../../../../src/decorator/columns/PrimaryColumn"; -import {Column} from "../../../../../../src/decorator/columns/Column"; +import {Entity} from "../../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryColumn} from "../../../../../../src/decorator/columns/PrimaryColumn.ts"; +import {Column} from "../../../../../../src/decorator/columns/Column.ts"; @Entity() export class PostWithoutTypes { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; - @Column() + @Column({ type: String }) name: string; - @Column() + @Column({ type: Boolean }) boolean: boolean; - @Column() - blob: Buffer; + @Column({ type: Uint8Array }) + blob: Uint8Array; /* Buffer; */ - @Column() + @Column({ type: Date }) datetime: Date; -} \ No newline at end of file +} diff --git a/test/functional/database-schema/column-types/oracle/column-types-oracle.ts b/test/functional/database-schema/column-types/oracle/column-types-oracle.ts index e07dd3795..85d069262 100644 --- a/test/functional/database-schema/column-types/oracle/column-types-oracle.ts +++ b/test/functional/database-schema/column-types/oracle/column-types-oracle.ts @@ -1,17 +1,21 @@ -import "reflect-metadata"; -import {Post} from "./entity/Post"; -import {Connection} from "../../../../../src/connection/Connection"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils"; -import {PostWithOptions} from "./entity/PostWithOptions"; -import {PostWithoutTypes} from "./entity/PostWithoutTypes"; -import {DateUtils} from "../../../../../src/util/DateUtils"; +import {join as joinPaths} from "../../../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../../../deps/mocha.ts"; +import "../../../../deps/chai.ts"; +import {Post} from "./entity/Post.ts"; +import {Connection} from "../../../../../src/connection/Connection.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils.ts"; +import {PostWithOptions} from "./entity/PostWithOptions.ts"; +import {PostWithoutTypes} from "./entity/PostWithoutTypes.ts"; +import {DateUtils} from "../../../../../src/util/DateUtils.ts"; describe("database schema > column types > oracle", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); + const encoder = new TextEncoder(); before(async () => { connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], enabledDrivers: ["oracle"], }); }); @@ -43,7 +47,8 @@ describe("database schema > column types > oracle", () => { post.varchar2 = "This is varchar2"; post.nvarchar2 = "This is nvarchar2"; post.long = "This is long"; - post.raw = new Buffer("This is raw"); + // TODO(uki00a) not fully tested yet. + post.raw = encoder.encode("This is raw");/* new Buffer("This is raw"); */ post.dateObj = new Date(); post.date = "2017-06-21"; post.timestamp = new Date(); @@ -52,7 +57,8 @@ describe("database schema > column types > oracle", () => { post.timestampWithTimeZone.setMilliseconds(0); post.timestampWithLocalTimeZone = new Date(); post.timestampWithLocalTimeZone.setMilliseconds(0); - post.blob = new Buffer("This is blob"); + // TODO(uki00a) not fully tested yet. + post.blob = encoder.encode("This is blob");/* new Buffer("This is blob"); */ post.clob = "This is clob"; post.nclob = "This is nclob"; post.simpleArray = ["A", "B", "C"]; @@ -137,7 +143,7 @@ describe("database schema > column types > oracle", () => { post.nchar = "AAA"; post.varchar2 = "This is varchar"; post.nvarchar2 = "This is nvarchar"; - post.raw = new Buffer("This is raw"); + post.raw = encoder.encode("This is raw");/* new Buffer("This is raw"); */ post.timestamp = new Date(); post.timestampWithTimeZone = new Date(); post.timestampWithLocalTimeZone = new Date(); @@ -204,7 +210,7 @@ describe("database schema > column types > oracle", () => { post.id = 1; post.name = "Post"; post.boolean = true; - post.blob = new Buffer("This is blob"); + post.blob = encoder.encode("This is blob");/* new Buffer("This is blob"); */ post.datetime = new Date(); await postRepository.save(post); @@ -224,3 +230,5 @@ describe("database schema > column types > oracle", () => { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/database-schema/column-types/oracle/entity/Post.ts b/test/functional/database-schema/column-types/oracle/entity/Post.ts index 09e5c744f..f3d697272 100644 --- a/test/functional/database-schema/column-types/oracle/entity/Post.ts +++ b/test/functional/database-schema/column-types/oracle/entity/Post.ts @@ -1,14 +1,14 @@ -import {Entity} from "../../../../../../src/decorator/entity/Entity"; -import {PrimaryColumn} from "../../../../../../src/decorator/columns/PrimaryColumn"; -import {Column} from "../../../../../../src/decorator/columns/Column"; +import {Entity} from "../../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryColumn} from "../../../../../../src/decorator/columns/PrimaryColumn.ts"; +import {Column} from "../../../../../../src/decorator/columns/Column.ts"; @Entity() export class Post { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; - @Column() + @Column({ type: String }) name: string; // ------------------------------------------------------------------------- @@ -65,7 +65,7 @@ export class Post { long: string; @Column("raw") - raw: Buffer; + raw: Uint8Array; /* Buffer; */ // ------------------------------------------------------------------------- // Date Types @@ -91,7 +91,7 @@ export class Post { // ------------------------------------------------------------------------- @Column("blob") - blob: Buffer; + blob: Uint8Array; /* Buffer; */ @Column("clob") clob: string; @@ -106,4 +106,4 @@ export class Post { @Column("simple-array") simpleArray: string[]; -} \ No newline at end of file +} diff --git a/test/functional/database-schema/column-types/oracle/entity/PostWithOptions.ts b/test/functional/database-schema/column-types/oracle/entity/PostWithOptions.ts index c5ba610ea..e16b79bb6 100644 --- a/test/functional/database-schema/column-types/oracle/entity/PostWithOptions.ts +++ b/test/functional/database-schema/column-types/oracle/entity/PostWithOptions.ts @@ -1,11 +1,11 @@ -import {Entity} from "../../../../../../src/decorator/entity/Entity"; -import {PrimaryColumn} from "../../../../../../src/decorator/columns/PrimaryColumn"; -import {Column} from "../../../../../../src/decorator/columns/Column"; +import {Entity} from "../../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryColumn} from "../../../../../../src/decorator/columns/PrimaryColumn.ts"; +import {Column} from "../../../../../../src/decorator/columns/Column.ts"; @Entity() export class PostWithOptions { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; // ------------------------------------------------------------------------- @@ -44,7 +44,7 @@ export class PostWithOptions { nvarchar2: string; @Column("raw", { length: 500 }) - raw: Buffer; + raw: Uint8Array; /* Buffer; */ // ------------------------------------------------------------------------- // Date Types @@ -59,4 +59,4 @@ export class PostWithOptions { @Column("timestamp with local time zone", { precision: 7 }) timestampWithLocalTimeZone: Date; -} \ No newline at end of file +} diff --git a/test/functional/database-schema/column-types/oracle/entity/PostWithoutTypes.ts b/test/functional/database-schema/column-types/oracle/entity/PostWithoutTypes.ts index d666f1244..d8a8df2cf 100644 --- a/test/functional/database-schema/column-types/oracle/entity/PostWithoutTypes.ts +++ b/test/functional/database-schema/column-types/oracle/entity/PostWithoutTypes.ts @@ -1,23 +1,23 @@ -import {Entity} from "../../../../../../src/decorator/entity/Entity"; -import {PrimaryColumn} from "../../../../../../src/decorator/columns/PrimaryColumn"; -import {Column} from "../../../../../../src/decorator/columns/Column"; +import {Entity} from "../../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryColumn} from "../../../../../../src/decorator/columns/PrimaryColumn.ts"; +import {Column} from "../../../../../../src/decorator/columns/Column.ts"; @Entity() export class PostWithoutTypes { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; - @Column() + @Column({ type: String }) name: string; - @Column() + @Column({ type: Boolean }) boolean: boolean; - @Column() - blob: Buffer; + @Column({ type: Uint8Array }) + blob: Uint8Array; /* Buffer; */ - @Column() + @Column({ type: Date }) datetime: Date; -} \ No newline at end of file +} diff --git a/test/functional/database-schema/column-types/postgres-enum/entity/Post.ts b/test/functional/database-schema/column-types/postgres-enum/entity/Post.ts index 9d32a1fc4..21a2ec6d2 100644 --- a/test/functional/database-schema/column-types/postgres-enum/entity/Post.ts +++ b/test/functional/database-schema/column-types/postgres-enum/entity/Post.ts @@ -1,6 +1,6 @@ -import {Column} from "../../../../../../src/decorator/columns/Column"; -import {Entity} from "../../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../../src"; +import {Column} from "../../../../../../src/decorator/columns/Column.ts"; +import {Entity} from "../../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../../src/index.ts"; @Entity() export class Post { @@ -14,6 +14,6 @@ export class Post { @Column("simple-enum", { enum: ["A", "B", "C"] }) simpleEnum: string; - @Column() + @Column({ type: String }) name: string; -} \ No newline at end of file +} diff --git a/test/functional/database-schema/column-types/postgres-enum/postgres-enum.ts b/test/functional/database-schema/column-types/postgres-enum/postgres-enum.ts index fef3c5d53..e1781e5fc 100644 --- a/test/functional/database-schema/column-types/postgres-enum/postgres-enum.ts +++ b/test/functional/database-schema/column-types/postgres-enum/postgres-enum.ts @@ -1,16 +1,18 @@ -import "reflect-metadata"; -import {Connection} from "../../../../../src/connection/Connection"; -import {expect} from "chai"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils"; -import {Post} from "./entity/Post"; -import {Table, TableColumn} from "../../../../../src"; +import {join as joinPaths} from "../../../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../../../deps/mocha.ts"; +import {expect} from "../../../../deps/chai.ts"; +import {Connection} from "../../../../../src/connection/Connection.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils.ts"; +import {Post} from "./entity/Post.ts"; +import {Table, TableColumn} from "../../../../../src/index.ts"; describe("database schema > column types > postgres-enum", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => { connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], enabledDrivers: ["postgres"], }); }); @@ -243,3 +245,5 @@ describe("database schema > column types > postgres-enum", () => { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/database-schema/column-types/postgres/column-types-postgres.ts b/test/functional/database-schema/column-types/postgres/column-types-postgres.ts index 9f192cc42..e1879a600 100644 --- a/test/functional/database-schema/column-types/postgres/column-types-postgres.ts +++ b/test/functional/database-schema/column-types/postgres/column-types-postgres.ts @@ -1,16 +1,20 @@ -import "reflect-metadata"; -import {PostWithOptions} from "./entity/PostWithOptions"; -import {Connection} from "../../../../../src/connection/Connection"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils"; -import {PostWithoutTypes} from "./entity/PostWithoutTypes"; -import {Post} from "./entity/Post"; +import {join as joinPaths} from "../../../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../../../deps/mocha.ts"; +import "../../../../deps/chai.ts"; +import {PostWithOptions} from "./entity/PostWithOptions.ts"; +import {Connection} from "../../../../../src/connection/Connection.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils.ts"; +import {PostWithoutTypes} from "./entity/PostWithoutTypes.ts"; +import {Post} from "./entity/Post.ts"; describe("database schema > column types > postgres", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); + const encoder = new TextEncoder(); before(async () => { connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], enabledDrivers: ["postgres"], }); }); @@ -48,7 +52,8 @@ describe("database schema > column types > postgres", () => { post.text = "This is text"; post.citext = "This is text"; post.hstore = "name => Alice, surname => A, age => 30"; - post.bytea = new Buffer("This is bytea"); + // TODO(uki00a) not fully tested yet. + post.bytea = encoder.encode("This is bytea");/* new Buffer("This is bytea"); */ post.date = "2017-06-21"; post.interval = "1 year 2 months 3 days 4 hours 5 minutes 6 seconds"; post.time = "15:30:00"; @@ -323,3 +328,5 @@ describe("database schema > column types > postgres", () => { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/database-schema/column-types/postgres/entity/Post.ts b/test/functional/database-schema/column-types/postgres/entity/Post.ts index a8a6610e3..dbfc3d46b 100644 --- a/test/functional/database-schema/column-types/postgres/entity/Post.ts +++ b/test/functional/database-schema/column-types/postgres/entity/Post.ts @@ -1,14 +1,14 @@ -import {Entity} from "../../../../../../src/decorator/entity/Entity"; -import {PrimaryColumn} from "../../../../../../src/decorator/columns/PrimaryColumn"; -import {Column} from "../../../../../../src/decorator/columns/Column"; +import {Entity} from "../../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryColumn} from "../../../../../../src/decorator/columns/PrimaryColumn.ts"; +import {Column} from "../../../../../../src/decorator/columns/Column.ts"; @Entity() export class Post { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; - @Column() + @Column({ type: String }) name: string; // ------------------------------------------------------------------------- @@ -91,7 +91,7 @@ export class Post { // ------------------------------------------------------------------------- @Column("bytea") - bytea: Buffer; + bytea: Uint8Array; /* Buffer; */ // ------------------------------------------------------------------------- // Date/Time Types @@ -254,4 +254,4 @@ export class Post { @Column("simple-enum", { enum: ["A", "B", "C"] }) simpleEnum: string; -} \ No newline at end of file +} diff --git a/test/functional/database-schema/column-types/postgres/entity/PostWithOptions.ts b/test/functional/database-schema/column-types/postgres/entity/PostWithOptions.ts index 2819bc436..05f261a73 100644 --- a/test/functional/database-schema/column-types/postgres/entity/PostWithOptions.ts +++ b/test/functional/database-schema/column-types/postgres/entity/PostWithOptions.ts @@ -1,11 +1,11 @@ -import {Entity} from "../../../../../../src/decorator/entity/Entity"; -import {PrimaryColumn} from "../../../../../../src/decorator/columns/PrimaryColumn"; -import {Column} from "../../../../../../src/decorator/columns/Column"; +import {Entity} from "../../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryColumn} from "../../../../../../src/decorator/columns/PrimaryColumn.ts"; +import {Column} from "../../../../../../src/decorator/columns/Column.ts"; @Entity() export class PostWithOptions { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; // ------------------------------------------------------------------------- @@ -52,4 +52,4 @@ export class PostWithOptions { @Column("int4range", { nullable: true }) int4range: string; -} \ No newline at end of file +} diff --git a/test/functional/database-schema/column-types/postgres/entity/PostWithoutTypes.ts b/test/functional/database-schema/column-types/postgres/entity/PostWithoutTypes.ts index 4c81793b5..ea2418be0 100644 --- a/test/functional/database-schema/column-types/postgres/entity/PostWithoutTypes.ts +++ b/test/functional/database-schema/column-types/postgres/entity/PostWithoutTypes.ts @@ -1,20 +1,20 @@ -import {Entity} from "../../../../../../src/decorator/entity/Entity"; -import {PrimaryColumn} from "../../../../../../src/decorator/columns/PrimaryColumn"; -import {Column} from "../../../../../../src/decorator/columns/Column"; +import {Entity} from "../../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryColumn} from "../../../../../../src/decorator/columns/PrimaryColumn.ts"; +import {Column} from "../../../../../../src/decorator/columns/Column.ts"; @Entity() export class PostWithoutTypes { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; - @Column() + @Column({ type: String }) name: string; - @Column() + @Column({ type: Boolean }) bit: boolean; - @Column() + @Column({ type: Date }) datetime: Date; -} \ No newline at end of file +} diff --git a/test/functional/database-schema/column-types/sap/column-types-sap.ts b/test/functional/database-schema/column-types/sap/column-types-sap.ts index 569d5db94..460b90c47 100644 --- a/test/functional/database-schema/column-types/sap/column-types-sap.ts +++ b/test/functional/database-schema/column-types/sap/column-types-sap.ts @@ -1,17 +1,21 @@ -import "reflect-metadata"; -import {Post} from "./entity/Post"; -import {Connection} from "../../../../../src"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils"; -import {PostWithOptions} from "./entity/PostWithOptions"; -import {PostWithoutTypes} from "./entity/PostWithoutTypes"; -import {DateUtils} from "../../../../../src/util/DateUtils"; +import {join as joinPaths} from "../../../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../../../deps/mocha.ts"; +import "../../../../deps/chai.ts"; +import {Post} from "./entity/Post.ts"; +import {Connection} from "../../../../../src/index.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils.ts"; +import {PostWithOptions} from "./entity/PostWithOptions.ts"; +import {PostWithoutTypes} from "./entity/PostWithoutTypes.ts"; +import {DateUtils} from "../../../../../src/util/DateUtils.ts"; describe("database schema > column types > sap", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); + const encoder = new TextEncoder(); before(async () => { connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], enabledDrivers: ["sap"], }); }); @@ -54,12 +58,14 @@ describe("database schema > column types > sap", () => { post.timestamp.setMilliseconds(0); post.seconddate = new Date(); post.seconddate.setMilliseconds(0); - post.blob = new Buffer("This is blob"); + // TODO(uki00a) not fully tested yet. + post.blob = encoder.encode("This is blob");/* new Buffer("This is blob"); */ post.clob = "This is clob"; post.nclob = "This is nclob"; post.boolean = true; // post.array = ["A", "B", "C"]; // TODO - post.varbinary = new Buffer("This is varbinary"); + // TODO(uki00a) not fully tested yet. + post.varbinary = encoder.encode("This is varbinary");/* new Buffer("This is varbinary"); */ post.simpleArray = ["A", "B", "C"]; await postRepository.save(post); @@ -187,7 +193,8 @@ describe("database schema > column types > sap", () => { post.id = 1; post.name = "Post"; post.boolean = true; - post.blob = new Buffer("This is blob"); + // TODO(uki00a) not fully tested yet. + post.blob = encoder.encode("This is blob");/* new Buffer("This is blob"); */ post.timestamp = new Date(); await postRepository.save(post); @@ -207,3 +214,5 @@ describe("database schema > column types > sap", () => { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/database-schema/column-types/sap/entity/Post.ts b/test/functional/database-schema/column-types/sap/entity/Post.ts index aef776530..c034d238e 100644 --- a/test/functional/database-schema/column-types/sap/entity/Post.ts +++ b/test/functional/database-schema/column-types/sap/entity/Post.ts @@ -1,14 +1,14 @@ -import {Entity} from "../../../../../../src"; -import {PrimaryColumn} from "../../../../../../src"; -import {Column} from "../../../../../../src"; +import {Entity} from "../../../../../../src/index.ts"; +import {PrimaryColumn} from "../../../../../../src/index.ts"; +import {Column} from "../../../../../../src/index.ts"; @Entity() export class Post { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; - @Column() + @Column({ type: String }) name: string; // ------------------------------------------------------------------------- @@ -100,7 +100,7 @@ export class Post { // ------------------------------------------------------------------------- @Column("blob") - blob: Buffer; + blob: Uint8Array; /* Buffer; */ @Column("clob") clob: string; @@ -119,7 +119,7 @@ export class Post { // array: string[]; @Column("varbinary") - varbinary: Buffer; + varbinary: Uint8Array; /* Buffer; */ // ------------------------------------------------------------------------- // TypeOrm Specific Type diff --git a/test/functional/database-schema/column-types/sap/entity/PostWithOptions.ts b/test/functional/database-schema/column-types/sap/entity/PostWithOptions.ts index 63e411a69..b27f3fe39 100644 --- a/test/functional/database-schema/column-types/sap/entity/PostWithOptions.ts +++ b/test/functional/database-schema/column-types/sap/entity/PostWithOptions.ts @@ -1,11 +1,11 @@ -import {Entity} from "../../../../../../src"; -import {PrimaryColumn} from "../../../../../../src"; -import {Column} from "../../../../../../src"; +import {Entity} from "../../../../../../src/index.ts"; +import {PrimaryColumn} from "../../../../../../src/index.ts"; +import {Column} from "../../../../../../src/index.ts"; @Entity() export class PostWithOptions { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; // ------------------------------------------------------------------------- diff --git a/test/functional/database-schema/column-types/sap/entity/PostWithoutTypes.ts b/test/functional/database-schema/column-types/sap/entity/PostWithoutTypes.ts index 142742adf..bac8f7b10 100644 --- a/test/functional/database-schema/column-types/sap/entity/PostWithoutTypes.ts +++ b/test/functional/database-schema/column-types/sap/entity/PostWithoutTypes.ts @@ -1,23 +1,23 @@ -import {Entity} from "../../../../../../src"; -import {PrimaryColumn} from "../../../../../../src"; -import {Column} from "../../../../../../src"; +import {Entity} from "../../../../../../src/index.ts"; +import {PrimaryColumn} from "../../../../../../src/index.ts"; +import {Column} from "../../../../../../src/index.ts"; @Entity() export class PostWithoutTypes { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; - @Column() + @Column({ type: String }) name: string; - @Column() + @Column({ type: Boolean }) boolean: boolean; - @Column() - blob: Buffer; + @Column({ type: Uint8Array }) + blob: Uint8Array; /* Buffer; */ - @Column() + @Column({ type: Date }) timestamp: Date; } diff --git a/test/functional/database-schema/column-types/sqlite/column-types-sqlite.ts b/test/functional/database-schema/column-types/sqlite/column-types-sqlite.ts index b44220a4b..fc0565d56 100644 --- a/test/functional/database-schema/column-types/sqlite/column-types-sqlite.ts +++ b/test/functional/database-schema/column-types/sqlite/column-types-sqlite.ts @@ -1,16 +1,20 @@ -import "reflect-metadata"; -import {Post} from "./entity/Post"; -import {Connection} from "../../../../../src/connection/Connection"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils"; -import {PostWithoutTypes} from "./entity/PostWithoutTypes"; -import {FruitEnum} from "./enum/FruitEnum"; +import {join as joinPaths} from "../../../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../../../deps/mocha.ts"; +import "../../../../deps/chai.ts"; +import {Post} from "./entity/Post.ts"; +import {Connection} from "../../../../../src/connection/Connection.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils.ts"; +import {PostWithoutTypes} from "./entity/PostWithoutTypes.ts"; +import {FruitEnum} from "./enum/FruitEnum.ts"; describe("database schema > column types > sqlite", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); + const encoder = new TextEncoder(); before(async () => { connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], enabledDrivers: ["sqlite"], }); }); @@ -42,7 +46,8 @@ describe("database schema > column types > sqlite", () => { post.nchar = "This is nchar"; post.nativeCharacter = "This is native character"; post.nvarchar = "This is nvarchar"; - post.blob = new Buffer("This is blob"); + // TODO(uki00a) not fully tested yet. + post.blob = encoder.encode("This is blob");/* new Buffer("This is blob"); */ post.clob = "This is clob"; post.text = "This is text"; post.real = 10.5; @@ -150,7 +155,7 @@ describe("database schema > column types > sqlite", () => { post.id = 1; post.name = "Post"; post.boolean = true; - post.blob = new Buffer("A"); + post.blob = encoder.encode("A");/* new Buffer("A"); */ post.datetime = new Date(); post.datetime.setMilliseconds(0); await postRepository.save(post); @@ -171,3 +176,5 @@ describe("database schema > column types > sqlite", () => { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/database-schema/column-types/sqlite/entity/Post.ts b/test/functional/database-schema/column-types/sqlite/entity/Post.ts index 3be2fbd44..e6bb6601d 100644 --- a/test/functional/database-schema/column-types/sqlite/entity/Post.ts +++ b/test/functional/database-schema/column-types/sqlite/entity/Post.ts @@ -1,15 +1,15 @@ -import {Entity} from "../../../../../../src/decorator/entity/Entity"; -import {PrimaryColumn} from "../../../../../../src/decorator/columns/PrimaryColumn"; -import {Column} from "../../../../../../src/decorator/columns/Column"; -import {FruitEnum} from "../enum/FruitEnum"; +import {Entity} from "../../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryColumn} from "../../../../../../src/decorator/columns/PrimaryColumn.ts"; +import {Column} from "../../../../../../src/decorator/columns/Column.ts"; +import {FruitEnum} from "../enum/FruitEnum.ts"; @Entity() export class Post { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; - @Column() + @Column({ type: String }) name: string; // ------------------------------------------------------------------------- @@ -69,7 +69,7 @@ export class Post { text: string; @Column("blob") - blob: Buffer; + blob: Uint8Array; /* Buffer; */ @Column("clob") clob: string; diff --git a/test/functional/database-schema/column-types/sqlite/entity/PostWithoutTypes.ts b/test/functional/database-schema/column-types/sqlite/entity/PostWithoutTypes.ts index d666f1244..d8a8df2cf 100644 --- a/test/functional/database-schema/column-types/sqlite/entity/PostWithoutTypes.ts +++ b/test/functional/database-schema/column-types/sqlite/entity/PostWithoutTypes.ts @@ -1,23 +1,23 @@ -import {Entity} from "../../../../../../src/decorator/entity/Entity"; -import {PrimaryColumn} from "../../../../../../src/decorator/columns/PrimaryColumn"; -import {Column} from "../../../../../../src/decorator/columns/Column"; +import {Entity} from "../../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryColumn} from "../../../../../../src/decorator/columns/PrimaryColumn.ts"; +import {Column} from "../../../../../../src/decorator/columns/Column.ts"; @Entity() export class PostWithoutTypes { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; - @Column() + @Column({ type: String }) name: string; - @Column() + @Column({ type: Boolean }) boolean: boolean; - @Column() - blob: Buffer; + @Column({ type: Uint8Array }) + blob: Uint8Array; /* Buffer; */ - @Column() + @Column({ type: Date }) datetime: Date; -} \ No newline at end of file +} diff --git a/test/functional/database-schema/column-width/mysql/column-width.ts b/test/functional/database-schema/column-width/mysql/column-width.ts index 7ec53e3de..999bafb49 100644 --- a/test/functional/database-schema/column-width/mysql/column-width.ts +++ b/test/functional/database-schema/column-width/mysql/column-width.ts @@ -1,8 +1,8 @@ -import "reflect-metadata"; -import {expect} from "chai"; -import {Post} from "./entity/Post"; -import {Connection} from "../../../../../src/connection/Connection"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils"; +import {runIfMain} from "../../../../deps/mocha.ts"; +import {expect} from "../../../../deps/chai.ts"; +import {Post} from "./entity/Post.ts"; +import {Connection} from "../../../../../src/connection/Connection.ts"; +import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils.ts"; describe("database schema > column width", () => { @@ -54,3 +54,5 @@ describe("database schema > column width", () => { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/database-schema/column-width/mysql/entity/Post.ts b/test/functional/database-schema/column-width/mysql/entity/Post.ts index 5db2a9629..a03f26593 100644 --- a/test/functional/database-schema/column-width/mysql/entity/Post.ts +++ b/test/functional/database-schema/column-width/mysql/entity/Post.ts @@ -1,11 +1,11 @@ -import {Entity} from "../../../../../../src/decorator/entity/Entity"; -import {PrimaryColumn} from "../../../../../../src/decorator/columns/PrimaryColumn"; -import {Column} from "../../../../../../src/decorator/columns/Column"; +import {Entity} from "../../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryColumn} from "../../../../../../src/decorator/columns/PrimaryColumn.ts"; +import {Column} from "../../../../../../src/decorator/columns/Column.ts"; @Entity() export class Post { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; @Column("int", { width: 10 }) diff --git a/test/functional/database-schema/enums-array/entity/EnumArrayEntity.ts b/test/functional/database-schema/enums-array/entity/EnumArrayEntity.ts index 02a4bd560..4643edff1 100644 --- a/test/functional/database-schema/enums-array/entity/EnumArrayEntity.ts +++ b/test/functional/database-schema/enums-array/entity/EnumArrayEntity.ts @@ -1,4 +1,4 @@ -import { Entity, Column, PrimaryColumn } from "../../../../../src"; +import { Entity, Column, PrimaryColumn } from "../../../../../src/index.ts"; export enum NumericEnum { @@ -35,7 +35,7 @@ export type ArrayDefinedNumericEnumType = 11 | 12 | 13; @Entity() export class EnumArrayEntity { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; @Column({ diff --git a/test/functional/database-schema/enums-array/enums-array.ts b/test/functional/database-schema/enums-array/enums-array.ts index 6b965541e..7f70a46b8 100644 --- a/test/functional/database-schema/enums-array/enums-array.ts +++ b/test/functional/database-schema/enums-array/enums-array.ts @@ -1,14 +1,17 @@ -import "reflect-metadata"; -import { Connection } from "../../../../src"; -import { closeTestingConnections, createTestingConnections, reloadTestingDatabases } from "../../../utils/test-utils"; -import { EnumArrayEntity, NumericEnum, StringEnum, HeterogeneousEnum, StringNumericEnum } from "./entity/EnumArrayEntity"; +import { join as joinPaths } from "../../../../vendor/https/deno.land/std/path/mod.ts"; +import { runIfMain } from "../../../deps/mocha.ts"; +import "../../../deps/chai.ts"; +import { Connection } from "../../../../src/index.ts"; +import { getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases } from "../../../utils/test-utils.ts"; +import { EnumArrayEntity, NumericEnum, StringEnum, HeterogeneousEnum, StringNumericEnum } from "./entity/EnumArrayEntity.ts"; describe("database schema > enum arrays", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => { connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], enabledDrivers: ["postgres"] }); }); @@ -60,3 +63,5 @@ describe("database schema > enum arrays", () => { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/database-schema/enums/entity/EnumEntity.ts b/test/functional/database-schema/enums/entity/EnumEntity.ts index 14ef11637..11772c4ba 100644 --- a/test/functional/database-schema/enums/entity/EnumEntity.ts +++ b/test/functional/database-schema/enums/entity/EnumEntity.ts @@ -1,4 +1,4 @@ -import { Entity, Column, PrimaryColumn } from "../../../../../src"; +import { Entity, Column, PrimaryColumn } from "../../../../../src/index.ts"; export enum NumericEnum { @@ -35,7 +35,7 @@ export type ArrayDefinedNumericEnumType = 11 | 12 | 13; @Entity() export class EnumEntity { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; @Column({ diff --git a/test/functional/database-schema/enums/enums.ts b/test/functional/database-schema/enums/enums.ts index 18537b721..b89c90067 100644 --- a/test/functional/database-schema/enums/enums.ts +++ b/test/functional/database-schema/enums/enums.ts @@ -1,14 +1,17 @@ -import "reflect-metadata"; -import { Connection } from "../../../../src"; -import { closeTestingConnections, createTestingConnections, reloadTestingDatabases } from "../../../utils/test-utils"; -import { EnumEntity, NumericEnum, StringEnum, HeterogeneousEnum, StringNumericEnum } from "./entity/EnumEntity"; +import {join as joinPaths} from "../../../../vendor/https/deno.land/std/path/mod.ts"; +import { runIfMain } from "../../../deps/mocha.ts"; +import "../../../deps/chai.ts"; +import { Connection } from "../../../../src/index.ts"; +import { getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases } from "../../../utils/test-utils.ts"; +import { EnumEntity, NumericEnum, StringEnum, HeterogeneousEnum, StringNumericEnum } from "./entity/EnumEntity.ts"; describe("database schema > enums", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => { connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], enabledDrivers: ["postgres", "mysql"] }); }); @@ -61,3 +64,5 @@ describe("database schema > enums", () => { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/database-schema/indices/entity/Person.ts b/test/functional/database-schema/indices/entity/Person.ts index 646bad4df..70a174b28 100644 --- a/test/functional/database-schema/indices/entity/Person.ts +++ b/test/functional/database-schema/indices/entity/Person.ts @@ -1,7 +1,7 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {Index} from "../../../../../src/decorator/Index"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {Index} from "../../../../../src/decorator/Index.ts"; @Entity() @Index("IDX_TEST", ["firstname", "lastname"]) @@ -10,10 +10,10 @@ export class Person { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) firstname: string; - @Column() + @Column({ type: String }) lastname: string; -} \ No newline at end of file +} diff --git a/test/functional/database-schema/indices/indices-create-modify.ts b/test/functional/database-schema/indices/indices-create-modify.ts index 817f10706..823571ae4 100644 --- a/test/functional/database-schema/indices/indices-create-modify.ts +++ b/test/functional/database-schema/indices/indices-create-modify.ts @@ -1,17 +1,19 @@ -import {expect} from "chai"; -import "reflect-metadata"; -import {Connection, EntityMetadata} from "../../../../src"; -import {CockroachDriver} from "../../../../src/driver/cockroachdb/CockroachDriver"; -import {IndexMetadata} from "../../../../src/metadata/IndexMetadata"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils"; +import {join as joinPaths} from "../../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../../deps/mocha.ts"; +import {expect} from "../../../deps/chai.ts"; +import {Connection, EntityMetadata} from "../../../../src/index.ts"; +// import {CockroachDriver} from "../../../../src/driver/cockroachdb/CockroachDriver.ts"; +import {IndexMetadata} from "../../../../src/metadata/IndexMetadata.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils.ts"; -import {Person} from "./entity/Person"; +import {Person} from "./entity/Person.ts"; describe("database schema > indices > reading index from entity and updating database", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], })); beforeEach(() => reloadTestingDatabases(connections)); after(() => closeTestingConnections(connections)); @@ -43,7 +45,7 @@ describe("database schema > indices > reading index from entity and updating dat await queryRunner.release(); // CockroachDB stores unique indices as UNIQUE constraints - if (connection.driver instanceof CockroachDriver) { + if (false/* connection.driver instanceof CockroachDriver */) { // TODO(uki00a) uncomment this when CockroachDriver is implemented. expect(table!.uniques.length).to.be.equal(1); expect(table!.uniques[0].name).to.be.equal("IDX_TEST"); expect(table!.uniques[0].columnNames.length).to.be.equal(2); @@ -87,3 +89,5 @@ describe("database schema > indices > reading index from entity and updating dat }))); }); + +runIfMain(import.meta); diff --git a/test/functional/database-schema/mssql-parameters/entity/Post.ts b/test/functional/database-schema/mssql-parameters/entity/Post.ts index bd5806e78..e62de6361 100644 --- a/test/functional/database-schema/mssql-parameters/entity/Post.ts +++ b/test/functional/database-schema/mssql-parameters/entity/Post.ts @@ -1,22 +1,22 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {CreateDateColumn} from "../../../../../src/decorator/columns/CreateDateColumn"; -import {UpdateDateColumn} from "../../../../../src/decorator/columns/UpdateDateColumn"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {CreateDateColumn} from "../../../../../src/decorator/columns/CreateDateColumn.ts"; +import {UpdateDateColumn} from "../../../../../src/decorator/columns/UpdateDateColumn.ts"; @Entity() export class Post { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; - @Column() + @Column({ type: String }) name: string; - @Column() + @Column({ type: String }) category: string; - @Column() + @Column({ type: String }) text: string; @CreateDateColumn() @@ -25,4 +25,4 @@ export class Post { @UpdateDateColumn() updateDate: Date; -} \ No newline at end of file +} diff --git a/test/functional/database-schema/mssql-parameters/mssql-parameters.ts b/test/functional/database-schema/mssql-parameters/mssql-parameters.ts index 163d5e0fd..ffd69d621 100644 --- a/test/functional/database-schema/mssql-parameters/mssql-parameters.ts +++ b/test/functional/database-schema/mssql-parameters/mssql-parameters.ts @@ -1,15 +1,17 @@ -import "reflect-metadata"; -import {Connection} from "../../../../src/connection/Connection"; -import {expect} from "chai"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils"; -import {Post} from "./entity/Post"; +import {Connection} from "../../../../src/connection/Connection.ts"; +import {join as joinPaths} from "../../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../../deps/mocha.ts"; +import {expect} from "../../../deps/chai.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils.ts"; +import {Post} from "./entity/Post.ts"; describe("database schema > mssql-parameters", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => { connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], enabledDrivers: ["mssql"], }); }); @@ -85,3 +87,5 @@ describe("database schema > mssql-parameters", () => { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/database-schema/rowid-column/rowid-column.ts b/test/functional/database-schema/rowid-column/rowid-column.ts index 802d44e35..8c43bfec5 100644 --- a/test/functional/database-schema/rowid-column/rowid-column.ts +++ b/test/functional/database-schema/rowid-column/rowid-column.ts @@ -1,12 +1,15 @@ -import "reflect-metadata"; -import {closeTestingConnections, createTestingConnections} from "../../../utils/test-utils"; -import {Connection} from "../../../../src/connection/Connection"; +import {join as joinPaths} from "../../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../../deps/mocha.ts"; +import "../../../deps/chai.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections} from "../../../utils/test-utils.ts"; +import {Connection} from "../../../../src/connection/Connection.ts"; describe("database-schema > rowid-column", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], enabledDrivers: ["cockroachdb"], dropSchema: true, schemaCreate: true, @@ -38,3 +41,5 @@ describe("database-schema > rowid-column", () => { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/database-schema/sequences/entity/Person.ts b/test/functional/database-schema/sequences/entity/Person.ts index d24ae0290..46ba8f026 100644 --- a/test/functional/database-schema/sequences/entity/Person.ts +++ b/test/functional/database-schema/sequences/entity/Person.ts @@ -1,6 +1,6 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../src/decorator/columns/Column"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; @Entity() export class Person { @@ -9,8 +9,9 @@ export class Person { Id: number; @Column({ + type: String, unique: true }) Name: string; -} \ No newline at end of file +} diff --git a/test/functional/database-schema/sequences/sequence-create-test.ts b/test/functional/database-schema/sequences/sequence-create-test.ts index c15ce6b8d..21cfd1a40 100644 --- a/test/functional/database-schema/sequences/sequence-create-test.ts +++ b/test/functional/database-schema/sequences/sequence-create-test.ts @@ -1,9 +1,9 @@ -import "reflect-metadata"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils"; -import {Connection} from "../../../../src/connection/Connection"; -import {expect} from "chai"; +import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils.ts"; +import {Connection} from "../../../../src/connection/Connection.ts"; +import {expect} from "../../../deps/chai.ts"; +import {runIfMain} from "../../../deps/mocha.ts"; -import {Person} from "./entity/Person"; +import {Person} from "./entity/Person.ts"; describe("sequences > creating a sequence and marking the column as generated", () => { @@ -26,7 +26,9 @@ describe("sequences > creating a sequence and marking the column as generated", expect(table!.findColumnByName("Id")!.isGenerated).to.be.true; }))); - + }); }); + +runIfMain(import.meta); diff --git a/test/functional/database-schema/simple-enums-array/entity/EnumArrayEntity.ts b/test/functional/database-schema/simple-enums-array/entity/EnumArrayEntity.ts index 731482dcf..196022d40 100644 --- a/test/functional/database-schema/simple-enums-array/entity/EnumArrayEntity.ts +++ b/test/functional/database-schema/simple-enums-array/entity/EnumArrayEntity.ts @@ -1,4 +1,4 @@ -import { Entity, Column, PrimaryColumn } from "../../../../../src"; +import { Entity, Column, PrimaryColumn } from "../../../../../src/index.ts"; export enum NumericEnum { @@ -35,7 +35,7 @@ export type ArrayDefinedNumericEnumType = 11 | 12 | 13; @Entity() export class EnumArrayEntity { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; @Column({ diff --git a/test/functional/database-schema/simple-enums-array/enums-array.ts b/test/functional/database-schema/simple-enums-array/enums-array.ts index 910dcf6e2..f2891ade4 100644 --- a/test/functional/database-schema/simple-enums-array/enums-array.ts +++ b/test/functional/database-schema/simple-enums-array/enums-array.ts @@ -1,14 +1,17 @@ -import "reflect-metadata"; -import { Connection } from "../../../../src"; -import { closeTestingConnections, createTestingConnections, reloadTestingDatabases } from "../../../utils/test-utils"; -import { EnumArrayEntity, NumericEnum, StringEnum, HeterogeneousEnum, StringNumericEnum } from "./entity/EnumArrayEntity"; +import { join as joinPaths } from "../../../../vendor/https/deno.land/std/path/mod.ts"; +import { runIfMain } from "../../../deps/mocha.ts"; +import "../../../deps/chai.ts"; +import { Connection } from "../../../../src/index.ts"; +import { getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases } from "../../../utils/test-utils.ts"; +import { EnumArrayEntity, NumericEnum, StringEnum, HeterogeneousEnum, StringNumericEnum } from "./entity/EnumArrayEntity.ts"; describe("database schema > simple enum arrays", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => { connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], enabledDrivers: ["postgres"] }); }); @@ -60,3 +63,5 @@ describe("database schema > simple enum arrays", () => { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/database-schema/simple-enums/entity/SimpleEnumEntity.ts b/test/functional/database-schema/simple-enums/entity/SimpleEnumEntity.ts index 4265f2b07..54ff6a1ec 100644 --- a/test/functional/database-schema/simple-enums/entity/SimpleEnumEntity.ts +++ b/test/functional/database-schema/simple-enums/entity/SimpleEnumEntity.ts @@ -1,4 +1,4 @@ -import { Entity, Column, PrimaryColumn } from "../../../../../src"; +import { Entity, Column, PrimaryColumn } from "../../../../../src/index.ts"; export enum NumericEnum { @@ -35,7 +35,7 @@ export type ArrayDefinedNumericEnumType = 11 | 12 | 13; @Entity() export class SimpleEnumEntity { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; @Column({ diff --git a/test/functional/database-schema/simple-enums/enums.ts b/test/functional/database-schema/simple-enums/enums.ts index 61f848934..106426983 100644 --- a/test/functional/database-schema/simple-enums/enums.ts +++ b/test/functional/database-schema/simple-enums/enums.ts @@ -1,14 +1,17 @@ -import "reflect-metadata"; -import { Connection } from "../../../../src"; -import { closeTestingConnections, createTestingConnections, reloadTestingDatabases } from "../../../utils/test-utils"; -import { SimpleEnumEntity, NumericEnum, StringEnum, HeterogeneousEnum, StringNumericEnum } from "./entity/SimpleEnumEntity"; +import { join as joinPaths } from "../../../../vendor/https/deno.land/std/path/mod.ts"; +import "../../../deps/chai.ts"; +import { runIfMain } from "../../../deps/mocha.ts"; +import { Connection } from "../../../../src/index.ts"; +import { getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases } from "../../../utils/test-utils.ts"; +import { SimpleEnumEntity, NumericEnum, StringEnum, HeterogeneousEnum, StringNumericEnum } from "./entity/SimpleEnumEntity.ts"; describe("database schema > simple-enums", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => { connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], enabledDrivers: ["mysql", "mariadb", "postgres", "sqlite", "mssql"] }); }); @@ -61,3 +64,5 @@ describe("database schema > simple-enums", () => { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/decorators/embedded/entity/Counters.ts b/test/functional/decorators/embedded/entity/Counters.ts index 96f542327..437978c52 100644 --- a/test/functional/decorators/embedded/entity/Counters.ts +++ b/test/functional/decorators/embedded/entity/Counters.ts @@ -1,14 +1,14 @@ -import {Column} from "../../../../../src/decorator/columns/Column"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; export class Counters { - @Column() + @Column({ type: Number }) likes: number; - @Column() + @Column({ type: Number }) comments: number; - @Column() + @Column({ type: Number }) favorites: number; -} \ No newline at end of file +} diff --git a/test/functional/decorators/embedded/entity/Post.ts b/test/functional/decorators/embedded/entity/Post.ts index 67171426e..67ac38ce1 100644 --- a/test/functional/decorators/embedded/entity/Post.ts +++ b/test/functional/decorators/embedded/entity/Post.ts @@ -1,7 +1,7 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {Counters} from "./Counters"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {Counters} from "./Counters.ts"; @Entity() export class Post { @@ -9,13 +9,13 @@ export class Post { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) title: string; - @Column() + @Column({ type: String }) text: string; @Column(() => Counters) counters: Counters; -} \ No newline at end of file +} diff --git a/test/functional/decorators/embedded/query-builder-embedded.ts b/test/functional/decorators/embedded/query-builder-embedded.ts index 53b195955..24e956739 100644 --- a/test/functional/decorators/embedded/query-builder-embedded.ts +++ b/test/functional/decorators/embedded/query-builder-embedded.ts @@ -1,8 +1,9 @@ -import "reflect-metadata"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils"; -import {Connection} from "../../../../src/connection/Connection"; -import {Post} from "./entity/Post"; -import {Counters} from "./entity/Counters"; +import {runIfMain} from "../../../deps/mocha.ts"; +import "../../../deps/chai.ts"; +import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils.ts"; +import {Connection} from "../../../../src/connection/Connection.ts"; +import {Post} from "./entity/Post.ts"; +import {Counters} from "./entity/Counters.ts"; describe("decorators > embedded", () => { @@ -121,3 +122,5 @@ describe("decorators > embedded", () => { }); }); + +runIfMain(import.meta); diff --git a/test/functional/decorators/relation-count/relation-count-many-to-many/entity/Category.ts b/test/functional/decorators/relation-count/relation-count-many-to-many/entity/Category.ts index e4ee7b732..093008f3f 100644 --- a/test/functional/decorators/relation-count/relation-count-many-to-many/entity/Category.ts +++ b/test/functional/decorators/relation-count/relation-count-many-to-many/entity/Category.ts @@ -1,22 +1,22 @@ -import {PrimaryColumn} from "../../../../../../src/decorator/columns/PrimaryColumn"; -import {Entity} from "../../../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../../../src/decorator/columns/Column"; -import {ManyToMany} from "../../../../../../src/decorator/relations/ManyToMany"; -import {JoinTable} from "../../../../../../src/decorator/relations/JoinTable"; -import {RelationCount} from "../../../../../../src/decorator/relations/RelationCount"; -import {Post} from "./Post"; -import {Image} from "./Image"; +import {PrimaryColumn} from "../../../../../../src/decorator/columns/PrimaryColumn.ts"; +import {Entity} from "../../../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../../../src/decorator/columns/Column.ts"; +import {ManyToMany} from "../../../../../../src/decorator/relations/ManyToMany.ts"; +import {JoinTable} from "../../../../../../src/decorator/relations/JoinTable.ts"; +import {RelationCount} from "../../../../../../src/decorator/relations/RelationCount.ts"; +import {Post} from "./Post.ts"; +import {Image} from "./Image.ts"; @Entity() export class Category { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; - @Column() + @Column({ type: String }) name: string; - @Column() + @Column({ type: Boolean }) isRemoved: boolean = false; @ManyToMany(type => Post, post => post.categories) diff --git a/test/functional/decorators/relation-count/relation-count-many-to-many/entity/Image.ts b/test/functional/decorators/relation-count/relation-count-many-to-many/entity/Image.ts index fc0054022..4458975f7 100644 --- a/test/functional/decorators/relation-count/relation-count-many-to-many/entity/Image.ts +++ b/test/functional/decorators/relation-count/relation-count-many-to-many/entity/Image.ts @@ -1,20 +1,20 @@ -import {PrimaryColumn} from "../../../../../../src/decorator/columns/PrimaryColumn"; -import {Entity} from "../../../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../../../src/decorator/columns/Column"; -import {ManyToMany} from "../../../../../../src/decorator/relations/ManyToMany"; -import {RelationCount} from "../../../../../../src/decorator/relations/RelationCount"; -import {Category} from "./Category"; +import {PrimaryColumn} from "../../../../../../src/decorator/columns/PrimaryColumn.ts"; +import {Entity} from "../../../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../../../src/decorator/columns/Column.ts"; +import {ManyToMany} from "../../../../../../src/decorator/relations/ManyToMany.ts"; +import {RelationCount} from "../../../../../../src/decorator/relations/RelationCount.ts"; +import {Category} from "./Category.ts"; @Entity() export class Image { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; - @Column() + @Column({ type: String }) name: string; - @Column() + @Column({ type: Boolean }) isRemoved: boolean = false; @ManyToMany(type => Category, category => category.images) diff --git a/test/functional/decorators/relation-count/relation-count-many-to-many/entity/Post.ts b/test/functional/decorators/relation-count/relation-count-many-to-many/entity/Post.ts index 5aa251c54..576a1da66 100644 --- a/test/functional/decorators/relation-count/relation-count-many-to-many/entity/Post.ts +++ b/test/functional/decorators/relation-count/relation-count-many-to-many/entity/Post.ts @@ -1,23 +1,23 @@ -import {PrimaryColumn} from "../../../../../../src/decorator/columns/PrimaryColumn"; -import {Entity} from "../../../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../../../src/decorator/columns/Column"; -import {ManyToMany} from "../../../../../../src/decorator/relations/ManyToMany"; -import {JoinTable} from "../../../../../../src/decorator/relations/JoinTable"; -import {RelationCount} from "../../../../../../src/decorator/relations/RelationCount"; -import {Category} from "./Category"; +import {PrimaryColumn} from "../../../../../../src/decorator/columns/PrimaryColumn.ts"; +import {Entity} from "../../../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../../../src/decorator/columns/Column.ts"; +import {ManyToMany} from "../../../../../../src/decorator/relations/ManyToMany.ts"; +import {JoinTable} from "../../../../../../src/decorator/relations/JoinTable.ts"; +import {RelationCount} from "../../../../../../src/decorator/relations/RelationCount.ts"; +import {Category} from "./Category.ts"; @Entity() export class Post { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; - @Column() + @Column({ type: String }) title: string; - @Column() + @Column({ type: Boolean }) isRemoved: boolean = false; - + @ManyToMany(type => Category, category => category.posts) @JoinTable() categories: Category[]; diff --git a/test/functional/decorators/relation-count/relation-count-many-to-many/relation-count-decorator-many-to-many.ts b/test/functional/decorators/relation-count/relation-count-many-to-many/relation-count-decorator-many-to-many.ts index f1a0a8e21..c0e7df9f8 100644 --- a/test/functional/decorators/relation-count/relation-count-many-to-many/relation-count-decorator-many-to-many.ts +++ b/test/functional/decorators/relation-count/relation-count-many-to-many/relation-count-decorator-many-to-many.ts @@ -1,16 +1,18 @@ -import "reflect-metadata"; -import {expect} from "chai"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils"; -import {Connection} from "../../../../../src"; -import {Category} from "./entity/Category"; -import {Post} from "./entity/Post"; -import {Image} from "./entity/Image"; +import {join as joinPaths} from "../../../../../vendor/https/deno.land/std/path/mod.ts"; +import {expect} from "../../../../deps/chai.ts"; +import {runIfMain} from "../../../../deps/mocha.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils.ts"; +import {Connection} from "../../../../../src/index.ts"; +import {Category} from "./entity/Category.ts"; +import {Post} from "./entity/Post.ts"; +import {Image} from "./entity/Image.ts"; describe("query builder > relation-count-decorator-many-to-many > many-to-many", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], })); beforeEach(() => reloadTestingDatabases(connections)); after(() => closeTestingConnections(connections)); @@ -456,3 +458,5 @@ describe("query builder > relation-count-decorator-many-to-many > many-to-many", }))); }); + +runIfMain(import.meta); diff --git a/test/functional/decorators/relation-count/relation-count-one-to-many/entity/Category.ts b/test/functional/decorators/relation-count/relation-count-one-to-many/entity/Category.ts index 34e1abc1c..3b3871f30 100644 --- a/test/functional/decorators/relation-count/relation-count-one-to-many/entity/Category.ts +++ b/test/functional/decorators/relation-count/relation-count-one-to-many/entity/Category.ts @@ -1,22 +1,22 @@ -import {PrimaryColumn} from "../../../../../../src/decorator/columns/PrimaryColumn"; -import {Entity} from "../../../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../../../src/decorator/columns/Column"; -import {ManyToOne} from "../../../../../../src/decorator/relations/ManyToOne"; -import {OneToMany} from "../../../../../../src/decorator/relations/OneToMany"; -import {RelationCount} from "../../../../../../src/decorator/relations/RelationCount"; -import {Image} from "./Image"; -import {Post} from "./Post"; +import {PrimaryColumn} from "../../../../../../src/decorator/columns/PrimaryColumn.ts"; +import {Entity} from "../../../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../../../src/decorator/columns/Column.ts"; +import {ManyToOne} from "../../../../../../src/decorator/relations/ManyToOne.ts"; +import {OneToMany} from "../../../../../../src/decorator/relations/OneToMany.ts"; +import {RelationCount} from "../../../../../../src/decorator/relations/RelationCount.ts"; +import {Image} from "./Image.ts"; +import {Post} from "./Post.ts"; @Entity() export class Category { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; - @Column() + @Column({ type: String }) name: string; - @Column() + @Column({ type: Boolean }) isRemoved: boolean = false; @ManyToOne(type => Post, post => post.categories) diff --git a/test/functional/decorators/relation-count/relation-count-one-to-many/entity/Image.ts b/test/functional/decorators/relation-count/relation-count-one-to-many/entity/Image.ts index 5bb8a1405..e8292b80a 100644 --- a/test/functional/decorators/relation-count/relation-count-one-to-many/entity/Image.ts +++ b/test/functional/decorators/relation-count/relation-count-one-to-many/entity/Image.ts @@ -1,19 +1,19 @@ -import {PrimaryColumn} from "../../../../../../src/decorator/columns/PrimaryColumn"; -import {Entity} from "../../../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../../../src/decorator/columns/Column"; -import {ManyToOne} from "../../../../../../src/decorator/relations/ManyToOne"; -import {Category} from "./Category"; +import {PrimaryColumn} from "../../../../../../src/decorator/columns/PrimaryColumn.ts"; +import {Entity} from "../../../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../../../src/decorator/columns/Column.ts"; +import {ManyToOne} from "../../../../../../src/decorator/relations/ManyToOne.ts"; +import {Category} from "./Category.ts"; @Entity() export class Image { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; - @Column() + @Column({ type: String }) name: string; - @Column() + @Column({ type: Boolean }) isRemoved: boolean = false; @ManyToOne(type => Category, category => category.images) diff --git a/test/functional/decorators/relation-count/relation-count-one-to-many/entity/Post.ts b/test/functional/decorators/relation-count/relation-count-one-to-many/entity/Post.ts index 210ef155c..a615dfdbe 100644 --- a/test/functional/decorators/relation-count/relation-count-one-to-many/entity/Post.ts +++ b/test/functional/decorators/relation-count/relation-count-one-to-many/entity/Post.ts @@ -1,19 +1,19 @@ -import {PrimaryColumn} from "../../../../../../src/decorator/columns/PrimaryColumn"; -import {Entity} from "../../../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../../../src/decorator/columns/Column"; -import {OneToMany} from "../../../../../../src/decorator/relations/OneToMany"; -import {RelationCount} from "../../../../../../src/decorator/relations/RelationCount"; -import {Category} from "./Category"; +import {PrimaryColumn} from "../../../../../../src/decorator/columns/PrimaryColumn.ts"; +import {Entity} from "../../../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../../../src/decorator/columns/Column.ts"; +import {OneToMany} from "../../../../../../src/decorator/relations/OneToMany.ts"; +import {RelationCount} from "../../../../../../src/decorator/relations/RelationCount.ts"; +import {Category} from "./Category.ts"; @Entity() export class Post { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; - @Column() + @Column({ type: String }) title: string; - + @OneToMany(type => Category, category => category.post) categories: Category[]; diff --git a/test/functional/decorators/relation-count/relation-count-one-to-many/relation-count-decorator-one-to-many.ts b/test/functional/decorators/relation-count/relation-count-one-to-many/relation-count-decorator-one-to-many.ts index a6216e3f0..886a09b0d 100644 --- a/test/functional/decorators/relation-count/relation-count-one-to-many/relation-count-decorator-one-to-many.ts +++ b/test/functional/decorators/relation-count/relation-count-one-to-many/relation-count-decorator-one-to-many.ts @@ -1,16 +1,18 @@ -import "reflect-metadata"; -import {expect} from "chai"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils"; -import {Connection} from "../../../../../src/connection/Connection"; -import {Category} from "./entity/Category"; -import {Post} from "./entity/Post"; -import {Image} from "./entity/Image"; +import {join as joinPaths} from "../../../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../../../deps/mocha.ts"; +import {expect} from "../../../../deps/chai.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils.ts"; +import {Connection} from "../../../../../src/connection/Connection.ts"; +import {Category} from "./entity/Category.ts"; +import {Post} from "./entity/Post.ts"; +import {Image} from "./entity/Image.ts"; describe("decorators > relation-count-decorator > one-to-many", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], })); beforeEach(() => reloadTestingDatabases(connections)); after(() => closeTestingConnections(connections)); @@ -92,3 +94,5 @@ describe("decorators > relation-count-decorator > one-to-many", () => { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/decorators/relation-id/relation-id-many-to-many/entity/Category.ts b/test/functional/decorators/relation-id/relation-id-many-to-many/entity/Category.ts index 44a5854a7..99d0fbe5f 100644 --- a/test/functional/decorators/relation-id/relation-id-many-to-many/entity/Category.ts +++ b/test/functional/decorators/relation-id/relation-id-many-to-many/entity/Category.ts @@ -1,22 +1,22 @@ -import {PrimaryColumn} from "../../../../../../src/decorator/columns/PrimaryColumn"; -import {Entity} from "../../../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../../../src/decorator/columns/Column"; -import {ManyToMany} from "../../../../../../src/decorator/relations/ManyToMany"; -import {JoinTable} from "../../../../../../src/decorator/relations/JoinTable"; -import {Post} from "./Post"; -import {Image} from "./Image"; -import {RelationId} from "../../../../../../src/decorator/relations/RelationId"; +import {PrimaryColumn} from "../../../../../../src/decorator/columns/PrimaryColumn.ts"; +import {Entity} from "../../../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../../../src/decorator/columns/Column.ts"; +import {ManyToMany} from "../../../../../../src/decorator/relations/ManyToMany.ts"; +import {JoinTable} from "../../../../../../src/decorator/relations/JoinTable.ts"; +import {Post} from "./Post.ts"; +import {Image} from "./Image.ts"; +import {RelationId} from "../../../../../../src/decorator/relations/RelationId.ts"; @Entity() export class Category { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; - @Column() + @Column({ type: String }) name: string; - @Column() + @Column({ type: Boolean }) isRemoved: boolean = false; @ManyToMany(type => Post, post => post.categories) diff --git a/test/functional/decorators/relation-id/relation-id-many-to-many/entity/Image.ts b/test/functional/decorators/relation-id/relation-id-many-to-many/entity/Image.ts index 504c2154e..cac15bfd7 100644 --- a/test/functional/decorators/relation-id/relation-id-many-to-many/entity/Image.ts +++ b/test/functional/decorators/relation-id/relation-id-many-to-many/entity/Image.ts @@ -1,17 +1,17 @@ -import {PrimaryColumn} from "../../../../../../src/decorator/columns/PrimaryColumn"; -import {Entity} from "../../../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../../../src/decorator/columns/Column"; +import {PrimaryColumn} from "../../../../../../src/decorator/columns/PrimaryColumn.ts"; +import {Entity} from "../../../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../../../src/decorator/columns/Column.ts"; @Entity() export class Image { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; - @Column() + @Column({ type: String }) name: string; - @Column() + @Column({ type: Boolean }) isRemoved: boolean = false; } diff --git a/test/functional/decorators/relation-id/relation-id-many-to-many/entity/Post.ts b/test/functional/decorators/relation-id/relation-id-many-to-many/entity/Post.ts index 810a24ed5..e642e18a6 100644 --- a/test/functional/decorators/relation-id/relation-id-many-to-many/entity/Post.ts +++ b/test/functional/decorators/relation-id/relation-id-many-to-many/entity/Post.ts @@ -1,21 +1,21 @@ -import {PrimaryColumn} from "../../../../../../src/decorator/columns/PrimaryColumn"; -import {ManyToMany} from "../../../../../../src/decorator/relations/ManyToMany"; -import {Entity} from "../../../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../../../src/decorator/columns/Column"; -import {JoinTable} from "../../../../../../src/decorator/relations/JoinTable"; -import {RelationId} from "../../../../../../src/decorator/relations/RelationId"; -import {Category} from "./Category"; +import {PrimaryColumn} from "../../../../../../src/decorator/columns/PrimaryColumn.ts"; +import {ManyToMany} from "../../../../../../src/decorator/relations/ManyToMany.ts"; +import {Entity} from "../../../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../../../src/decorator/columns/Column.ts"; +import {JoinTable} from "../../../../../../src/decorator/relations/JoinTable.ts"; +import {RelationId} from "../../../../../../src/decorator/relations/RelationId.ts"; +import {Category} from "./Category.ts"; @Entity() export class Post { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; - @Column() + @Column({ type: String }) title: string; - @Column() + @Column({ type: Boolean }) isRemoved: boolean = false; @ManyToMany(type => Category, category => category.posts) diff --git a/test/functional/decorators/relation-id/relation-id-many-to-many/relation-id-decorator-many-to-many.ts b/test/functional/decorators/relation-id/relation-id-many-to-many/relation-id-decorator-many-to-many.ts index 99429f9f0..e12072db9 100644 --- a/test/functional/decorators/relation-id/relation-id-many-to-many/relation-id-decorator-many-to-many.ts +++ b/test/functional/decorators/relation-id/relation-id-many-to-many/relation-id-decorator-many-to-many.ts @@ -1,16 +1,18 @@ -import "reflect-metadata"; -import {expect} from "chai"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils"; -import {Connection} from "../../../../../src/connection/Connection"; -import {Post} from "./entity/Post"; -import {Category} from "./entity/Category"; -import {Image} from "./entity/Image"; +import {join as joinPaths} from "../../../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../../../deps/mocha.ts"; +import {expect} from "../../../../deps/chai.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils.ts"; +import {Connection} from "../../../../../src/connection/Connection.ts"; +import {Post} from "./entity/Post.ts"; +import {Category} from "./entity/Category.ts"; +import {Image} from "./entity/Image.ts"; describe("decorators > relation-id-decorator > many-to-many", () => { - + let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], })); beforeEach(() => reloadTestingDatabases(connections)); after(() => closeTestingConnections(connections)); @@ -452,3 +454,5 @@ describe("decorators > relation-id-decorator > many-to-many", () => { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/decorators/relation-id/relation-id-many-to-one/entity/Category.ts b/test/functional/decorators/relation-id/relation-id-many-to-one/entity/Category.ts index eabfd13af..fbc8407ff 100644 --- a/test/functional/decorators/relation-id/relation-id-many-to-one/entity/Category.ts +++ b/test/functional/decorators/relation-id/relation-id-many-to-one/entity/Category.ts @@ -1,14 +1,14 @@ -import {PrimaryColumn} from "../../../../../../src/decorator/columns/PrimaryColumn"; -import {Entity} from "../../../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../../../src/decorator/columns/Column"; +import {PrimaryColumn} from "../../../../../../src/decorator/columns/PrimaryColumn.ts"; +import {Entity} from "../../../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../../../src/decorator/columns/Column.ts"; @Entity() export class Category { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; - @Column({ unique: true }) + @Column({ unique: true, type: String }) name: string; } diff --git a/test/functional/decorators/relation-id/relation-id-many-to-one/entity/Post.ts b/test/functional/decorators/relation-id/relation-id-many-to-one/entity/Post.ts index 897accf40..282779c0b 100644 --- a/test/functional/decorators/relation-id/relation-id-many-to-one/entity/Post.ts +++ b/test/functional/decorators/relation-id/relation-id-many-to-one/entity/Post.ts @@ -1,20 +1,20 @@ -import {PrimaryColumn} from "../../../../../../src/decorator/columns/PrimaryColumn"; -import {Entity} from "../../../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../../../src/decorator/columns/Column"; -import {ManyToOne} from "../../../../../../src/decorator/relations/ManyToOne"; -import {JoinColumn} from "../../../../../../src/decorator/relations/JoinColumn"; -import {RelationId} from "../../../../../../src/decorator/relations/RelationId"; -import {Category} from "./Category"; +import {PrimaryColumn} from "../../../../../../src/decorator/columns/PrimaryColumn.ts"; +import {Entity} from "../../../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../../../src/decorator/columns/Column.ts"; +import {ManyToOne} from "../../../../../../src/decorator/relations/ManyToOne.ts"; +import {JoinColumn} from "../../../../../../src/decorator/relations/JoinColumn.ts"; +import {RelationId} from "../../../../../../src/decorator/relations/RelationId.ts"; +import {Category} from "./Category.ts"; @Entity() export class Post { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; - @Column() + @Column({ type: String }) title: string; - + @ManyToOne(type => Category) @JoinColumn() category: Category; diff --git a/test/functional/decorators/relation-id/relation-id-many-to-one/relation-id-decorator-many-to-one.ts b/test/functional/decorators/relation-id/relation-id-many-to-one/relation-id-decorator-many-to-one.ts index c7ddd6178..5967dc3a8 100644 --- a/test/functional/decorators/relation-id/relation-id-many-to-one/relation-id-decorator-many-to-one.ts +++ b/test/functional/decorators/relation-id/relation-id-many-to-one/relation-id-decorator-many-to-one.ts @@ -1,15 +1,17 @@ -import "reflect-metadata"; -import {expect} from "chai"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils"; -import {Connection} from "../../../../../src/connection/Connection"; -import {Post} from "./entity/Post"; -import {Category} from "./entity/Category"; +import {join as joinPaths} from "../../../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../../../deps/mocha.ts"; +import {expect} from "../../../../deps/chai.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils.ts"; +import {Connection} from "../../../../../src/connection/Connection.ts"; +import {Post} from "./entity/Post.ts"; +import {Category} from "./entity/Category.ts"; describe("decorators > relation-id-decorator > many-to-one", () => { - + let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], })); beforeEach(() => reloadTestingDatabases(connections)); after(() => closeTestingConnections(connections)); @@ -76,3 +78,5 @@ describe("decorators > relation-id-decorator > many-to-one", () => { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/decorators/relation-id/relation-id-one-to-many/entity/Category.ts b/test/functional/decorators/relation-id/relation-id-one-to-many/entity/Category.ts index ff9d3279d..3b10f437c 100644 --- a/test/functional/decorators/relation-id/relation-id-one-to-many/entity/Category.ts +++ b/test/functional/decorators/relation-id/relation-id-one-to-many/entity/Category.ts @@ -1,17 +1,17 @@ -import {PrimaryColumn} from "../../../../../../src/decorator/columns/PrimaryColumn"; -import {Entity} from "../../../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../../../src/decorator/columns/Column"; -import {OneToMany} from "../../../../../../src/decorator/relations/OneToMany"; -import {RelationId} from "../../../../../../src/decorator/relations/RelationId"; -import {Post} from "./Post"; +import {PrimaryColumn} from "../../../../../../src/decorator/columns/PrimaryColumn.ts"; +import {Entity} from "../../../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../../../src/decorator/columns/Column.ts"; +import {OneToMany} from "../../../../../../src/decorator/relations/OneToMany.ts"; +import {RelationId} from "../../../../../../src/decorator/relations/RelationId.ts"; +import {Post} from "./Post.ts"; @Entity() export class Category { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; - @Column() + @Column({ type: String }) name: string; @OneToMany(type => Post, post => post.category) diff --git a/test/functional/decorators/relation-id/relation-id-one-to-many/entity/Post.ts b/test/functional/decorators/relation-id/relation-id-one-to-many/entity/Post.ts index 1d97ce730..4cc67750d 100644 --- a/test/functional/decorators/relation-id/relation-id-one-to-many/entity/Post.ts +++ b/test/functional/decorators/relation-id/relation-id-one-to-many/entity/Post.ts @@ -1,24 +1,24 @@ -import {Column} from "../../../../../../src/decorator/columns/Column"; -import {PrimaryColumn} from "../../../../../../src/decorator/columns/PrimaryColumn"; -import {Entity} from "../../../../../../src/decorator/entity/Entity"; -import {ManyToOne} from "../../../../../../src/decorator/relations/ManyToOne"; -import {Category} from "./Category"; +import {Column} from "../../../../../../src/decorator/columns/Column.ts"; +import {PrimaryColumn} from "../../../../../../src/decorator/columns/PrimaryColumn.ts"; +import {Entity} from "../../../../../../src/decorator/entity/Entity.ts"; +import {ManyToOne} from "../../../../../../src/decorator/relations/ManyToOne.ts"; +import {Category} from "./Category.ts"; @Entity() export class Post { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; - @Column() + @Column({ type: String }) title: string; - @Column() + @Column({ type: Boolean }) isRemoved: boolean = false; - + @ManyToOne(type => Category) category: Category; - + categoryId: number; } diff --git a/test/functional/decorators/relation-id/relation-id-one-to-many/relation-id-decorator-one-to-many.ts b/test/functional/decorators/relation-id/relation-id-one-to-many/relation-id-decorator-one-to-many.ts index 867f67778..d7866463e 100644 --- a/test/functional/decorators/relation-id/relation-id-one-to-many/relation-id-decorator-one-to-many.ts +++ b/test/functional/decorators/relation-id/relation-id-one-to-many/relation-id-decorator-one-to-many.ts @@ -1,15 +1,17 @@ -import "reflect-metadata"; -import {expect} from "chai"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils"; -import {Connection} from "../../../../../src/connection/Connection"; -import {Category} from "./entity/Category"; -import {Post} from "./entity/Post"; +import {join as joinPaths} from "../../../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../../../deps/mocha.ts"; +import {expect} from "../../../../deps/chai.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils.ts"; +import {Connection} from "../../../../../src/connection/Connection.ts"; +import {Category} from "./entity/Category.ts"; +import {Post} from "./entity/Post.ts"; describe("decorators > relation-id > one-to-many", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], })); beforeEach(() => reloadTestingDatabases(connections)); after(() => closeTestingConnections(connections)); @@ -119,3 +121,5 @@ describe("decorators > relation-id > one-to-many", () => { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/decorators/relation-id/relation-id-one-to-one/entity/Category.ts b/test/functional/decorators/relation-id/relation-id-one-to-one/entity/Category.ts index 800740d73..9ff1ea994 100644 --- a/test/functional/decorators/relation-id/relation-id-one-to-one/entity/Category.ts +++ b/test/functional/decorators/relation-id/relation-id-one-to-one/entity/Category.ts @@ -1,17 +1,17 @@ -import {Column} from "../../../../../../src/decorator/columns/Column"; -import {PrimaryColumn} from "../../../../../../src/decorator/columns/PrimaryColumn"; -import {Entity} from "../../../../../../src/decorator/entity/Entity"; -import {OneToOne} from "../../../../../../src/decorator/relations/OneToOne"; -import {RelationId} from "../../../../../../src/decorator/relations/RelationId"; -import {Post} from "./Post"; +import {Column} from "../../../../../../src/decorator/columns/Column.ts"; +import {PrimaryColumn} from "../../../../../../src/decorator/columns/PrimaryColumn.ts"; +import {Entity} from "../../../../../../src/decorator/entity/Entity.ts"; +import {OneToOne} from "../../../../../../src/decorator/relations/OneToOne.ts"; +import {RelationId} from "../../../../../../src/decorator/relations/RelationId.ts"; +import {Post} from "./Post.ts"; @Entity() export class Category { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; - @Column({ unique: true }) + @Column({ unique: true, type: String }) name: string; @OneToOne(type => Post, post => post.category2) diff --git a/test/functional/decorators/relation-id/relation-id-one-to-one/entity/Post.ts b/test/functional/decorators/relation-id/relation-id-one-to-one/entity/Post.ts index c52bf996c..b3fab5be5 100644 --- a/test/functional/decorators/relation-id/relation-id-one-to-one/entity/Post.ts +++ b/test/functional/decorators/relation-id/relation-id-one-to-one/entity/Post.ts @@ -1,20 +1,20 @@ -import {PrimaryColumn} from "../../../../../../src/decorator/columns/PrimaryColumn"; -import {Entity} from "../../../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../../../src/decorator/columns/Column"; -import {OneToOne} from "../../../../../../src/decorator/relations/OneToOne"; -import {JoinColumn} from "../../../../../../src/decorator/relations/JoinColumn"; -import {Category} from "./Category"; -import {RelationId} from "../../../../../../src/decorator/relations/RelationId"; +import {PrimaryColumn} from "../../../../../../src/decorator/columns/PrimaryColumn.ts"; +import {Entity} from "../../../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../../../src/decorator/columns/Column.ts"; +import {OneToOne} from "../../../../../../src/decorator/relations/OneToOne.ts"; +import {JoinColumn} from "../../../../../../src/decorator/relations/JoinColumn.ts"; +import {Category} from "./Category.ts"; +import {RelationId} from "../../../../../../src/decorator/relations/RelationId.ts"; @Entity() export class Post { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; - @Column() + @Column({ type: String }) title: string; - + @OneToOne(type => Category) @JoinColumn() category: Category; diff --git a/test/functional/decorators/relation-id/relation-id-one-to-one/relation-id-decorator-one-to-one.ts b/test/functional/decorators/relation-id/relation-id-one-to-one/relation-id-decorator-one-to-one.ts index 6f48aa3dd..b4af8eec2 100644 --- a/test/functional/decorators/relation-id/relation-id-one-to-one/relation-id-decorator-one-to-one.ts +++ b/test/functional/decorators/relation-id/relation-id-one-to-one/relation-id-decorator-one-to-one.ts @@ -1,15 +1,17 @@ -import "reflect-metadata"; -import {expect} from "chai"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils"; -import {Connection} from "../../../../../src/connection/Connection"; -import {Category} from "./entity/Category"; -import {Post} from "./entity/Post"; +import {join as joinPaths} from "../../../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../../../deps/mocha.ts"; +import {expect} from "../../../../deps/chai.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils.ts"; +import {Connection} from "../../../../../src/connection/Connection.ts"; +import {Category} from "./entity/Category.ts"; +import {Post} from "./entity/Post.ts"; describe("decorators > relation-id > one-to-one", () => { - + let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], })); beforeEach(() => reloadTestingDatabases(connections)); after(() => closeTestingConnections(connections)); @@ -119,3 +121,5 @@ describe("decorators > relation-id > one-to-one", () => { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/deferrable/deferrable.ts b/test/functional/deferrable/deferrable.ts index 52a49bc06..214e821f2 100644 --- a/test/functional/deferrable/deferrable.ts +++ b/test/functional/deferrable/deferrable.ts @@ -1,16 +1,18 @@ -import "reflect-metadata"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../utils/test-utils"; -import {Connection} from "../../../src/connection/Connection"; -import {Company} from "./entity/Company"; -import {Office} from "./entity/Office"; -import {User} from "./entity/User"; -import {expect} from "chai"; +import {join as joinPaths} from "../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../deps/mocha.ts"; +import {expect} from "../../deps/chai.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../utils/test-utils.ts"; +import {Connection} from "../../../src/connection/Connection.ts"; +import {Company} from "./entity/Company.ts"; +import {Office} from "./entity/Office.ts"; +import {User} from "./entity/User.ts"; describe("deferrable fk constraints should be check at the end of transaction (#2191)", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], enabledDrivers: ["postgres"] })); beforeEach(() => reloadTestingDatabases(connections)); @@ -93,3 +95,5 @@ describe("deferrable fk constraints should be check at the end of transaction (# }); }))); }); + +runIfMain(import.meta); diff --git a/test/functional/deferrable/entity/Company.ts b/test/functional/deferrable/entity/Company.ts index 2bdbde219..74db51801 100644 --- a/test/functional/deferrable/entity/Company.ts +++ b/test/functional/deferrable/entity/Company.ts @@ -1,14 +1,14 @@ -import {Entity} from "../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../src/decorator/columns/Column"; -import {PrimaryColumn} from "../../../../src/decorator/columns/PrimaryColumn"; +import {Entity} from "../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../src/decorator/columns/Column.ts"; +import {PrimaryColumn} from "../../../../src/decorator/columns/PrimaryColumn.ts"; @Entity() export class Company { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; - @Column() + @Column({ type: String }) name?: string; -} \ No newline at end of file +} diff --git a/test/functional/deferrable/entity/Office.ts b/test/functional/deferrable/entity/Office.ts index 481128b7e..5fdc1b43d 100644 --- a/test/functional/deferrable/entity/Office.ts +++ b/test/functional/deferrable/entity/Office.ts @@ -1,16 +1,16 @@ -import {Entity} from "../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../src/decorator/columns/Column"; -import {ManyToOne} from "../../../../src/decorator/relations/ManyToOne"; -import {PrimaryColumn} from "../../../../src/decorator/columns/PrimaryColumn"; -import {Company} from "./Company"; +import {Entity} from "../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../src/decorator/columns/Column.ts"; +import {ManyToOne} from "../../../../src/decorator/relations/ManyToOne.ts"; +import {PrimaryColumn} from "../../../../src/decorator/columns/PrimaryColumn.ts"; +import {Company} from "./Company.ts"; @Entity() export class Office { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; - @Column() + @Column({ type: String }) name: string; @ManyToOne(type => Company, company => company.id, { diff --git a/test/functional/deferrable/entity/User.ts b/test/functional/deferrable/entity/User.ts index 8e73555ea..7ba319629 100644 --- a/test/functional/deferrable/entity/User.ts +++ b/test/functional/deferrable/entity/User.ts @@ -1,16 +1,16 @@ -import {Entity} from "../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../src/decorator/columns/Column"; -import {ManyToOne} from "../../../../src/decorator/relations/ManyToOne"; -import {PrimaryColumn} from "../../../../src/decorator/columns/PrimaryColumn"; -import {Company} from "./Company"; +import {Entity} from "../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../src/decorator/columns/Column.ts"; +import {ManyToOne} from "../../../../src/decorator/relations/ManyToOne.ts"; +import {PrimaryColumn} from "../../../../src/decorator/columns/PrimaryColumn.ts"; +import {Company} from "./Company.ts"; @Entity() export class User { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; - @Column() + @Column({ type: String }) name: string; @ManyToOne(type => Company, company => company.id, { diff --git a/test/functional/driver/convert-to-entity/convert-to-entity.ts b/test/functional/driver/convert-to-entity/convert-to-entity.ts index 6d8ae1044..04c979589 100644 --- a/test/functional/driver/convert-to-entity/convert-to-entity.ts +++ b/test/functional/driver/convert-to-entity/convert-to-entity.ts @@ -1,8 +1,8 @@ -import "reflect-metadata"; -import {expect} from "chai"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils"; -import {Connection} from "../../../../src/connection/Connection"; -import {Post} from "./entity/Post"; +import {runIfMain} from "../../../deps/mocha.ts"; +import {expect} from "../../../deps/chai.ts"; +import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils.ts"; +import {Connection} from "../../../../src/connection/Connection.ts"; +import {Post} from "./entity/Post.ts"; describe("driver > convert raw results to entity", () => { @@ -54,3 +54,5 @@ describe("driver > convert raw results to entity", () => { } }))); }); + +runIfMain(import.meta); diff --git a/test/functional/driver/convert-to-entity/entity/Post.ts b/test/functional/driver/convert-to-entity/entity/Post.ts index 55621d728..2f9cca480 100644 --- a/test/functional/driver/convert-to-entity/entity/Post.ts +++ b/test/functional/driver/convert-to-entity/entity/Post.ts @@ -1,6 +1,6 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn.ts"; @Entity() export class Post { @@ -8,6 +8,6 @@ export class Post { @PrimaryColumn("int") id: number; - @Column({nullable: true}) + @Column({nullable: true, type: Boolean}) isNew: boolean; -} \ No newline at end of file +} diff --git a/test/functional/embedded/basic-functionality/basic-functionality.ts b/test/functional/embedded/basic-functionality/basic-functionality.ts index 489f98dd2..38e2e4852 100644 --- a/test/functional/embedded/basic-functionality/basic-functionality.ts +++ b/test/functional/embedded/basic-functionality/basic-functionality.ts @@ -1,15 +1,17 @@ -import "reflect-metadata"; -import {Post} from "./entity/Post"; -import {Counters} from "./entity/Counters"; -import {Connection} from "../../../../src/connection/Connection"; -import {expect} from "chai"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils"; +import {join as joinPaths} from "../../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../../deps/mocha.ts"; +import {Post} from "./entity/Post.ts"; +import {Counters} from "./entity/Counters.ts"; +import {Connection} from "../../../../src/connection/Connection.ts"; +import {expect} from "../../../deps/chai.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils.ts"; describe("embedded > basic functionality", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], })); beforeEach(() => reloadTestingDatabases(connections)); after(() => closeTestingConnections(connections)); @@ -60,3 +62,5 @@ describe("embedded > basic functionality", () => { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/embedded/basic-functionality/entity/Counters.ts b/test/functional/embedded/basic-functionality/entity/Counters.ts index 96f542327..437978c52 100644 --- a/test/functional/embedded/basic-functionality/entity/Counters.ts +++ b/test/functional/embedded/basic-functionality/entity/Counters.ts @@ -1,14 +1,14 @@ -import {Column} from "../../../../../src/decorator/columns/Column"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; export class Counters { - @Column() + @Column({ type: Number }) likes: number; - @Column() + @Column({ type: Number }) comments: number; - @Column() + @Column({ type: Number }) favorites: number; -} \ No newline at end of file +} diff --git a/test/functional/embedded/basic-functionality/entity/Post.ts b/test/functional/embedded/basic-functionality/entity/Post.ts index 67171426e..67ac38ce1 100644 --- a/test/functional/embedded/basic-functionality/entity/Post.ts +++ b/test/functional/embedded/basic-functionality/entity/Post.ts @@ -1,7 +1,7 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {Counters} from "./Counters"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {Counters} from "./Counters.ts"; @Entity() export class Post { @@ -9,13 +9,13 @@ export class Post { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) title: string; - @Column() + @Column({ type: String }) text: string; @Column(() => Counters) counters: Counters; -} \ No newline at end of file +} diff --git a/test/functional/embedded/embedded-listeners/embedded-listeners.ts b/test/functional/embedded/embedded-listeners/embedded-listeners.ts index e26ba4bad..29b04f7b5 100644 --- a/test/functional/embedded/embedded-listeners/embedded-listeners.ts +++ b/test/functional/embedded/embedded-listeners/embedded-listeners.ts @@ -1,14 +1,16 @@ -import "reflect-metadata"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils"; -import {Connection} from "../../../../src/connection/Connection"; -import {Post} from "./entity/Post"; -import {expect} from "chai"; +import {join as joinPaths} from "../../../../vendor/https/deno.land/std/path/mod.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils.ts"; +import {Connection} from "../../../../src/connection/Connection.ts"; +import {Post} from "./entity/Post.ts"; +import {runIfMain} from "../../../deps/mocha.ts"; +import {expect} from "../../../deps/chai.ts"; describe("other issues > entity listeners must work in embeddeds as well", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], })); beforeEach(() => reloadTestingDatabases(connections)); after(() => closeTestingConnections(connections)); @@ -35,3 +37,5 @@ describe("other issues > entity listeners must work in embeddeds as well", () => }))); }); + +runIfMain(import.meta); diff --git a/test/functional/embedded/embedded-listeners/entity/Post.ts b/test/functional/embedded/embedded-listeners/entity/Post.ts index 3fb17531a..a7c025b11 100644 --- a/test/functional/embedded/embedded-listeners/entity/Post.ts +++ b/test/functional/embedded/embedded-listeners/entity/Post.ts @@ -1,8 +1,8 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {PostInformation} from "./PostInformation"; -import {Index} from "../../../../../src/decorator/Index"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {PostInformation} from "./PostInformation.ts"; +import {Index} from "../../../../../src/decorator/Index.ts"; @Entity() export class Post { @@ -10,14 +10,14 @@ export class Post { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) @Index() title: string; - @Column() + @Column({ type: String }) text: string; @Column(type => PostInformation, { prefix: "info" }) information: PostInformation = new PostInformation(); -} \ No newline at end of file +} diff --git a/test/functional/embedded/embedded-listeners/entity/PostCounter.ts b/test/functional/embedded/embedded-listeners/entity/PostCounter.ts index cc9ded61d..01383469a 100644 --- a/test/functional/embedded/embedded-listeners/entity/PostCounter.ts +++ b/test/functional/embedded/embedded-listeners/entity/PostCounter.ts @@ -1,18 +1,18 @@ -import {Column} from "../../../../../src/decorator/columns/Column"; -import {BeforeInsert} from "../../../../../src/decorator/listeners/BeforeInsert"; -import {BeforeUpdate} from "../../../../../src/decorator/listeners/BeforeUpdate"; -import {Index} from "../../../../../src/decorator/Index"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {BeforeInsert} from "../../../../../src/decorator/listeners/BeforeInsert.ts"; +import {BeforeUpdate} from "../../../../../src/decorator/listeners/BeforeUpdate.ts"; +import {Index} from "../../../../../src/decorator/Index.ts"; @Index(["likes", "favorites"]) export class PostCounter { - @Column() + @Column({ type: Number }) likes: number; - @Column() + @Column({ type: Number }) favorites: number; - @Column() + @Column({ type: Number }) comments: number; @BeforeInsert() @@ -29,4 +29,4 @@ export class PostCounter { this.comments++; } -} \ No newline at end of file +} diff --git a/test/functional/embedded/embedded-listeners/entity/PostInformation.ts b/test/functional/embedded/embedded-listeners/entity/PostInformation.ts index 4ef1c78c9..0079953c1 100644 --- a/test/functional/embedded/embedded-listeners/entity/PostInformation.ts +++ b/test/functional/embedded/embedded-listeners/entity/PostInformation.ts @@ -1,11 +1,11 @@ -import {Column} from "../../../../../src/decorator/columns/Column"; -import {PostCounter} from "./PostCounter"; -import {BeforeInsert} from "../../../../../src/decorator/listeners/BeforeInsert"; -import {Index} from "../../../../../src/decorator/Index"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {PostCounter} from "./PostCounter.ts"; +import {BeforeInsert} from "../../../../../src/decorator/listeners/BeforeInsert.ts"; +import {Index} from "../../../../../src/decorator/Index.ts"; export class PostInformation { - @Column() + @Column({ type: String }) @Index() description: string; @@ -17,4 +17,4 @@ export class PostInformation { this.description = "default post description"; } -} \ No newline at end of file +} diff --git a/test/functional/embedded/embedded-many-to-many-case1/embedded-many-to-many-case1.ts b/test/functional/embedded/embedded-many-to-many-case1/embedded-many-to-many-case1.ts index 574317c6a..701b2fb6d 100644 --- a/test/functional/embedded/embedded-many-to-many-case1/embedded-many-to-many-case1.ts +++ b/test/functional/embedded/embedded-many-to-many-case1/embedded-many-to-many-case1.ts @@ -1,17 +1,19 @@ -import "reflect-metadata"; -import {Post} from "./entity/Post"; -import {Counters} from "./entity/Counters"; -import {Connection} from "../../../../src/connection/Connection"; -import {expect} from "chai"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils"; -import {Subcounters} from "./entity/Subcounters"; -import {User} from "./entity/User"; +import {join as joinPaths} from "../../../../vendor/https/deno.land/std/path/mod.ts"; +import {Post} from "./entity/Post.ts"; +import {Counters} from "./entity/Counters.ts"; +import {Connection} from "../../../../src/connection/Connection.ts"; +import {runIfMain} from "../../../deps/mocha.ts"; +import {expect} from "../../../deps/chai.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils.ts"; +import {Subcounters} from "./entity/Subcounters.ts"; +import {User} from "./entity/User.ts"; describe("embedded > embedded-many-to-many-case1", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], })); beforeEach(() => reloadTestingDatabases(connections)); after(() => closeTestingConnections(connections)); @@ -422,3 +424,5 @@ describe("embedded > embedded-many-to-many-case1", () => { }); }); + +runIfMain(import.meta); diff --git a/test/functional/embedded/embedded-many-to-many-case1/entity/Counters.ts b/test/functional/embedded/embedded-many-to-many-case1/entity/Counters.ts index fbc187776..77d4bcff6 100644 --- a/test/functional/embedded/embedded-many-to-many-case1/entity/Counters.ts +++ b/test/functional/embedded/embedded-many-to-many-case1/entity/Counters.ts @@ -1,21 +1,21 @@ -import {Column} from "../../../../../src/decorator/columns/Column"; -import {ManyToMany} from "../../../../../src/decorator/relations/ManyToMany"; -import {JoinTable} from "../../../../../src/decorator/relations/JoinTable"; -import {Subcounters} from "./Subcounters"; -import {User} from "./User"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {ManyToMany} from "../../../../../src/decorator/relations/ManyToMany.ts"; +import {JoinTable} from "../../../../../src/decorator/relations/JoinTable.ts"; +import {Subcounters} from "./Subcounters.ts"; +import {User} from "./User.ts"; export class Counters { - @Column() + @Column({ type: Number }) code: number; - @Column() + @Column({ type: Number }) likes: number; - @Column() + @Column({ type: Number }) comments: number; - @Column() + @Column({ type: Number }) favorites: number; @Column(() => Subcounters, { prefix: "subcnt" }) @@ -25,4 +25,4 @@ export class Counters { @JoinTable() likedUsers: User[]; -} \ No newline at end of file +} diff --git a/test/functional/embedded/embedded-many-to-many-case1/entity/Post.ts b/test/functional/embedded/embedded-many-to-many-case1/entity/Post.ts index e6ec86e6f..070db99d7 100644 --- a/test/functional/embedded/embedded-many-to-many-case1/entity/Post.ts +++ b/test/functional/embedded/embedded-many-to-many-case1/entity/Post.ts @@ -1,15 +1,15 @@ -import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn"; -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {Counters} from "./Counters"; +import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn.ts"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {Counters} from "./Counters.ts"; @Entity() export class Post { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; - @Column() + @Column({ type: String }) title: string; @Column(() => Counters) diff --git a/test/functional/embedded/embedded-many-to-many-case1/entity/Subcounters.ts b/test/functional/embedded/embedded-many-to-many-case1/entity/Subcounters.ts index a89a0cbc5..69704012f 100644 --- a/test/functional/embedded/embedded-many-to-many-case1/entity/Subcounters.ts +++ b/test/functional/embedded/embedded-many-to-many-case1/entity/Subcounters.ts @@ -1,11 +1,11 @@ -import {Column} from "../../../../../src/decorator/columns/Column"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; export class Subcounters { - @Column() + @Column({ type: Number }) version: number; - @Column() + @Column({ type: Number }) watches: number; -} \ No newline at end of file +} diff --git a/test/functional/embedded/embedded-many-to-many-case1/entity/User.ts b/test/functional/embedded/embedded-many-to-many-case1/entity/User.ts index fc164e370..0477096be 100644 --- a/test/functional/embedded/embedded-many-to-many-case1/entity/User.ts +++ b/test/functional/embedded/embedded-many-to-many-case1/entity/User.ts @@ -1,16 +1,16 @@ -import {Column} from "../../../../../src/decorator/columns/Column"; -import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn"; -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {ManyToMany} from "../../../../../src/decorator/relations/ManyToMany"; -import {Post} from "./Post"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn.ts"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {ManyToMany} from "../../../../../src/decorator/relations/ManyToMany.ts"; +import {Post} from "./Post.ts"; @Entity() export class User { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; - @Column() + @Column({ type: String }) name: string; @ManyToMany(type => Post, post => post.counters.likedUsers) diff --git a/test/functional/embedded/embedded-many-to-many-case2/embedded-many-to-many-case2.ts b/test/functional/embedded/embedded-many-to-many-case2/embedded-many-to-many-case2.ts index 6b1f9c20a..34b9a067b 100644 --- a/test/functional/embedded/embedded-many-to-many-case2/embedded-many-to-many-case2.ts +++ b/test/functional/embedded/embedded-many-to-many-case2/embedded-many-to-many-case2.ts @@ -1,17 +1,19 @@ -import "reflect-metadata"; -import {Post} from "./entity/Post"; -import {Counters} from "./entity/Counters"; -import {Connection} from "../../../../src/connection/Connection"; -import {expect} from "chai"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils"; -import {Subcounters} from "./entity/Subcounters"; -import {User} from "./entity/User"; +import {join as joinPaths} from "../../../../vendor/https/deno.land/std/path/mod.ts"; +import {Post} from "./entity/Post.ts"; +import {Counters} from "./entity/Counters.ts"; +import {Connection} from "../../../../src/connection/Connection.ts"; +import {runIfMain} from "../../../deps/mocha.ts"; +import {expect} from "../../../deps/chai.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils.ts"; +import {Subcounters} from "./entity/Subcounters.ts"; +import {User} from "./entity/User.ts"; describe("embedded > embedded-many-to-many-case2", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], })); beforeEach(() => reloadTestingDatabases(connections)); after(() => closeTestingConnections(connections)); @@ -421,3 +423,5 @@ describe("embedded > embedded-many-to-many-case2", () => { }))); }); }); + +runIfMain(import.meta); diff --git a/test/functional/embedded/embedded-many-to-many-case2/entity/Counters.ts b/test/functional/embedded/embedded-many-to-many-case2/entity/Counters.ts index 16fea22dc..89498ef02 100644 --- a/test/functional/embedded/embedded-many-to-many-case2/entity/Counters.ts +++ b/test/functional/embedded/embedded-many-to-many-case2/entity/Counters.ts @@ -1,20 +1,20 @@ -import {Column} from "../../../../../src/decorator/columns/Column"; -import {ManyToMany} from "../../../../../src/decorator/relations/ManyToMany"; -import {Subcounters} from "./Subcounters"; -import {User} from "./User"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {ManyToMany} from "../../../../../src/decorator/relations/ManyToMany.ts"; +import {Subcounters} from "./Subcounters.ts"; +import {User} from "./User.ts"; export class Counters { - @Column() + @Column({ type: Number }) code: number; - @Column() + @Column({ type: Number }) likes: number; - @Column() + @Column({ type: Number }) comments: number; - @Column() + @Column({ type: Number }) favorites: number; @Column(() => Subcounters, { prefix: "subcnt" }) @@ -23,4 +23,4 @@ export class Counters { @ManyToMany(type => User, user => user.likedPosts) likedUsers: User[]; -} \ No newline at end of file +} diff --git a/test/functional/embedded/embedded-many-to-many-case2/entity/Post.ts b/test/functional/embedded/embedded-many-to-many-case2/entity/Post.ts index e6ec86e6f..070db99d7 100644 --- a/test/functional/embedded/embedded-many-to-many-case2/entity/Post.ts +++ b/test/functional/embedded/embedded-many-to-many-case2/entity/Post.ts @@ -1,15 +1,15 @@ -import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn"; -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {Counters} from "./Counters"; +import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn.ts"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {Counters} from "./Counters.ts"; @Entity() export class Post { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; - @Column() + @Column({ type: String }) title: string; @Column(() => Counters) diff --git a/test/functional/embedded/embedded-many-to-many-case2/entity/Subcounters.ts b/test/functional/embedded/embedded-many-to-many-case2/entity/Subcounters.ts index a89a0cbc5..69704012f 100644 --- a/test/functional/embedded/embedded-many-to-many-case2/entity/Subcounters.ts +++ b/test/functional/embedded/embedded-many-to-many-case2/entity/Subcounters.ts @@ -1,11 +1,11 @@ -import {Column} from "../../../../../src/decorator/columns/Column"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; export class Subcounters { - @Column() + @Column({ type: Number }) version: number; - @Column() + @Column({ type: Number }) watches: number; -} \ No newline at end of file +} diff --git a/test/functional/embedded/embedded-many-to-many-case2/entity/User.ts b/test/functional/embedded/embedded-many-to-many-case2/entity/User.ts index 470c8fb6a..9d73de31b 100644 --- a/test/functional/embedded/embedded-many-to-many-case2/entity/User.ts +++ b/test/functional/embedded/embedded-many-to-many-case2/entity/User.ts @@ -1,17 +1,17 @@ -import {Column} from "../../../../../src/decorator/columns/Column"; -import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn"; -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {ManyToMany} from "../../../../../src/decorator/relations/ManyToMany"; -import {Post} from "./Post"; -import {JoinTable} from "../../../../../src/decorator/relations/JoinTable"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn.ts"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {ManyToMany} from "../../../../../src/decorator/relations/ManyToMany.ts"; +import {Post} from "./Post.ts"; +import {JoinTable} from "../../../../../src/decorator/relations/JoinTable.ts"; @Entity() export class User { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; - @Column() + @Column({ type: String }) name: string; @ManyToMany(type => Post, post => post.counters.likedUsers) diff --git a/test/functional/embedded/embedded-many-to-many-case3/embedded-many-to-many-case3.ts b/test/functional/embedded/embedded-many-to-many-case3/embedded-many-to-many-case3.ts index 716f3f33e..2027c5757 100644 --- a/test/functional/embedded/embedded-many-to-many-case3/embedded-many-to-many-case3.ts +++ b/test/functional/embedded/embedded-many-to-many-case3/embedded-many-to-many-case3.ts @@ -1,17 +1,19 @@ -import "reflect-metadata"; -import {Post} from "./entity/Post"; -import {Counters} from "./entity/Counters"; -import {Connection} from "../../../../src/connection/Connection"; -import {expect} from "chai"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils"; -import {Subcounters} from "./entity/Subcounters"; -import {User} from "./entity/User"; +import {join as joinPaths} from "../../../../vendor/https/deno.land/std/path/mod.ts"; +import {Post} from "./entity/Post.ts"; +import {Counters} from "./entity/Counters.ts"; +import {Connection} from "../../../../src/connection/Connection.ts"; +import {runIfMain} from "../../../deps/mocha.ts"; +import {expect} from "../../../deps/chai.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils.ts"; +import {Subcounters} from "./entity/Subcounters.ts"; +import {User} from "./entity/User.ts"; describe("embedded > embedded-many-to-many-case3", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], })); beforeEach(() => reloadTestingDatabases(connections)); after(() => closeTestingConnections(connections)); @@ -420,3 +422,5 @@ describe("embedded > embedded-many-to-many-case3", () => { }); }); + +runIfMain(import.meta); diff --git a/test/functional/embedded/embedded-many-to-many-case3/entity/Counters.ts b/test/functional/embedded/embedded-many-to-many-case3/entity/Counters.ts index ba93b1543..aabe0777f 100644 --- a/test/functional/embedded/embedded-many-to-many-case3/entity/Counters.ts +++ b/test/functional/embedded/embedded-many-to-many-case3/entity/Counters.ts @@ -1,22 +1,22 @@ -import {Column} from "../../../../../src/decorator/columns/Column"; -import {ManyToMany} from "../../../../../src/decorator/relations/ManyToMany"; -import {JoinTable} from "../../../../../src/decorator/relations/JoinTable"; -import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn"; -import {Subcounters} from "./Subcounters"; -import {User} from "./User"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {ManyToMany} from "../../../../../src/decorator/relations/ManyToMany.ts"; +import {JoinTable} from "../../../../../src/decorator/relations/JoinTable.ts"; +import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn.ts"; +import {Subcounters} from "./Subcounters.ts"; +import {User} from "./User.ts"; export class Counters { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) code: number; - @Column() + @Column({ type: Number }) likes: number; - @Column() + @Column({ type: Number }) comments: number; - @Column() + @Column({ type: Number }) favorites: number; @Column(() => Subcounters, { prefix: "subcnt" }) @@ -26,4 +26,4 @@ export class Counters { @JoinTable() likedUsers: User[]; -} \ No newline at end of file +} diff --git a/test/functional/embedded/embedded-many-to-many-case3/entity/Post.ts b/test/functional/embedded/embedded-many-to-many-case3/entity/Post.ts index 59854b2a9..ea39d1e4b 100644 --- a/test/functional/embedded/embedded-many-to-many-case3/entity/Post.ts +++ b/test/functional/embedded/embedded-many-to-many-case3/entity/Post.ts @@ -1,18 +1,18 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn"; -import {Counters} from "./Counters"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn.ts"; +import {Counters} from "./Counters.ts"; @Entity() export class Post { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; - @Column() + @Column({ type: String }) title: string; @Column(() => Counters) counters: Counters; -} \ No newline at end of file +} diff --git a/test/functional/embedded/embedded-many-to-many-case3/entity/Subcounters.ts b/test/functional/embedded/embedded-many-to-many-case3/entity/Subcounters.ts index c0aa97f1f..898ef504e 100644 --- a/test/functional/embedded/embedded-many-to-many-case3/entity/Subcounters.ts +++ b/test/functional/embedded/embedded-many-to-many-case3/entity/Subcounters.ts @@ -1,12 +1,12 @@ -import {Column} from "../../../../../src/decorator/columns/Column"; -import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn.ts"; export class Subcounters { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) version: number; - @Column() + @Column({ type: Number }) watches: number; -} \ No newline at end of file +} diff --git a/test/functional/embedded/embedded-many-to-many-case3/entity/User.ts b/test/functional/embedded/embedded-many-to-many-case3/entity/User.ts index fc164e370..0477096be 100644 --- a/test/functional/embedded/embedded-many-to-many-case3/entity/User.ts +++ b/test/functional/embedded/embedded-many-to-many-case3/entity/User.ts @@ -1,16 +1,16 @@ -import {Column} from "../../../../../src/decorator/columns/Column"; -import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn"; -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {ManyToMany} from "../../../../../src/decorator/relations/ManyToMany"; -import {Post} from "./Post"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn.ts"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {ManyToMany} from "../../../../../src/decorator/relations/ManyToMany.ts"; +import {Post} from "./Post.ts"; @Entity() export class User { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; - @Column() + @Column({ type: String }) name: string; @ManyToMany(type => Post, post => post.counters.likedUsers) diff --git a/test/functional/embedded/embedded-many-to-many-case4/embedded-many-to-many-case4.ts b/test/functional/embedded/embedded-many-to-many-case4/embedded-many-to-many-case4.ts index 02c59f160..b94a13da4 100644 --- a/test/functional/embedded/embedded-many-to-many-case4/embedded-many-to-many-case4.ts +++ b/test/functional/embedded/embedded-many-to-many-case4/embedded-many-to-many-case4.ts @@ -1,17 +1,19 @@ -import "reflect-metadata"; -import {Post} from "./entity/Post"; -import {Counters} from "./entity/Counters"; -import {Connection} from "../../../../src/connection/Connection"; -import {expect} from "chai"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils"; -import {Subcounters} from "./entity/Subcounters"; -import {User} from "./entity/User"; +import {join as joinPaths} from "../../../../vendor/https/deno.land/std/path/mod.ts"; +import {Post} from "./entity/Post.ts"; +import {Counters} from "./entity/Counters.ts"; +import {Connection} from "../../../../src/connection/Connection.ts"; +import {runIfMain} from "../../../deps/mocha.ts"; +import {expect} from "../../../deps/chai.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils.ts"; +import {Subcounters} from "./entity/Subcounters.ts"; +import {User} from "./entity/User.ts"; describe("embedded > embedded-many-to-many-case4", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], })); beforeEach(() => reloadTestingDatabases(connections)); after(() => closeTestingConnections(connections)); @@ -437,3 +439,5 @@ describe("embedded > embedded-many-to-many-case4", () => { }); }); + +runIfMain(import.meta); diff --git a/test/functional/embedded/embedded-many-to-many-case4/entity/Counters.ts b/test/functional/embedded/embedded-many-to-many-case4/entity/Counters.ts index fbc187776..77d4bcff6 100644 --- a/test/functional/embedded/embedded-many-to-many-case4/entity/Counters.ts +++ b/test/functional/embedded/embedded-many-to-many-case4/entity/Counters.ts @@ -1,21 +1,21 @@ -import {Column} from "../../../../../src/decorator/columns/Column"; -import {ManyToMany} from "../../../../../src/decorator/relations/ManyToMany"; -import {JoinTable} from "../../../../../src/decorator/relations/JoinTable"; -import {Subcounters} from "./Subcounters"; -import {User} from "./User"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {ManyToMany} from "../../../../../src/decorator/relations/ManyToMany.ts"; +import {JoinTable} from "../../../../../src/decorator/relations/JoinTable.ts"; +import {Subcounters} from "./Subcounters.ts"; +import {User} from "./User.ts"; export class Counters { - @Column() + @Column({ type: Number }) code: number; - @Column() + @Column({ type: Number }) likes: number; - @Column() + @Column({ type: Number }) comments: number; - @Column() + @Column({ type: Number }) favorites: number; @Column(() => Subcounters, { prefix: "subcnt" }) @@ -25,4 +25,4 @@ export class Counters { @JoinTable() likedUsers: User[]; -} \ No newline at end of file +} diff --git a/test/functional/embedded/embedded-many-to-many-case4/entity/Post.ts b/test/functional/embedded/embedded-many-to-many-case4/entity/Post.ts index e6ec86e6f..070db99d7 100644 --- a/test/functional/embedded/embedded-many-to-many-case4/entity/Post.ts +++ b/test/functional/embedded/embedded-many-to-many-case4/entity/Post.ts @@ -1,15 +1,15 @@ -import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn"; -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {Counters} from "./Counters"; +import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn.ts"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {Counters} from "./Counters.ts"; @Entity() export class Post { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; - @Column() + @Column({ type: String }) title: string; @Column(() => Counters) diff --git a/test/functional/embedded/embedded-many-to-many-case4/entity/Subcounters.ts b/test/functional/embedded/embedded-many-to-many-case4/entity/Subcounters.ts index a89a0cbc5..69704012f 100644 --- a/test/functional/embedded/embedded-many-to-many-case4/entity/Subcounters.ts +++ b/test/functional/embedded/embedded-many-to-many-case4/entity/Subcounters.ts @@ -1,11 +1,11 @@ -import {Column} from "../../../../../src/decorator/columns/Column"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; export class Subcounters { - @Column() + @Column({ type: Number }) version: number; - @Column() + @Column({ type: Number }) watches: number; -} \ No newline at end of file +} diff --git a/test/functional/embedded/embedded-many-to-many-case4/entity/User.ts b/test/functional/embedded/embedded-many-to-many-case4/entity/User.ts index 705e6902c..0d7c2a200 100644 --- a/test/functional/embedded/embedded-many-to-many-case4/entity/User.ts +++ b/test/functional/embedded/embedded-many-to-many-case4/entity/User.ts @@ -1,22 +1,22 @@ -import {Column} from "../../../../../src/decorator/columns/Column"; -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {ManyToMany} from "../../../../../src/decorator/relations/ManyToMany"; -import {Post} from "./Post"; -import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {ManyToMany} from "../../../../../src/decorator/relations/ManyToMany.ts"; +import {Post} from "./Post.ts"; +import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn.ts"; @Entity() export class User { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; - @PrimaryColumn() + @PrimaryColumn({ type: Number }) personId: number; - @Column() + @Column({ type: String }) name: string; @ManyToMany(type => Post, post => post.counters.likedUsers) likedPosts: Post[]; -} \ No newline at end of file +} diff --git a/test/functional/embedded/embedded-many-to-many-case5/embedded-many-to-many-case5.ts b/test/functional/embedded/embedded-many-to-many-case5/embedded-many-to-many-case5.ts index 73d3cbd48..5be72e7ee 100644 --- a/test/functional/embedded/embedded-many-to-many-case5/embedded-many-to-many-case5.ts +++ b/test/functional/embedded/embedded-many-to-many-case5/embedded-many-to-many-case5.ts @@ -1,17 +1,19 @@ -import "reflect-metadata"; -import {Post} from "./entity/Post"; -import {Counters} from "./entity/Counters"; -import {Connection} from "../../../../src/connection/Connection"; -import {expect} from "chai"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils"; -import {Subcounters} from "./entity/Subcounters"; -import {User} from "./entity/User"; +import {join as joinPaths} from "../../../../vendor/https/deno.land/std/path/mod.ts"; +import {Post} from "./entity/Post.ts"; +import {Counters} from "./entity/Counters.ts"; +import {Connection} from "../../../../src/connection/Connection.ts"; +import {runIfMain} from "../../../deps/mocha.ts"; +import {expect} from "../../../deps/chai.ts"; +import {closeTestingConnections, createTestingConnections, reloadTestingDatabases, getDirnameOfCurrentModule} from "../../../utils/test-utils.ts"; +import {Subcounters} from "./entity/Subcounters.ts"; +import {User} from "./entity/User.ts"; describe("embedded > embedded-many-to-many-case5", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], })); beforeEach(() => reloadTestingDatabases(connections)); after(() => closeTestingConnections(connections)); @@ -437,3 +439,5 @@ describe("embedded > embedded-many-to-many-case5", () => { }); }); + +runIfMain(import.meta); diff --git a/test/functional/embedded/embedded-many-to-many-case5/entity/Counters.ts b/test/functional/embedded/embedded-many-to-many-case5/entity/Counters.ts index c719066c6..6ebd011df 100644 --- a/test/functional/embedded/embedded-many-to-many-case5/entity/Counters.ts +++ b/test/functional/embedded/embedded-many-to-many-case5/entity/Counters.ts @@ -1,22 +1,22 @@ -import {Column} from "../../../../../src/decorator/columns/Column"; -import {ManyToMany} from "../../../../../src/decorator/relations/ManyToMany"; -import {JoinTable} from "../../../../../src/decorator/relations/JoinTable"; -import {Subcounters} from "./Subcounters"; -import {User} from "./User"; -import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {ManyToMany} from "../../../../../src/decorator/relations/ManyToMany.ts"; +import {JoinTable} from "../../../../../src/decorator/relations/JoinTable.ts"; +import {Subcounters} from "./Subcounters.ts"; +import {User} from "./User.ts"; +import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn.ts"; export class Counters { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) code: number; - @Column() + @Column({ type: Number }) likes: number; - @Column() + @Column({ type: Number }) comments: number; - @Column() + @Column({ type: Number }) favorites: number; @Column(() => Subcounters, { prefix: "subcnt" }) @@ -26,4 +26,4 @@ export class Counters { @JoinTable() likedUsers: User[]; -} \ No newline at end of file +} diff --git a/test/functional/embedded/embedded-many-to-many-case5/entity/Post.ts b/test/functional/embedded/embedded-many-to-many-case5/entity/Post.ts index 4bca9ad49..433c2abf4 100644 --- a/test/functional/embedded/embedded-many-to-many-case5/entity/Post.ts +++ b/test/functional/embedded/embedded-many-to-many-case5/entity/Post.ts @@ -1,15 +1,15 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {Counters} from "./Counters"; -import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {Counters} from "./Counters.ts"; +import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn.ts"; @Entity() export class Post { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; - @Column() + @Column({ type: String }) title: string; @Column(() => Counters) diff --git a/test/functional/embedded/embedded-many-to-many-case5/entity/Subcounters.ts b/test/functional/embedded/embedded-many-to-many-case5/entity/Subcounters.ts index c0aa97f1f..898ef504e 100644 --- a/test/functional/embedded/embedded-many-to-many-case5/entity/Subcounters.ts +++ b/test/functional/embedded/embedded-many-to-many-case5/entity/Subcounters.ts @@ -1,12 +1,12 @@ -import {Column} from "../../../../../src/decorator/columns/Column"; -import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn.ts"; export class Subcounters { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) version: number; - @Column() + @Column({ type: Number }) watches: number; -} \ No newline at end of file +} diff --git a/test/functional/embedded/embedded-many-to-many-case5/entity/User.ts b/test/functional/embedded/embedded-many-to-many-case5/entity/User.ts index 78da1a622..a9b043622 100644 --- a/test/functional/embedded/embedded-many-to-many-case5/entity/User.ts +++ b/test/functional/embedded/embedded-many-to-many-case5/entity/User.ts @@ -1,22 +1,22 @@ -import {Column} from "../../../../../src/decorator/columns/Column"; -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {ManyToMany} from "../../../../../src/decorator/relations/ManyToMany"; -import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn"; -import {Post} from "./Post"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {ManyToMany} from "../../../../../src/decorator/relations/ManyToMany.ts"; +import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn.ts"; +import {Post} from "./Post.ts"; @Entity() export class User { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; - @PrimaryColumn() + @PrimaryColumn({ type: Number }) personId: number; - @Column() + @Column({ type: String }) name: string; @ManyToMany(type => Post, post => post.counters.likedUsers) likedPosts: Post[]; -} \ No newline at end of file +} diff --git a/test/functional/embedded/embedded-many-to-one-case1/embedded-many-to-one-case1.ts b/test/functional/embedded/embedded-many-to-one-case1/embedded-many-to-one-case1.ts index d882adefa..df6e0b8ab 100644 --- a/test/functional/embedded/embedded-many-to-one-case1/embedded-many-to-one-case1.ts +++ b/test/functional/embedded/embedded-many-to-one-case1/embedded-many-to-one-case1.ts @@ -1,17 +1,19 @@ -import "reflect-metadata"; -import {Post} from "./entity/Post"; -import {Counters} from "./entity/Counters"; -import {Connection} from "../../../../src/connection/Connection"; -import {expect} from "chai"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils"; -import {Subcounters} from "./entity/Subcounters"; -import {User} from "./entity/User"; +import {join as joinPaths} from "../../../../vendor/https/deno.land/std/path/mod.ts"; +import {Post} from "./entity/Post.ts"; +import {Counters} from "./entity/Counters.ts"; +import {Connection} from "../../../../src/connection/Connection.ts"; +import {runIfMain} from "../../../deps/mocha.ts"; +import {expect} from "../../../deps/chai.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils.ts"; +import {Subcounters} from "./entity/Subcounters.ts"; +import {User} from "./entity/User.ts"; describe("embedded > embedded-many-to-one-case1", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], })); beforeEach(() => reloadTestingDatabases(connections)); after(() => closeTestingConnections(connections)); @@ -376,3 +378,5 @@ describe("embedded > embedded-many-to-one-case1", () => { }); }); + +runIfMain(import.meta); diff --git a/test/functional/embedded/embedded-many-to-one-case1/entity/Counters.ts b/test/functional/embedded/embedded-many-to-one-case1/entity/Counters.ts index 9ff3b9440..85db31706 100644 --- a/test/functional/embedded/embedded-many-to-one-case1/entity/Counters.ts +++ b/test/functional/embedded/embedded-many-to-one-case1/entity/Counters.ts @@ -1,21 +1,21 @@ -import {Column} from "../../../../../src/decorator/columns/Column"; -import {JoinColumn} from "../../../../../src/decorator/relations/JoinColumn"; -import {ManyToOne} from "../../../../../src/decorator/relations/ManyToOne"; -import {User} from "./User"; -import {Subcounters} from "./Subcounters"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {JoinColumn} from "../../../../../src/decorator/relations/JoinColumn.ts"; +import {ManyToOne} from "../../../../../src/decorator/relations/ManyToOne.ts"; +import {User} from "./User.ts"; +import {Subcounters} from "./Subcounters.ts"; export class Counters { - @Column() + @Column({ type: Number }) code: number; - @Column() + @Column({ type: Number }) likes: number; - @Column() + @Column({ type: Number }) comments: number; - @Column() + @Column({ type: Number }) favorites: number; @Column(() => Subcounters, { prefix: "subcnt" }) @@ -25,4 +25,4 @@ export class Counters { @JoinColumn() likedUser: User; -} \ No newline at end of file +} diff --git a/test/functional/embedded/embedded-many-to-one-case1/entity/Post.ts b/test/functional/embedded/embedded-many-to-one-case1/entity/Post.ts index e6ec86e6f..070db99d7 100644 --- a/test/functional/embedded/embedded-many-to-one-case1/entity/Post.ts +++ b/test/functional/embedded/embedded-many-to-one-case1/entity/Post.ts @@ -1,15 +1,15 @@ -import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn"; -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {Counters} from "./Counters"; +import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn.ts"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {Counters} from "./Counters.ts"; @Entity() export class Post { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; - @Column() + @Column({ type: String }) title: string; @Column(() => Counters) diff --git a/test/functional/embedded/embedded-many-to-one-case1/entity/Subcounters.ts b/test/functional/embedded/embedded-many-to-one-case1/entity/Subcounters.ts index a89a0cbc5..69704012f 100644 --- a/test/functional/embedded/embedded-many-to-one-case1/entity/Subcounters.ts +++ b/test/functional/embedded/embedded-many-to-one-case1/entity/Subcounters.ts @@ -1,11 +1,11 @@ -import {Column} from "../../../../../src/decorator/columns/Column"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; export class Subcounters { - @Column() + @Column({ type: Number }) version: number; - @Column() + @Column({ type: Number }) watches: number; -} \ No newline at end of file +} diff --git a/test/functional/embedded/embedded-many-to-one-case1/entity/User.ts b/test/functional/embedded/embedded-many-to-one-case1/entity/User.ts index 761f5e18d..91518421e 100644 --- a/test/functional/embedded/embedded-many-to-one-case1/entity/User.ts +++ b/test/functional/embedded/embedded-many-to-one-case1/entity/User.ts @@ -1,16 +1,16 @@ -import {Column} from "../../../../../src/decorator/columns/Column"; -import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn"; -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {OneToMany} from "../../../../../src/decorator/relations/OneToMany"; -import {Post} from "./Post"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn.ts"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {OneToMany} from "../../../../../src/decorator/relations/OneToMany.ts"; +import {Post} from "./Post.ts"; @Entity() export class User { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; - @Column() + @Column({ type: String }) name: string; @OneToMany(type => Post, post => post.counters.likedUser) diff --git a/test/functional/embedded/embedded-many-to-one-case2/embedded-many-to-one-case2.ts b/test/functional/embedded/embedded-many-to-one-case2/embedded-many-to-one-case2.ts index 928853945..c347afd77 100644 --- a/test/functional/embedded/embedded-many-to-one-case2/embedded-many-to-one-case2.ts +++ b/test/functional/embedded/embedded-many-to-one-case2/embedded-many-to-one-case2.ts @@ -1,17 +1,19 @@ -import "reflect-metadata"; -import {Connection} from "../../../../src/connection/Connection"; -import {expect} from "chai"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils"; -import {Post} from "./entity/Post"; -import {Counters} from "./entity/Counters"; -import {Subcounters} from "./entity/Subcounters"; -import {User} from "./entity/User"; +import {join as joinPaths} from "../../../../vendor/https/deno.land/std/path/mod.ts"; +import {Connection} from "../../../../src/connection/Connection.ts"; +import {runIfMain} from "../../../deps/mocha.ts"; +import {expect} from "../../../deps/chai.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils.ts"; +import {Post} from "./entity/Post.ts"; +import {Counters} from "./entity/Counters.ts"; +import {Subcounters} from "./entity/Subcounters.ts"; +import {User} from "./entity/User.ts"; describe("embedded > embedded-many-to-one-case2", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], })); beforeEach(() => reloadTestingDatabases(connections)); after(() => closeTestingConnections(connections)); @@ -347,3 +349,5 @@ describe("embedded > embedded-many-to-one-case2", () => { }))); }); }); + +runIfMain(import.meta); diff --git a/test/functional/embedded/embedded-many-to-one-case2/entity/Counters.ts b/test/functional/embedded/embedded-many-to-one-case2/entity/Counters.ts index 84a0d3344..42cf6339c 100644 --- a/test/functional/embedded/embedded-many-to-one-case2/entity/Counters.ts +++ b/test/functional/embedded/embedded-many-to-one-case2/entity/Counters.ts @@ -1,20 +1,20 @@ -import {Column} from "../../../../../src/decorator/columns/Column"; -import {OneToMany} from "../../../../../src/decorator/relations/OneToMany"; -import {User} from "./User"; -import {Subcounters} from "./Subcounters"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {OneToMany} from "../../../../../src/decorator/relations/OneToMany.ts"; +import {User} from "./User.ts"; +import {Subcounters} from "./Subcounters.ts"; export class Counters { - @Column() + @Column({ type: Number }) code: number; - @Column() + @Column({ type: Number }) likes: number; - @Column() + @Column({ type: Number }) comments: number; - @Column() + @Column({ type: Number }) favorites: number; @Column(() => Subcounters, { prefix: "subcnt" }) @@ -23,4 +23,4 @@ export class Counters { @OneToMany(type => User, user => user.likedPost) likedUsers: User[]; -} \ No newline at end of file +} diff --git a/test/functional/embedded/embedded-many-to-one-case2/entity/Post.ts b/test/functional/embedded/embedded-many-to-one-case2/entity/Post.ts index e6ec86e6f..070db99d7 100644 --- a/test/functional/embedded/embedded-many-to-one-case2/entity/Post.ts +++ b/test/functional/embedded/embedded-many-to-one-case2/entity/Post.ts @@ -1,15 +1,15 @@ -import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn"; -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {Counters} from "./Counters"; +import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn.ts"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {Counters} from "./Counters.ts"; @Entity() export class Post { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; - @Column() + @Column({ type: String }) title: string; @Column(() => Counters) diff --git a/test/functional/embedded/embedded-many-to-one-case2/entity/Subcounters.ts b/test/functional/embedded/embedded-many-to-one-case2/entity/Subcounters.ts index a89a0cbc5..69704012f 100644 --- a/test/functional/embedded/embedded-many-to-one-case2/entity/Subcounters.ts +++ b/test/functional/embedded/embedded-many-to-one-case2/entity/Subcounters.ts @@ -1,11 +1,11 @@ -import {Column} from "../../../../../src/decorator/columns/Column"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; export class Subcounters { - @Column() + @Column({ type: Number }) version: number; - @Column() + @Column({ type: Number }) watches: number; -} \ No newline at end of file +} diff --git a/test/functional/embedded/embedded-many-to-one-case2/entity/User.ts b/test/functional/embedded/embedded-many-to-one-case2/entity/User.ts index fb91ff0ed..4c619da7f 100644 --- a/test/functional/embedded/embedded-many-to-one-case2/entity/User.ts +++ b/test/functional/embedded/embedded-many-to-one-case2/entity/User.ts @@ -1,17 +1,17 @@ -import {Column} from "../../../../../src/decorator/columns/Column"; -import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn"; -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {ManyToOne} from "../../../../../src/decorator/relations/ManyToOne"; -import {JoinColumn} from "../../../../../src/decorator/relations/JoinColumn"; -import {Post} from "./Post"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn.ts"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {ManyToOne} from "../../../../../src/decorator/relations/ManyToOne.ts"; +import {JoinColumn} from "../../../../../src/decorator/relations/JoinColumn.ts"; +import {Post} from "./Post.ts"; @Entity() export class User { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; - @Column() + @Column({ type: String }) name: string; @ManyToOne(type => Post) diff --git a/test/functional/embedded/embedded-many-to-one-case3/embedded-many-to-one-case3.ts b/test/functional/embedded/embedded-many-to-one-case3/embedded-many-to-one-case3.ts index 2ca468b03..b2c5fb2e4 100644 --- a/test/functional/embedded/embedded-many-to-one-case3/embedded-many-to-one-case3.ts +++ b/test/functional/embedded/embedded-many-to-one-case3/embedded-many-to-one-case3.ts @@ -1,17 +1,19 @@ -import "reflect-metadata"; -import {Post} from "./entity/Post"; -import {Counters} from "./entity/Counters"; -import {Connection} from "../../../../src/connection/Connection"; -import {expect} from "chai"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils"; -import {Subcounters} from "./entity/Subcounters"; -import {User} from "./entity/User"; +import {join as joinPaths} from "../../../../vendor/https/deno.land/std/path/mod.ts"; +import {Post} from "./entity/Post.ts"; +import {Counters} from "./entity/Counters.ts"; +import {Connection} from "../../../../src/connection/Connection.ts"; +import {expect} from "../../../deps/chai.ts"; +import {runIfMain} from "../../../deps/mocha.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils.ts"; +import {Subcounters} from "./entity/Subcounters.ts"; +import {User} from "./entity/User.ts"; describe("embedded > embedded-many-to-one-case3", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], })); beforeEach(() => reloadTestingDatabases(connections)); after(() => closeTestingConnections(connections)); @@ -376,3 +378,5 @@ describe("embedded > embedded-many-to-one-case3", () => { }); }); + +runIfMain(import.meta); diff --git a/test/functional/embedded/embedded-many-to-one-case3/entity/Counters.ts b/test/functional/embedded/embedded-many-to-one-case3/entity/Counters.ts index dbf00d9d6..8855f20ad 100644 --- a/test/functional/embedded/embedded-many-to-one-case3/entity/Counters.ts +++ b/test/functional/embedded/embedded-many-to-one-case3/entity/Counters.ts @@ -1,22 +1,22 @@ -import {Column} from "../../../../../src/decorator/columns/Column"; -import {JoinColumn} from "../../../../../src/decorator/relations/JoinColumn"; -import {ManyToOne} from "../../../../../src/decorator/relations/ManyToOne"; -import {User} from "./User"; -import {Subcounters} from "./Subcounters"; -import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {JoinColumn} from "../../../../../src/decorator/relations/JoinColumn.ts"; +import {ManyToOne} from "../../../../../src/decorator/relations/ManyToOne.ts"; +import {User} from "./User.ts"; +import {Subcounters} from "./Subcounters.ts"; +import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn.ts"; export class Counters { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) code: number; - @Column() + @Column({ type: Number }) likes: number; - @Column() + @Column({ type: Number }) comments: number; - @Column() + @Column({ type: Number }) favorites: number; @Column(() => Subcounters, { prefix: "subcnt" }) @@ -26,4 +26,4 @@ export class Counters { @JoinColumn() likedUser: User; -} \ No newline at end of file +} diff --git a/test/functional/embedded/embedded-many-to-one-case3/entity/Post.ts b/test/functional/embedded/embedded-many-to-one-case3/entity/Post.ts index 59854b2a9..ea39d1e4b 100644 --- a/test/functional/embedded/embedded-many-to-one-case3/entity/Post.ts +++ b/test/functional/embedded/embedded-many-to-one-case3/entity/Post.ts @@ -1,18 +1,18 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn"; -import {Counters} from "./Counters"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn.ts"; +import {Counters} from "./Counters.ts"; @Entity() export class Post { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; - @Column() + @Column({ type: String }) title: string; @Column(() => Counters) counters: Counters; -} \ No newline at end of file +} diff --git a/test/functional/embedded/embedded-many-to-one-case3/entity/Subcounters.ts b/test/functional/embedded/embedded-many-to-one-case3/entity/Subcounters.ts index c0aa97f1f..898ef504e 100644 --- a/test/functional/embedded/embedded-many-to-one-case3/entity/Subcounters.ts +++ b/test/functional/embedded/embedded-many-to-one-case3/entity/Subcounters.ts @@ -1,12 +1,12 @@ -import {Column} from "../../../../../src/decorator/columns/Column"; -import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn.ts"; export class Subcounters { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) version: number; - @Column() + @Column({ type: Number }) watches: number; -} \ No newline at end of file +} diff --git a/test/functional/embedded/embedded-many-to-one-case3/entity/User.ts b/test/functional/embedded/embedded-many-to-one-case3/entity/User.ts index 761f5e18d..91518421e 100644 --- a/test/functional/embedded/embedded-many-to-one-case3/entity/User.ts +++ b/test/functional/embedded/embedded-many-to-one-case3/entity/User.ts @@ -1,16 +1,16 @@ -import {Column} from "../../../../../src/decorator/columns/Column"; -import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn"; -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {OneToMany} from "../../../../../src/decorator/relations/OneToMany"; -import {Post} from "./Post"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn.ts"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {OneToMany} from "../../../../../src/decorator/relations/OneToMany.ts"; +import {Post} from "./Post.ts"; @Entity() export class User { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; - @Column() + @Column({ type: String }) name: string; @OneToMany(type => Post, post => post.counters.likedUser) diff --git a/test/functional/embedded/embedded-many-to-one-case4/embedded-many-to-one-case4.ts b/test/functional/embedded/embedded-many-to-one-case4/embedded-many-to-one-case4.ts index 57efbdea6..5fd78d95e 100644 --- a/test/functional/embedded/embedded-many-to-one-case4/embedded-many-to-one-case4.ts +++ b/test/functional/embedded/embedded-many-to-one-case4/embedded-many-to-one-case4.ts @@ -1,17 +1,19 @@ -import "reflect-metadata"; -import {Post} from "./entity/Post"; -import {Counters} from "./entity/Counters"; -import {Connection} from "../../../../src/connection/Connection"; -import {expect} from "chai"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils"; -import {Subcounters} from "./entity/Subcounters"; -import {User} from "./entity/User"; +import {join as joinPaths} from "../../../../vendor/https/deno.land/std/path/mod.ts"; +import {Post} from "./entity/Post.ts"; +import {Counters} from "./entity/Counters.ts"; +import {Connection} from "../../../../src/connection/Connection.ts"; +import {expect} from "../../../deps/chai.ts"; +import {runIfMain} from "../../../deps/mocha.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils.ts"; +import {Subcounters} from "./entity/Subcounters.ts"; +import {User} from "./entity/User.ts"; describe("embedded > embedded-many-to-one-case4", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], })); beforeEach(() => reloadTestingDatabases(connections)); after(() => closeTestingConnections(connections)); @@ -385,3 +387,5 @@ describe("embedded > embedded-many-to-one-case4", () => { }); }); + +runIfMain(import.meta); diff --git a/test/functional/embedded/embedded-many-to-one-case4/entity/Counters.ts b/test/functional/embedded/embedded-many-to-one-case4/entity/Counters.ts index 9ff3b9440..85db31706 100644 --- a/test/functional/embedded/embedded-many-to-one-case4/entity/Counters.ts +++ b/test/functional/embedded/embedded-many-to-one-case4/entity/Counters.ts @@ -1,21 +1,21 @@ -import {Column} from "../../../../../src/decorator/columns/Column"; -import {JoinColumn} from "../../../../../src/decorator/relations/JoinColumn"; -import {ManyToOne} from "../../../../../src/decorator/relations/ManyToOne"; -import {User} from "./User"; -import {Subcounters} from "./Subcounters"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {JoinColumn} from "../../../../../src/decorator/relations/JoinColumn.ts"; +import {ManyToOne} from "../../../../../src/decorator/relations/ManyToOne.ts"; +import {User} from "./User.ts"; +import {Subcounters} from "./Subcounters.ts"; export class Counters { - @Column() + @Column({ type: Number }) code: number; - @Column() + @Column({ type: Number }) likes: number; - @Column() + @Column({ type: Number }) comments: number; - @Column() + @Column({ type: Number }) favorites: number; @Column(() => Subcounters, { prefix: "subcnt" }) @@ -25,4 +25,4 @@ export class Counters { @JoinColumn() likedUser: User; -} \ No newline at end of file +} diff --git a/test/functional/embedded/embedded-many-to-one-case4/entity/Post.ts b/test/functional/embedded/embedded-many-to-one-case4/entity/Post.ts index e6ec86e6f..070db99d7 100644 --- a/test/functional/embedded/embedded-many-to-one-case4/entity/Post.ts +++ b/test/functional/embedded/embedded-many-to-one-case4/entity/Post.ts @@ -1,15 +1,15 @@ -import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn"; -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {Counters} from "./Counters"; +import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn.ts"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {Counters} from "./Counters.ts"; @Entity() export class Post { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; - @Column() + @Column({ type: String }) title: string; @Column(() => Counters) diff --git a/test/functional/embedded/embedded-many-to-one-case4/entity/Subcounters.ts b/test/functional/embedded/embedded-many-to-one-case4/entity/Subcounters.ts index a89a0cbc5..69704012f 100644 --- a/test/functional/embedded/embedded-many-to-one-case4/entity/Subcounters.ts +++ b/test/functional/embedded/embedded-many-to-one-case4/entity/Subcounters.ts @@ -1,11 +1,11 @@ -import {Column} from "../../../../../src/decorator/columns/Column"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; export class Subcounters { - @Column() + @Column({ type: Number }) version: number; - @Column() + @Column({ type: Number }) watches: number; -} \ No newline at end of file +} diff --git a/test/functional/embedded/embedded-many-to-one-case4/entity/User.ts b/test/functional/embedded/embedded-many-to-one-case4/entity/User.ts index c807ad6d6..2f58b24a1 100644 --- a/test/functional/embedded/embedded-many-to-one-case4/entity/User.ts +++ b/test/functional/embedded/embedded-many-to-one-case4/entity/User.ts @@ -1,22 +1,22 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {OneToMany} from "../../../../../src/decorator/relations/OneToMany"; -import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {Post} from "./Post"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {OneToMany} from "../../../../../src/decorator/relations/OneToMany.ts"; +import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {Post} from "./Post.ts"; @Entity() export class User { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; - @PrimaryColumn() + @PrimaryColumn({ type: Number }) personId: number; - @Column() + @Column({ type: String }) name: string; @OneToMany(type => Post, post => post.counters.likedUser) likedPosts: Post[]; -} \ No newline at end of file +} diff --git a/test/functional/embedded/embedded-many-to-one-case5/embedded-many-to-one-case5.ts b/test/functional/embedded/embedded-many-to-one-case5/embedded-many-to-one-case5.ts index a7a556e4f..ab11bf19e 100644 --- a/test/functional/embedded/embedded-many-to-one-case5/embedded-many-to-one-case5.ts +++ b/test/functional/embedded/embedded-many-to-one-case5/embedded-many-to-one-case5.ts @@ -1,17 +1,19 @@ -import "reflect-metadata"; -import {Post} from "./entity/Post"; -import {Counters} from "./entity/Counters"; -import {Connection} from "../../../../src/connection/Connection"; -import {expect} from "chai"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils"; -import {Subcounters} from "./entity/Subcounters"; -import {User} from "./entity/User"; +import {join as joinPaths} from "../../../../vendor/https/deno.land/std/path/mod.ts"; +import {Post} from "./entity/Post.ts"; +import {Counters} from "./entity/Counters.ts"; +import {Connection} from "../../../../src/connection/Connection.ts"; +import {expect} from "../../../deps/chai.ts"; +import {runIfMain} from "../../../deps/mocha.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils.ts"; +import {Subcounters} from "./entity/Subcounters.ts"; +import {User} from "./entity/User.ts"; describe("embedded > embedded-many-to-one-case5", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], })); beforeEach(() => reloadTestingDatabases(connections)); after(() => closeTestingConnections(connections)); @@ -385,3 +387,5 @@ describe("embedded > embedded-many-to-one-case5", () => { }); }); + +runIfMain(import.meta); diff --git a/test/functional/embedded/embedded-many-to-one-case5/entity/Counters.ts b/test/functional/embedded/embedded-many-to-one-case5/entity/Counters.ts index 67624cf53..7a1feaabe 100644 --- a/test/functional/embedded/embedded-many-to-one-case5/entity/Counters.ts +++ b/test/functional/embedded/embedded-many-to-one-case5/entity/Counters.ts @@ -1,22 +1,22 @@ -import {Column} from "../../../../../src/decorator/columns/Column"; -import {JoinColumn} from "../../../../../src/decorator/relations/JoinColumn"; -import {ManyToOne} from "../../../../../src/decorator/relations/ManyToOne"; -import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn"; -import {User} from "./User"; -import {Subcounters} from "./Subcounters"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {JoinColumn} from "../../../../../src/decorator/relations/JoinColumn.ts"; +import {ManyToOne} from "../../../../../src/decorator/relations/ManyToOne.ts"; +import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn.ts"; +import {User} from "./User.ts"; +import {Subcounters} from "./Subcounters.ts"; export class Counters { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) code: number; - @Column() + @Column({ type: Number }) likes: number; - @Column() + @Column({ type: Number }) comments: number; - @Column() + @Column({ type: Number }) favorites: number; @Column(() => Subcounters, { prefix: "subcnt" }) @@ -26,4 +26,4 @@ export class Counters { @JoinColumn() likedUser: User; -} \ No newline at end of file +} diff --git a/test/functional/embedded/embedded-many-to-one-case5/entity/Post.ts b/test/functional/embedded/embedded-many-to-one-case5/entity/Post.ts index a25b39718..433c2abf4 100644 --- a/test/functional/embedded/embedded-many-to-one-case5/entity/Post.ts +++ b/test/functional/embedded/embedded-many-to-one-case5/entity/Post.ts @@ -1,18 +1,18 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {Counters} from "./Counters"; -import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {Counters} from "./Counters.ts"; +import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn.ts"; @Entity() export class Post { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; - @Column() + @Column({ type: String }) title: string; @Column(() => Counters) counters: Counters; -} \ No newline at end of file +} diff --git a/test/functional/embedded/embedded-many-to-one-case5/entity/Subcounters.ts b/test/functional/embedded/embedded-many-to-one-case5/entity/Subcounters.ts index c0aa97f1f..898ef504e 100644 --- a/test/functional/embedded/embedded-many-to-one-case5/entity/Subcounters.ts +++ b/test/functional/embedded/embedded-many-to-one-case5/entity/Subcounters.ts @@ -1,12 +1,12 @@ -import {Column} from "../../../../../src/decorator/columns/Column"; -import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn.ts"; export class Subcounters { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) version: number; - @Column() + @Column({ type: Number }) watches: number; -} \ No newline at end of file +} diff --git a/test/functional/embedded/embedded-many-to-one-case5/entity/User.ts b/test/functional/embedded/embedded-many-to-one-case5/entity/User.ts index c807ad6d6..2f58b24a1 100644 --- a/test/functional/embedded/embedded-many-to-one-case5/entity/User.ts +++ b/test/functional/embedded/embedded-many-to-one-case5/entity/User.ts @@ -1,22 +1,22 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {OneToMany} from "../../../../../src/decorator/relations/OneToMany"; -import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {Post} from "./Post"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {OneToMany} from "../../../../../src/decorator/relations/OneToMany.ts"; +import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {Post} from "./Post.ts"; @Entity() export class User { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; - @PrimaryColumn() + @PrimaryColumn({ type: Number }) personId: number; - @Column() + @Column({ type: String }) name: string; @OneToMany(type => Post, post => post.counters.likedUser) likedPosts: Post[]; -} \ No newline at end of file +} diff --git a/test/functional/embedded/embedded-one-to-one/embedded-one-to-one.ts b/test/functional/embedded/embedded-one-to-one/embedded-one-to-one.ts index 3c1cedd4a..7b46c2cab 100644 --- a/test/functional/embedded/embedded-one-to-one/embedded-one-to-one.ts +++ b/test/functional/embedded/embedded-one-to-one/embedded-one-to-one.ts @@ -1,17 +1,19 @@ -import "reflect-metadata"; -import {Post} from "./entity/Post"; -import {Counters} from "./entity/Counters"; -import {Connection} from "../../../../src/connection/Connection"; -import {expect} from "chai"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils"; -import {Subcounters} from "./entity/Subcounters"; -import {User} from "./entity/User"; +import {join as joinPaths} from "../../../../vendor/https/deno.land/std/path/mod.ts"; +import {Post} from "./entity/Post.ts"; +import {Counters} from "./entity/Counters.ts"; +import {Connection} from "../../../../src/connection/Connection.ts"; +import {expect} from "../../../deps/chai.ts"; +import {runIfMain} from "../../../deps/mocha.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils.ts"; +import {Subcounters} from "./entity/Subcounters.ts"; +import {User} from "./entity/User.ts"; describe("embedded > embedded-one-to-one", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], })); beforeEach(() => reloadTestingDatabases(connections)); after(() => closeTestingConnections(connections)); @@ -337,3 +339,5 @@ describe("embedded > embedded-one-to-one", () => { }))); }); }); + +runIfMain(import.meta); diff --git a/test/functional/embedded/embedded-one-to-one/entity/Counters.ts b/test/functional/embedded/embedded-one-to-one/entity/Counters.ts index f7b2dbc8f..d903289d9 100644 --- a/test/functional/embedded/embedded-one-to-one/entity/Counters.ts +++ b/test/functional/embedded/embedded-one-to-one/entity/Counters.ts @@ -1,21 +1,21 @@ -import {Column} from "../../../../../src/decorator/columns/Column"; -import {JoinColumn} from "../../../../../src/decorator/relations/JoinColumn"; -import {OneToOne} from "../../../../../src/decorator/relations/OneToOne"; -import {User} from "./User"; -import {Subcounters} from "./Subcounters"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {JoinColumn} from "../../../../../src/decorator/relations/JoinColumn.ts"; +import {OneToOne} from "../../../../../src/decorator/relations/OneToOne.ts"; +import {User} from "./User.ts"; +import {Subcounters} from "./Subcounters.ts"; export class Counters { - @Column() + @Column({ type: Number }) code: number; - @Column() + @Column({ type: Number }) likes: number; - @Column() + @Column({ type: Number }) comments: number; - @Column() + @Column({ type: Number }) favorites: number; @Column(() => Subcounters, { prefix: "subcnt" }) @@ -25,4 +25,4 @@ export class Counters { @JoinColumn() likedUser: User; -} \ No newline at end of file +} diff --git a/test/functional/embedded/embedded-one-to-one/entity/Post.ts b/test/functional/embedded/embedded-one-to-one/entity/Post.ts index e6ec86e6f..070db99d7 100644 --- a/test/functional/embedded/embedded-one-to-one/entity/Post.ts +++ b/test/functional/embedded/embedded-one-to-one/entity/Post.ts @@ -1,15 +1,15 @@ -import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn"; -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {Counters} from "./Counters"; +import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn.ts"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {Counters} from "./Counters.ts"; @Entity() export class Post { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; - @Column() + @Column({ type: String }) title: string; @Column(() => Counters) diff --git a/test/functional/embedded/embedded-one-to-one/entity/Subcounters.ts b/test/functional/embedded/embedded-one-to-one/entity/Subcounters.ts index a89a0cbc5..69704012f 100644 --- a/test/functional/embedded/embedded-one-to-one/entity/Subcounters.ts +++ b/test/functional/embedded/embedded-one-to-one/entity/Subcounters.ts @@ -1,11 +1,11 @@ -import {Column} from "../../../../../src/decorator/columns/Column"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; export class Subcounters { - @Column() + @Column({ type: Number }) version: number; - @Column() + @Column({ type: Number }) watches: number; -} \ No newline at end of file +} diff --git a/test/functional/embedded/embedded-one-to-one/entity/User.ts b/test/functional/embedded/embedded-one-to-one/entity/User.ts index aa7df105c..0c32a41c7 100644 --- a/test/functional/embedded/embedded-one-to-one/entity/User.ts +++ b/test/functional/embedded/embedded-one-to-one/entity/User.ts @@ -1,16 +1,16 @@ -import {Column} from "../../../../../src/decorator/columns/Column"; -import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn"; -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {Post} from "./Post"; -import {OneToOne} from "../../../../../src/decorator/relations/OneToOne"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn.ts"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {Post} from "./Post.ts"; +import {OneToOne} from "../../../../../src/decorator/relations/OneToOne.ts"; @Entity() export class User { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; - @Column() + @Column({ type: String }) name: string; @OneToOne(() => Post, post => post.counters.likedUser) diff --git a/test/functional/embedded/embedded-with-special-columns/embedded-with-special-columns.ts b/test/functional/embedded/embedded-with-special-columns/embedded-with-special-columns.ts index a239a1023..f2390aef4 100644 --- a/test/functional/embedded/embedded-with-special-columns/embedded-with-special-columns.ts +++ b/test/functional/embedded/embedded-with-special-columns/embedded-with-special-columns.ts @@ -1,21 +1,28 @@ -import "reflect-metadata"; -import {expect} from "chai"; -import {Post} from "./entity/Post"; -import {Counters} from "./entity/Counters"; -import {Connection} from "../../../../src/connection/Connection"; +import {join as joinPaths} from "../../../../vendor/https/deno.land/std/path/mod.ts"; +import {expect} from "../../../deps/chai.ts"; +import {runIfMain} from "../../../deps/mocha.ts"; +import {Post} from "./entity/Post.ts"; +import {Counters} from "./entity/Counters.ts"; +import {Connection} from "../../../../src/connection/Connection.ts"; import { + getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases, sleep -} from "../../../utils/test-utils"; -import {Subcounters} from "../embedded-many-to-one-case2/entity/Subcounters"; +} from "../../../utils/test-utils.ts"; +import {Subcounters} from "../embedded-many-to-one-case2/entity/Subcounters.ts"; describe("embedded > embedded-with-special-columns", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], + // TODO(uki00a) Remove `enableDrivers` option when deno-sqlite supports `datetime('now')`. + // deno-sqlite currently does not support `datetime('now')`. This is due to lack of support for getting current time in WASI. + // @see https://github.com/dyedgreen/deno-sqlite/blob/a68be951b8a09e5df3eb76a1659d93e18ba048c5/build/src/vfs.c#L235 + enabledDrivers: ["postgres", "mysql", "mssql", "oracle"] })); beforeEach(() => reloadTestingDatabases(connections)); after(() => closeTestingConnections(connections)); @@ -84,3 +91,5 @@ describe("embedded > embedded-with-special-columns", () => { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/embedded/embedded-with-special-columns/entity/Counters.ts b/test/functional/embedded/embedded-with-special-columns/entity/Counters.ts index cd91ad38f..2dbf8b6aa 100644 --- a/test/functional/embedded/embedded-with-special-columns/entity/Counters.ts +++ b/test/functional/embedded/embedded-with-special-columns/entity/Counters.ts @@ -1,17 +1,17 @@ -import {Column} from "../../../../../src/decorator/columns/Column"; -import {CreateDateColumn} from "../../../../../src/decorator/columns/CreateDateColumn"; -import {UpdateDateColumn} from "../../../../../src/decorator/columns/UpdateDateColumn"; -import {Subcounters} from "./Subcounters"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {CreateDateColumn} from "../../../../../src/decorator/columns/CreateDateColumn.ts"; +import {UpdateDateColumn} from "../../../../../src/decorator/columns/UpdateDateColumn.ts"; +import {Subcounters} from "./Subcounters.ts"; export class Counters { - @Column() + @Column({ type: Number }) likes: number; - @Column() + @Column({ type: Number }) comments: number; - @Column() + @Column({ type: Number }) favorites: number; @Column(() => Subcounters, { prefix: "subcnt" }) @@ -23,4 +23,4 @@ export class Counters { @UpdateDateColumn() updatedDate: Date; -} \ No newline at end of file +} diff --git a/test/functional/embedded/embedded-with-special-columns/entity/Post.ts b/test/functional/embedded/embedded-with-special-columns/entity/Post.ts index e6ec86e6f..070db99d7 100644 --- a/test/functional/embedded/embedded-with-special-columns/entity/Post.ts +++ b/test/functional/embedded/embedded-with-special-columns/entity/Post.ts @@ -1,15 +1,15 @@ -import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn"; -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {Counters} from "./Counters"; +import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn.ts"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {Counters} from "./Counters.ts"; @Entity() export class Post { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; - @Column() + @Column({ type: String }) title: string; @Column(() => Counters) diff --git a/test/functional/embedded/embedded-with-special-columns/entity/Subcounters.ts b/test/functional/embedded/embedded-with-special-columns/entity/Subcounters.ts index fc171a8f3..b86b376a3 100644 --- a/test/functional/embedded/embedded-with-special-columns/entity/Subcounters.ts +++ b/test/functional/embedded/embedded-with-special-columns/entity/Subcounters.ts @@ -1,12 +1,12 @@ -import {Column} from "../../../../../src/decorator/columns/Column"; -import {VersionColumn} from "../../../../../src/decorator/columns/VersionColumn"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {VersionColumn} from "../../../../../src/decorator/columns/VersionColumn.ts"; export class Subcounters { - @VersionColumn() + @VersionColumn({ type: Number }) version: number; - @Column() + @Column({ type: Number }) watches: number; -} \ No newline at end of file +} diff --git a/test/functional/embedded/multiple-primary-columns-with-nested-embed/entity/Counters.ts b/test/functional/embedded/multiple-primary-columns-with-nested-embed/entity/Counters.ts index ef192cceb..11948aa6c 100644 --- a/test/functional/embedded/multiple-primary-columns-with-nested-embed/entity/Counters.ts +++ b/test/functional/embedded/multiple-primary-columns-with-nested-embed/entity/Counters.ts @@ -1,22 +1,22 @@ -import {Column} from "../../../../../src/decorator/columns/Column"; -import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn"; -import {Subcounters} from "./Subcounters"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn.ts"; +import {Subcounters} from "./Subcounters.ts"; export class Counters { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) code: number; - @Column() + @Column({ type: Number }) likes: number; - @Column() + @Column({ type: Number }) comments: number; - @Column() + @Column({ type: Number }) favorites: number; @Column(() => Subcounters, { prefix: "subcnt" }) subcounters: Subcounters; -} \ No newline at end of file +} diff --git a/test/functional/embedded/multiple-primary-columns-with-nested-embed/entity/Post.ts b/test/functional/embedded/multiple-primary-columns-with-nested-embed/entity/Post.ts index a25b39718..433c2abf4 100644 --- a/test/functional/embedded/multiple-primary-columns-with-nested-embed/entity/Post.ts +++ b/test/functional/embedded/multiple-primary-columns-with-nested-embed/entity/Post.ts @@ -1,18 +1,18 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {Counters} from "./Counters"; -import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {Counters} from "./Counters.ts"; +import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn.ts"; @Entity() export class Post { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; - @Column() + @Column({ type: String }) title: string; @Column(() => Counters) counters: Counters; -} \ No newline at end of file +} diff --git a/test/functional/embedded/multiple-primary-columns-with-nested-embed/entity/Subcounters.ts b/test/functional/embedded/multiple-primary-columns-with-nested-embed/entity/Subcounters.ts index c0aa97f1f..898ef504e 100644 --- a/test/functional/embedded/multiple-primary-columns-with-nested-embed/entity/Subcounters.ts +++ b/test/functional/embedded/multiple-primary-columns-with-nested-embed/entity/Subcounters.ts @@ -1,12 +1,12 @@ -import {Column} from "../../../../../src/decorator/columns/Column"; -import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn.ts"; export class Subcounters { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) version: number; - @Column() + @Column({ type: Number }) watches: number; -} \ No newline at end of file +} diff --git a/test/functional/embedded/multiple-primary-columns-with-nested-embed/multiple-primary-columns-with-nested-embed.ts b/test/functional/embedded/multiple-primary-columns-with-nested-embed/multiple-primary-columns-with-nested-embed.ts index 394e7eb9e..f18291e24 100644 --- a/test/functional/embedded/multiple-primary-columns-with-nested-embed/multiple-primary-columns-with-nested-embed.ts +++ b/test/functional/embedded/multiple-primary-columns-with-nested-embed/multiple-primary-columns-with-nested-embed.ts @@ -1,16 +1,18 @@ -import "reflect-metadata"; -import {Post} from "./entity/Post"; -import {Counters} from "./entity/Counters"; -import {Connection} from "../../../../src/connection/Connection"; -import {expect} from "chai"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils"; -import {Subcounters} from "./entity/Subcounters"; +import {join as joinPaths} from "../../../../vendor/https/deno.land/std/path/mod.ts"; +import {Post} from "./entity/Post.ts"; +import {Counters} from "./entity/Counters.ts"; +import {Connection} from "../../../../src/connection/Connection.ts"; +import {runIfMain} from "../../../deps/mocha.ts"; +import {expect} from "../../../deps/chai.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils.ts"; +import {Subcounters} from "./entity/Subcounters.ts"; describe("embedded > multiple-primary-columns-with-nested-embed", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], })); beforeEach(() => reloadTestingDatabases(connections)); after(() => closeTestingConnections(connections)); @@ -131,3 +133,5 @@ describe("embedded > multiple-primary-columns-with-nested-embed", () => { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/embedded/multiple-primary-columns/entity/Counters.ts b/test/functional/embedded/multiple-primary-columns/entity/Counters.ts index 052df243f..dd735b820 100644 --- a/test/functional/embedded/multiple-primary-columns/entity/Counters.ts +++ b/test/functional/embedded/multiple-primary-columns/entity/Counters.ts @@ -1,18 +1,18 @@ -import {Column} from "../../../../../src/decorator/columns/Column"; -import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn.ts"; export class Counters { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) code: number; - @Column() + @Column({ type: Number }) likes: number; - @Column() + @Column({ type: Number }) comments: number; - @Column() + @Column({ type: Number }) favorites: number; -} \ No newline at end of file +} diff --git a/test/functional/embedded/multiple-primary-columns/entity/Post.ts b/test/functional/embedded/multiple-primary-columns/entity/Post.ts index a25b39718..433c2abf4 100644 --- a/test/functional/embedded/multiple-primary-columns/entity/Post.ts +++ b/test/functional/embedded/multiple-primary-columns/entity/Post.ts @@ -1,18 +1,18 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {Counters} from "./Counters"; -import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {Counters} from "./Counters.ts"; +import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn.ts"; @Entity() export class Post { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; - @Column() + @Column({ type: String }) title: string; @Column(() => Counters) counters: Counters; -} \ No newline at end of file +} diff --git a/test/functional/embedded/multiple-primary-columns/multiple-primary-columns.ts b/test/functional/embedded/multiple-primary-columns/multiple-primary-columns.ts index 092b8c79b..2fda97c6d 100644 --- a/test/functional/embedded/multiple-primary-columns/multiple-primary-columns.ts +++ b/test/functional/embedded/multiple-primary-columns/multiple-primary-columns.ts @@ -1,15 +1,17 @@ -import "reflect-metadata"; -import {Post} from "./entity/Post"; -import {Counters} from "./entity/Counters"; -import {Connection} from "../../../../src/connection/Connection"; -import {expect} from "chai"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils"; +import {join as joinPaths} from "../../../../vendor/https/deno.land/std/path/mod.ts"; +import {Post} from "./entity/Post.ts"; +import {Counters} from "./entity/Counters.ts"; +import {Connection} from "../../../../src/connection/Connection.ts"; +import {runIfMain} from "../../../deps/mocha.ts"; +import {expect} from "../../../deps/chai.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils.ts"; describe("embedded > multiple-primary-column", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], })); beforeEach(() => reloadTestingDatabases(connections)); after(() => closeTestingConnections(connections)); @@ -67,3 +69,5 @@ describe("embedded > multiple-primary-column", () => { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/embedded/optional-embedded-listeners/entity/Post.ts b/test/functional/embedded/optional-embedded-listeners/entity/Post.ts index 9a80fe694..772f83a4f 100644 --- a/test/functional/embedded/optional-embedded-listeners/entity/Post.ts +++ b/test/functional/embedded/optional-embedded-listeners/entity/Post.ts @@ -1,8 +1,8 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {PostInformation} from "./PostInformation"; -import {Index} from "../../../../../src/decorator/Index"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {PostInformation} from "./PostInformation.ts"; +import {Index} from "../../../../../src/decorator/Index.ts"; @Entity() export class Post { @@ -10,11 +10,11 @@ export class Post { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) @Index() title: string; - @Column() + @Column({ type: String }) text: string; @Column(type => PostInformation, { prefix: "info" }) diff --git a/test/functional/embedded/optional-embedded-listeners/entity/PostCounter.ts b/test/functional/embedded/optional-embedded-listeners/entity/PostCounter.ts index 2dc65acf7..34569a368 100644 --- a/test/functional/embedded/optional-embedded-listeners/entity/PostCounter.ts +++ b/test/functional/embedded/optional-embedded-listeners/entity/PostCounter.ts @@ -1,10 +1,10 @@ -import {Column} from "../../../../../src/decorator/columns/Column"; -import {BeforeInsert} from "../../../../../src/decorator/listeners/BeforeInsert"; -import {BeforeUpdate} from "../../../../../src/decorator/listeners/BeforeUpdate"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {BeforeInsert} from "../../../../../src/decorator/listeners/BeforeInsert.ts"; +import {BeforeUpdate} from "../../../../../src/decorator/listeners/BeforeUpdate.ts"; export class PostCounter { - @Column({nullable: true}) + @Column({nullable: true, type: Number}) likes: number; @BeforeInsert() diff --git a/test/functional/embedded/optional-embedded-listeners/entity/PostInformation.ts b/test/functional/embedded/optional-embedded-listeners/entity/PostInformation.ts index a912f8a66..4b340cd50 100644 --- a/test/functional/embedded/optional-embedded-listeners/entity/PostInformation.ts +++ b/test/functional/embedded/optional-embedded-listeners/entity/PostInformation.ts @@ -1,10 +1,10 @@ -import {Column} from "../../../../../src/decorator/columns/Column"; -import {BeforeInsert, BeforeUpdate} from "../../../../../src"; -import {PostCounter} from "./PostCounter"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {BeforeInsert, BeforeUpdate} from "../../../../../src/index.ts"; +import {PostCounter} from "./PostCounter.ts"; export class PostInformation { - @Column({nullable: true}) + @Column({nullable: true, type: String}) description?: string; @Column(type => PostCounter, {prefix: "counters"}) diff --git a/test/functional/embedded/optional-embedded-listeners/optional-embedded-listeners.ts b/test/functional/embedded/optional-embedded-listeners/optional-embedded-listeners.ts index 3093577bb..005bc7ec1 100644 --- a/test/functional/embedded/optional-embedded-listeners/optional-embedded-listeners.ts +++ b/test/functional/embedded/optional-embedded-listeners/optional-embedded-listeners.ts @@ -1,16 +1,18 @@ -import "reflect-metadata"; -import { closeTestingConnections, createTestingConnections, reloadTestingDatabases } from "../../../utils/test-utils"; -import { Connection } from "../../../../src/connection/Connection"; -import { Post } from "./entity/Post"; -import { expect } from "chai"; -import {PostInformation} from "./entity/PostInformation"; -import {PostCounter} from "./entity/PostCounter"; +import { join as joinPaths } from "../../../../vendor/https/deno.land/std/path/mod.ts"; +import { getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases } from "../../../utils/test-utils.ts"; +import { Connection } from "../../../../src/connection/Connection.ts"; +import { Post } from "./entity/Post.ts"; +import { runIfMain } from "../../../deps/mocha.ts"; +import { expect } from "../../../deps/chai.ts"; +import {PostInformation} from "./entity/PostInformation.ts"; +import {PostCounter} from "./entity/PostCounter.ts"; describe("other issues > entity listeners must work in optional embeddeds as well", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], enabledDrivers: ["postgres"] })); beforeEach(() => reloadTestingDatabases(connections)); @@ -59,3 +61,5 @@ describe("other issues > entity listeners must work in optional embeddeds as wel }))); }); + +runIfMain(import.meta); diff --git a/test/functional/embedded/outer-primary-column/entity/Counters.ts b/test/functional/embedded/outer-primary-column/entity/Counters.ts index 052df243f..dd735b820 100644 --- a/test/functional/embedded/outer-primary-column/entity/Counters.ts +++ b/test/functional/embedded/outer-primary-column/entity/Counters.ts @@ -1,18 +1,18 @@ -import {Column} from "../../../../../src/decorator/columns/Column"; -import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn.ts"; export class Counters { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) code: number; - @Column() + @Column({ type: Number }) likes: number; - @Column() + @Column({ type: Number }) comments: number; - @Column() + @Column({ type: Number }) favorites: number; -} \ No newline at end of file +} diff --git a/test/functional/embedded/outer-primary-column/entity/Post.ts b/test/functional/embedded/outer-primary-column/entity/Post.ts index c4ec2883d..442673894 100644 --- a/test/functional/embedded/outer-primary-column/entity/Post.ts +++ b/test/functional/embedded/outer-primary-column/entity/Post.ts @@ -1,17 +1,17 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {Counters} from "./Counters"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {Counters} from "./Counters.ts"; @Entity() export class Post { - @Column() + @Column({ type: String }) title: string; - @Column() + @Column({ type: String }) text: string; @Column(() => Counters, { prefix: "cnt" }) counters: Counters; -} \ No newline at end of file +} diff --git a/test/functional/embedded/outer-primary-column/outer-primary-column.ts b/test/functional/embedded/outer-primary-column/outer-primary-column.ts index 15c0dcd77..8975930a1 100644 --- a/test/functional/embedded/outer-primary-column/outer-primary-column.ts +++ b/test/functional/embedded/outer-primary-column/outer-primary-column.ts @@ -1,15 +1,17 @@ -import "reflect-metadata"; -import {Post} from "./entity/Post"; -import {Counters} from "./entity/Counters"; -import {Connection} from "../../../../src/connection/Connection"; -import {expect} from "chai"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils"; +import {join as joinPaths} from "../../../../vendor/https/deno.land/std/path/mod.ts"; +import {Post} from "./entity/Post.ts"; +import {Counters} from "./entity/Counters.ts"; +import {Connection} from "../../../../src/connection/Connection.ts"; +import {expect} from "../../../deps/chai.ts"; +import {runIfMain} from "../../../deps/mocha.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils.ts"; describe("embedded > outer-primary-column", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], })); beforeEach(() => reloadTestingDatabases(connections)); after(() => closeTestingConnections(connections)); @@ -67,3 +69,5 @@ describe("embedded > outer-primary-column", () => { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/embedded/prefix/embedded-prefix.ts b/test/functional/embedded/prefix/embedded-prefix.ts index 246b5078f..4d1be5f2d 100644 --- a/test/functional/embedded/prefix/embedded-prefix.ts +++ b/test/functional/embedded/prefix/embedded-prefix.ts @@ -1,14 +1,17 @@ -import "reflect-metadata"; -import {Post} from "./entity/Post"; -import {Counters} from "./entity/Counters"; -import {Connection} from "../../../../src/connection/Connection"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils"; +import {join as joinPaths} from "../../../../vendor/https/deno.land/std/path/mod.ts"; +import "../../../deps/chai.ts"; +import {runIfMain} from "../../../deps/mocha.ts"; +import {Post} from "./entity/Post.ts"; +import {Counters} from "./entity/Counters.ts"; +import {Connection} from "../../../../src/connection/Connection.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils.ts"; describe("embedded > prefix functionality", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], })); beforeEach(() => reloadTestingDatabases(connections)); after(() => closeTestingConnections(connections)); @@ -40,3 +43,5 @@ describe("embedded > prefix functionality", () => { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/embedded/prefix/entity/Counters.ts b/test/functional/embedded/prefix/entity/Counters.ts index c20706b8e..093a65595 100644 --- a/test/functional/embedded/prefix/entity/Counters.ts +++ b/test/functional/embedded/prefix/entity/Counters.ts @@ -1,14 +1,14 @@ -import {Column} from "../../../../../src/decorator/columns/Column"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; export class Counters { - @Column({ name: "_likes" }) + @Column({ name: "_likes", type: Number }) likes: number; - @Column({ name: "_comments" }) + @Column({ name: "_comments", type: Number }) comments: number; - @Column({ name: "_favorites" }) + @Column({ name: "_favorites", type: Number }) favorites: number; -} \ No newline at end of file +} diff --git a/test/functional/embedded/prefix/entity/Post.ts b/test/functional/embedded/prefix/entity/Post.ts index b45020ddb..8aaa5a59a 100644 --- a/test/functional/embedded/prefix/entity/Post.ts +++ b/test/functional/embedded/prefix/entity/Post.ts @@ -1,18 +1,18 @@ -import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn"; -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {Counters} from "./Counters"; +import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn.ts"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {Counters} from "./Counters.ts"; @Entity() export class Post { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; - @Column() + @Column({ type: String }) title: string; - @Column() + @Column({ type: String }) text: string; @Column(() => Counters, { prefix: "cnt" }) diff --git a/test/functional/entity-listeners/entity-listeners.ts b/test/functional/entity-listeners/entity-listeners.ts index 81faee24c..09feb6995 100644 --- a/test/functional/entity-listeners/entity-listeners.ts +++ b/test/functional/entity-listeners/entity-listeners.ts @@ -1,12 +1,16 @@ -import {Connection} from "../../../src"; -import {closeTestingConnections, createTestingConnections} from "../../utils/test-utils"; -import {Post} from "./entity/Post"; +import {join as joinPaths} from "../../../vendor/https/deno.land/std/path/mod.ts"; +import {Connection} from "../../../src/index.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections} from "../../utils/test-utils.ts"; +import {Post} from "./entity/Post.ts"; +import "../../deps/chai.ts"; +import {runIfMain} from "../../deps/mocha.ts"; describe("entity-listeners", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], dropSchema: true, schemaCreate: true })); @@ -27,3 +31,5 @@ describe("entity-listeners", () => { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/entity-listeners/entity/Post.ts b/test/functional/entity-listeners/entity/Post.ts index 0f24978b3..aacc310fa 100644 --- a/test/functional/entity-listeners/entity/Post.ts +++ b/test/functional/entity-listeners/entity/Post.ts @@ -1,7 +1,7 @@ -import {BeforeUpdate} from "../../../../src"; -import {Column} from "../../../../src/decorator/columns/Column"; -import {PrimaryGeneratedColumn} from "../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Entity} from "../../../../src/decorator/entity/Entity"; +import {BeforeUpdate} from "../../../../src/index.ts"; +import {Column} from "../../../../src/decorator/columns/Column.ts"; +import {PrimaryGeneratedColumn} from "../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Entity} from "../../../../src/decorator/entity/Entity.ts"; @Entity() export class Post { @@ -9,10 +9,10 @@ export class Post { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) title: string; - @Column() + @Column({ type: String }) text: string; @BeforeUpdate() diff --git a/test/functional/entity-metadata-validator/basic/entity-metadata-validator.ts b/test/functional/entity-metadata-validator/basic/entity-metadata-validator.ts index c2319b295..897b501db 100644 --- a/test/functional/entity-metadata-validator/basic/entity-metadata-validator.ts +++ b/test/functional/entity-metadata-validator/basic/entity-metadata-validator.ts @@ -1,24 +1,35 @@ -import "reflect-metadata"; -import {Connection} from "../../../../src/connection/Connection"; -import {ConnectionMetadataBuilder} from "../../../../src/connection/ConnectionMetadataBuilder"; -import {EntityMetadataValidator} from "../../../../src/metadata-builder/EntityMetadataValidator"; -import {expect} from "chai"; +import {join as joinPaths} from "../../../../vendor/https/deno.land/std/path/mod.ts"; +import {Connection} from "../../../../src/connection/Connection.ts"; +import {ConnectionMetadataBuilder} from "../../../../src/connection/ConnectionMetadataBuilder.ts"; +import {EntityMetadataValidator} from "../../../../src/metadata-builder/EntityMetadataValidator.ts"; +import {getDirnameOfCurrentModule} from "../../../utils/test-utils.ts"; +import {expect} from "../../../deps/chai.ts"; +import {runIfMain} from "../../../deps/mocha.ts"; describe("entity-metadata-validator", () => { - it("should throw error if relation count decorator used with ManyToOne or OneToOne relations", () => { + it("should throw error if relation count decorator used with ManyToOne or OneToOne relations", async function() { + const __dirname = getDirnameOfCurrentModule(import.meta); const connection = new Connection({ // dummy connection options, connection won't be established anyway + // TODO(uki00a) uncomment this when MysqlDriver is implemented. + /* type: "mysql", host: "localhost", username: "test", password: "test", database: "test", - entities: [__dirname + "/entity/*{.js,.ts}"] + entities: [joinPaths(__dirname, "/entity/*.ts")] + */ + type: "sqlite", + database: ":memory:", + entities: [joinPaths(__dirname, "/entity/*.ts")] }); const connectionMetadataBuilder = new ConnectionMetadataBuilder(connection); - const entityMetadatas = connectionMetadataBuilder.buildEntityMetadatas([__dirname + "/entity/*{.js,.ts}"]); + const entityMetadatas = await connectionMetadataBuilder.buildEntityMetadatas([joinPaths(__dirname, "/entity/*.ts")]); const entityMetadataValidator = new EntityMetadataValidator(); expect(() => entityMetadataValidator.validateMany(entityMetadatas, connection.driver)).to.throw(Error); }); -}); \ No newline at end of file +}); + +runIfMain(import.meta); diff --git a/test/functional/entity-metadata-validator/basic/entity/Category.ts b/test/functional/entity-metadata-validator/basic/entity/Category.ts index 0095127bd..fdbf6b325 100644 --- a/test/functional/entity-metadata-validator/basic/entity/Category.ts +++ b/test/functional/entity-metadata-validator/basic/entity/Category.ts @@ -1,6 +1,6 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../src/decorator/columns/Column"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; @Entity() export class Category { @@ -8,7 +8,7 @@ export class Category { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) name: string; -} \ No newline at end of file +} diff --git a/test/functional/entity-metadata-validator/basic/entity/Post.ts b/test/functional/entity-metadata-validator/basic/entity/Post.ts index 0d0de660c..3c7c80bdd 100644 --- a/test/functional/entity-metadata-validator/basic/entity/Post.ts +++ b/test/functional/entity-metadata-validator/basic/entity/Post.ts @@ -1,10 +1,10 @@ -import {OneToOne} from "../../../../../src/decorator/relations/OneToOne"; -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {RelationCount} from "../../../../../src/decorator/relations/RelationCount"; -import {ManyToMany} from "../../../../../src/decorator/relations/ManyToMany"; -import {Category} from "./Category"; +import {OneToOne} from "../../../../../src/decorator/relations/OneToOne.ts"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {RelationCount} from "../../../../../src/decorator/relations/RelationCount.ts"; +import {ManyToMany} from "../../../../../src/decorator/relations/ManyToMany.ts"; +import {Category} from "./Category.ts"; @Entity() export class Post { @@ -12,9 +12,9 @@ export class Post { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) title: string; - + @OneToOne(type => Category) category: Category; @@ -27,4 +27,4 @@ export class Post { @RelationCount((post: Post) => post.category2) categoryCount2: number; -} \ No newline at end of file +} diff --git a/test/functional/entity-metadata-validator/initialized-relations/entity/Category.ts b/test/functional/entity-metadata-validator/initialized-relations/entity/Category.ts index 0095127bd..fdbf6b325 100644 --- a/test/functional/entity-metadata-validator/initialized-relations/entity/Category.ts +++ b/test/functional/entity-metadata-validator/initialized-relations/entity/Category.ts @@ -1,6 +1,6 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../src/decorator/columns/Column"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; @Entity() export class Category { @@ -8,7 +8,7 @@ export class Category { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) name: string; -} \ No newline at end of file +} diff --git a/test/functional/entity-metadata-validator/initialized-relations/entity/Image.ts b/test/functional/entity-metadata-validator/initialized-relations/entity/Image.ts index 853d1e6cb..7fec981a4 100644 --- a/test/functional/entity-metadata-validator/initialized-relations/entity/Image.ts +++ b/test/functional/entity-metadata-validator/initialized-relations/entity/Image.ts @@ -1,8 +1,8 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {ImageInfo} from "./ImageInfo"; -import {OneToMany} from "../../../../../src/decorator/relations/OneToMany"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {ImageInfo} from "./ImageInfo.ts"; +import {OneToMany} from "../../../../../src/decorator/relations/OneToMany.ts"; @Entity() export class Image { @@ -10,10 +10,10 @@ export class Image { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) title: string; @OneToMany(type => ImageInfo, imageInfo => imageInfo.image) informations: ImageInfo[] = []; -} \ No newline at end of file +} diff --git a/test/functional/entity-metadata-validator/initialized-relations/entity/ImageInfo.ts b/test/functional/entity-metadata-validator/initialized-relations/entity/ImageInfo.ts index d3b9b89e8..2be63b985 100644 --- a/test/functional/entity-metadata-validator/initialized-relations/entity/ImageInfo.ts +++ b/test/functional/entity-metadata-validator/initialized-relations/entity/ImageInfo.ts @@ -1,8 +1,8 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {ManyToOne} from "../../../../../src/decorator/relations/ManyToOne"; -import {Image} from "./Image"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {ManyToOne} from "../../../../../src/decorator/relations/ManyToOne.ts"; +import {Image} from "./Image.ts"; @Entity() export class ImageInfo { @@ -10,10 +10,10 @@ export class ImageInfo { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) name: string; @ManyToOne(type => Image, image => image.informations) image: Image; -} \ No newline at end of file +} diff --git a/test/functional/entity-metadata-validator/initialized-relations/entity/Post.ts b/test/functional/entity-metadata-validator/initialized-relations/entity/Post.ts index 6e30b5b7f..f5f728126 100644 --- a/test/functional/entity-metadata-validator/initialized-relations/entity/Post.ts +++ b/test/functional/entity-metadata-validator/initialized-relations/entity/Post.ts @@ -1,11 +1,11 @@ -import {OneToOne} from "../../../../../src/decorator/relations/OneToOne"; -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {ManyToMany} from "../../../../../src/decorator/relations/ManyToMany"; -import {Category} from "./Category"; -import {JoinTable} from "../../../../../src/decorator/relations/JoinTable"; -import {JoinColumn} from "../../../../../src/decorator/relations/JoinColumn"; +import {OneToOne} from "../../../../../src/decorator/relations/OneToOne.ts"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {ManyToMany} from "../../../../../src/decorator/relations/ManyToMany.ts"; +import {Category} from "./Category.ts"; +import {JoinTable} from "../../../../../src/decorator/relations/JoinTable.ts"; +import {JoinColumn} from "../../../../../src/decorator/relations/JoinColumn.ts"; @Entity() export class Post { @@ -13,7 +13,7 @@ export class Post { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) title: string; @OneToOne(type => Category) @@ -24,4 +24,4 @@ export class Post { @JoinTable() categories: Category[] = []; -} \ No newline at end of file +} diff --git a/test/functional/entity-metadata-validator/initialized-relations/entity/Question.ts b/test/functional/entity-metadata-validator/initialized-relations/entity/Question.ts index bbb2c0d15..b23033538 100644 --- a/test/functional/entity-metadata-validator/initialized-relations/entity/Question.ts +++ b/test/functional/entity-metadata-validator/initialized-relations/entity/Question.ts @@ -1,9 +1,9 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {ManyToMany} from "../../../../../src/decorator/relations/ManyToMany"; -import {Category} from "./Category"; -import {JoinTable} from "../../../../../src/decorator/relations/JoinTable"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {ManyToMany} from "../../../../../src/decorator/relations/ManyToMany.ts"; +import {Category} from "./Category.ts"; +import {JoinTable} from "../../../../../src/decorator/relations/JoinTable.ts"; @Entity() export class Question { @@ -11,11 +11,11 @@ export class Question { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) title: string; @ManyToMany(type => Category, { persistence: false }) @JoinTable() categories: Category[] = []; -} \ No newline at end of file +} diff --git a/test/functional/entity-metadata-validator/initialized-relations/validator-intialized-relations.ts b/test/functional/entity-metadata-validator/initialized-relations/validator-intialized-relations.ts index 0a862da9e..81676fbbf 100644 --- a/test/functional/entity-metadata-validator/initialized-relations/validator-intialized-relations.ts +++ b/test/functional/entity-metadata-validator/initialized-relations/validator-intialized-relations.ts @@ -1,75 +1,100 @@ -import "reflect-metadata"; -import {Connection} from "../../../../src/connection/Connection"; -import {ConnectionMetadataBuilder} from "../../../../src/connection/ConnectionMetadataBuilder"; -import {EntityMetadataValidator} from "../../../../src/metadata-builder/EntityMetadataValidator"; -import {expect} from "chai"; -import {InitializedRelationError} from "../../../../src/error/InitializedRelationError"; -import {Category} from "./entity/Category"; -import {Post} from "./entity/Post"; -import {Image} from "./entity/Image"; -import {ImageInfo} from "./entity/ImageInfo"; -import {Question} from "./entity/Question"; +import {Connection} from "../../../../src/connection/Connection.ts"; +import {ConnectionMetadataBuilder} from "../../../../src/connection/ConnectionMetadataBuilder.ts"; +import {EntityMetadataValidator} from "../../../../src/metadata-builder/EntityMetadataValidator.ts"; +import {expect} from "../../../deps/chai.ts"; +import {runIfMain} from "../../../deps/mocha.ts"; +import {InitializedRelationError} from "../../../../src/error/InitializedRelationError.ts"; +import {Category} from "./entity/Category.ts"; +import {Post} from "./entity/Post.ts"; +import {Image} from "./entity/Image.ts"; +import {ImageInfo} from "./entity/ImageInfo.ts"; +import {Question} from "./entity/Question.ts"; -describe("entity-metadata-validator > initialized relations", () => { - - it("should throw error if relation with initialized array was found on many-to-many relation", () => { +describe("entity-metadata-validator > initialized relations", function() { + it("should throw error if relation with initialized array was found on many-to-many relation", async () => { const connection = new Connection({ // dummy connection options, connection won't be established anyway + // TODO(uki00a) uncomment this when MysqlDriver is implemented. + /* type: "mysql", host: "localhost", username: "test", password: "test", database: "test", entities: [Post, Category] + */ + type: "sqlite", + database: ":memory:", + entities: [Post, Category] }); const connectionMetadataBuilder = new ConnectionMetadataBuilder(connection); - const entityMetadatas = connectionMetadataBuilder.buildEntityMetadatas([Post, Category]); + const entityMetadatas = await connectionMetadataBuilder.buildEntityMetadatas([Post, Category]); const entityMetadataValidator = new EntityMetadataValidator(); expect(() => entityMetadataValidator.validateMany(entityMetadatas, connection.driver)).to.throw(InitializedRelationError); }); - it("should throw error if relation with initialized array was found on one-to-many relation", () => { + it("should throw error if relation with initialized array was found on one-to-many relation", async () => { const connection = new Connection({ // dummy connection options, connection won't be established anyway + // TODO(uki00a) uncomment this when MysqlDriver is implemented. + /* type: "mysql", host: "localhost", username: "test", password: "test", database: "test", entities: [Image, ImageInfo] + */ + type: "sqlite", + database: ":memory:", + entities: [Image, ImageInfo] }); const connectionMetadataBuilder = new ConnectionMetadataBuilder(connection); - const entityMetadatas = connectionMetadataBuilder.buildEntityMetadatas([Image, ImageInfo]); + const entityMetadatas = await connectionMetadataBuilder.buildEntityMetadatas([Image, ImageInfo]); const entityMetadataValidator = new EntityMetadataValidator(); expect(() => entityMetadataValidator.validateMany(entityMetadatas, connection.driver)).to.throw(InitializedRelationError); }); - it("should not throw error if relation with initialized array was not found", () => { + it("should not throw error if relation with initialized array was not found", async () => { const connection = new Connection({ // dummy connection options, connection won't be established anyway + // TODO(uki00a) uncomment this when MysqlDriver is implemented. + /* type: "mysql", host: "localhost", username: "test", password: "test", database: "test", entities: [Category] + */ + type: "sqlite", + database: ":memory:", + entities: [Category] }); const connectionMetadataBuilder = new ConnectionMetadataBuilder(connection); - const entityMetadatas = connectionMetadataBuilder.buildEntityMetadatas([Category]); + const entityMetadatas = await connectionMetadataBuilder.buildEntityMetadatas([Category]); const entityMetadataValidator = new EntityMetadataValidator(); expect(() => entityMetadataValidator.validateMany(entityMetadatas, connection.driver)).not.to.throw(InitializedRelationError); }); - it("should not throw error if relation with initialized array was found, but persistence for this relation was disabled", () => { + it("should not throw error if relation with initialized array was found, but persistence for this relation was disabled", async () => { const connection = new Connection({ // dummy connection options, connection won't be established anyway + // TODO(uki00a) uncomment this when MysqlDriver is implemented. + /* type: "mysql", host: "localhost", username: "test", password: "test", database: "test", entities: [Question, Category] + */ + type: "sqlite", + database: ":memory:", + entities: [Question, Category] }); const connectionMetadataBuilder = new ConnectionMetadataBuilder(connection); - const entityMetadatas = connectionMetadataBuilder.buildEntityMetadatas([Question, Category]); + const entityMetadatas = await connectionMetadataBuilder.buildEntityMetadatas([Question, Category]); const entityMetadataValidator = new EntityMetadataValidator(); expect(() => entityMetadataValidator.validateMany(entityMetadatas, connection.driver)).not.to.throw(InitializedRelationError); }); -}); \ No newline at end of file +}); + +runIfMain(import.meta); diff --git a/test/functional/entity-metadata/entity-metadata-property-map.ts b/test/functional/entity-metadata/entity-metadata-property-map.ts index e38140023..2d4c1b74e 100644 --- a/test/functional/entity-metadata/entity-metadata-property-map.ts +++ b/test/functional/entity-metadata/entity-metadata-property-map.ts @@ -1,17 +1,19 @@ -import "reflect-metadata"; -import {Post} from "./entity/Post"; -import {Counters} from "./entity/Counters"; -import {Connection} from "../../../src/connection/Connection"; -import {expect} from "chai"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../utils/test-utils"; -import {Subcounters} from "./entity/Subcounters"; -import {User} from "./entity/User"; +import {join as joinPaths} from "../../../vendor/https/deno.land/std/path/mod.ts"; +import {Post} from "./entity/Post.ts"; +import {Counters} from "./entity/Counters.ts"; +import {Connection} from "../../../src/connection/Connection.ts"; +import {expect} from "../../deps/chai.ts"; +import {runIfMain} from "../../deps/mocha.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../utils/test-utils.ts"; +import {Subcounters} from "./entity/Subcounters.ts"; +import {User} from "./entity/User.ts"; describe("entity-metadata > property-map", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], })); beforeEach(() => reloadTestingDatabases(connections)); after(() => closeTestingConnections(connections)); @@ -56,3 +58,5 @@ describe("entity-metadata > property-map", () => { )); }))); }); + +runIfMain(import.meta); diff --git a/test/functional/entity-metadata/entity/Counters.ts b/test/functional/entity-metadata/entity/Counters.ts index 647103d43..e67389dcf 100644 --- a/test/functional/entity-metadata/entity/Counters.ts +++ b/test/functional/entity-metadata/entity/Counters.ts @@ -1,21 +1,21 @@ -import {Column} from "../../../../src/decorator/columns/Column"; -import {ManyToMany} from "../../../../src/decorator/relations/ManyToMany"; -import {JoinTable} from "../../../../src/decorator/relations/JoinTable"; -import {Subcounters} from "./Subcounters"; -import {User} from "./User"; +import {Column} from "../../../../src/decorator/columns/Column.ts"; +import {ManyToMany} from "../../../../src/decorator/relations/ManyToMany.ts"; +import {JoinTable} from "../../../../src/decorator/relations/JoinTable.ts"; +import {Subcounters} from "./Subcounters.ts"; +import {User} from "./User.ts"; export class Counters { - @Column() + @Column({ type: Number }) code: number; - @Column() + @Column({ type: Number }) likes: number; - @Column() + @Column({ type: Number }) comments: number; - @Column() + @Column({ type: Number }) favorites: number; @Column(() => Subcounters) @@ -25,4 +25,4 @@ export class Counters { @JoinTable() likedUsers: User[]; -} \ No newline at end of file +} diff --git a/test/functional/entity-metadata/entity/Post.ts b/test/functional/entity-metadata/entity/Post.ts index af942bc1f..58abc50b6 100644 --- a/test/functional/entity-metadata/entity/Post.ts +++ b/test/functional/entity-metadata/entity/Post.ts @@ -1,7 +1,7 @@ -import {Entity} from "../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../src/decorator/columns/Column"; -import {PrimaryGeneratedColumn} from "../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Counters} from "./Counters"; +import {Entity} from "../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../src/decorator/columns/Column.ts"; +import {PrimaryGeneratedColumn} from "../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Counters} from "./Counters.ts"; @Entity() export class Post { @@ -9,10 +9,10 @@ export class Post { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) title: string; @Column(() => Counters) counters: Counters; -} \ No newline at end of file +} diff --git a/test/functional/entity-metadata/entity/Subcounters.ts b/test/functional/entity-metadata/entity/Subcounters.ts index 3ee67ba73..c73e2f7d7 100644 --- a/test/functional/entity-metadata/entity/Subcounters.ts +++ b/test/functional/entity-metadata/entity/Subcounters.ts @@ -1,18 +1,18 @@ -import {Column} from "../../../../src/decorator/columns/Column"; -import {ManyToMany} from "../../../../src/decorator/relations/ManyToMany"; -import {JoinTable} from "../../../../src/decorator/relations/JoinTable"; -import {User} from "./User"; +import {Column} from "../../../../src/decorator/columns/Column.ts"; +import {ManyToMany} from "../../../../src/decorator/relations/ManyToMany.ts"; +import {JoinTable} from "../../../../src/decorator/relations/JoinTable.ts"; +import {User} from "./User.ts"; export class Subcounters { - @Column() + @Column({ type: Number }) version: number; - @Column() + @Column({ type: Number }) watches: number; @ManyToMany(type => User) @JoinTable({ name: "post_cnt_subcnt_wtch_users" }) watchedUsers: User[]; -} \ No newline at end of file +} diff --git a/test/functional/entity-metadata/entity/User.ts b/test/functional/entity-metadata/entity/User.ts index 2c8a6fe2c..37a18f203 100644 --- a/test/functional/entity-metadata/entity/User.ts +++ b/test/functional/entity-metadata/entity/User.ts @@ -1,8 +1,8 @@ -import {Column} from "../../../../src/decorator/columns/Column"; -import {PrimaryGeneratedColumn} from "../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Entity} from "../../../../src/decorator/entity/Entity"; -import {ManyToMany} from "../../../../src/decorator/relations/ManyToMany"; -import {Post} from "./Post"; +import {Column} from "../../../../src/decorator/columns/Column.ts"; +import {PrimaryGeneratedColumn} from "../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Entity} from "../../../../src/decorator/entity/Entity.ts"; +import {ManyToMany} from "../../../../src/decorator/relations/ManyToMany.ts"; +import {Post} from "./Post.ts"; @Entity() export class User { @@ -10,10 +10,10 @@ export class User { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) name: string; @ManyToMany(type => Post, post => post.counters.likedUsers) likedPosts: Post[]; -} \ No newline at end of file +} diff --git a/test/functional/entity-model/entity-model.ts b/test/functional/entity-model/entity-model.ts index 5be6481c1..b48ffaff2 100644 --- a/test/functional/entity-model/entity-model.ts +++ b/test/functional/entity-model/entity-model.ts @@ -1,15 +1,18 @@ -import "reflect-metadata"; -import {Post} from "./entity/Post"; -import {Category} from "./entity/Category"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../utils/test-utils"; -import {Connection} from "../../../src/connection/Connection"; -import {PromiseUtils} from "../../../src/util/PromiseUtils"; +import {join as joinPaths} from "../../../vendor/https/deno.land/std/path/mod.ts"; +import "../../deps/chai.ts"; +import {runIfMain} from "../../deps/mocha.ts"; +import {Post} from "./entity/Post.ts"; +import {Category} from "./entity/Category.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../utils/test-utils.ts"; +import {Connection} from "../../../src/connection/Connection.ts"; +import {PromiseUtils} from "../../../src/util/PromiseUtils.ts"; describe("entity-model", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], })); beforeEach(() => reloadTestingDatabases(connections)); after(() => closeTestingConnections(connections)); @@ -71,3 +74,5 @@ describe("entity-model", () => { })); }); + +runIfMain(import.meta); diff --git a/test/functional/entity-model/entity/Category.ts b/test/functional/entity-model/entity/Category.ts index 95c7b4125..a88f789d9 100644 --- a/test/functional/entity-model/entity/Category.ts +++ b/test/functional/entity-model/entity/Category.ts @@ -1,15 +1,15 @@ -import {PrimaryColumn} from "../../../../src/decorator/columns/PrimaryColumn"; -import {Entity} from "../../../../src/decorator/entity/Entity"; -import {BaseEntity} from "../../../../src/repository/BaseEntity"; -import {Column} from "../../../../src/decorator/columns/Column"; +import {PrimaryColumn} from "../../../../src/decorator/columns/PrimaryColumn.ts"; +import {Entity} from "../../../../src/decorator/entity/Entity.ts"; +import {BaseEntity} from "../../../../src/repository/BaseEntity.ts"; +import {Column} from "../../../../src/decorator/columns/Column.ts"; @Entity() export class Category extends BaseEntity { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; - @Column() + @Column({ type: String }) name: string; } diff --git a/test/functional/entity-model/entity/Post.ts b/test/functional/entity-model/entity/Post.ts index fc77fe36f..d59ae549a 100644 --- a/test/functional/entity-model/entity/Post.ts +++ b/test/functional/entity-model/entity/Post.ts @@ -1,9 +1,9 @@ -import {Entity} from "../../../../src/decorator/entity/Entity"; -import {BaseEntity} from "../../../../src/repository/BaseEntity"; -import {PrimaryGeneratedColumn} from "../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../src/decorator/columns/Column"; -import {ManyToMany, JoinTable} from "../../../../src"; -import {Category} from "./Category"; +import {Entity} from "../../../../src/decorator/entity/Entity.ts"; +import {BaseEntity} from "../../../../src/repository/BaseEntity.ts"; +import {PrimaryGeneratedColumn} from "../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../src/decorator/columns/Column.ts"; +import {ManyToMany, JoinTable} from "../../../../src/index.ts"; +import {Category} from "./Category.ts"; @Entity() export class Post extends BaseEntity { @@ -11,10 +11,11 @@ export class Post extends BaseEntity { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) title: string; @Column({ + type: String, default: "This is default text." }) text: string; @@ -23,4 +24,4 @@ export class Post extends BaseEntity { @JoinTable() categories: Category[]; -} \ No newline at end of file +} diff --git a/test/functional/entity-schema/basic/entity-schema-basic.ts b/test/functional/entity-schema/basic/entity-schema-basic.ts index 1db77317a..3c0578c45 100644 --- a/test/functional/entity-schema/basic/entity-schema-basic.ts +++ b/test/functional/entity-schema/basic/entity-schema-basic.ts @@ -1,8 +1,9 @@ -import "reflect-metadata"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils"; -import {Connection} from "../../../../src"; -import {PostEntity} from "./entity/PostEntity"; -import {CategoryEntity} from "./entity/CategoryEntity"; +import "../../../deps/chai.ts"; +import {runIfMain} from "../../../deps/mocha.ts"; +import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils.ts"; +import {Connection} from "../../../../src/index.ts"; +import {PostEntity} from "./entity/PostEntity.ts"; +import {CategoryEntity} from "./entity/CategoryEntity.ts"; describe("entity schemas > basic functionality", () => { @@ -32,3 +33,5 @@ describe("entity schemas > basic functionality", () => { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/entity-schema/basic/entity/CategoryEntity.ts b/test/functional/entity-schema/basic/entity/CategoryEntity.ts index 22dea7772..886b5f420 100644 --- a/test/functional/entity-schema/basic/entity/CategoryEntity.ts +++ b/test/functional/entity-schema/basic/entity/CategoryEntity.ts @@ -1,5 +1,5 @@ -import {EntitySchema} from "../../../../../src"; -import {Category} from "../model/Category"; +import {EntitySchema} from "../../../../../src/index.ts"; +import {Category} from "../model/Category.ts"; export const CategoryEntity = new EntitySchema({ name: "category", @@ -13,4 +13,4 @@ export const CategoryEntity = new EntitySchema({ type: String } } -}); \ No newline at end of file +}); diff --git a/test/functional/entity-schema/basic/entity/PostEntity.ts b/test/functional/entity-schema/basic/entity/PostEntity.ts index 3b7c34d43..7f6e079f3 100644 --- a/test/functional/entity-schema/basic/entity/PostEntity.ts +++ b/test/functional/entity-schema/basic/entity/PostEntity.ts @@ -1,5 +1,5 @@ -import {EntitySchema} from "../../../../../src"; -import {Post} from "../model/Post"; +import {EntitySchema} from "../../../../../src/index.ts"; +import {Post} from "../model/Post.ts"; export const PostEntity = new EntitySchema({ name: "post", @@ -22,4 +22,4 @@ export const PostEntity = new EntitySchema({ target: "category" // CategoryEntity } } -}); \ No newline at end of file +}); diff --git a/test/functional/entity-schema/basic/model/Post.ts b/test/functional/entity-schema/basic/model/Post.ts index 8fe565592..0192c49ae 100644 --- a/test/functional/entity-schema/basic/model/Post.ts +++ b/test/functional/entity-schema/basic/model/Post.ts @@ -1,4 +1,4 @@ -import {Category} from "./Category"; +import {Category} from "./Category.ts"; export interface Post { @@ -7,4 +7,4 @@ export interface Post { text: string; categories: Category[]; -} \ No newline at end of file +} diff --git a/test/functional/entity-schema/checks/checks-basic.ts b/test/functional/entity-schema/checks/checks-basic.ts index 65be3613d..76c048f89 100644 --- a/test/functional/entity-schema/checks/checks-basic.ts +++ b/test/functional/entity-schema/checks/checks-basic.ts @@ -1,14 +1,15 @@ -import "reflect-metadata"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils"; -import {Connection} from "../../../../src/connection/Connection"; -import {PersonSchema} from "./entity/Person"; -import {MysqlDriver} from "../../../../src/driver/mysql/MysqlDriver"; +import {runIfMain} from "../../../deps/mocha.ts"; +import "../../../deps/chai.ts"; +import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils.ts"; +import {Connection} from "../../../../src/connection/Connection.ts"; +import {PersonSchema} from "./entity/Person.ts"; +import {MysqlDriver} from "../../../../src/driver/mysql/MysqlDriver.ts"; describe("entity-schema > checks", () => { let connections: Connection[]; before(async () => connections = await createTestingConnections({ - entities: [PersonSchema], + entities: [PersonSchema as any], })); beforeEach(() => reloadTestingDatabases(connections)); after(() => closeTestingConnections(connections)); @@ -27,3 +28,5 @@ describe("entity-schema > checks", () => { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/entity-schema/checks/entity/Person.ts b/test/functional/entity-schema/checks/entity/Person.ts index 69cd5b238..4ddd456eb 100644 --- a/test/functional/entity-schema/checks/entity/Person.ts +++ b/test/functional/entity-schema/checks/entity/Person.ts @@ -1,4 +1,4 @@ -import {EntitySchema} from "../../../../../src/index"; +import {EntitySchema} from "../../../../../src/index.ts"; export const PersonSchema = new EntitySchema({ name: "Person", @@ -26,4 +26,4 @@ export const PersonSchema = new EntitySchema({ { expression: `"FirstName" <> 'John' AND "LastName" <> 'Doe'` }, { expression: `"Age" > 18` } ] -}); \ No newline at end of file +}); diff --git a/test/functional/entity-schema/columns/mysql/columns-mysql.ts b/test/functional/entity-schema/columns/mysql/columns-mysql.ts index d1955501a..0c5250d97 100644 --- a/test/functional/entity-schema/columns/mysql/columns-mysql.ts +++ b/test/functional/entity-schema/columns/mysql/columns-mysql.ts @@ -1,13 +1,15 @@ -import "reflect-metadata"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils"; -import {Connection} from "../../../../../src/connection/Connection"; -import {PersonSchema} from "./entity/Person"; +import {runIfMain} from "../../../../deps/mocha.ts"; +import "../../../../deps/chai.ts"; +import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils.ts"; +import {Connection} from "../../../../../src/connection/Connection.ts"; +import {PersonSchema} from "./entity/Person.ts"; -describe("entity-schema > columns > mysql", () => { +// TODO(uki00a) Remove `.skip` when MysqlDriver is implemented. +describe.skip("entity-schema > columns > mysql", () => { let connections: Connection[]; before(async () => connections = await createTestingConnections({ - entities: [PersonSchema], + entities: [PersonSchema as any], enabledDrivers: ["mysql"] })); beforeEach(() => reloadTestingDatabases(connections)); @@ -32,3 +34,5 @@ describe("entity-schema > columns > mysql", () => { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/entity-schema/columns/mysql/entity/Person.ts b/test/functional/entity-schema/columns/mysql/entity/Person.ts index 1c112b951..674f25f0c 100644 --- a/test/functional/entity-schema/columns/mysql/entity/Person.ts +++ b/test/functional/entity-schema/columns/mysql/entity/Person.ts @@ -1,4 +1,4 @@ -import {EntitySchema} from "../../../../../../src"; +import {EntitySchema} from "../../../../../../src/index.ts"; export const PersonSchema = new EntitySchema({ name: "Person", @@ -40,4 +40,4 @@ export const PersonSchema = new EntitySchema({ onUpdate: "CURRENT_TIMESTAMP(3)" } } -}); \ No newline at end of file +}); diff --git a/test/functional/entity-schema/exclusions/entity/Meeting.ts b/test/functional/entity-schema/exclusions/entity/Meeting.ts index b536a4e0b..a19f0a6a0 100644 --- a/test/functional/entity-schema/exclusions/entity/Meeting.ts +++ b/test/functional/entity-schema/exclusions/entity/Meeting.ts @@ -1,4 +1,4 @@ -import {EntitySchema} from "../../../../../src/index"; +import {EntitySchema} from "../../../../../src/index.ts"; export const MeetingSchema = new EntitySchema({ name: "Meeting", diff --git a/test/functional/entity-schema/exclusions/exclusions-basic.ts b/test/functional/entity-schema/exclusions/exclusions-basic.ts index 1e20cda48..3a1431cb3 100644 --- a/test/functional/entity-schema/exclusions/exclusions-basic.ts +++ b/test/functional/entity-schema/exclusions/exclusions-basic.ts @@ -1,29 +1,34 @@ -import "reflect-metadata"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils"; -import {Connection} from "../../../../src/connection/Connection"; -import {MeetingSchema} from "./entity/Meeting"; -import {PostgresDriver} from "../../../../src/driver/postgres/PostgresDriver"; +import {runIfMain} from "../../../deps/mocha.ts"; +import {expect} from "../../../deps/chai.ts"; +import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils.ts"; +import {Connection} from "../../../../src/connection/Connection.ts"; +import {MeetingSchema} from "./entity/Meeting.ts"; +// TODO(uki00a) uncomment this when PostgresDriver is implemented. +// import {PostgresDriver} from "../../../../src/driver/postgres/PostgresDriver.ts"; -describe("entity-schema > exclusions", () => { +// TODO(uki00a) Remove `.skip` when PostgresDriver is implemented. +describe.skip("entity-schema > exclusions", () => { let connections: Connection[]; before(async () => connections = await createTestingConnections({ - entities: [MeetingSchema], + entities: [MeetingSchema as any], })); beforeEach(() => reloadTestingDatabases(connections)); after(() => closeTestingConnections(connections)); it("should create an exclusion constraint", () => Promise.all(connections.map(async connection => { // Only PostgreSQL supports exclusion constraints. - if (!(connection.driver instanceof PostgresDriver)) + if (false/*!(connection.driver instanceof PostgresDriver)*/) // TODO(uki00a) uncomment this when PostgresDriver is implemented. return; const queryRunner = connection.createQueryRunner(); const table = await queryRunner.getTable("meeting"); await queryRunner.release(); - table!.exclusions.length.should.be.equal(1); + expect(table!.exclusions.length).to.equal(1); }))); }); + +runIfMain(import.meta); diff --git a/test/functional/entity-schema/indices/basic/entity/Person.ts b/test/functional/entity-schema/indices/basic/entity/Person.ts index 994bf950b..22cb49f7a 100644 --- a/test/functional/entity-schema/indices/basic/entity/Person.ts +++ b/test/functional/entity-schema/indices/basic/entity/Person.ts @@ -1,4 +1,4 @@ -import {EntitySchema} from "../../../../../../src/index"; +import {EntitySchema} from "../../../../../../src/index.ts"; export const PersonSchema = new EntitySchema({ name: "Person", @@ -28,4 +28,4 @@ export const PersonSchema = new EntitySchema({ ] } ] -}); \ No newline at end of file +}); diff --git a/test/functional/entity-schema/indices/basic/indices-basic.ts b/test/functional/entity-schema/indices/basic/indices-basic.ts index 64126d8dc..0ca32f325 100644 --- a/test/functional/entity-schema/indices/basic/indices-basic.ts +++ b/test/functional/entity-schema/indices/basic/indices-basic.ts @@ -1,17 +1,18 @@ -import "reflect-metadata"; -import {CockroachDriver} from "../../../../../src/driver/cockroachdb/CockroachDriver"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils"; -import {Connection} from "../../../../../src/connection/Connection"; -import {EntityMetadata} from "../../../../../src/metadata/EntityMetadata"; -import {IndexMetadata} from "../../../../../src/metadata/IndexMetadata"; -import {expect} from "chai"; -import {PersonSchema} from "./entity/Person"; +// TODO(uki00a) uncomment this when CockroachDriver is implemented. +// import {CockroachDriver} from "../../../../../src/driver/cockroachdb/CockroachDriver.ts"; +import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils.ts"; +import {Connection} from "../../../../../src/connection/Connection.ts"; +import {EntityMetadata} from "../../../../../src/metadata/EntityMetadata.ts"; +import {IndexMetadata} from "../../../../../src/metadata/IndexMetadata.ts"; +import {expect} from "../../../../deps/chai.ts"; +import {runIfMain} from "../../../../deps/mocha.ts"; +import {PersonSchema} from "./entity/Person.ts"; describe("entity-schema > indices > basic", () => { let connections: Connection[]; before(async () => connections = await createTestingConnections({ - entities: [PersonSchema], + entities: [PersonSchema as any], })); beforeEach(() => reloadTestingDatabases(connections)); after(() => closeTestingConnections(connections)); @@ -43,7 +44,7 @@ describe("entity-schema > indices > basic", () => { await queryRunner.release(); // CockroachDB stores unique indices as UNIQUE constraints - if (connection.driver instanceof CockroachDriver) { + if (false/* connection.driver instanceof CockroachDriver */) { // TODO(uki00a) uncomment this when CockroachDriver is implemented. expect(table!.uniques.length).to.be.equal(1); expect(table!.uniques[0].name).to.be.equal("IDX_TEST"); expect(table!.uniques[0].columnNames.length).to.be.equal(2); @@ -88,3 +89,5 @@ describe("entity-schema > indices > basic", () => { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/entity-schema/indices/mysql/entity/Person.ts b/test/functional/entity-schema/indices/mysql/entity/Person.ts index 96cdd0951..3c46bf248 100644 --- a/test/functional/entity-schema/indices/mysql/entity/Person.ts +++ b/test/functional/entity-schema/indices/mysql/entity/Person.ts @@ -1,4 +1,4 @@ -import {EntitySchema} from "../../../../../../src/index"; +import {EntitySchema} from "../../../../../../src/index.ts"; export const PersonSchema = new EntitySchema({ name: "Person", @@ -37,4 +37,4 @@ export const PersonSchema = new EntitySchema({ ] } ] -}); \ No newline at end of file +}); diff --git a/test/functional/entity-schema/indices/mysql/indices-mysql.ts b/test/functional/entity-schema/indices/mysql/indices-mysql.ts index f02e8d4cf..6b19c8068 100644 --- a/test/functional/entity-schema/indices/mysql/indices-mysql.ts +++ b/test/functional/entity-schema/indices/mysql/indices-mysql.ts @@ -1,13 +1,15 @@ -import "reflect-metadata"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils"; -import {Connection} from "../../../../../src/connection/Connection"; -import {PersonSchema} from "./entity/Person"; +import "../../../../deps/chai.ts"; +import {runIfMain} from "../../../../deps/mocha.ts"; +import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils.ts"; +import {Connection} from "../../../../../src/connection/Connection.ts"; +import {PersonSchema} from "./entity/Person.ts"; -describe("entity-schema > indices > mysql", () => { +// TODO(uki00a) uncomment this when MysqlDriver is implemented. +describe.skip("entity-schema > indices > mysql", () => { let connections: Connection[]; before(async () => connections = await createTestingConnections({ - entities: [PersonSchema], + entities: [PersonSchema as any], enabledDrivers: ["mysql"] })); beforeEach(() => reloadTestingDatabases(connections)); @@ -27,3 +29,5 @@ describe("entity-schema > indices > mysql", () => { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/entity-schema/target/entity-schema-target.ts b/test/functional/entity-schema/target/entity-schema-target.ts index f2beab20d..2ed09d210 100644 --- a/test/functional/entity-schema/target/entity-schema-target.ts +++ b/test/functional/entity-schema/target/entity-schema-target.ts @@ -1,8 +1,9 @@ -import "reflect-metadata"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils"; -import {Connection} from "../../../../src"; -import {PostEntity} from "./entity/PostEntity"; -import {Post} from "./model/Post"; +import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils.ts"; +import {Connection} from "../../../../src/index.ts"; +import {PostEntity} from "./entity/PostEntity.ts"; +import {Post} from "./model/Post.ts"; +import {runIfMain} from "../../../deps/mocha.ts"; +import "../../../deps/chai.ts"; describe("entity schemas > target option", () => { @@ -34,3 +35,5 @@ describe("entity schemas > target option", () => { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/entity-schema/target/entity/PostEntity.ts b/test/functional/entity-schema/target/entity/PostEntity.ts index b11ad97b5..0bdae06d2 100644 --- a/test/functional/entity-schema/target/entity/PostEntity.ts +++ b/test/functional/entity-schema/target/entity/PostEntity.ts @@ -1,5 +1,5 @@ -import {EntitySchema} from "../../../../../src"; -import {Post} from "../model/Post"; +import {EntitySchema} from "../../../../../src/index.ts"; +import {Post} from "../model/Post.ts"; export const PostEntity = new EntitySchema({ name: "post", @@ -17,4 +17,4 @@ export const PostEntity = new EntitySchema({ type: String } } -}); \ No newline at end of file +}); diff --git a/test/functional/entity-schema/uniques/entity/Person.ts b/test/functional/entity-schema/uniques/entity/Person.ts index d2fa7cc34..2008bd870 100644 --- a/test/functional/entity-schema/uniques/entity/Person.ts +++ b/test/functional/entity-schema/uniques/entity/Person.ts @@ -1,4 +1,4 @@ -import {EntitySchema} from "../../../../../src/index"; +import {EntitySchema} from "../../../../../src/index.ts"; export const PersonSchema = new EntitySchema({ name: "Person", @@ -27,4 +27,4 @@ export const PersonSchema = new EntitySchema({ ] } ] -}); \ No newline at end of file +}); diff --git a/test/functional/entity-schema/uniques/uniques-basic.ts b/test/functional/entity-schema/uniques/uniques-basic.ts index 9e53752cb..b96bf01d7 100644 --- a/test/functional/entity-schema/uniques/uniques-basic.ts +++ b/test/functional/entity-schema/uniques/uniques-basic.ts @@ -1,17 +1,17 @@ -import "reflect-metadata"; -import {SapDriver} from "../../../../src/driver/sap/SapDriver"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils"; -import {Connection} from "../../../../src/connection/Connection"; -import {expect} from "chai"; -import {PersonSchema} from "./entity/Person"; -import {MysqlDriver} from "../../../../src/driver/mysql/MysqlDriver"; -import {AbstractSqliteDriver} from "../../../../src/driver/sqlite-abstract/AbstractSqliteDriver"; +import {SapDriver} from "../../../../src/driver/sap/SapDriver.ts"; +import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils.ts"; +import {Connection} from "../../../../src/connection/Connection.ts"; +import {expect} from "../../../deps/chai.ts"; +import {runIfMain} from "../../../deps/mocha.ts"; +import {PersonSchema} from "./entity/Person.ts"; +import {MysqlDriver} from "../../../../src/driver/mysql/MysqlDriver.ts"; +import {AbstractSqliteDriver} from "../../../../src/driver/sqlite-abstract/AbstractSqliteDriver.ts"; describe("entity-schema > uniques", () => { let connections: Connection[]; before(async () => connections = await createTestingConnections({ - entities: [PersonSchema], + entities: [PersonSchema as any], })); beforeEach(() => reloadTestingDatabases(connections)); after(() => closeTestingConnections(connections)); @@ -44,3 +44,5 @@ describe("entity-schema > uniques", () => { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/indices/basic-unique-index-test/basic-unique-index-test.ts b/test/functional/indices/basic-unique-index-test/basic-unique-index-test.ts index 53125f1c2..918a4b7d1 100644 --- a/test/functional/indices/basic-unique-index-test/basic-unique-index-test.ts +++ b/test/functional/indices/basic-unique-index-test/basic-unique-index-test.ts @@ -1,13 +1,16 @@ -import "reflect-metadata"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils"; -import {Connection} from "../../../../src/connection/Connection"; -import {Customer} from "./entity/Customer"; +import {join as joinPaths} from "../../../../vendor/https/deno.land/std/path/mod.ts"; +import "../../../deps/chai.ts"; +import {runIfMain} from "../../../deps/mocha.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils.ts"; +import {Connection} from "../../../../src/connection/Connection.ts"; +import {Customer} from "./entity/Customer.ts"; describe("indices > basic unique index test", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], })); beforeEach(() => reloadTestingDatabases(connections)); after(() => closeTestingConnections(connections)); @@ -24,3 +27,5 @@ describe("indices > basic unique index test", () => { }); }); + +runIfMain(import.meta); diff --git a/test/functional/indices/basic-unique-index-test/entity/Customer.ts b/test/functional/indices/basic-unique-index-test/entity/Customer.ts index 000d2ee68..1810a8001 100644 --- a/test/functional/indices/basic-unique-index-test/entity/Customer.ts +++ b/test/functional/indices/basic-unique-index-test/entity/Customer.ts @@ -1,7 +1,7 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {Index} from "../../../../../src/decorator/Index"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../src/decorator/columns/Column"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {Index} from "../../../../../src/decorator/Index.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; @Entity() @Index("index_name_english", ["nameEnglish"], { unique: true }) @@ -10,10 +10,10 @@ export class Customer { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) nameHebrew: string; - @Column() + @Column({ type: String }) nameEnglish: string; -} \ No newline at end of file +} diff --git a/test/functional/indices/conditional-index/conditional-index.ts b/test/functional/indices/conditional-index/conditional-index.ts index 67f6648c8..69790da52 100644 --- a/test/functional/indices/conditional-index/conditional-index.ts +++ b/test/functional/indices/conditional-index/conditional-index.ts @@ -1,14 +1,15 @@ -import "reflect-metadata"; -import {Connection} from "../../../../src"; -import {closeTestingConnections, createTestingConnections} from "../../../utils/test-utils"; -import {expect} from "chai"; - -describe("indices > conditional index", () => { +import {join as joinPaths} from "../../../../vendor/https/deno.land/std/path/mod.ts"; +import {Connection} from "../../../../src/index.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections} from "../../../utils/test-utils.ts"; +import {expect} from "../../../deps/chai.ts"; +import {runIfMain} from "../../../deps/mocha.ts"; +describe("indices > conditional index", function() { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => { connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], enabledDrivers: ["mssql", "postgres", "sqlite"], // only these drivers supports conditional indices schemaCreate: true, dropSchema: true, @@ -54,3 +55,5 @@ describe("indices > conditional index", () => { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/indices/conditional-index/entity/Post.ts b/test/functional/indices/conditional-index/entity/Post.ts index c8f739664..cef4690be 100644 --- a/test/functional/indices/conditional-index/entity/Post.ts +++ b/test/functional/indices/conditional-index/entity/Post.ts @@ -1,5 +1,5 @@ -import {Column, Entity, PrimaryGeneratedColumn} from "../../../../../src"; -import {Index} from "../../../../../src/decorator/Index"; +import {Column, Entity, PrimaryGeneratedColumn} from "../../../../../src/index.ts"; +import {Index} from "../../../../../src/decorator/Index.ts"; @Index(["name", "text"], { where: `"name" IS NOT NULL AND "text" IS NOT NULL` }) @Entity() @@ -8,14 +8,14 @@ export class Post { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) name: string; - @Column() + @Column({ type: String }) text: string; @Index({ where: `"version" IS NOT NULL AND "version" > 0` }) - @Column() + @Column({ type: Number }) version: number; -} \ No newline at end of file +} diff --git a/test/functional/indices/embeddeds-index-test/embeddeds-unique-index-test.ts b/test/functional/indices/embeddeds-index-test/embeddeds-unique-index-test.ts index d49263668..b3567c5d5 100644 --- a/test/functional/indices/embeddeds-index-test/embeddeds-unique-index-test.ts +++ b/test/functional/indices/embeddeds-index-test/embeddeds-unique-index-test.ts @@ -1,14 +1,17 @@ -import "reflect-metadata"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils"; -import {Connection} from "../../../../src/connection/Connection"; -import {Customer} from "./entity/Customer"; -import {Profile} from "./entity/Profile"; +import {join as joinPaths} from "../../../../vendor/https/deno.land/std/path/mod.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils.ts"; +import {Connection} from "../../../../src/connection/Connection.ts"; +import {Customer} from "./entity/Customer.ts"; +import {Profile} from "./entity/Profile.ts"; +import "../../../deps/chai.ts"; +import {runIfMain} from "../../../deps/mocha.ts"; describe("indices > embeds index test", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"] + entities: [joinPaths(__dirname, "/entity/*.ts")] })); beforeEach(() => reloadTestingDatabases(connections)); after(() => closeTestingConnections(connections)); @@ -28,3 +31,5 @@ describe("indices > embeds index test", () => { }); }); + +runIfMain(import.meta); diff --git a/test/functional/indices/embeddeds-index-test/entity/Customer.ts b/test/functional/indices/embeddeds-index-test/entity/Customer.ts index 27d3d1f97..abe88d916 100644 --- a/test/functional/indices/embeddeds-index-test/entity/Customer.ts +++ b/test/functional/indices/embeddeds-index-test/entity/Customer.ts @@ -1,8 +1,8 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {Index} from "../../../../../src/decorator/Index"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {Profile} from "./Profile"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {Index} from "../../../../../src/decorator/Index.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {Profile} from "./Profile.ts"; @Entity() @Index("index_name_english", ["nameEnglish"], { unique: true }) @@ -12,12 +12,12 @@ export class Customer { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) nameHebrew: string; - @Column() + @Column({ type: String }) nameEnglish: string; @Column(() => Profile) profile: Profile; -} \ No newline at end of file +} diff --git a/test/functional/indices/embeddeds-index-test/entity/Profile.ts b/test/functional/indices/embeddeds-index-test/entity/Profile.ts index 5a9500206..c4ae8ad17 100644 --- a/test/functional/indices/embeddeds-index-test/entity/Profile.ts +++ b/test/functional/indices/embeddeds-index-test/entity/Profile.ts @@ -1,12 +1,12 @@ -import {Column} from "../../../../../src/decorator/columns/Column"; -import {Index} from "../../../../../src/decorator/Index"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {Index} from "../../../../../src/decorator/Index.ts"; export class Profile { - @Column() + @Column({ type: String }) job: string; - @Column() + @Column({ type: String }) @Index("customer_profile_address") address: string; -} \ No newline at end of file +} diff --git a/test/functional/json/entity/Record.ts b/test/functional/json/entity/Record.ts index 72503bd35..e232083d7 100644 --- a/test/functional/json/entity/Record.ts +++ b/test/functional/json/entity/Record.ts @@ -1,6 +1,6 @@ -import {Entity} from "../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../src/decorator/columns/Column"; +import {Entity} from "../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../src/decorator/columns/Column.ts"; /** * For testing Postgres jsonb @@ -17,4 +17,4 @@ export class Record { @Column({ type: "jsonb", nullable: true }) data: any; -} \ No newline at end of file +} diff --git a/test/functional/json/jsonb.ts b/test/functional/json/jsonb.ts index 052ba816f..64b62d5ac 100644 --- a/test/functional/json/jsonb.ts +++ b/test/functional/json/jsonb.ts @@ -1,8 +1,8 @@ -import "reflect-metadata"; -import {expect} from "chai"; -import {Record} from "./entity/Record"; -import {Connection} from "../../../src/connection/Connection"; -import {closeTestingConnections, createTestingConnections} from "../../utils/test-utils"; +import {expect} from "../../deps/chai.ts"; +import {runIfMain} from "../../deps/mocha.ts"; +import {Record} from "./entity/Record.ts"; +import {Connection} from "../../../src/connection/Connection.ts"; +import {closeTestingConnections, createTestingConnections} from "../../utils/test-utils.ts"; describe("jsonb type", () => { @@ -56,3 +56,5 @@ describe("jsonb type", () => { expect(foundRecord!.data).to.deep.include.members([1, "2", { a: 3 }]); }))); }); + +runIfMain(import.meta); diff --git a/test/functional/metadata-builder/column-metadata/column-metadata.ts b/test/functional/metadata-builder/column-metadata/column-metadata.ts index e61b4d3fd..ac4856a88 100644 --- a/test/functional/metadata-builder/column-metadata/column-metadata.ts +++ b/test/functional/metadata-builder/column-metadata/column-metadata.ts @@ -1,16 +1,18 @@ -import "reflect-metadata"; -import {expect} from "chai"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils"; -import {Connection} from "../../../../src/connection/Connection"; -import {Post} from "./entity/Post"; -import {Counters} from "./entity/Counters"; -import {Subcounters} from "./entity/Subcounters"; +import {join as joinPaths} from "../../../../vendor/https/deno.land/std/path/mod.ts"; +import {expect} from "../../../deps/chai.ts"; +import {runIfMain} from "../../../deps/mocha.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils.ts"; +import {Connection} from "../../../../src/connection/Connection.ts"; +import {Post} from "./entity/Post.ts"; +import {Counters} from "./entity/Counters.ts"; +import {Subcounters} from "./entity/Subcounters.ts"; describe("metadata-builder > ColumnMetadata", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], })); beforeEach(() => reloadTestingDatabases(connections)); after(() => closeTestingConnections(connections)); @@ -85,3 +87,5 @@ describe("metadata-builder > ColumnMetadata", () => { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/metadata-builder/column-metadata/entity/Counters.ts b/test/functional/metadata-builder/column-metadata/entity/Counters.ts index 41862371a..b58cc25b8 100644 --- a/test/functional/metadata-builder/column-metadata/entity/Counters.ts +++ b/test/functional/metadata-builder/column-metadata/entity/Counters.ts @@ -1,21 +1,21 @@ -import {Column} from "../../../../../src/decorator/columns/Column"; -import {Subcounters} from "./Subcounters"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {Subcounters} from "./Subcounters.ts"; export class Counters { - @Column() + @Column({ type: Number }) code: number; - @Column() + @Column({ type: Number }) likes: number; - @Column() + @Column({ type: Number }) comments: number; - @Column() + @Column({ type: Number }) favorites: number; @Column(() => Subcounters) subcounters: Subcounters; -} \ No newline at end of file +} diff --git a/test/functional/metadata-builder/column-metadata/entity/Post.ts b/test/functional/metadata-builder/column-metadata/entity/Post.ts index e6ec86e6f..070db99d7 100644 --- a/test/functional/metadata-builder/column-metadata/entity/Post.ts +++ b/test/functional/metadata-builder/column-metadata/entity/Post.ts @@ -1,15 +1,15 @@ -import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn"; -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {Counters} from "./Counters"; +import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn.ts"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {Counters} from "./Counters.ts"; @Entity() export class Post { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; - @Column() + @Column({ type: String }) title: string; @Column(() => Counters) diff --git a/test/functional/metadata-builder/column-metadata/entity/Subcounters.ts b/test/functional/metadata-builder/column-metadata/entity/Subcounters.ts index a89a0cbc5..69704012f 100644 --- a/test/functional/metadata-builder/column-metadata/entity/Subcounters.ts +++ b/test/functional/metadata-builder/column-metadata/entity/Subcounters.ts @@ -1,11 +1,11 @@ -import {Column} from "../../../../../src/decorator/columns/Column"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; export class Subcounters { - @Column() + @Column({ type: Number }) version: number; - @Column() + @Column({ type: Number }) watches: number; -} \ No newline at end of file +} diff --git a/test/functional/metadata-builder/metadata-args-storage/entity/ContentModule.ts b/test/functional/metadata-builder/metadata-args-storage/entity/ContentModule.ts index 7961ab039..0b90acd4c 100644 --- a/test/functional/metadata-builder/metadata-args-storage/entity/ContentModule.ts +++ b/test/functional/metadata-builder/metadata-args-storage/entity/ContentModule.ts @@ -1,9 +1,9 @@ -import {Column} from "../../../../../src/decorator/columns/Column"; -import {Unit} from "./Unit"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {Unit} from "./Unit.ts"; export class ContentModule extends Unit { - @Column() + @Column({ type: String }) tag: string; -} \ No newline at end of file +} diff --git a/test/functional/metadata-builder/metadata-args-storage/entity/Post.ts b/test/functional/metadata-builder/metadata-args-storage/entity/Post.ts index 76f86b414..5fad59254 100644 --- a/test/functional/metadata-builder/metadata-args-storage/entity/Post.ts +++ b/test/functional/metadata-builder/metadata-args-storage/entity/Post.ts @@ -1,14 +1,14 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {ContentModule} from "./ContentModule"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {ContentModule} from "./ContentModule.ts"; @Entity() export class Post extends ContentModule { - @Column() + @Column({ type: String }) title: string; - @Column() + @Column({ type: String }) text: string; -} \ No newline at end of file +} diff --git a/test/functional/metadata-builder/metadata-args-storage/entity/Unit.ts b/test/functional/metadata-builder/metadata-args-storage/entity/Unit.ts index f5790a984..befbad6ef 100644 --- a/test/functional/metadata-builder/metadata-args-storage/entity/Unit.ts +++ b/test/functional/metadata-builder/metadata-args-storage/entity/Unit.ts @@ -1,12 +1,12 @@ -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../src/decorator/columns/Column"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; export class Unit { @PrimaryGeneratedColumn() id: string; - @Column() + @Column({ type: String }) type: string; -} \ No newline at end of file +} diff --git a/test/functional/metadata-builder/metadata-args-storage/metadata-args-storage.ts b/test/functional/metadata-builder/metadata-args-storage/metadata-args-storage.ts index 1c5cbbae3..b32d85681 100644 --- a/test/functional/metadata-builder/metadata-args-storage/metadata-args-storage.ts +++ b/test/functional/metadata-builder/metadata-args-storage/metadata-args-storage.ts @@ -1,8 +1,9 @@ -import "reflect-metadata"; -import {Post} from "./entity/Post"; -import {ContentModule} from "./entity/ContentModule"; -import {Unit} from "./entity/Unit"; -import {MetadataUtils} from "../../../../src/metadata-builder/MetadataUtils"; +import {Post} from "./entity/Post.ts"; +import {ContentModule} from "./entity/ContentModule.ts"; +import {Unit} from "./entity/Unit.ts"; +import {MetadataUtils} from "../../../../src/metadata-builder/MetadataUtils.ts"; +import "../../../deps/chai.ts"; +import {runIfMain} from "../../../deps/mocha.ts"; describe("metadata builder > MetadataArgsUtils", () => { @@ -82,4 +83,6 @@ describe("metadata builder > MetadataArgsUtils", () => { ]); }); -}); \ No newline at end of file +}); + +runIfMain(import.meta); diff --git a/test/functional/migrations/show-command/command.ts b/test/functional/migrations/show-command/command.ts index 0266edc7c..a491e3138 100644 --- a/test/functional/migrations/show-command/command.ts +++ b/test/functional/migrations/show-command/command.ts @@ -1,12 +1,15 @@ -import "reflect-metadata"; -import {createTestingConnections, closeTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils"; -import {Connection} from "../../../../src/connection/Connection"; +import {join as joinPaths} from "../../../../vendor/https/deno.land/std/path/mod.ts"; +import {getDirnameOfCurrentModule, createTestingConnections, closeTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils.ts"; +import {Connection} from "../../../../src/connection/Connection.ts"; +import "../../../deps/chai.ts"; +import {runIfMain} from "../../../deps/mocha.ts"; -describe("migrations > show command", () => { +describe("migrations > show command", function() { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => connections = await createTestingConnections({ - migrations: [__dirname + "/migration/*.js"], - enabledDrivers: ["postgres"], + migrations: [joinPaths(__dirname, "/migration/*.ts")], + enabledDrivers: ["sqlite", "postgres"], schemaCreate: true, dropSchema: true, })); @@ -23,4 +26,6 @@ describe("migrations > show command", () => { const migrations = await connection.showMigrations(); migrations.should.be.equal(false); }))); - }); +}); + +runIfMain(import.meta); diff --git a/test/functional/migrations/show-command/migration/1530542855524-ExampleMigration.ts b/test/functional/migrations/show-command/migration/1530542855524-ExampleMigration.ts index 182efb38d..1c069eadb 100644 --- a/test/functional/migrations/show-command/migration/1530542855524-ExampleMigration.ts +++ b/test/functional/migrations/show-command/migration/1530542855524-ExampleMigration.ts @@ -1,5 +1,5 @@ -import { MigrationInterface } from "../../../../../src/migration/MigrationInterface"; -import { QueryRunner } from "../../../../../src/query-runner/QueryRunner"; +import { MigrationInterface } from "../../../../../src/migration/MigrationInterface.ts"; +import { QueryRunner } from "../../../../../src/query-runner/QueryRunner.ts"; export class ExampleMigration1530542855524 implements MigrationInterface { public async up(queryRunner: QueryRunner): Promise { diff --git a/test/functional/migrations/show-command/migration/1530542855524-ExampleMigrationTwo.ts b/test/functional/migrations/show-command/migration/1530542855524-ExampleMigrationTwo.ts index faf11568c..3e8837b6f 100644 --- a/test/functional/migrations/show-command/migration/1530542855524-ExampleMigrationTwo.ts +++ b/test/functional/migrations/show-command/migration/1530542855524-ExampleMigrationTwo.ts @@ -1,5 +1,5 @@ -import { MigrationInterface } from "../../../../../src/migration/MigrationInterface"; -import { QueryRunner } from "../../../../../src/query-runner/QueryRunner"; +import { MigrationInterface } from "../../../../../src/migration/MigrationInterface.ts"; +import { QueryRunner } from "../../../../../src/query-runner/QueryRunner.ts"; export class ExampleMigrationTwo1530542855524 implements MigrationInterface { public async up(queryRunner: QueryRunner): Promise { diff --git a/test/functional/mongodb/basic/array-columns/entity/Counters.ts b/test/functional/mongodb/basic/array-columns/entity/Counters.ts index 570e599a7..4f1431ed8 100644 --- a/test/functional/mongodb/basic/array-columns/entity/Counters.ts +++ b/test/functional/mongodb/basic/array-columns/entity/Counters.ts @@ -1,11 +1,11 @@ -import {Column} from "../../../../../../src/decorator/columns/Column"; +import {Column} from "../../../../../../src/decorator/columns/Column.ts"; export class Counters { - @Column() + @Column({ type: Number }) likes: number; - @Column() + @Column({ type: String }) text: string; constructor(likes: number, text: string) { @@ -13,4 +13,4 @@ export class Counters { this.text = text; } -} \ No newline at end of file +} diff --git a/test/functional/mongodb/basic/array-columns/entity/Post.ts b/test/functional/mongodb/basic/array-columns/entity/Post.ts index 397edc0b7..3a4224944 100644 --- a/test/functional/mongodb/basic/array-columns/entity/Post.ts +++ b/test/functional/mongodb/basic/array-columns/entity/Post.ts @@ -1,8 +1,8 @@ -import {Entity} from "../../../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../../../src/decorator/columns/Column"; -import {ObjectIdColumn} from "../../../../../../src/decorator/columns/ObjectIdColumn"; -import {Counters} from "./Counters"; -import {ObjectID} from "../../../../../../src/driver/mongodb/typings"; +import {Entity} from "../../../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../../../src/decorator/columns/Column.ts"; +import {ObjectIdColumn} from "../../../../../../src/decorator/columns/ObjectIdColumn.ts"; +import {Counters} from "./Counters.ts"; +import {ObjectID} from "../../../../../../src/driver/mongodb/typings.ts"; @Entity() export class Post { @@ -10,19 +10,19 @@ export class Post { @ObjectIdColumn() id: ObjectID; - @Column() + @Column({ type: String }) title: string; @Column(type => Counters) counters: Counters[]; - @Column() + @Column({ type: String, array: true }) names: string[]; - @Column() + @Column({ type: Number, array: true }) numbers: number[]; - @Column() + @Column({ type: Boolean, array: true }) booleans: boolean[]; @Column(type => Counters) @@ -31,4 +31,4 @@ export class Post { @Column(type => Counters) other2: Counters[]; -} \ No newline at end of file +} diff --git a/test/functional/mongodb/basic/array-columns/mongodb-array-columns.ts b/test/functional/mongodb/basic/array-columns/mongodb-array-columns.ts index fa3840705..5fbab57a7 100644 --- a/test/functional/mongodb/basic/array-columns/mongodb-array-columns.ts +++ b/test/functional/mongodb/basic/array-columns/mongodb-array-columns.ts @@ -1,11 +1,12 @@ -import "reflect-metadata"; -import {Connection} from "../../../../../src/connection/Connection"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils"; -import {Post} from "./entity/Post"; -import {Counters} from "./entity/Counters"; -import {expect} from "chai"; +import {Connection} from "../../../../../src/connection/Connection.ts"; +import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils.ts"; +import {Post} from "./entity/Post.ts"; +import {Counters} from "./entity/Counters.ts"; +import {expect} from "../../../../deps/chai.ts"; +import {runIfMain} from "../../../../deps/mocha.ts"; -describe("mongodb > array columns", () => { +// TODO(uki00a) Remove `.skip` when MongoDriver is implemented. +describe.skip("mongodb > array columns", () => { let connections: Connection[]; before(async () => connections = await createTestingConnections({ @@ -119,3 +120,5 @@ describe("mongodb > array columns", () => { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/mongodb/basic/embedded-columns-listeners/entity/Counters.ts b/test/functional/mongodb/basic/embedded-columns-listeners/entity/Counters.ts index 901685083..1abce3e41 100644 --- a/test/functional/mongodb/basic/embedded-columns-listeners/entity/Counters.ts +++ b/test/functional/mongodb/basic/embedded-columns-listeners/entity/Counters.ts @@ -1,10 +1,10 @@ -import {Column} from "../../../../../../src/decorator/columns/Column"; -import {Information} from "./Information"; -import {BeforeInsert} from "../../../../../../src"; +import {Column} from "../../../../../../src/decorator/columns/Column.ts"; +import {Information} from "./Information.ts"; +import {BeforeInsert} from "../../../../../../src/index.ts"; export class Counters { - @Column() + @Column({ type: Number }) likes: number; @Column(type => Information) @@ -14,4 +14,4 @@ export class Counters { beforeInsert() { this.likes = 100; } -} \ No newline at end of file +} diff --git a/test/functional/mongodb/basic/embedded-columns-listeners/entity/Information.ts b/test/functional/mongodb/basic/embedded-columns-listeners/entity/Information.ts index 12577177d..b1adbec9f 100644 --- a/test/functional/mongodb/basic/embedded-columns-listeners/entity/Information.ts +++ b/test/functional/mongodb/basic/embedded-columns-listeners/entity/Information.ts @@ -1,12 +1,12 @@ -import {Column} from "../../../../../../src/decorator/columns/Column"; -import {AfterLoad, BeforeInsert} from "../../../../../../src"; +import {Column} from "../../../../../../src/decorator/columns/Column.ts"; +import {AfterLoad, BeforeInsert} from "../../../../../../src/index.ts"; export class Information { - @Column() + @Column({ type: String }) description?: string; - @Column() + @Column({ type: Number }) comments?: number; @BeforeInsert() @@ -19,4 +19,4 @@ export class Information { this.comments = 1; } -} \ No newline at end of file +} diff --git a/test/functional/mongodb/basic/embedded-columns-listeners/entity/Post.ts b/test/functional/mongodb/basic/embedded-columns-listeners/entity/Post.ts index f3caf9ebb..99a1f5461 100644 --- a/test/functional/mongodb/basic/embedded-columns-listeners/entity/Post.ts +++ b/test/functional/mongodb/basic/embedded-columns-listeners/entity/Post.ts @@ -1,8 +1,8 @@ -import {Entity} from "../../../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../../../src/decorator/columns/Column"; -import {ObjectIdColumn} from "../../../../../../src/decorator/columns/ObjectIdColumn"; -import {Counters} from "./Counters"; -import {ObjectID} from "../../../../../../src/driver/mongodb/typings"; +import {Entity} from "../../../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../../../src/decorator/columns/Column.ts"; +import {ObjectIdColumn} from "../../../../../../src/decorator/columns/ObjectIdColumn.ts"; +import {Counters} from "./Counters.ts"; +import {ObjectID} from "../../../../../../src/driver/mongodb/typings.ts"; @Entity() export class Post { @@ -10,13 +10,13 @@ export class Post { @ObjectIdColumn() id: ObjectID; - @Column() + @Column({ type: String }) title: string; - @Column() + @Column({ type: String }) text: string; @Column(type => Counters) counters?: Counters; -} \ No newline at end of file +} diff --git a/test/functional/mongodb/basic/embedded-columns-listeners/mongodb-embedded-columns-listeners.ts b/test/functional/mongodb/basic/embedded-columns-listeners/mongodb-embedded-columns-listeners.ts index e4c2d28c6..e8a268e24 100644 --- a/test/functional/mongodb/basic/embedded-columns-listeners/mongodb-embedded-columns-listeners.ts +++ b/test/functional/mongodb/basic/embedded-columns-listeners/mongodb-embedded-columns-listeners.ts @@ -1,12 +1,13 @@ -import "reflect-metadata"; -import {Connection} from "../../../../../src/connection/Connection"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils"; -import {Post} from "./entity/Post"; -import {Counters} from "./entity/Counters"; -import {Information} from "./entity/Information"; -import {expect} from "chai"; +import {Connection} from "../../../../../src/connection/Connection.ts"; +import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils.ts"; +import {Post} from "./entity/Post.ts"; +import {Counters} from "./entity/Counters.ts"; +import {Information} from "./entity/Information.ts"; +import {expect} from "../../../../deps/chai.ts"; +import {runIfMain} from "../../../../deps/mocha.ts"; -describe("mongodb > embedded columns listeners", () => { +// TODO(uki00a) Remove `.skip` when MongoDriver is implemented. +describe.skip("mongodb > embedded columns listeners", () => { let connections: Connection[]; before(async () => connections = await createTestingConnections({ @@ -71,3 +72,5 @@ describe("mongodb > embedded columns listeners", () => { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/mongodb/basic/embedded-columns/entity/Counters.ts b/test/functional/mongodb/basic/embedded-columns/entity/Counters.ts index 5790429fa..ee7ea1252 100644 --- a/test/functional/mongodb/basic/embedded-columns/entity/Counters.ts +++ b/test/functional/mongodb/basic/embedded-columns/entity/Counters.ts @@ -1,16 +1,16 @@ -import {Column} from "../../../../../../src/decorator/columns/Column"; -import {Information} from "./Information"; -import {ExtraInformation} from "./ExtraInformation"; +import {Column} from "../../../../../../src/decorator/columns/Column.ts"; +import {Information} from "./Information.ts"; +import {ExtraInformation} from "./ExtraInformation.ts"; export class Counters { - @Column() + @Column({ type: Number }) likes: number; - @Column() + @Column({ type: Number }) comments: number; - @Column() + @Column({ type: Number }) favorites: number; @Column(type => Information) @@ -18,4 +18,4 @@ export class Counters { @Column(type => ExtraInformation) extraInformation: ExtraInformation; -} \ No newline at end of file +} diff --git a/test/functional/mongodb/basic/embedded-columns/entity/EditHistory.ts b/test/functional/mongodb/basic/embedded-columns/entity/EditHistory.ts index c221e88d8..ced66b024 100644 --- a/test/functional/mongodb/basic/embedded-columns/entity/EditHistory.ts +++ b/test/functional/mongodb/basic/embedded-columns/entity/EditHistory.ts @@ -1,11 +1,11 @@ -import {Column} from "../../../../../../src/decorator/columns/Column"; +import {Column} from "../../../../../../src/decorator/columns/Column.ts"; export class EditHistory { - @Column() + @Column({ type: String }) title: string; - @Column() + @Column({ type: String }) text: string; } diff --git a/test/functional/mongodb/basic/embedded-columns/entity/ExtraInformation.ts b/test/functional/mongodb/basic/embedded-columns/entity/ExtraInformation.ts index 1f22b8ea3..2bce35808 100644 --- a/test/functional/mongodb/basic/embedded-columns/entity/ExtraInformation.ts +++ b/test/functional/mongodb/basic/embedded-columns/entity/ExtraInformation.ts @@ -1,5 +1,5 @@ -import {Column} from "../../../../../../src/decorator/columns/Column"; -import {EditHistory} from "./EditHistory"; +import {Column} from "../../../../../../src/decorator/columns/Column.ts"; +import {EditHistory} from "./EditHistory.ts"; export class ExtraInformation { diff --git a/test/functional/mongodb/basic/embedded-columns/entity/Information.ts b/test/functional/mongodb/basic/embedded-columns/entity/Information.ts index 3b7a6fdd4..845585129 100644 --- a/test/functional/mongodb/basic/embedded-columns/entity/Information.ts +++ b/test/functional/mongodb/basic/embedded-columns/entity/Information.ts @@ -1,14 +1,14 @@ -import {Column} from "../../../../../../src/decorator/columns/Column"; +import {Column} from "../../../../../../src/decorator/columns/Column.ts"; export class Information { - @Column() + @Column({ type: String }) description: string; - @Column() + @Column({ type: Boolean }) visible: boolean; - @Column() + @Column({ type: Boolean }) editable: boolean; } diff --git a/test/functional/mongodb/basic/embedded-columns/entity/Post.ts b/test/functional/mongodb/basic/embedded-columns/entity/Post.ts index f642b6f5d..e44c1dba1 100644 --- a/test/functional/mongodb/basic/embedded-columns/entity/Post.ts +++ b/test/functional/mongodb/basic/embedded-columns/entity/Post.ts @@ -1,8 +1,8 @@ -import {Entity} from "../../../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../../../src/decorator/columns/Column"; -import {ObjectIdColumn} from "../../../../../../src/decorator/columns/ObjectIdColumn"; -import {Counters} from "./Counters"; -import {ObjectID} from "../../../../../../src/driver/mongodb/typings"; +import {Entity} from "../../../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../../../src/decorator/columns/Column.ts"; +import {ObjectIdColumn} from "../../../../../../src/decorator/columns/ObjectIdColumn.ts"; +import {Counters} from "./Counters.ts"; +import {ObjectID} from "../../../../../../src/driver/mongodb/typings.ts"; @Entity() export class Post { @@ -10,13 +10,13 @@ export class Post { @ObjectIdColumn() id: ObjectID; - @Column() + @Column({ type: String }) title: string; - @Column() + @Column({ type: String }) text: string; @Column(type => Counters) counters: Counters; -} \ No newline at end of file +} diff --git a/test/functional/mongodb/basic/embedded-columns/mongodb-embedded-columns.ts b/test/functional/mongodb/basic/embedded-columns/mongodb-embedded-columns.ts index db2058284..817ebfb4d 100644 --- a/test/functional/mongodb/basic/embedded-columns/mongodb-embedded-columns.ts +++ b/test/functional/mongodb/basic/embedded-columns/mongodb-embedded-columns.ts @@ -1,14 +1,15 @@ -import "reflect-metadata"; -import {Connection} from "../../../../../src/connection/Connection"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils"; -import {Post} from "./entity/Post"; -import {Counters} from "./entity/Counters"; -import {Information} from "./entity/Information"; -import {ExtraInformation} from "./entity/ExtraInformation"; -import {EditHistory} from "./entity/EditHistory"; -import {expect} from "chai"; - -describe("mongodb > embedded columns", () => { +import {Connection} from "../../../../../src/connection/Connection.ts"; +import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils.ts"; +import {Post} from "./entity/Post.ts"; +import {Counters} from "./entity/Counters.ts"; +import {Information} from "./entity/Information.ts"; +import {ExtraInformation} from "./entity/ExtraInformation.ts"; +import {EditHistory} from "./entity/EditHistory.ts"; +import {expect} from "../../../../deps/chai.ts"; +import {runIfMain} from "../../../../deps/mocha.ts"; + +// TODO(uki00a) Remove `.skip` when MongoDriver is implemented. +describe.skip("mongodb > embedded columns", () => { let connections: Connection[]; before(async () => connections = await createTestingConnections({ @@ -130,7 +131,7 @@ describe("mongodb > embedded columns", () => { }))); - + it("should transform entity with nested embedded columns correctly", () => Promise.all(connections.map(async connection => { const postRepository = connection.getMongoRepository(Post); @@ -159,3 +160,5 @@ describe("mongodb > embedded columns", () => { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/mongodb/basic/mongo-embeddeds-index/entity/Information.ts b/test/functional/mongodb/basic/mongo-embeddeds-index/entity/Information.ts index 4cf1fb7f9..c4916f339 100644 --- a/test/functional/mongodb/basic/mongo-embeddeds-index/entity/Information.ts +++ b/test/functional/mongodb/basic/mongo-embeddeds-index/entity/Information.ts @@ -1,13 +1,13 @@ -import {Column} from "../../../../../../src/decorator/columns/Column"; -import {Index} from "../../../../../../src/decorator/Index"; +import {Column} from "../../../../../../src/decorator/columns/Column.ts"; +import {Index} from "../../../../../../src/decorator/Index.ts"; export class Information { - @Column() + @Column({ type: String }) description: string; - @Column() + @Column({ type: Number }) @Index("post_likes") likes: number; -} \ No newline at end of file +} diff --git a/test/functional/mongodb/basic/mongo-embeddeds-index/entity/Post.ts b/test/functional/mongodb/basic/mongo-embeddeds-index/entity/Post.ts index 25d832ef3..8cd63bcc2 100644 --- a/test/functional/mongodb/basic/mongo-embeddeds-index/entity/Post.ts +++ b/test/functional/mongodb/basic/mongo-embeddeds-index/entity/Post.ts @@ -1,9 +1,9 @@ -import {Entity} from "../../../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../../../src/decorator/columns/Column"; -import {ObjectIdColumn} from "../../../../../../src/decorator/columns/ObjectIdColumn"; -import {Index} from "../../../../../../src/decorator/Index"; -import {ObjectID} from "../../../../../../src/driver/mongodb/typings"; -import {Information} from "./Information"; +import {Entity} from "../../../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../../../src/decorator/columns/Column.ts"; +import {ObjectIdColumn} from "../../../../../../src/decorator/columns/ObjectIdColumn.ts"; +import {Index} from "../../../../../../src/decorator/Index.ts"; +import {ObjectID} from "../../../../../../src/driver/mongodb/typings.ts"; +import {Information} from "./Information.ts"; @Entity() @Index("info_description", ["info.description"]) @@ -12,13 +12,13 @@ export class Post { @ObjectIdColumn() id: ObjectID; - @Column() + @Column({ type: String }) title: string; - @Column() + @Column({ type: String }) name: string; @Column(() => Information) info: Information; -} \ No newline at end of file +} diff --git a/test/functional/mongodb/basic/mongo-embeddeds-index/mongo-embeddeds-index.ts b/test/functional/mongodb/basic/mongo-embeddeds-index/mongo-embeddeds-index.ts index ee2b1d9e7..5cccdbf34 100644 --- a/test/functional/mongodb/basic/mongo-embeddeds-index/mongo-embeddeds-index.ts +++ b/test/functional/mongodb/basic/mongo-embeddeds-index/mongo-embeddeds-index.ts @@ -1,11 +1,12 @@ -import "reflect-metadata"; -import {Connection} from "../../../../../src/connection/Connection"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils"; -import {Post} from "./entity/Post"; -import {expect} from "chai"; -import {Information} from "./entity/Information"; +import {Connection} from "../../../../../src/connection/Connection.ts"; +import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils.ts"; +import {Post} from "./entity/Post.ts"; +import {expect} from "../../../../deps/chai.ts"; +import {runIfMain} from "../../../../deps/mocha.ts"; +import {Information} from "./entity/Information.ts"; -describe("mongodb > embeddeds indices", () => { +// TODO(uki00a) Remove `.skip` when MongoDriver is implemented. +describe.skip("mongodb > embeddeds indices", () => { let connections: Connection[]; before(async () => connections = await createTestingConnections({ @@ -33,3 +34,5 @@ describe("mongodb > embeddeds indices", () => { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/mongodb/basic/mongo-index/entity/Post.ts b/test/functional/mongodb/basic/mongo-index/entity/Post.ts index 16923da83..5ac5320e1 100644 --- a/test/functional/mongodb/basic/mongo-index/entity/Post.ts +++ b/test/functional/mongodb/basic/mongo-index/entity/Post.ts @@ -1,8 +1,8 @@ -import {Entity} from "../../../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../../../src/decorator/columns/Column"; -import {ObjectIdColumn} from "../../../../../../src/decorator/columns/ObjectIdColumn"; -import {Index} from "../../../../../../src/decorator/Index"; -import {ObjectID} from "../../../../../../src/driver/mongodb/typings"; +import {Entity} from "../../../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../../../src/decorator/columns/Column.ts"; +import {ObjectIdColumn} from "../../../../../../src/decorator/columns/ObjectIdColumn.ts"; +import {Index} from "../../../../../../src/decorator/Index.ts"; +import {ObjectID} from "../../../../../../src/driver/mongodb/typings.ts"; @Entity() @Index(["title", "name"]) @@ -16,15 +16,15 @@ export class Post { @ObjectIdColumn() id: ObjectID; - @Column() + @Column({ type: String }) @Index() title: string; - @Column() + @Column({ type: String }) @Index() name: string; - @Column() + @Column({ type: Number }) @Index({ unique: true }) count: number; diff --git a/test/functional/mongodb/basic/mongo-index/mongo-index.ts b/test/functional/mongodb/basic/mongo-index/mongo-index.ts index 77bf52fc2..212aa5fb8 100644 --- a/test/functional/mongodb/basic/mongo-index/mongo-index.ts +++ b/test/functional/mongodb/basic/mongo-index/mongo-index.ts @@ -1,10 +1,11 @@ -import "reflect-metadata"; -import {Connection} from "../../../../../src/connection/Connection"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils"; -import {Post} from "./entity/Post"; -import {expect} from "chai"; +import {Connection} from "../../../../../src/connection/Connection.ts"; +import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils.ts"; +import {Post} from "./entity/Post.ts"; +import {expect} from "../../../../deps/chai.ts"; +import {runIfMain} from "../../../../deps/mocha.ts"; -describe("mongodb > indices", () => { +// TODO(uki00a) Remove `.skip` when MongoDriver is implemented. +describe.skip("mongodb > indices", () => { let connections: Connection[]; before(async () => connections = await createTestingConnections({ @@ -30,3 +31,5 @@ describe("mongodb > indices", () => { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/mongodb/basic/mongo-repository/entity/Post.ts b/test/functional/mongodb/basic/mongo-repository/entity/Post.ts index 77bc6df74..cb60eb2a8 100644 --- a/test/functional/mongodb/basic/mongo-repository/entity/Post.ts +++ b/test/functional/mongodb/basic/mongo-repository/entity/Post.ts @@ -1,7 +1,7 @@ -import {Entity} from "../../../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../../../src/decorator/columns/Column"; -import {ObjectIdColumn} from "../../../../../../src/decorator/columns/ObjectIdColumn"; -import {ObjectID} from "../../../../../../src/driver/mongodb/typings"; +import {Entity} from "../../../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../../../src/decorator/columns/Column.ts"; +import {ObjectIdColumn} from "../../../../../../src/decorator/columns/ObjectIdColumn.ts"; +import {ObjectID} from "../../../../../../src/driver/mongodb/typings.ts"; @Entity() export class Post { @@ -9,13 +9,13 @@ export class Post { @ObjectIdColumn() id: ObjectID; - @Column() + @Column({ type: String }) title: string; - @Column() + @Column({ type: String }) text: string; // @Column(() => Counters) // counters: Counters; -} \ No newline at end of file +} diff --git a/test/functional/mongodb/basic/mongo-repository/mongo-repository.ts b/test/functional/mongodb/basic/mongo-repository/mongo-repository.ts index 3d229cd23..6748745d5 100644 --- a/test/functional/mongodb/basic/mongo-repository/mongo-repository.ts +++ b/test/functional/mongodb/basic/mongo-repository/mongo-repository.ts @@ -1,10 +1,12 @@ -import "reflect-metadata"; -import {Connection} from "../../../../../src/connection/Connection"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils"; -import {Post} from "./entity/Post"; -import {MongoRepository} from "../../../../../src/repository/MongoRepository"; +import {Connection} from "../../../../../src/connection/Connection.ts"; +import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils.ts"; +import {Post} from "./entity/Post.ts"; +import {MongoRepository} from "../../../../../src/repository/MongoRepository.ts"; +import "../../../../deps/chai.ts"; +import {runIfMain} from "../../../../deps/mocha.ts"; -describe("mongodb > MongoRepository", () => { +// TODO(uki00a) Remove `.skip` when MongoDriver is implemeneted. +describe.skip("mongodb > MongoRepository", () => { let connections: Connection[]; before(async () => connections = await createTestingConnections({ @@ -89,3 +91,5 @@ describe("mongodb > MongoRepository", () => { // todo: cover other methods as well }); + +runIfMain(import.meta); diff --git a/test/functional/mongodb/basic/object-id/entity/Post.ts b/test/functional/mongodb/basic/object-id/entity/Post.ts index 65bb5ebf9..c8cfee91a 100644 --- a/test/functional/mongodb/basic/object-id/entity/Post.ts +++ b/test/functional/mongodb/basic/object-id/entity/Post.ts @@ -1,7 +1,7 @@ -import { Entity } from "../../../../../../src/decorator/entity/Entity"; -import { Column } from "../../../../../../src/decorator/columns/Column"; -import { ObjectIdColumn } from "../../../../../../src/decorator/columns/ObjectIdColumn"; -import { ObjectID } from "../../../../../../src/driver/mongodb/typings"; +import { Entity } from "../../../../../../src/decorator/entity/Entity.ts"; +import { Column } from "../../../../../../src/decorator/columns/Column.ts"; +import { ObjectIdColumn } from "../../../../../../src/decorator/columns/ObjectIdColumn.ts"; +import { ObjectID } from "../../../../../../src/driver/mongodb/typings.ts"; @Entity() export class Post { @@ -9,6 +9,6 @@ export class Post { @ObjectIdColumn() nonIdNameOfObjectId: ObjectID; - @Column() + @Column({ type: String }) title: string; } diff --git a/test/functional/mongodb/basic/object-id/entity/PostWithUnderscoreId.ts b/test/functional/mongodb/basic/object-id/entity/PostWithUnderscoreId.ts index 0a8b10f7f..0d663b2d8 100644 --- a/test/functional/mongodb/basic/object-id/entity/PostWithUnderscoreId.ts +++ b/test/functional/mongodb/basic/object-id/entity/PostWithUnderscoreId.ts @@ -1,7 +1,7 @@ -import { Entity } from "../../../../../../src/decorator/entity/Entity"; -import { Column } from "../../../../../../src/decorator/columns/Column"; -import { ObjectIdColumn } from "../../../../../../src/decorator/columns/ObjectIdColumn"; -import { ObjectID } from "../../../../../../src/driver/mongodb/typings"; +import { Entity } from "../../../../../../src/decorator/entity/Entity.ts"; +import { Column } from "../../../../../../src/decorator/columns/Column.ts"; +import { ObjectIdColumn } from "../../../../../../src/decorator/columns/ObjectIdColumn.ts"; +import { ObjectID } from "../../../../../../src/driver/mongodb/typings.ts"; @Entity() export class PostWithUnderscoreId { @@ -9,6 +9,6 @@ export class PostWithUnderscoreId { @ObjectIdColumn() _id: ObjectID; - @Column() + @Column({ type: String }) title: string; } diff --git a/test/functional/mongodb/basic/object-id/mongodb-object-id.ts b/test/functional/mongodb/basic/object-id/mongodb-object-id.ts index f78f111c1..15c34b62f 100644 --- a/test/functional/mongodb/basic/object-id/mongodb-object-id.ts +++ b/test/functional/mongodb/basic/object-id/mongodb-object-id.ts @@ -1,12 +1,13 @@ -import "reflect-metadata"; -import { Connection } from "../../../../../src/connection/Connection"; -import { closeTestingConnections, createTestingConnections, reloadTestingDatabases } from "../../../../utils/test-utils"; -import { Post } from "./entity/Post"; -import { PostWithUnderscoreId } from "./entity/PostWithUnderscoreId"; -import { expect } from "chai"; +import { Connection } from "../../../../../src/connection/Connection.ts"; +import { closeTestingConnections, createTestingConnections, reloadTestingDatabases } from "../../../../utils/test-utils.ts"; +import { Post } from "./entity/Post.ts"; +import { PostWithUnderscoreId } from "./entity/PostWithUnderscoreId.ts"; +import { expect } from "../../../../deps/chai.ts"; +import { runIfMain } from "../../../../deps/mocha.ts"; -describe("mongodb > object id columns", () => { +// TODO(uki00a) Remove `.skip` when MongoDriver is implemented. +describe.skip("mongodb > object id columns", () => { let connections: Connection[]; before(async () => connections = await createTestingConnections({ @@ -83,3 +84,5 @@ describe("mongodb > object id columns", () => { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/mongodb/basic/repository-actions/entity/Post.ts b/test/functional/mongodb/basic/repository-actions/entity/Post.ts index 281d15c25..284470e8b 100644 --- a/test/functional/mongodb/basic/repository-actions/entity/Post.ts +++ b/test/functional/mongodb/basic/repository-actions/entity/Post.ts @@ -1,7 +1,7 @@ -import {Entity} from "../../../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../../../src/decorator/columns/Column"; -import {ObjectIdColumn} from "../../../../../../src/decorator/columns/ObjectIdColumn"; -import {ObjectID} from "../../../../../../src/driver/mongodb/typings"; +import {Entity} from "../../../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../../../src/decorator/columns/Column.ts"; +import {ObjectIdColumn} from "../../../../../../src/decorator/columns/ObjectIdColumn.ts"; +import {ObjectID} from "../../../../../../src/driver/mongodb/typings.ts"; @Entity() export class Post { @@ -9,13 +9,13 @@ export class Post { @ObjectIdColumn() id: ObjectID; - @Column() + @Column({ type: String }) title: string; - @Column() + @Column({ type: String }) text: string; - @Column() + @Column({ type: Number }) index: number; // @Column(() => Counters) diff --git a/test/functional/mongodb/basic/repository-actions/mongodb-repository-actions.ts b/test/functional/mongodb/basic/repository-actions/mongodb-repository-actions.ts index 7385ceeaa..cddd764c5 100644 --- a/test/functional/mongodb/basic/repository-actions/mongodb-repository-actions.ts +++ b/test/functional/mongodb/basic/repository-actions/mongodb-repository-actions.ts @@ -1,10 +1,11 @@ -import "reflect-metadata"; -import {expect} from "chai"; -import {Connection} from "../../../../../src/connection/Connection"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils"; -import {Post} from "./entity/Post"; +import {expect} from "../../../../deps/chai.ts"; +import {runIfMain} from "../../../../deps/mocha.ts"; +import {Connection} from "../../../../../src/connection/Connection.ts"; +import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils.ts"; +import {Post} from "./entity/Post.ts"; -describe("mongodb > basic repository actions", () => { +// TODO(uki00a) Remove `.skip` when MongoDriver is implemented. +describe.skip("mongodb > basic repository actions", () => { let connections: Connection[]; before(async () => connections = await createTestingConnections({ @@ -286,3 +287,5 @@ describe("mongodb > basic repository actions", () => { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/mongodb/basic/timestampable-columns/entity/Post.ts b/test/functional/mongodb/basic/timestampable-columns/entity/Post.ts index 72915e37e..1206953f7 100644 --- a/test/functional/mongodb/basic/timestampable-columns/entity/Post.ts +++ b/test/functional/mongodb/basic/timestampable-columns/entity/Post.ts @@ -1,9 +1,9 @@ -import { Entity } from "../../../../../../src/decorator/entity/Entity"; -import { Column } from "../../../../../../src/decorator/columns/Column"; -import { ObjectIdColumn } from "../../../../../../src/decorator/columns/ObjectIdColumn"; -import { ObjectID } from "../../../../../../src/driver/mongodb/typings"; -import { CreateDateColumn } from "../../../../../../src/decorator/columns/CreateDateColumn"; -import { UpdateDateColumn } from "../../../../../../src/decorator/columns/UpdateDateColumn"; +import { Entity } from "../../../../../../src/decorator/entity/Entity.ts"; +import { Column } from "../../../../../../src/decorator/columns/Column.ts"; +import { ObjectIdColumn } from "../../../../../../src/decorator/columns/ObjectIdColumn.ts"; +import { ObjectID } from "../../../../../../src/driver/mongodb/typings.ts"; +import { CreateDateColumn } from "../../../../../../src/decorator/columns/CreateDateColumn.ts"; +import { UpdateDateColumn } from "../../../../../../src/decorator/columns/UpdateDateColumn.ts"; @Entity() export class Post { @@ -11,14 +11,14 @@ export class Post { @ObjectIdColumn() id: ObjectID; - @Column() + @Column({ type: String }) message: string; - @Column() + @Column({ type: Date }) @CreateDateColumn() createdAt: Date; - @Column() + @Column({ type: Date }) @UpdateDateColumn() updatedAt: Date; } diff --git a/test/functional/mongodb/basic/timestampable-columns/timestampable-columns.ts b/test/functional/mongodb/basic/timestampable-columns/timestampable-columns.ts index 7628024ab..5fa43a923 100644 --- a/test/functional/mongodb/basic/timestampable-columns/timestampable-columns.ts +++ b/test/functional/mongodb/basic/timestampable-columns/timestampable-columns.ts @@ -1,14 +1,15 @@ -import "reflect-metadata"; -import {Connection} from "../../../../../src/connection/Connection"; +import {Connection} from "../../../../../src/connection/Connection.ts"; import { closeTestingConnections, createTestingConnections, reloadTestingDatabases -} from "../../../../utils/test-utils"; -import {Post} from "./entity/Post"; -import {expect} from "chai"; +} from "../../../../utils/test-utils.ts"; +import {Post} from "./entity/Post.ts"; +import {expect} from "../../../../deps/chai.ts"; +import {runIfMain} from "../../../../deps/mocha.ts"; -describe("mongodb > timestampable columns", () => { +// TODO(uki00a) Remove `.skip` when MongoDriver is implemented. +describe.skip("mongodb > timestampable columns", () => { let connections: Connection[]; before(async () => connections = await createTestingConnections({ @@ -55,3 +56,4 @@ describe("mongodb > timestampable columns", () => { }); +runIfMain(import.meta); diff --git a/test/functional/multi-schema-and-database/custom-junction-database/custom-junction-database.ts b/test/functional/multi-schema-and-database/custom-junction-database/custom-junction-database.ts index a27b9fa8a..9d45a0c02 100644 --- a/test/functional/multi-schema-and-database/custom-junction-database/custom-junction-database.ts +++ b/test/functional/multi-schema-and-database/custom-junction-database/custom-junction-database.ts @@ -1,10 +1,10 @@ -import "reflect-metadata"; -import {Connection} from "../../../../src/connection/Connection"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils"; -import {Post} from "./entity/Post"; -import {Category} from "./entity/Category"; -import {expect} from "chai"; -import {SqlServerDriver} from "../../../../src/driver/sqlserver/SqlServerDriver"; +import {Connection} from "../../../../src/connection/Connection.ts"; +import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils.ts"; +import {Post} from "./entity/Post.ts"; +import {Category} from "./entity/Category.ts"; +import {expect} from "../../../deps/chai.ts"; +import {runIfMain} from "../../../deps/mocha.ts"; +import {SqlServerDriver} from "../../../../src/driver/sqlserver/SqlServerDriver.ts"; describe("multi-schema-and-database > custom-junction-database", () => { @@ -48,3 +48,5 @@ describe("multi-schema-and-database > custom-junction-database", () => { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/multi-schema-and-database/custom-junction-database/entity/Category.ts b/test/functional/multi-schema-and-database/custom-junction-database/entity/Category.ts index a97f7fd8d..db0f0bd74 100644 --- a/test/functional/multi-schema-and-database/custom-junction-database/entity/Category.ts +++ b/test/functional/multi-schema-and-database/custom-junction-database/entity/Category.ts @@ -1,6 +1,6 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; @Entity({ database: "yoman" @@ -10,7 +10,7 @@ export class Category { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) name: string; -} \ No newline at end of file +} diff --git a/test/functional/multi-schema-and-database/custom-junction-database/entity/Post.ts b/test/functional/multi-schema-and-database/custom-junction-database/entity/Post.ts index 0731b0731..2df80b486 100644 --- a/test/functional/multi-schema-and-database/custom-junction-database/entity/Post.ts +++ b/test/functional/multi-schema-and-database/custom-junction-database/entity/Post.ts @@ -1,9 +1,9 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {ManyToMany} from "../../../../../src/decorator/relations/ManyToMany"; -import {JoinTable} from "../../../../../src/decorator/relations/JoinTable"; -import {Category} from "./Category"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {ManyToMany} from "../../../../../src/decorator/relations/ManyToMany.ts"; +import {JoinTable} from "../../../../../src/decorator/relations/JoinTable.ts"; +import {Category} from "./Category.ts"; @Entity({ database: "yoman" @@ -13,11 +13,11 @@ export class Post { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) name: string; @ManyToMany(type => Category) @JoinTable({ database: "yoman" }) categories: Category[]; -} \ No newline at end of file +} diff --git a/test/functional/multi-schema-and-database/custom-junction-schema/custom-junction-schema.ts b/test/functional/multi-schema-and-database/custom-junction-schema/custom-junction-schema.ts index 98a94dff4..212edadaf 100644 --- a/test/functional/multi-schema-and-database/custom-junction-schema/custom-junction-schema.ts +++ b/test/functional/multi-schema-and-database/custom-junction-schema/custom-junction-schema.ts @@ -1,9 +1,9 @@ -import "reflect-metadata"; -import {Connection} from "../../../../src/connection/Connection"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils"; -import {Post} from "./entity/Post"; -import {Category} from "./entity/Category"; -import {expect} from "chai"; +import {Connection} from "../../../../src/connection/Connection.ts"; +import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils.ts"; +import {Post} from "./entity/Post.ts"; +import {Category} from "./entity/Category.ts"; +import {expect} from "../../../deps/chai.ts"; +import {runIfMain} from "../../../deps/mocha.ts"; describe("multi-schema-and-database > custom-junction-schema", () => { @@ -33,3 +33,5 @@ describe("multi-schema-and-database > custom-junction-schema", () => { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/multi-schema-and-database/custom-junction-schema/entity/Category.ts b/test/functional/multi-schema-and-database/custom-junction-schema/entity/Category.ts index aaa474992..7c19cc713 100644 --- a/test/functional/multi-schema-and-database/custom-junction-schema/entity/Category.ts +++ b/test/functional/multi-schema-and-database/custom-junction-schema/entity/Category.ts @@ -1,6 +1,6 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; @Entity({ schema: "yoman" @@ -10,7 +10,7 @@ export class Category { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) name: string; -} \ No newline at end of file +} diff --git a/test/functional/multi-schema-and-database/custom-junction-schema/entity/Post.ts b/test/functional/multi-schema-and-database/custom-junction-schema/entity/Post.ts index f3face5ee..17e191019 100644 --- a/test/functional/multi-schema-and-database/custom-junction-schema/entity/Post.ts +++ b/test/functional/multi-schema-and-database/custom-junction-schema/entity/Post.ts @@ -1,9 +1,9 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {ManyToMany} from "../../../../../src/decorator/relations/ManyToMany"; -import {JoinTable} from "../../../../../src/decorator/relations/JoinTable"; -import {Category} from "./Category"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {ManyToMany} from "../../../../../src/decorator/relations/ManyToMany.ts"; +import {JoinTable} from "../../../../../src/decorator/relations/JoinTable.ts"; +import {Category} from "./Category.ts"; @Entity({ schema: "yoman" @@ -13,11 +13,11 @@ export class Post { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) name: string; @ManyToMany(type => Category) @JoinTable({ schema: "yoman" }) categories: Category[]; -} \ No newline at end of file +} diff --git a/test/functional/multi-schema-and-database/multi-schema-and-database-basic-functionality/entity/Answer.ts b/test/functional/multi-schema-and-database/multi-schema-and-database-basic-functionality/entity/Answer.ts index ee73042b8..3ebf086a5 100644 --- a/test/functional/multi-schema-and-database/multi-schema-and-database-basic-functionality/entity/Answer.ts +++ b/test/functional/multi-schema-and-database/multi-schema-and-database-basic-functionality/entity/Answer.ts @@ -1,6 +1,6 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; @Entity({ database: "secondDB", schema: "answers" }) export class Answer { @@ -8,10 +8,10 @@ export class Answer { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) text: string; - @Column() + @Column({ type: Number }) questionId: number; -} \ No newline at end of file +} diff --git a/test/functional/multi-schema-and-database/multi-schema-and-database-basic-functionality/entity/Category.ts b/test/functional/multi-schema-and-database/multi-schema-and-database-basic-functionality/entity/Category.ts index 06f9e6958..06be499fc 100644 --- a/test/functional/multi-schema-and-database/multi-schema-and-database-basic-functionality/entity/Category.ts +++ b/test/functional/multi-schema-and-database/multi-schema-and-database-basic-functionality/entity/Category.ts @@ -1,8 +1,8 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {ManyToOne} from "../../../../../src/decorator/relations/ManyToOne"; -import {Post} from "./Post"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {ManyToOne} from "../../../../../src/decorator/relations/ManyToOne.ts"; +import {Post} from "./Post.ts"; @Entity({schema: "guest"}) export class Category { @@ -10,10 +10,10 @@ export class Category { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) name: string; @ManyToOne(type => Post) post: Post; -} \ No newline at end of file +} diff --git a/test/functional/multi-schema-and-database/multi-schema-and-database-basic-functionality/entity/Person.ts b/test/functional/multi-schema-and-database/multi-schema-and-database-basic-functionality/entity/Person.ts index 1a6d24f0b..18a531371 100644 --- a/test/functional/multi-schema-and-database/multi-schema-and-database-basic-functionality/entity/Person.ts +++ b/test/functional/multi-schema-and-database/multi-schema-and-database-basic-functionality/entity/Person.ts @@ -1,6 +1,6 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; @Entity({ database: "secondDB" }) export class Person { @@ -8,7 +8,7 @@ export class Person { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) name: string; -} \ No newline at end of file +} diff --git a/test/functional/multi-schema-and-database/multi-schema-and-database-basic-functionality/entity/Post.ts b/test/functional/multi-schema-and-database/multi-schema-and-database-basic-functionality/entity/Post.ts index 3cb8638bf..0c6953b95 100644 --- a/test/functional/multi-schema-and-database/multi-schema-and-database-basic-functionality/entity/Post.ts +++ b/test/functional/multi-schema-and-database/multi-schema-and-database-basic-functionality/entity/Post.ts @@ -1,6 +1,6 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; @Entity() export class Post { @@ -8,7 +8,7 @@ export class Post { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) name: string; -} \ No newline at end of file +} diff --git a/test/functional/multi-schema-and-database/multi-schema-and-database-basic-functionality/entity/Question.ts b/test/functional/multi-schema-and-database/multi-schema-and-database-basic-functionality/entity/Question.ts index ac583ff9d..2518ac3bc 100644 --- a/test/functional/multi-schema-and-database/multi-schema-and-database-basic-functionality/entity/Question.ts +++ b/test/functional/multi-schema-and-database/multi-schema-and-database-basic-functionality/entity/Question.ts @@ -1,6 +1,6 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; @Entity({ database: "testDB", schema: "questions" }) export class Question { @@ -8,7 +8,7 @@ export class Question { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) name: string; -} \ No newline at end of file +} diff --git a/test/functional/multi-schema-and-database/multi-schema-and-database-basic-functionality/entity/User.ts b/test/functional/multi-schema-and-database/multi-schema-and-database-basic-functionality/entity/User.ts index cf0f09597..83c40b1c9 100644 --- a/test/functional/multi-schema-and-database/multi-schema-and-database-basic-functionality/entity/User.ts +++ b/test/functional/multi-schema-and-database/multi-schema-and-database-basic-functionality/entity/User.ts @@ -1,6 +1,6 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; @Entity({ schema: "userSchema" }) export class User { @@ -8,7 +8,7 @@ export class User { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) name: string; -} \ No newline at end of file +} diff --git a/test/functional/multi-schema-and-database/multi-schema-and-database-basic-functionality/multi-schema-and-database-basic-functionality.ts b/test/functional/multi-schema-and-database/multi-schema-and-database-basic-functionality/multi-schema-and-database-basic-functionality.ts index c6fbdd915..599f34d94 100644 --- a/test/functional/multi-schema-and-database/multi-schema-and-database-basic-functionality/multi-schema-and-database-basic-functionality.ts +++ b/test/functional/multi-schema-and-database/multi-schema-and-database-basic-functionality/multi-schema-and-database-basic-functionality.ts @@ -1,16 +1,17 @@ -import "reflect-metadata"; -import {Connection} from "../../../../src/connection/Connection"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils"; -import {expect} from "chai"; -import {Post} from "./entity/Post"; -import {PostgresDriver} from "../../../../src/driver/postgres/PostgresDriver"; -import {SqlServerDriver} from "../../../../src/driver/sqlserver/SqlServerDriver"; -import {User} from "./entity/User"; -import {Category} from "./entity/Category"; -import {Person} from "./entity/Person"; -import {Question} from "./entity/Question"; -import {Answer} from "./entity/Answer"; -import {MysqlDriver} from "../../../../src/driver/mysql/MysqlDriver"; +import {Connection} from "../../../../src/connection/Connection.ts"; +import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils.ts"; +import {expect} from "../../../deps/chai.ts"; +import {runIfMain} from "../../../deps/mocha.ts"; +import {Post} from "./entity/Post.ts"; +// TODO(uki00a) uncomment this when PostgresDriver is implemented. +// import {PostgresDriver} from "../../../../src/driver/postgres/PostgresDriver.ts"; +import {SqlServerDriver} from "../../../../src/driver/sqlserver/SqlServerDriver.ts"; +import {User} from "./entity/User.ts"; +import {Category} from "./entity/Category.ts"; +import {Person} from "./entity/Person.ts"; +import {Question} from "./entity/Question.ts"; +import {Answer} from "./entity/Answer.ts"; +import {MysqlDriver} from "../../../../src/driver/mysql/MysqlDriver.ts"; describe("multi-schema-and-database > basic-functionality", () => { @@ -41,7 +42,7 @@ describe("multi-schema-and-database > basic-functionality", () => { .where("post.id = :id", {id: 1}) .getSql(); - if (connection.driver instanceof PostgresDriver) + if (false/* connection.driver instanceof PostgresDriver */) // TDOO(uki00a) uncomment this when PostgresDriver is implemented. sql.should.be.equal(`SELECT "post"."id" AS "post_id", "post"."name" AS "post_name" FROM "custom"."post" "post" WHERE "post"."id" = $1`); if (connection.driver instanceof SqlServerDriver) @@ -64,7 +65,7 @@ describe("multi-schema-and-database > basic-functionality", () => { .where("user.id = :id", {id: 1}) .getSql(); - if (connection.driver instanceof PostgresDriver) + if (false/* connection.driver instanceof PostgresDriver */) // TODO(uki00a) uncomment this when PostgresDriver is implemented. sql.should.be.equal(`SELECT "user"."id" AS "user_id", "user"."name" AS "user_name" FROM "userSchema"."user" "user" WHERE "user"."id" = $1`); if (connection.driver instanceof SqlServerDriver) @@ -102,7 +103,7 @@ describe("multi-schema-and-database > basic-functionality", () => { .where("category.id = :id", {id: 1}) .getSql(); - if (connection.driver instanceof PostgresDriver) + if (false/* connection.driver instanceof PostgresDriver */) // TODO(uki00a) uncomment this when PostgresDriver is implemeneted. sql.should.be.equal(`SELECT "category"."id" AS "category_id", "category"."name" AS "category_name",` + ` "category"."postId" AS "category_postId", "post"."id" AS "post_id", "post"."name" AS "post_name"` + ` FROM "guest"."category" "category" INNER JOIN "custom"."post" "post" ON "post"."id"="category"."postId" WHERE "category"."id" = $1`); @@ -140,7 +141,7 @@ describe("multi-schema-and-database > basic-functionality", () => { (await query.getRawOne())!.should.be.not.empty; - if (connection.driver instanceof PostgresDriver) + if (false/* connection.driver instanceof PostgresDriver */) // TODO(uki00a) uncomment this when PostgresDriver is implemented. query.getSql().should.be.equal(`SELECT * FROM "guest"."category" "category", "userSchema"."user" "user",` + ` "custom"."post" "post" WHERE "category"."id" = $1 AND "post"."id" = "category"."postId"`); @@ -257,3 +258,5 @@ describe("multi-schema-and-database > basic-functionality", () => { }); }); + +runIfMain(import.meta); diff --git a/test/functional/persistence/basic-functionality/entity/Category.ts b/test/functional/persistence/basic-functionality/entity/Category.ts index 4d8a48068..a7652c5c1 100644 --- a/test/functional/persistence/basic-functionality/entity/Category.ts +++ b/test/functional/persistence/basic-functionality/entity/Category.ts @@ -1,14 +1,14 @@ -import {Column} from "../../../../../src/decorator/columns/Column"; -import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn"; -import {Entity} from "../../../../../src/decorator/entity/Entity"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn.ts"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; @Entity() export class Category { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; - @Column() + @Column({ type: String }) name: string; constructor(id: number, name: string) { diff --git a/test/functional/persistence/basic-functionality/entity/Post.ts b/test/functional/persistence/basic-functionality/entity/Post.ts index 36c4799ae..e3fd5c99e 100644 --- a/test/functional/persistence/basic-functionality/entity/Post.ts +++ b/test/functional/persistence/basic-functionality/entity/Post.ts @@ -1,14 +1,14 @@ -import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn"; -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../../src/decorator/columns/Column"; +import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn.ts"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; @Entity() export class Post { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; - @Column() + @Column({ type: String }) title: string; constructor(id: number, title: string) { diff --git a/test/functional/persistence/basic-functionality/entity/User.ts b/test/functional/persistence/basic-functionality/entity/User.ts index 944060702..f75db0f6c 100644 --- a/test/functional/persistence/basic-functionality/entity/User.ts +++ b/test/functional/persistence/basic-functionality/entity/User.ts @@ -1,14 +1,14 @@ -import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn"; -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../../src/decorator/columns/Column"; +import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn.ts"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; @Entity() export class User { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; - @Column() + @Column({ type: String }) name: string; constructor(id: number, name: string) { diff --git a/test/functional/persistence/basic-functionality/persistence-basic-functionality.ts b/test/functional/persistence/basic-functionality/persistence-basic-functionality.ts index f0c800e43..e3ccbe7cd 100644 --- a/test/functional/persistence/basic-functionality/persistence-basic-functionality.ts +++ b/test/functional/persistence/basic-functionality/persistence-basic-functionality.ts @@ -1,16 +1,20 @@ -import "reflect-metadata"; -import {Connection} from "../../../../src/connection/Connection"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils"; -import {Post} from "./entity/Post"; -import {Category} from "./entity/Category"; -import {User} from "./entity/User"; +import {join as joinPaths} from "../../../../vendor/https/deno.land/std/path/mod.ts"; +import {Connection} from "../../../../src/connection/Connection.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils.ts"; +import {Post} from "./entity/Post.ts"; +import {Category} from "./entity/Category.ts"; +import {User} from "./entity/User.ts"; +import "../../../deps/chai.ts"; +import {runIfMain} from "../../../deps/mocha.ts"; +import { expect } from "../../../deps/chai.ts"; describe("persistence > basic functionality", function() { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => { connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], }); }); beforeEach(() => reloadTestingDatabases(connections)); @@ -27,24 +31,95 @@ describe("persistence > basic functionality", function() { }))); it("should throw an error when not an object is passed to a save method", () => Promise.all(connections.map(async connection => { - await connection.manager.save(undefined).should.be.rejectedWith(`Cannot save, given value must be an entity, instead "undefined" is given.`); - await connection.manager.save(null).should.be.rejectedWith(`Cannot save, given value must be an entity, instead "null" is given.`); - await connection.manager.save(123).should.be.rejectedWith(`Cannot save, given value must be an entity, instead "123" is given.`); + // TODO(uki00a) Refactor following codes. + try { + await connection.manager.save(undefined); + expect.fail('an error not to be thrown.'); + } catch (err) { + expect(err.message).to.equal(`Cannot save, given value must be an entity, instead "undefined" is given.`); + } + + try { + await connection.manager.save(null); + expect.fail('an error not to be thrown.'); + } catch (err) { + expect(err.message).to.equal(`Cannot save, given value must be an entity, instead "null" is given.`); + } + + try { + await connection.manager.save(123); + expect.fail('an error not to be thrown'); + } catch (err) { + expect(err.message).to.equal(`Cannot save, given value must be an entity, instead "123" is given.`); + } }))); it("should throw an error when not an object is passed to a remove method", () => Promise.all(connections.map(async connection => { - await connection.manager.remove(undefined).should.be.rejectedWith(`Cannot remove, given value must be an entity, instead "undefined" is given.`); - await connection.manager.remove(null).should.be.rejectedWith(`Cannot remove, given value must be an entity, instead "null" is given.`); - await connection.manager.remove(123).should.be.rejectedWith(`Cannot remove, given value must be an entity, instead "123" is given.`); + // TODO(uki00a) Refactor following codes. + try { + await connection.manager.remove(undefined); + expect.fail('an error not to be thrown.'); + } catch (err) { + expect(err.message).to.equal(`Cannot remove, given value must be an entity, instead "undefined" is given.`); + } + + try { + await connection.manager.remove(null); + expect.fail('an error not to be thrown.'); + } catch (err) { + expect(err.message).to.equal(`Cannot remove, given value must be an entity, instead "null" is given.`); + } + + try { + await connection.manager.remove(123); + expect.fail('an error not to be thrown.'); + } catch (err) { + expect(err.message).to.equal(`Cannot remove, given value must be an entity, instead "123" is given.`); + } }))); it("should throw an exception if object literal is given instead of constructed entity because it cannot determine what to save", () => Promise.all(connections.map(async connection => { - await connection.manager.save({}).should.be.rejectedWith(`Cannot save, given value must be instance of entity class, instead object literal is given. Or you must specify an entity target to method call.`); - await connection.manager.save([{}, {}]).should.be.rejectedWith(`Cannot save, given value must be instance of entity class, instead object literal is given. Or you must specify an entity target to method call.`); - await connection.manager.save([new Post(1, "Hello Post"), {}]).should.be.rejectedWith(`Cannot save, given value must be instance of entity class, instead object literal is given. Or you must specify an entity target to method call.`); - await connection.manager.remove({}).should.be.rejectedWith(`Cannot remove, given value must be instance of entity class, instead object literal is given. Or you must specify an entity target to method call.`); - await connection.manager.remove([{}, {}]).should.be.rejectedWith(`Cannot remove, given value must be instance of entity class, instead object literal is given. Or you must specify an entity target to method call.`); - await connection.manager.remove([new Post(1, "Hello Post"), {}]).should.be.rejectedWith(`Cannot remove, given value must be instance of entity class, instead object literal is given. Or you must specify an entity target to method call.`); + // TODO(uki00a) Refactor following codes. + try { + await connection.manager.save({}); + expect.fail('an error not to be thrown.'); + } catch (err) { + expect(err.message).to.equal(`Cannot save, given value must be instance of entity class, instead object literal is given. Or you must specify an entity target to method call.`); + } + + try { + await connection.manager.save([{}, {}]); + expect.fail('an error not to be thrown.'); + } catch (err) { + expect(err.message).to.equal(`Cannot save, given value must be instance of entity class, instead object literal is given. Or you must specify an entity target to method call.`); + } + + try { + await connection.manager.save([new Post(1, "Hello Post"), {}]); + expect.fail('an error not to be thrown.'); + } catch (err) { + expect(err.message).to.equal(`Cannot save, given value must be instance of entity class, instead object literal is given. Or you must specify an entity target to method call.`); + } + + try { + await connection.manager.remove({}); + expect.fail('an error not to be thrown.'); + } catch (err) { + expect(err.message).to.equal(`Cannot remove, given value must be instance of entity class, instead object literal is given. Or you must specify an entity target to method call.`); + } + + try { + await connection.manager.remove([{}, {}]); + expect.fail('an error not to be thrown.'); + } catch (err) { + expect(err.message).to.equal(`Cannot remove, given value must be instance of entity class, instead object literal is given. Or you must specify an entity target to method call.`); + } + + try { + await connection.manager.remove([new Post(1, "Hello Post"), {}]); + } catch (err) { + expect(err.message).to.equal(`Cannot remove, given value must be instance of entity class, instead object literal is given. Or you must specify an entity target to method call.`) + } }))); it("should be able to save and remove entities of different types", () => Promise.all(connections.map(async connection => { @@ -53,14 +128,16 @@ describe("persistence > basic functionality", function() { const user = new User(1, "Hello User"); await connection.manager.save([post, category, user]); - await connection.manager.findOne(Post, 1).should.eventually.eql({ id: 1, title: "Hello Post" }); - await connection.manager.findOne(Category, 1).should.eventually.eql({ id: 1, name: "Hello Category" }); - await connection.manager.findOne(User, 1).should.eventually.eql({ id: 1, name: "Hello User" }); + expect(await connection.manager.findOne(Post, 1)).to.eql({ id: 1, title: "Hello Post" }); + expect(await connection.manager.findOne(Category, 1)).to.eql({ id: 1, name: "Hello Category" }); + expect(await connection.manager.findOne(User, 1)).to.eql({ id: 1, name: "Hello User" }); await connection.manager.remove([post, category, user]); - await connection.manager.findOne(Post, 1).should.eventually.be.undefined; - await connection.manager.findOne(Category, 1).should.eventually.be.undefined; - await connection.manager.findOne(User, 1).should.eventually.be.undefined; + expect(await connection.manager.findOne(Post, 1)).to.be.undefined; + expect(await connection.manager.findOne(Category, 1)).to.be.undefined; + expect(await connection.manager.findOne(User, 1)).to.be.undefined; }))); }); + +runIfMain(import.meta); diff --git a/test/functional/persistence/bulk-insert-remove-optimization/bulk-insert-remove-optimization.ts b/test/functional/persistence/bulk-insert-remove-optimization/bulk-insert-remove-optimization.ts index 9869dbe5f..a2ab83f7d 100644 --- a/test/functional/persistence/bulk-insert-remove-optimization/bulk-insert-remove-optimization.ts +++ b/test/functional/persistence/bulk-insert-remove-optimization/bulk-insert-remove-optimization.ts @@ -1,8 +1,10 @@ -import "reflect-metadata"; -import {Connection} from "../../../../src/connection/Connection"; -import {Post} from "./entity/Post"; -import {Category} from "./entity/Category"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils"; +import {join as joinPaths} from "../../../../vendor/https/deno.land/std/path/mod.ts"; +import {Connection} from "../../../../src/connection/Connection.ts"; +import {Post} from "./entity/Post.ts"; +import {Category} from "./entity/Category.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils.ts"; +import {runIfMain} from "../../../deps/mocha.ts"; + // import {expect} from "chai"; describe("persistence > bulk-insert-remove-optimization", function() { @@ -12,7 +14,8 @@ describe("persistence > bulk-insert-remove-optimization", function() { // ------------------------------------------------------------------------- let connections: Connection[]; - before(async () => connections = await createTestingConnections({ __dirname })); + const __dirname = getDirnameOfCurrentModule(import.meta); + before(async () => connections = await createTestingConnections({ entities: [joinPaths(__dirname, "/entity/*.ts")] })); beforeEach(() => reloadTestingDatabases(connections)); after(() => closeTestingConnections(connections)); @@ -40,3 +43,5 @@ describe("persistence > bulk-insert-remove-optimization", function() { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/persistence/bulk-insert-remove-optimization/entity/Category.ts b/test/functional/persistence/bulk-insert-remove-optimization/entity/Category.ts index 80f1d8ea3..4ed59f233 100644 --- a/test/functional/persistence/bulk-insert-remove-optimization/entity/Category.ts +++ b/test/functional/persistence/bulk-insert-remove-optimization/entity/Category.ts @@ -1,8 +1,8 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Post} from "./Post"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {ManyToMany} from "../../../../../src/decorator/relations/ManyToMany"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Post} from "./Post.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {ManyToMany} from "../../../../../src/decorator/relations/ManyToMany.ts"; @Entity() export class Category { @@ -10,10 +10,10 @@ export class Category { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) name: string; - + @ManyToMany(type => Post, post => post.categories) posts: Post[]; -} \ No newline at end of file +} diff --git a/test/functional/persistence/bulk-insert-remove-optimization/entity/Post.ts b/test/functional/persistence/bulk-insert-remove-optimization/entity/Post.ts index 3e28f3ff7..dffc28a16 100644 --- a/test/functional/persistence/bulk-insert-remove-optimization/entity/Post.ts +++ b/test/functional/persistence/bulk-insert-remove-optimization/entity/Post.ts @@ -1,9 +1,9 @@ -import {Category} from "./Category"; -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {ManyToMany} from "../../../../../src/decorator/relations/ManyToMany"; -import {JoinTable} from "../../../../../src/decorator/relations/JoinTable"; +import {Category} from "./Category.ts"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {ManyToMany} from "../../../../../src/decorator/relations/ManyToMany.ts"; +import {JoinTable} from "../../../../../src/decorator/relations/JoinTable.ts"; @Entity() export class Post { @@ -11,11 +11,11 @@ export class Post { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) title: string; @ManyToMany(type => Category, category => category.posts, { cascade: ["insert"] }) @JoinTable() categories: Category[]; -} \ No newline at end of file +} diff --git a/test/functional/persistence/cascades/cascades-example1/cascades-example1.ts b/test/functional/persistence/cascades/cascades-example1/cascades-example1.ts index 68a7972d5..3061a3973 100644 --- a/test/functional/persistence/cascades/cascades-example1/cascades-example1.ts +++ b/test/functional/persistence/cascades/cascades-example1/cascades-example1.ts @@ -1,15 +1,18 @@ -import "reflect-metadata"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils"; -import {Connection} from "../../../../../src/connection/Connection"; -import {Profile} from "./entity/Profile"; -import {Photo} from "./entity/Photo"; -import {User} from "./entity/User"; +import {join as joinPaths} from "../../../../../vendor/https/deno.land/std/path/mod.ts"; +import "../../../../deps/chai.ts"; +import {runIfMain} from "../../../../deps/mocha.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils.ts"; +import {Connection} from "../../../../../src/connection/Connection.ts"; +import {Profile} from "./entity/Profile.ts"; +import {Photo} from "./entity/Photo.ts"; +import {User} from "./entity/User.ts"; describe("persistence > cascades > example 1", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], })); beforeEach(() => reloadTestingDatabases(connections)); after(() => closeTestingConnections(connections)); @@ -52,3 +55,5 @@ describe("persistence > cascades > example 1", () => { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/persistence/cascades/cascades-example1/entity/Photo.ts b/test/functional/persistence/cascades/cascades-example1/entity/Photo.ts index 041fc88cf..de3d15214 100644 --- a/test/functional/persistence/cascades/cascades-example1/entity/Photo.ts +++ b/test/functional/persistence/cascades/cascades-example1/entity/Photo.ts @@ -1,6 +1,6 @@ -import {Column} from "../../../../../../src/decorator/columns/Column"; -import {Entity} from "../../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../../src/decorator/columns/PrimaryGeneratedColumn"; +import {Column} from "../../../../../../src/decorator/columns/Column.ts"; +import {Entity} from "../../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; @Entity() export class Photo { @@ -8,7 +8,7 @@ export class Photo { @PrimaryGeneratedColumn() id: number; - @Column({ default: "My photo" }) + @Column({ default: "My photo", type: String }) name: string; } diff --git a/test/functional/persistence/cascades/cascades-example1/entity/Profile.ts b/test/functional/persistence/cascades/cascades-example1/entity/Profile.ts index d164c08e1..e8e673fae 100644 --- a/test/functional/persistence/cascades/cascades-example1/entity/Profile.ts +++ b/test/functional/persistence/cascades/cascades-example1/entity/Profile.ts @@ -1,9 +1,9 @@ -import {Entity} from "../../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {User} from "./User"; -import {Photo} from "./Photo"; -import {OneToOne} from "../../../../../../src/decorator/relations/OneToOne"; -import {JoinColumn} from "../../../../../../src/decorator/relations/JoinColumn"; +import {Entity} from "../../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {User} from "./User.ts"; +import {Photo} from "./Photo.ts"; +import {OneToOne} from "../../../../../../src/decorator/relations/OneToOne.ts"; +import {JoinColumn} from "../../../../../../src/decorator/relations/JoinColumn.ts"; @Entity() export class Profile { diff --git a/test/functional/persistence/cascades/cascades-example1/entity/User.ts b/test/functional/persistence/cascades/cascades-example1/entity/User.ts index 22675d59c..4a58968e3 100644 --- a/test/functional/persistence/cascades/cascades-example1/entity/User.ts +++ b/test/functional/persistence/cascades/cascades-example1/entity/User.ts @@ -1,8 +1,8 @@ -import {Column} from "../../../../../../src/decorator/columns/Column"; -import {Entity} from "../../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Profile} from "./Profile"; -import {OneToOne} from "../../../../../../src/decorator/relations/OneToOne"; +import {Column} from "../../../../../../src/decorator/columns/Column.ts"; +import {Entity} from "../../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Profile} from "./Profile.ts"; +import {OneToOne} from "../../../../../../src/decorator/relations/OneToOne.ts"; @Entity() export class User { @@ -10,7 +10,7 @@ export class User { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) name: string; @OneToOne(type => Profile, profile => profile.user, { cascade: ["insert"] }) diff --git a/test/functional/persistence/cascades/cascades-example2/cascades-example2.ts b/test/functional/persistence/cascades/cascades-example2/cascades-example2.ts index b62b32fc9..cabce9f02 100644 --- a/test/functional/persistence/cascades/cascades-example2/cascades-example2.ts +++ b/test/functional/persistence/cascades/cascades-example2/cascades-example2.ts @@ -1,16 +1,19 @@ -import "reflect-metadata"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils"; -import {Connection} from "../../../../../src/connection/Connection"; -import {Question} from "./entity/Question"; -import {Answer} from "./entity/Answer"; -import {Photo} from "./entity/Photo"; -import {User} from "./entity/User"; +import {join as joinPaths} from "../../../../../vendor/https/deno.land/std/path/mod.ts"; +import "../../../../deps/chai.ts"; +import {runIfMain} from "../../../../deps/mocha.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils.ts"; +import {Connection} from "../../../../../src/connection/Connection.ts"; +import {Question} from "./entity/Question.ts"; +import {Answer} from "./entity/Answer.ts"; +import {Photo} from "./entity/Photo.ts"; +import {User} from "./entity/User.ts"; describe("persistence > cascades > example 2", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], })); beforeEach(() => reloadTestingDatabases(connections)); after(() => closeTestingConnections(connections)); @@ -76,3 +79,5 @@ describe("persistence > cascades > example 2", () => { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/persistence/cascades/cascades-example2/entity/Answer.ts b/test/functional/persistence/cascades/cascades-example2/entity/Answer.ts index a50725f89..c69a61782 100644 --- a/test/functional/persistence/cascades/cascades-example2/entity/Answer.ts +++ b/test/functional/persistence/cascades/cascades-example2/entity/Answer.ts @@ -1,9 +1,9 @@ -import {Entity} from "../../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {ManyToOne} from "../../../../../../src/decorator/relations/ManyToOne"; -import {Photo} from "./Photo"; -import {User} from "./User"; -import {Question} from "./Question"; +import {Entity} from "../../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {ManyToOne} from "../../../../../../src/decorator/relations/ManyToOne.ts"; +import {Photo} from "./Photo.ts"; +import {User} from "./User.ts"; +import {Question} from "./Question.ts"; @Entity() export class Answer { diff --git a/test/functional/persistence/cascades/cascades-example2/entity/Photo.ts b/test/functional/persistence/cascades/cascades-example2/entity/Photo.ts index 21fbebaf0..dc99b97ea 100644 --- a/test/functional/persistence/cascades/cascades-example2/entity/Photo.ts +++ b/test/functional/persistence/cascades/cascades-example2/entity/Photo.ts @@ -1,6 +1,6 @@ -import {Column} from "../../../../../../src"; -import {Entity} from "../../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../../src/decorator/columns/PrimaryGeneratedColumn"; +import {Column} from "../../../../../../src/index.ts"; +import {Entity} from "../../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; @Entity() export class Photo { @@ -8,7 +8,7 @@ export class Photo { @PrimaryGeneratedColumn() id: number; - @Column({ default: "My photo" }) + @Column({ default: "My photo", type: String }) name: string; diff --git a/test/functional/persistence/cascades/cascades-example2/entity/Question.ts b/test/functional/persistence/cascades/cascades-example2/entity/Question.ts index 8fda0fc5e..ebca95aa9 100644 --- a/test/functional/persistence/cascades/cascades-example2/entity/Question.ts +++ b/test/functional/persistence/cascades/cascades-example2/entity/Question.ts @@ -1,8 +1,8 @@ -import {Column} from "../../../../../../src"; -import {Entity} from "../../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Answer} from "./Answer"; -import {OneToMany} from "../../../../../../src/decorator/relations/OneToMany"; +import {Column} from "../../../../../../src/index.ts"; +import {Entity} from "../../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Answer} from "./Answer.ts"; +import {OneToMany} from "../../../../../../src/decorator/relations/OneToMany.ts"; @Entity() export class Question { @@ -10,7 +10,7 @@ export class Question { @PrimaryGeneratedColumn() id: number; - @Column({ default: "My question" }) + @Column({ default: "My question", type: String }) name: string; @OneToMany(type => Answer, answer => answer.question, { cascade: ["insert"] }) diff --git a/test/functional/persistence/cascades/cascades-example2/entity/User.ts b/test/functional/persistence/cascades/cascades-example2/entity/User.ts index ea1769689..45debb742 100644 --- a/test/functional/persistence/cascades/cascades-example2/entity/User.ts +++ b/test/functional/persistence/cascades/cascades-example2/entity/User.ts @@ -1,7 +1,7 @@ -import {Entity} from "../../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Question} from "./Question"; -import {ManyToOne} from "../../../../../../src/decorator/relations/ManyToOne"; +import {Entity} from "../../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Question} from "./Question.ts"; +import {ManyToOne} from "../../../../../../src/decorator/relations/ManyToOne.ts"; @Entity() export class User { diff --git a/test/functional/persistence/cascades/cascades-remove/cascades-remove.ts b/test/functional/persistence/cascades/cascades-remove/cascades-remove.ts index 294c1392a..dd9efa2cf 100644 --- a/test/functional/persistence/cascades/cascades-remove/cascades-remove.ts +++ b/test/functional/persistence/cascades/cascades-remove/cascades-remove.ts @@ -1,13 +1,15 @@ -import "reflect-metadata"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils"; -import {Connection} from "../../../../../src/connection/Connection"; -import {Photo} from "./entity/Photo"; -import {User} from "./entity/User"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils.ts"; +import {Connection} from "../../../../../src/connection/Connection.ts"; +import {Photo} from "./entity/Photo.ts"; +import {User} from "./entity/User.ts"; +import "../../../../deps/chai.ts"; +import {runIfMain} from "../../../../deps/mocha.ts"; // todo: fix later describe.skip("persistence > cascades > remove", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => connections = await createTestingConnections({ __dirname, enabledDrivers: ["mysql"] })); beforeEach(() => reloadTestingDatabases(connections)); after(() => closeTestingConnections(connections)); @@ -51,3 +53,5 @@ describe.skip("persistence > cascades > remove", () => { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/persistence/cascades/cascades-remove/entity/Photo.ts b/test/functional/persistence/cascades/cascades-remove/entity/Photo.ts index 5bb8693db..e627c6151 100644 --- a/test/functional/persistence/cascades/cascades-remove/entity/Photo.ts +++ b/test/functional/persistence/cascades/cascades-remove/entity/Photo.ts @@ -1,8 +1,8 @@ -import {Entity} from "../../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {ManyToOne} from "../../../../../../src/decorator/relations/ManyToOne"; -import {User} from "./User"; -import {Column} from "../../../../../../src/decorator/columns/Column"; +import {Entity} from "../../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {ManyToOne} from "../../../../../../src/decorator/relations/ManyToOne.ts"; +import {User} from "./User.ts"; +import {Column} from "../../../../../../src/decorator/columns/Column.ts"; @Entity() export class Photo { @@ -10,7 +10,7 @@ export class Photo { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) name: string; @ManyToOne(type => User, user => user.manyPhotos) @@ -20,4 +20,4 @@ export class Photo { this.name = name; } -} \ No newline at end of file +} diff --git a/test/functional/persistence/cascades/cascades-remove/entity/User.ts b/test/functional/persistence/cascades/cascades-remove/entity/User.ts index b2c928823..66b655908 100644 --- a/test/functional/persistence/cascades/cascades-remove/entity/User.ts +++ b/test/functional/persistence/cascades/cascades-remove/entity/User.ts @@ -1,18 +1,18 @@ -import {PrimaryColumn} from "../../../../../../src/decorator/columns/PrimaryColumn"; -import {Entity} from "../../../../../../src/decorator/entity/Entity"; -import {ManyToMany} from "../../../../../../src/decorator/relations/ManyToMany"; -import {Photo} from "./Photo"; -import {OneToMany} from "../../../../../../src/decorator/relations/OneToMany"; -import {JoinTable} from "../../../../../../src/decorator/relations/JoinTable"; -import {Column} from "../../../../../../src/decorator/columns/Column"; +import {PrimaryColumn} from "../../../../../../src/decorator/columns/PrimaryColumn.ts"; +import {Entity} from "../../../../../../src/decorator/entity/Entity.ts"; +import {ManyToMany} from "../../../../../../src/decorator/relations/ManyToMany.ts"; +import {Photo} from "./Photo.ts"; +import {OneToMany} from "../../../../../../src/decorator/relations/OneToMany.ts"; +import {JoinTable} from "../../../../../../src/decorator/relations/JoinTable.ts"; +import {Column} from "../../../../../../src/decorator/columns/Column.ts"; @Entity() export class User { // todo: check one-to-one relation as well, but in another model or test - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; - @Column() + @Column({ type: String }) name: string; @OneToMany(type => Photo, photo => photo.user, { cascade: true }) diff --git a/test/functional/persistence/custom-column-name-pk/custom-column-name-pk.ts b/test/functional/persistence/custom-column-name-pk/custom-column-name-pk.ts index 757d8c4e4..f7131951d 100644 --- a/test/functional/persistence/custom-column-name-pk/custom-column-name-pk.ts +++ b/test/functional/persistence/custom-column-name-pk/custom-column-name-pk.ts @@ -1,14 +1,17 @@ -import "reflect-metadata"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils"; -import {Connection} from "../../../../src/connection/Connection"; -import {Post} from "./entity/Post"; -import {Category} from "./entity/Category"; +import {join as joinPaths} from "../../../../vendor/https/deno.land/std/path/mod.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils.ts"; +import {Connection} from "../../../../src/connection/Connection.ts"; +import {Post} from "./entity/Post.ts"; +import {Category} from "./entity/Category.ts"; +import {runIfMain} from "../../../deps/mocha.ts"; +import "../../../deps/chai.ts"; describe("persistence > cascade operations with custom name", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], })); beforeEach(() => reloadTestingDatabases(connections)); after(() => closeTestingConnections(connections)); @@ -54,3 +57,5 @@ describe("persistence > cascade operations with custom name", () => { }); }); + +runIfMain(import.meta); diff --git a/test/functional/persistence/custom-column-name-pk/entity/Category.ts b/test/functional/persistence/custom-column-name-pk/entity/Category.ts index 40035d801..6bebee19d 100644 --- a/test/functional/persistence/custom-column-name-pk/entity/Category.ts +++ b/test/functional/persistence/custom-column-name-pk/entity/Category.ts @@ -1,18 +1,18 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {Post} from "./Post"; -import {OneToMany} from "../../../../../src/decorator/relations/OneToMany"; -import {Generated} from "../../../../../src/decorator/Generated"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {Post} from "./Post.ts"; +import {OneToMany} from "../../../../../src/decorator/relations/OneToMany.ts"; +import {Generated} from "../../../../../src/decorator/Generated.ts"; @Entity() export class Category { - @PrimaryColumn({name: "theId"}) + @PrimaryColumn({name: "theId", type: Number}) @Generated() id: number; - @Column() + @Column({ type: String }) name: string; @OneToMany(type => Post, post => post.category, { diff --git a/test/functional/persistence/custom-column-name-pk/entity/Post.ts b/test/functional/persistence/custom-column-name-pk/entity/Post.ts index b3a8b39d7..f2e7372a0 100644 --- a/test/functional/persistence/custom-column-name-pk/entity/Post.ts +++ b/test/functional/persistence/custom-column-name-pk/entity/Post.ts @@ -1,18 +1,18 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {ManyToOne} from "../../../../../src/decorator/relations/ManyToOne"; -import {Category} from "./Category"; -import {Generated} from "../../../../../src/decorator/Generated"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {ManyToOne} from "../../../../../src/decorator/relations/ManyToOne.ts"; +import {Category} from "./Category.ts"; +import {Generated} from "../../../../../src/decorator/Generated.ts"; @Entity() export class Post { - @PrimaryColumn({name: "theId"}) + @PrimaryColumn({name: "theId", type: Number}) @Generated() id: number; - @Column() + @Column({type: String}) title: string; @ManyToOne(type => Category, category => category.posts, { diff --git a/test/functional/persistence/custom-column-names/entity/Category.ts b/test/functional/persistence/custom-column-names/entity/Category.ts index 84e10cf6a..df6ba796e 100644 --- a/test/functional/persistence/custom-column-names/entity/Category.ts +++ b/test/functional/persistence/custom-column-names/entity/Category.ts @@ -1,11 +1,11 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Post} from "./Post"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {OneToMany} from "../../../../../src/decorator/relations/OneToMany"; -import {OneToOne} from "../../../../../src/decorator/relations/OneToOne"; -import {JoinColumn} from "../../../../../src/decorator/relations/JoinColumn"; -import {CategoryMetadata} from "./CategoryMetadata"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Post} from "./Post.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {OneToMany} from "../../../../../src/decorator/relations/OneToMany.ts"; +import {OneToOne} from "../../../../../src/decorator/relations/OneToOne.ts"; +import {JoinColumn} from "../../../../../src/decorator/relations/JoinColumn.ts"; +import {CategoryMetadata} from "./CategoryMetadata.ts"; @Entity() export class Category { @@ -18,14 +18,14 @@ export class Category { @Column({ type: "int", nullable: true }) metadataId: number; - + @OneToOne(type => CategoryMetadata, metadata => metadata.category, { cascade: ["insert"] }) @JoinColumn({ name: "metadataId" }) metadata: CategoryMetadata; - - @Column() + + @Column({ type: String }) name: string; -} \ No newline at end of file +} diff --git a/test/functional/persistence/custom-column-names/entity/CategoryMetadata.ts b/test/functional/persistence/custom-column-names/entity/CategoryMetadata.ts index d2c789056..0c24fc840 100644 --- a/test/functional/persistence/custom-column-names/entity/CategoryMetadata.ts +++ b/test/functional/persistence/custom-column-names/entity/CategoryMetadata.ts @@ -1,19 +1,19 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {OneToOne} from "../../../../../src/decorator/relations/OneToOne"; -import {Category} from "./Category"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {OneToOne} from "../../../../../src/decorator/relations/OneToOne.ts"; +import {Category} from "./Category.ts"; @Entity() export class CategoryMetadata { @PrimaryGeneratedColumn() id: number; - - @Column() + + @Column({ type: String }) keyword: string; @OneToOne(type => Category, category => category.metadata) category: Category; -} \ No newline at end of file +} diff --git a/test/functional/persistence/custom-column-names/entity/Post.ts b/test/functional/persistence/custom-column-names/entity/Post.ts index ff4b865cc..32ff5bc24 100644 --- a/test/functional/persistence/custom-column-names/entity/Post.ts +++ b/test/functional/persistence/custom-column-names/entity/Post.ts @@ -1,9 +1,9 @@ -import {Category} from "./Category"; -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {ManyToOne} from "../../../../../src/decorator/relations/ManyToOne"; -import {JoinColumn} from "../../../../../src/decorator/relations/JoinColumn"; +import {Category} from "./Category.ts"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {ManyToOne} from "../../../../../src/decorator/relations/ManyToOne.ts"; +import {JoinColumn} from "../../../../../src/decorator/relations/JoinColumn.ts"; @Entity() export class Post { @@ -11,7 +11,7 @@ export class Post { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) title: string; @Column("int", { nullable: true }) @@ -23,4 +23,4 @@ export class Post { @JoinColumn({ name: "categoryId" }) category: Category; -} \ No newline at end of file +} diff --git a/test/functional/persistence/custom-column-names/persistence-custom-column-names.ts b/test/functional/persistence/custom-column-names/persistence-custom-column-names.ts index bc597c3e3..8ecfb1c36 100644 --- a/test/functional/persistence/custom-column-names/persistence-custom-column-names.ts +++ b/test/functional/persistence/custom-column-names/persistence-custom-column-names.ts @@ -1,14 +1,16 @@ -import {expect} from "chai"; -import "reflect-metadata"; -import {getConnectionManager} from "../../../../src"; -import {Connection} from "../../../../src/connection/Connection"; -import {Repository} from "../../../../src/repository/Repository"; -import {setupSingleTestingConnection} from "../../../utils/test-utils"; -import {Category} from "./entity/Category"; -import {CategoryMetadata} from "./entity/CategoryMetadata"; -import {Post} from "./entity/Post"; - -describe("persistence > custom-column-names", function() { +import {expect} from "../../../deps/chai.ts"; +import {runIfMain} from "../../../deps/mocha.ts"; +import {getConnectionManager} from "../../../../src/index.ts"; +import {Connection} from "../../../../src/connection/Connection.ts"; +import {Repository} from "../../../../src/repository/Repository.ts"; +import {setupSingleTestingConnection} from "../../../utils/test-utils.ts"; +import {Category} from "./entity/Category.ts"; +import {CategoryMetadata} from "./entity/CategoryMetadata.ts"; +import {Post} from "./entity/Post.ts"; + +// TODO(uki00a) The tests in this file do not appear to run... +// TODO(uki00a) Remove `.skip` when MysqlDriver is implemented. +describe.skip("persistence > custom-column-names", function() { // ------------------------------------------------------------------------- // Configuration @@ -20,6 +22,7 @@ describe("persistence > custom-column-names", function() { const options = setupSingleTestingConnection("mysql", { entities: [Post, Category, CategoryMetadata] }); + console.log(options) if (!options) return; @@ -53,7 +56,7 @@ describe("persistence > custom-column-names", function() { // ------------------------------------------------------------------------- // Specifications // ------------------------------------------------------------------------- - + describe("attach exist entity to exist entity with many-to-one relation", function() { if (!connection) return; @@ -265,3 +268,5 @@ describe("persistence > custom-column-names", function() { }); }); + +runIfMain(import.meta); diff --git a/test/functional/persistence/entity-updation/entity/PostComplex.ts b/test/functional/persistence/entity-updation/entity/PostComplex.ts index 176860b49..58a189fee 100644 --- a/test/functional/persistence/entity-updation/entity/PostComplex.ts +++ b/test/functional/persistence/entity-updation/entity/PostComplex.ts @@ -1,18 +1,18 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {PostEmbedded} from "./PostEmbedded"; -import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {PostEmbedded} from "./PostEmbedded.ts"; +import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn.ts"; @Entity() export class PostComplex { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) firstId: number; - @Column({ default: "Hello Complexity" }) + @Column({ default: "Hello Complexity", type: String }) text: string; @Column(type => PostEmbedded) embed: PostEmbedded; -} \ No newline at end of file +} diff --git a/test/functional/persistence/entity-updation/entity/PostDefaultValues.ts b/test/functional/persistence/entity-updation/entity/PostDefaultValues.ts index de4cc0698..ad165e729 100644 --- a/test/functional/persistence/entity-updation/entity/PostDefaultValues.ts +++ b/test/functional/persistence/entity-updation/entity/PostDefaultValues.ts @@ -1,6 +1,6 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../src/decorator/columns/Column"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; @Entity() export class PostDefaultValues { @@ -8,22 +8,22 @@ export class PostDefaultValues { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) title: string; - @Column({ default: "hello post" }) + @Column({ default: "hello post", type: String }) text: string; - @Column({ default: true }) + @Column({ default: true, type: Boolean }) isActive: boolean; - @Column({ default: () => "CURRENT_TIMESTAMP" }) + @Column({ default: () => "CURRENT_TIMESTAMP", type: Date }) addDate: Date; - @Column({ default: 0 }) + @Column({ default: 0, type: Number }) views: number; - @Column({ nullable: true }) + @Column({ nullable: true, type: String }) description: string; -} \ No newline at end of file +} diff --git a/test/functional/persistence/entity-updation/entity/PostEmbedded.ts b/test/functional/persistence/entity-updation/entity/PostEmbedded.ts index 6c756b1e3..847df1643 100644 --- a/test/functional/persistence/entity-updation/entity/PostEmbedded.ts +++ b/test/functional/persistence/entity-updation/entity/PostEmbedded.ts @@ -1,20 +1,20 @@ -import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn"; -import {UpdateDateColumn} from "../../../../../src/decorator/columns/UpdateDateColumn"; -import {CreateDateColumn} from "../../../../../src/decorator/columns/CreateDateColumn"; -import {VersionColumn} from "../../../../../src/decorator/columns/VersionColumn"; +import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn.ts"; +import {UpdateDateColumn} from "../../../../../src/decorator/columns/UpdateDateColumn.ts"; +import {CreateDateColumn} from "../../../../../src/decorator/columns/CreateDateColumn.ts"; +import {VersionColumn} from "../../../../../src/decorator/columns/VersionColumn.ts"; export class PostEmbedded { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) secondId: number; - @CreateDateColumn() + @CreateDateColumn({ type: Date }) createDate: Date; - @UpdateDateColumn() + @UpdateDateColumn({ type: Date }) updateDate: Date; - @VersionColumn() + @VersionColumn({ type: Number }) version: number; -} \ No newline at end of file +} diff --git a/test/functional/persistence/entity-updation/entity/PostIncrement.ts b/test/functional/persistence/entity-updation/entity/PostIncrement.ts index e2458ab50..0d35cd068 100644 --- a/test/functional/persistence/entity-updation/entity/PostIncrement.ts +++ b/test/functional/persistence/entity-updation/entity/PostIncrement.ts @@ -1,6 +1,6 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; @Entity() export class PostIncrement { @@ -8,7 +8,7 @@ export class PostIncrement { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) text: string; -} \ No newline at end of file +} diff --git a/test/functional/persistence/entity-updation/entity/PostMultiplePrimaryKeys.ts b/test/functional/persistence/entity-updation/entity/PostMultiplePrimaryKeys.ts index 9de48421a..21c50b777 100644 --- a/test/functional/persistence/entity-updation/entity/PostMultiplePrimaryKeys.ts +++ b/test/functional/persistence/entity-updation/entity/PostMultiplePrimaryKeys.ts @@ -1,17 +1,17 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn.ts"; @Entity() export class PostMultiplePrimaryKeys { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) firstId: number; - @PrimaryColumn() + @PrimaryColumn({ type: Number }) secondId: number; - @Column({ default: "Hello Multi Ids" }) + @Column({ default: "Hello Multi Ids", type: String }) text: string; -} \ No newline at end of file +} diff --git a/test/functional/persistence/entity-updation/entity/PostSpecialColumns.ts b/test/functional/persistence/entity-updation/entity/PostSpecialColumns.ts index 257bca71a..e693d3019 100644 --- a/test/functional/persistence/entity-updation/entity/PostSpecialColumns.ts +++ b/test/functional/persistence/entity-updation/entity/PostSpecialColumns.ts @@ -1,9 +1,9 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {CreateDateColumn} from "../../../../../src/decorator/columns/CreateDateColumn"; -import {UpdateDateColumn} from "../../../../../src/decorator/columns/UpdateDateColumn"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {VersionColumn} from "../../../../../src/decorator/columns/VersionColumn"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {CreateDateColumn} from "../../../../../src/decorator/columns/CreateDateColumn.ts"; +import {UpdateDateColumn} from "../../../../../src/decorator/columns/UpdateDateColumn.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {VersionColumn} from "../../../../../src/decorator/columns/VersionColumn.ts"; @Entity() export class PostSpecialColumns { @@ -11,7 +11,7 @@ export class PostSpecialColumns { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) title: string; @CreateDateColumn() @@ -20,7 +20,7 @@ export class PostSpecialColumns { @UpdateDateColumn() updateDate: Date; - @VersionColumn() + @VersionColumn({ type: Number }) version: number; -} \ No newline at end of file +} diff --git a/test/functional/persistence/entity-updation/entity/PostUuid.ts b/test/functional/persistence/entity-updation/entity/PostUuid.ts index 14abd7f43..9816953ca 100644 --- a/test/functional/persistence/entity-updation/entity/PostUuid.ts +++ b/test/functional/persistence/entity-updation/entity/PostUuid.ts @@ -1,6 +1,6 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; @Entity() export class PostUuid { @@ -8,7 +8,7 @@ export class PostUuid { @PrimaryGeneratedColumn("uuid") id: number; - @Column() + @Column({ type: String }) text: string; -} \ No newline at end of file +} diff --git a/test/functional/persistence/entity-updation/persistence-entity-updation.ts b/test/functional/persistence/entity-updation/persistence-entity-updation.ts index b3d91ea39..301b83dc3 100644 --- a/test/functional/persistence/entity-updation/persistence-entity-updation.ts +++ b/test/functional/persistence/entity-updation/persistence-entity-updation.ts @@ -1,20 +1,26 @@ -import "reflect-metadata"; -import {Connection} from "../../../../src/connection/Connection"; -import {CockroachDriver} from "../../../../src/driver/cockroachdb/CockroachDriver"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils"; -import {PostIncrement} from "./entity/PostIncrement"; -import {PostUuid} from "./entity/PostUuid"; -import {PostDefaultValues} from "./entity/PostDefaultValues"; -import {PostSpecialColumns} from "./entity/PostSpecialColumns"; -import {expect} from "chai"; -import {PostMultiplePrimaryKeys} from "./entity/PostMultiplePrimaryKeys"; -import {PostComplex} from "./entity/PostComplex"; -import {PostEmbedded} from "./entity/PostEmbedded"; +import {join as joinPaths} from "../../../../vendor/https/deno.land/std/path/mod.ts"; +import {Connection} from "../../../../src/connection/Connection.ts"; +// TODO(uki00a) uncomment when CockroachDriver is implemented. +// import {CockroachDriver} from "../../../../src/driver/cockroachdb/CockroachDriver.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils.ts"; +import {PostIncrement} from "./entity/PostIncrement.ts"; +import {PostUuid} from "./entity/PostUuid.ts"; +import {PostDefaultValues} from "./entity/PostDefaultValues.ts"; +import {PostSpecialColumns} from "./entity/PostSpecialColumns.ts"; +import {expect} from "../../../deps/chai.ts"; +import {runIfMain} from "../../../deps/mocha.ts"; +import {PostMultiplePrimaryKeys} from "./entity/PostMultiplePrimaryKeys.ts"; +import {PostComplex} from "./entity/PostComplex.ts"; +import {PostEmbedded} from "./entity/PostEmbedded.ts"; describe("persistence > entity updation", () => { let connections: Connection[]; - before(async () => connections = await createTestingConnections({ __dirname })); + const __dirname = getDirnameOfCurrentModule(import.meta); + before(async () => connections = await createTestingConnections({ + entities: [joinPaths(__dirname, "/entity/*.ts")], + enabledDrivers: ["postgres", "mysql", "mssql", "oracle"] // TODO(uki00a) Remove this when deno-sqlite supports `datetime('now')` + })); beforeEach(() => reloadTestingDatabases(connections)); after(() => closeTestingConnections(connections)); @@ -23,7 +29,7 @@ describe("persistence > entity updation", () => { post.text = "Hello Post"; await connection.manager.save(post); // CockroachDB does not use incremental ids - if (!(connection.driver instanceof CockroachDriver)) + if (true/* !(connection.driver instanceof CockroachDriver) */) // TODO(uki00a) uncomment this when CockroachDriver is implemented. post.id.should.be.equal(1); }))); @@ -90,3 +96,5 @@ describe("persistence > entity updation", () => { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/persistence/insert/update-relation-columns-after-insertion/entity/Category.ts b/test/functional/persistence/insert/update-relation-columns-after-insertion/entity/Category.ts index b8f117810..d886fa857 100644 --- a/test/functional/persistence/insert/update-relation-columns-after-insertion/entity/Category.ts +++ b/test/functional/persistence/insert/update-relation-columns-after-insertion/entity/Category.ts @@ -1,8 +1,8 @@ -import {Entity} from "../../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../../src/decorator/columns/Column"; -import {OneToMany} from "../../../../../../src/decorator/relations/OneToMany"; -import {Post} from "./Post"; +import {Entity} from "../../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../../src/decorator/columns/Column.ts"; +import {OneToMany} from "../../../../../../src/decorator/relations/OneToMany.ts"; +import {Post} from "./Post.ts"; @Entity() export class Category { @@ -10,10 +10,10 @@ export class Category { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) name: string; @OneToMany(type => Post, post => post.category) posts: Post[]; -} \ No newline at end of file +} diff --git a/test/functional/persistence/insert/update-relation-columns-after-insertion/entity/Post.ts b/test/functional/persistence/insert/update-relation-columns-after-insertion/entity/Post.ts index e07e624df..5de350154 100644 --- a/test/functional/persistence/insert/update-relation-columns-after-insertion/entity/Post.ts +++ b/test/functional/persistence/insert/update-relation-columns-after-insertion/entity/Post.ts @@ -1,8 +1,8 @@ -import {Entity} from "../../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../../src/decorator/columns/Column"; -import {ManyToOne} from "../../../../../../src/decorator/relations/ManyToOne"; -import {Category} from "./Category"; +import {Entity} from "../../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../../src/decorator/columns/Column.ts"; +import {ManyToOne} from "../../../../../../src/decorator/relations/ManyToOne.ts"; +import {Category} from "./Category.ts"; @Entity() export class Post { @@ -10,10 +10,10 @@ export class Post { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) title: string; @ManyToOne(type => Category, category => category.posts) category: Category; -} \ No newline at end of file +} diff --git a/test/functional/persistence/insert/update-relation-columns-after-insertion/update-relation-columns-after-insertion.ts b/test/functional/persistence/insert/update-relation-columns-after-insertion/update-relation-columns-after-insertion.ts index 367615bc7..1eb5ee6d8 100644 --- a/test/functional/persistence/insert/update-relation-columns-after-insertion/update-relation-columns-after-insertion.ts +++ b/test/functional/persistence/insert/update-relation-columns-after-insertion/update-relation-columns-after-insertion.ts @@ -1,14 +1,17 @@ -import "reflect-metadata"; -import {Post} from "./entity/Post"; -import {Category} from "./entity/Category"; -import {Connection} from "../../../../../src/connection/Connection"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils"; +import {join as joinPaths} from "../../../../../vendor/https/deno.land/std/path/mod.ts"; +import "../../../../deps/chai.ts"; +import {runIfMain} from "../../../../deps/mocha.ts"; +import {Post} from "./entity/Post.ts"; +import {Category} from "./entity/Category.ts"; +import {Connection} from "../../../../../src/connection/Connection.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils.ts"; describe("persistence > insert > update-relation-columns-after-insertion", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], })); beforeEach(() => reloadTestingDatabases(connections)); @@ -32,3 +35,5 @@ describe("persistence > insert > update-relation-columns-after-insertion", () => }))); }); + +runIfMain(import.meta); diff --git a/test/functional/persistence/many-to-many/entity/Category.ts b/test/functional/persistence/many-to-many/entity/Category.ts index 80f1d8ea3..4ed59f233 100644 --- a/test/functional/persistence/many-to-many/entity/Category.ts +++ b/test/functional/persistence/many-to-many/entity/Category.ts @@ -1,8 +1,8 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Post} from "./Post"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {ManyToMany} from "../../../../../src/decorator/relations/ManyToMany"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Post} from "./Post.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {ManyToMany} from "../../../../../src/decorator/relations/ManyToMany.ts"; @Entity() export class Category { @@ -10,10 +10,10 @@ export class Category { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) name: string; - + @ManyToMany(type => Post, post => post.categories) posts: Post[]; -} \ No newline at end of file +} diff --git a/test/functional/persistence/many-to-many/entity/Post.ts b/test/functional/persistence/many-to-many/entity/Post.ts index d5ccb5205..025ba2483 100644 --- a/test/functional/persistence/many-to-many/entity/Post.ts +++ b/test/functional/persistence/many-to-many/entity/Post.ts @@ -1,9 +1,9 @@ -import {Category} from "./Category"; -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {ManyToMany} from "../../../../../src/decorator/relations/ManyToMany"; -import {JoinTable} from "../../../../../src/decorator/relations/JoinTable"; +import {Category} from "./Category.ts"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {ManyToMany} from "../../../../../src/decorator/relations/ManyToMany.ts"; +import {JoinTable} from "../../../../../src/decorator/relations/JoinTable.ts"; @Entity() export class Post { @@ -11,11 +11,11 @@ export class Post { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) title: string; @ManyToMany(type => Category, category => category.posts) @JoinTable() categories: Category[]|null; -} \ No newline at end of file +} diff --git a/test/functional/persistence/many-to-many/entity/User.ts b/test/functional/persistence/many-to-many/entity/User.ts index e256adcb9..6438f4beb 100644 --- a/test/functional/persistence/many-to-many/entity/User.ts +++ b/test/functional/persistence/many-to-many/entity/User.ts @@ -1,8 +1,8 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {ManyToOne} from "../../../../../src/decorator/relations/ManyToOne"; -import {Post} from "./Post"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {ManyToOne} from "../../../../../src/decorator/relations/ManyToOne.ts"; +import {Post} from "./Post.ts"; @Entity() export class User { @@ -10,10 +10,10 @@ export class User { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) name: string; @ManyToOne(type => Post, { cascade: ["update"] }) post: Post; -} \ No newline at end of file +} diff --git a/test/functional/persistence/many-to-many/persistence-many-to-many.ts b/test/functional/persistence/many-to-many/persistence-many-to-many.ts index 03865a63b..acaa060de 100644 --- a/test/functional/persistence/many-to-many/persistence-many-to-many.ts +++ b/test/functional/persistence/many-to-many/persistence-many-to-many.ts @@ -1,10 +1,11 @@ -import "reflect-metadata"; -import {expect} from "chai"; -import {Connection} from "../../../../src/connection/Connection"; -import {Post} from "./entity/Post"; -import {Category} from "./entity/Category"; -import {User} from "./entity/User"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils"; +import {join as joinPaths} from "../../../../vendor/https/deno.land/std/path/mod.ts"; +import {expect} from "../../../deps/chai.ts"; +import {runIfMain} from "../../../deps/mocha.ts"; +import {Connection} from "../../../../src/connection/Connection.ts"; +import {Post} from "./entity/Post.ts"; +import {Category} from "./entity/Category.ts"; +import {User} from "./entity/User.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils.ts"; describe("persistence > many-to-many", function() { @@ -13,14 +14,15 @@ describe("persistence > many-to-many", function() { // ------------------------------------------------------------------------- let connections: Connection[]; - before(async () => connections = await createTestingConnections({ __dirname })); + const __dirname = getDirnameOfCurrentModule(import.meta); + before(async () => connections = await createTestingConnections({ entities: [joinPaths(__dirname, "/entity/*.ts")] })); beforeEach(() => reloadTestingDatabases(connections)); after(() => closeTestingConnections(connections)); // ------------------------------------------------------------------------- // Specifications // ------------------------------------------------------------------------- - + it("add exist element to exist object with empty many-to-many relation and save it and it should contain a new category", () => Promise.all(connections.map(async connection => { const postRepository = connection.getRepository(Post); @@ -276,3 +278,5 @@ describe("persistence > many-to-many", function() { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/persistence/many-to-one-bi-directional/entity/Category.ts b/test/functional/persistence/many-to-one-bi-directional/entity/Category.ts index b67bc6ae5..b2f5a9134 100644 --- a/test/functional/persistence/many-to-one-bi-directional/entity/Category.ts +++ b/test/functional/persistence/many-to-one-bi-directional/entity/Category.ts @@ -1,16 +1,16 @@ -import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn"; -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {ManyToOne} from "../../../../../src/decorator/relations/ManyToOne"; -import {Post} from "./Post"; +import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn.ts"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {ManyToOne} from "../../../../../src/decorator/relations/ManyToOne.ts"; +import {Post} from "./Post.ts"; @Entity() export class Category { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; - @Column() + @Column({ type: String }) name: string; @ManyToOne(type => Post, post => post.categories, { diff --git a/test/functional/persistence/many-to-one-bi-directional/entity/Post.ts b/test/functional/persistence/many-to-one-bi-directional/entity/Post.ts index 961fc75b1..5248f8aaf 100644 --- a/test/functional/persistence/many-to-one-bi-directional/entity/Post.ts +++ b/test/functional/persistence/many-to-one-bi-directional/entity/Post.ts @@ -1,16 +1,16 @@ -import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn"; -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {Category} from "./Category"; -import {OneToMany} from "../../../../../src/decorator/relations/OneToMany"; +import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn.ts"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {Category} from "./Category.ts"; +import {OneToMany} from "../../../../../src/decorator/relations/OneToMany.ts"; @Entity() export class Post { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; - @Column() + @Column({ type: String }) title: string; @OneToMany(type => Category, category => category.post) diff --git a/test/functional/persistence/many-to-one-bi-directional/persistence-many-to-one-bi-directional.ts b/test/functional/persistence/many-to-one-bi-directional/persistence-many-to-one-bi-directional.ts index 47754a72e..000ff70de 100644 --- a/test/functional/persistence/many-to-one-bi-directional/persistence-many-to-one-bi-directional.ts +++ b/test/functional/persistence/many-to-one-bi-directional/persistence-many-to-one-bi-directional.ts @@ -1,16 +1,18 @@ -import "reflect-metadata"; -import {Connection} from "../../../../src/connection/Connection"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils"; -import {Post} from "./entity/Post"; -import {Category} from "./entity/Category"; -import {expect} from "chai"; +import {join as joinPaths} from "../../../../vendor/https/deno.land/std/path/mod.ts"; +import {Connection} from "../../../../src/connection/Connection.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils.ts"; +import {Post} from "./entity/Post.ts"; +import {Category} from "./entity/Category.ts"; +import {expect} from "../../../deps/chai.ts"; +import {runIfMain} from "../../../deps/mocha.ts"; describe("persistence > many-to-one bi-directional relation", function() { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => { connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], }); }); beforeEach(() => reloadTestingDatabases(connections)); @@ -167,3 +169,5 @@ describe("persistence > many-to-one bi-directional relation", function() { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/persistence/many-to-one-uni-directional/entity/Category.ts b/test/functional/persistence/many-to-one-uni-directional/entity/Category.ts index 10eb98fee..8819fb48c 100644 --- a/test/functional/persistence/many-to-one-uni-directional/entity/Category.ts +++ b/test/functional/persistence/many-to-one-uni-directional/entity/Category.ts @@ -1,16 +1,16 @@ -import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn"; -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {ManyToOne} from "../../../../../src/decorator/relations/ManyToOne"; -import {Post} from "./Post"; +import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn.ts"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {ManyToOne} from "../../../../../src/decorator/relations/ManyToOne.ts"; +import {Post} from "./Post.ts"; @Entity() export class Category { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; - @Column() + @Column({ type: String }) name: string; @ManyToOne(type => Post, { diff --git a/test/functional/persistence/many-to-one-uni-directional/entity/Post.ts b/test/functional/persistence/many-to-one-uni-directional/entity/Post.ts index 36c4799ae..e3fd5c99e 100644 --- a/test/functional/persistence/many-to-one-uni-directional/entity/Post.ts +++ b/test/functional/persistence/many-to-one-uni-directional/entity/Post.ts @@ -1,14 +1,14 @@ -import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn"; -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../../src/decorator/columns/Column"; +import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn.ts"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; @Entity() export class Post { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; - @Column() + @Column({ type: String }) title: string; constructor(id: number, title: string) { diff --git a/test/functional/persistence/many-to-one-uni-directional/persistence-many-to-one-uni-directional.ts b/test/functional/persistence/many-to-one-uni-directional/persistence-many-to-one-uni-directional.ts index 6c003163c..45d3aa97a 100644 --- a/test/functional/persistence/many-to-one-uni-directional/persistence-many-to-one-uni-directional.ts +++ b/test/functional/persistence/many-to-one-uni-directional/persistence-many-to-one-uni-directional.ts @@ -1,16 +1,18 @@ -import "reflect-metadata"; -import {Connection} from "../../../../src/connection/Connection"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils"; -import {Post} from "./entity/Post"; -import {Category} from "./entity/Category"; -import {expect} from "chai"; +import {join as joinPaths} from "../../../../vendor/https/deno.land/std/path/mod.ts"; +import {Connection} from "../../../../src/connection/Connection.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils.ts"; +import {Post} from "./entity/Post.ts"; +import {Category} from "./entity/Category.ts"; +import {expect} from "../../../deps/chai.ts"; +import {runIfMain} from "../../../deps/mocha.ts"; describe("persistence > many-to-one uni-directional relation", function() { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => { connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], }); }); beforeEach(() => reloadTestingDatabases(connections)); @@ -167,3 +169,5 @@ describe("persistence > many-to-one uni-directional relation", function() { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/persistence/multi-primary-key-on-both-sides/entity/Category.ts b/test/functional/persistence/multi-primary-key-on-both-sides/entity/Category.ts index 8335f6a14..46c5c486e 100644 --- a/test/functional/persistence/multi-primary-key-on-both-sides/entity/Category.ts +++ b/test/functional/persistence/multi-primary-key-on-both-sides/entity/Category.ts @@ -1,17 +1,17 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {Post} from "./Post"; -import {OneToMany} from "../../../../../src/decorator/relations/OneToMany"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {Post} from "./Post.ts"; +import {OneToMany} from "../../../../../src/decorator/relations/OneToMany.ts"; @Entity() export class Category { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) categoryId: number; - @Column() + @Column({ type: String }) name: string; @OneToMany(type => Post, post => post.category) diff --git a/test/functional/persistence/multi-primary-key-on-both-sides/entity/Post.ts b/test/functional/persistence/multi-primary-key-on-both-sides/entity/Post.ts index d6d61c34c..bb87cad74 100644 --- a/test/functional/persistence/multi-primary-key-on-both-sides/entity/Post.ts +++ b/test/functional/persistence/multi-primary-key-on-both-sides/entity/Post.ts @@ -1,19 +1,19 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {ManyToOne} from "../../../../../src/decorator/relations/ManyToOne"; -import {Category} from "./Category"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {ManyToOne} from "../../../../../src/decorator/relations/ManyToOne.ts"; +import {Category} from "./Category.ts"; @Entity() export class Post { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) firstId: number; - @PrimaryColumn() + @PrimaryColumn({ type: Number }) secondId: number; - @Column() + @Column({ type: String }) title: string; @ManyToOne(type => Category, category => category.posts) diff --git a/test/functional/persistence/multi-primary-key-on-both-sides/multi-primary-key.ts b/test/functional/persistence/multi-primary-key-on-both-sides/multi-primary-key.ts index 6ce5fb26a..e4da23a1e 100644 --- a/test/functional/persistence/multi-primary-key-on-both-sides/multi-primary-key.ts +++ b/test/functional/persistence/multi-primary-key-on-both-sides/multi-primary-key.ts @@ -1,14 +1,17 @@ -import "reflect-metadata"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils"; -import {Connection} from "../../../../src/connection/Connection"; -import {Post} from "./entity/Post"; -import {Category} from "./entity/Category"; +import {join as joinPaths} from "../../../../vendor/https/deno.land/std/path/mod.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils.ts"; +import {Connection} from "../../../../src/connection/Connection.ts"; +import {Post} from "./entity/Post.ts"; +import {Category} from "./entity/Category.ts"; +import "../../../deps/chai.ts"; +import {runIfMain} from "../../../deps/mocha.ts"; describe("persistence > multi primary keys", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], })); beforeEach(() => reloadTestingDatabases(connections)); after(() => closeTestingConnections(connections)); @@ -56,3 +59,5 @@ describe("persistence > multi primary keys", () => { }))); }); }); + +runIfMain(import.meta); diff --git a/test/functional/persistence/multi-primary-key/entity/Category.ts b/test/functional/persistence/multi-primary-key/entity/Category.ts index c2dc70bb7..8805a4843 100644 --- a/test/functional/persistence/multi-primary-key/entity/Category.ts +++ b/test/functional/persistence/multi-primary-key/entity/Category.ts @@ -1,9 +1,9 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {Post} from "./Post"; -import {OneToMany} from "../../../../../src/decorator/relations/OneToMany"; -import {Generated} from "../../../../../src/decorator/Generated"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {Post} from "./Post.ts"; +import {OneToMany} from "../../../../../src/decorator/relations/OneToMany.ts"; +import {Generated} from "../../../../../src/decorator/Generated.ts"; @Entity() @@ -13,10 +13,10 @@ export class Category { @Generated() categoryId: number; - @Column() + @Column({ type: String }) name: string; @OneToMany(type => Post, post => post.category) posts: Post[]; -} \ No newline at end of file +} diff --git a/test/functional/persistence/multi-primary-key/entity/Post.ts b/test/functional/persistence/multi-primary-key/entity/Post.ts index d6d61c34c..bb87cad74 100644 --- a/test/functional/persistence/multi-primary-key/entity/Post.ts +++ b/test/functional/persistence/multi-primary-key/entity/Post.ts @@ -1,19 +1,19 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {ManyToOne} from "../../../../../src/decorator/relations/ManyToOne"; -import {Category} from "./Category"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {ManyToOne} from "../../../../../src/decorator/relations/ManyToOne.ts"; +import {Category} from "./Category.ts"; @Entity() export class Post { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) firstId: number; - @PrimaryColumn() + @PrimaryColumn({ type: Number }) secondId: number; - @Column() + @Column({ type: String }) title: string; @ManyToOne(type => Category, category => category.posts) diff --git a/test/functional/persistence/multi-primary-key/multi-primary-key.ts b/test/functional/persistence/multi-primary-key/multi-primary-key.ts index c6f1c8b46..27cc9ea60 100644 --- a/test/functional/persistence/multi-primary-key/multi-primary-key.ts +++ b/test/functional/persistence/multi-primary-key/multi-primary-key.ts @@ -1,14 +1,17 @@ -import "reflect-metadata"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils"; -import {Connection} from "../../../../src/connection/Connection"; -import {Post} from "./entity/Post"; -import {Category} from "./entity/Category"; +import {join as joinPaths} from "../../../../vendor/https/deno.land/std/path/mod.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils.ts"; +import {Connection} from "../../../../src/connection/Connection.ts"; +import {Post} from "./entity/Post.ts"; +import {Category} from "./entity/Category.ts"; +import "../../../deps/chai.ts"; +import {runIfMain} from "../../../deps/mocha.ts"; describe("persistence > multi primary keys", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], })); beforeEach(() => reloadTestingDatabases(connections)); after(() => closeTestingConnections(connections)); @@ -63,3 +66,5 @@ describe("persistence > multi primary keys", () => { }))); }); }); + +runIfMain(import.meta); diff --git a/test/functional/persistence/null-and-default-behaviour/entity/Post.ts b/test/functional/persistence/null-and-default-behaviour/entity/Post.ts index 868ae48b6..b193487ee 100644 --- a/test/functional/persistence/null-and-default-behaviour/entity/Post.ts +++ b/test/functional/persistence/null-and-default-behaviour/entity/Post.ts @@ -1,11 +1,11 @@ -import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn"; -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../../src/decorator/columns/Column"; +import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn.ts"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; @Entity() export class Post { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; @Column({ type: String, default: "hello default value", nullable: true }) diff --git a/test/functional/persistence/null-and-default-behaviour/null-and-default-behaviour.ts b/test/functional/persistence/null-and-default-behaviour/null-and-default-behaviour.ts index 7a621f57d..55847ddde 100644 --- a/test/functional/persistence/null-and-default-behaviour/null-and-default-behaviour.ts +++ b/test/functional/persistence/null-and-default-behaviour/null-and-default-behaviour.ts @@ -1,14 +1,16 @@ -import "reflect-metadata"; -import {Connection} from "../../../../src/connection/Connection"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils"; -import {Post} from "./entity/Post"; -import {expect} from "chai"; +import {join as joinPaths} from "../../../../vendor/https/deno.land/std/path/mod.ts"; +import {Connection} from "../../../../src/connection/Connection.ts"; +import {closeTestingConnections, createTestingConnections, reloadTestingDatabases, getDirnameOfCurrentModule} from "../../../utils/test-utils.ts"; +import {Post} from "./entity/Post.ts"; +import {expect} from "../../../deps/chai.ts"; +import {runIfMain} from "../../../deps/mocha.ts"; describe("persistence > null and default behaviour", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], })); beforeEach(() => reloadTestingDatabases(connections)); @@ -104,3 +106,5 @@ describe("persistence > null and default behaviour", () => { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/persistence/one-to-many/entity/Category.ts b/test/functional/persistence/one-to-many/entity/Category.ts index ecc4d78e8..77150f3a0 100644 --- a/test/functional/persistence/one-to-many/entity/Category.ts +++ b/test/functional/persistence/one-to-many/entity/Category.ts @@ -1,8 +1,8 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {ManyToOne} from "../../../../../src/decorator/relations/ManyToOne"; -import {Post} from "./Post"; -import {Column} from "../../../../../src/decorator/columns/Column"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {ManyToOne} from "../../../../../src/decorator/relations/ManyToOne.ts"; +import {Post} from "./Post.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; @Entity() export class Category { @@ -12,8 +12,8 @@ export class Category { @ManyToOne(type => Post, post => post.categories) post: Post; - - @Column() + + @Column({ type: String }) name: string; -} \ No newline at end of file +} diff --git a/test/functional/persistence/one-to-many/entity/Post.ts b/test/functional/persistence/one-to-many/entity/Post.ts index 546d0bd33..e7e6028d7 100644 --- a/test/functional/persistence/one-to-many/entity/Post.ts +++ b/test/functional/persistence/one-to-many/entity/Post.ts @@ -1,8 +1,8 @@ -import {Category} from "./Category"; -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {OneToMany} from "../../../../../src/decorator/relations/OneToMany"; -import {Column} from "../../../../../src/decorator/columns/Column"; +import {Category} from "./Category.ts"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {OneToMany} from "../../../../../src/decorator/relations/OneToMany.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; @Entity() export class Post { @@ -14,8 +14,9 @@ export class Post { categories: Category[]|null; @Column({ + type: String, default: "supervalue" }) title: string; -} \ No newline at end of file +} diff --git a/test/functional/persistence/one-to-many/persistence-one-to-many.ts b/test/functional/persistence/one-to-many/persistence-one-to-many.ts index 8546f74cb..f741f4a21 100644 --- a/test/functional/persistence/one-to-many/persistence-one-to-many.ts +++ b/test/functional/persistence/one-to-many/persistence-one-to-many.ts @@ -1,9 +1,9 @@ -import "reflect-metadata"; -import {expect} from "chai"; -import {Connection} from "../../../../src/connection/Connection"; -import {Post} from "./entity/Post"; -import {Category} from "./entity/Category"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils"; +import {expect} from "../../../deps/chai.ts"; +import {runIfMain} from "../../../deps/mocha.ts"; +import {Connection} from "../../../../src/connection/Connection.ts"; +import {Post} from "./entity/Post.ts"; +import {Category} from "./entity/Category.ts"; +import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils.ts"; describe("persistence > one-to-many", function() { @@ -171,3 +171,5 @@ describe("persistence > one-to-many", function() { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/persistence/one-to-one/entity/AccessToken.ts b/test/functional/persistence/one-to-one/entity/AccessToken.ts index 02801977f..ca30fd3b2 100644 --- a/test/functional/persistence/one-to-one/entity/AccessToken.ts +++ b/test/functional/persistence/one-to-one/entity/AccessToken.ts @@ -1,9 +1,9 @@ -import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn"; -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {JoinColumn} from "../../../../../src/decorator/relations/JoinColumn"; -import {OneToOne} from "../../../../../src/decorator/relations/OneToOne"; -import {User} from "./User"; -import {Generated} from "../../../../../src/decorator/Generated"; +import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn.ts"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {JoinColumn} from "../../../../../src/decorator/relations/JoinColumn.ts"; +import {OneToOne} from "../../../../../src/decorator/relations/OneToOne.ts"; +import {User} from "./User.ts"; +import {Generated} from "../../../../../src/decorator/Generated.ts"; @Entity() export class AccessToken { diff --git a/test/functional/persistence/one-to-one/entity/User.ts b/test/functional/persistence/one-to-one/entity/User.ts index 442b7f37d..c0ac49031 100644 --- a/test/functional/persistence/one-to-one/entity/User.ts +++ b/test/functional/persistence/one-to-one/entity/User.ts @@ -1,9 +1,9 @@ -import {AccessToken} from "./AccessToken"; -import {OneToOne} from "../../../../../src/decorator/relations/OneToOne"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn"; -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {Generated} from "../../../../../src/decorator/Generated"; +import {AccessToken} from "./AccessToken.ts"; +import {OneToOne} from "../../../../../src/decorator/relations/OneToOne.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn.ts"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {Generated} from "../../../../../src/decorator/Generated.ts"; @Entity() export class User { @@ -12,7 +12,7 @@ export class User { @Generated() primaryKey: number; - @Column() + @Column({ type: String }) email: string; @OneToOne(type => AccessToken, token => token.user) diff --git a/test/functional/persistence/one-to-one/persistence-one-to-one.ts b/test/functional/persistence/one-to-one/persistence-one-to-one.ts index 285b5d189..c678ca0a1 100644 --- a/test/functional/persistence/one-to-one/persistence-one-to-one.ts +++ b/test/functional/persistence/one-to-one/persistence-one-to-one.ts @@ -1,9 +1,9 @@ -import "reflect-metadata"; -import {expect} from "chai"; -import {Connection} from "../../../../src/connection/Connection"; -import {User} from "./entity/User"; -import {AccessToken} from "./entity/AccessToken"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils"; +import {expect} from "../../../deps/chai.ts"; +import {runIfMain} from "../../../deps/mocha.ts"; +import {Connection} from "../../../../src/connection/Connection.ts"; +import {User} from "./entity/User.ts"; +import {AccessToken} from "./entity/AccessToken.ts"; +import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils.ts"; describe("persistence > one-to-one", function() { @@ -82,3 +82,5 @@ describe("persistence > one-to-one", function() { }); }); + +runIfMain(import.meta); diff --git a/test/functional/persistence/partial-persist/entity/Category.ts b/test/functional/persistence/partial-persist/entity/Category.ts index 9b19c4a3a..3431b6262 100644 --- a/test/functional/persistence/partial-persist/entity/Category.ts +++ b/test/functional/persistence/partial-persist/entity/Category.ts @@ -1,21 +1,21 @@ -import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn"; -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {Post} from "./Post"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {ManyToMany} from "../../../../../src/decorator/relations/ManyToMany"; +import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn.ts"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {Post} from "./Post.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {ManyToMany} from "../../../../../src/decorator/relations/ManyToMany.ts"; @Entity() export class Category { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; - @Column() + @Column({ type: String }) name: string; - @Column() + @Column({ type: Number }) position: number; - + @ManyToMany(type => Post, post => post.categories) posts: Post[]; diff --git a/test/functional/persistence/partial-persist/entity/Counters.ts b/test/functional/persistence/partial-persist/entity/Counters.ts index 43c9b3446..f5cdcbbe3 100644 --- a/test/functional/persistence/partial-persist/entity/Counters.ts +++ b/test/functional/persistence/partial-persist/entity/Counters.ts @@ -1,14 +1,14 @@ -import {Column} from "../../../../../src/decorator/columns/Column"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; export class Counters { - @Column() + @Column({ type: Number }) stars: number; - @Column() + @Column({ type: Number }) commentCount: number; - @Column() + @Column({ type: String }) metadata: string; -} \ No newline at end of file +} diff --git a/test/functional/persistence/partial-persist/entity/Post.ts b/test/functional/persistence/partial-persist/entity/Post.ts index 23b97f49e..85ffdafac 100644 --- a/test/functional/persistence/partial-persist/entity/Post.ts +++ b/test/functional/persistence/partial-persist/entity/Post.ts @@ -1,21 +1,21 @@ -import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn"; -import {Category} from "./Category"; -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {ManyToMany} from "../../../../../src/decorator/relations/ManyToMany"; -import {JoinTable} from "../../../../../src/decorator/relations/JoinTable"; -import {Counters} from "./Counters"; +import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn.ts"; +import {Category} from "./Category.ts"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {ManyToMany} from "../../../../../src/decorator/relations/ManyToMany.ts"; +import {JoinTable} from "../../../../../src/decorator/relations/JoinTable.ts"; +import {Counters} from "./Counters.ts"; @Entity() export class Post { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; - @Column() + @Column({ type: String }) title: string; - @Column() + @Column({ type: String }) description: string; @Column(type => Counters) diff --git a/test/functional/persistence/partial-persist/partial-persist.ts b/test/functional/persistence/partial-persist/partial-persist.ts index 26ca3ddee..53013d105 100644 --- a/test/functional/persistence/partial-persist/partial-persist.ts +++ b/test/functional/persistence/partial-persist/partial-persist.ts @@ -1,10 +1,11 @@ -import "reflect-metadata"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils"; -import {Connection} from "../../../../src/connection/Connection"; -import {Post} from "./entity/Post"; -import {Category} from "./entity/Category"; -import {expect} from "chai"; -import {Counters} from "./entity/Counters"; +import {join as joinPaths} from "../../../../vendor/https/deno.land/std/path/mod.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils.ts"; +import {Connection} from "../../../../src/connection/Connection.ts"; +import {Post} from "./entity/Post.ts"; +import {Category} from "./entity/Category.ts"; +import {expect} from "../../../deps/chai.ts"; +import {runIfMain} from "../../../deps/mocha.ts"; +import {Counters} from "./entity/Counters.ts"; describe("persistence > partial persist", () => { @@ -13,8 +14,9 @@ describe("persistence > partial persist", () => { // ------------------------------------------------------------------------- let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], })); beforeEach(() => reloadTestingDatabases(connections)); after(() => closeTestingConnections(connections)); @@ -139,3 +141,5 @@ describe("persistence > partial persist", () => { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/persistence/persistence-options/chunks/entity/Post.ts b/test/functional/persistence/persistence-options/chunks/entity/Post.ts index 02719a6f8..37dfa5b2a 100644 --- a/test/functional/persistence/persistence-options/chunks/entity/Post.ts +++ b/test/functional/persistence/persistence-options/chunks/entity/Post.ts @@ -1,6 +1,6 @@ -import {Entity} from "../../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../../src/decorator/columns/Column"; +import {Entity} from "../../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../../src/decorator/columns/Column.ts"; @Entity() export class Post { @@ -8,10 +8,10 @@ export class Post { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) title: string; - @Column() + @Column({ type: String }) description: string; -} \ No newline at end of file +} diff --git a/test/functional/persistence/persistence-options/chunks/persistence-options-chunks.ts b/test/functional/persistence/persistence-options/chunks/persistence-options-chunks.ts index 8dbdd7569..49fe70859 100644 --- a/test/functional/persistence/persistence-options/chunks/persistence-options-chunks.ts +++ b/test/functional/persistence/persistence-options/chunks/persistence-options-chunks.ts @@ -1,7 +1,8 @@ -import "reflect-metadata"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils"; -import {Post} from "./entity/Post"; -import {Connection} from "../../../../../src/connection/Connection"; +import {join as joinPaths} from "../../../../../vendor/https/deno.land/std/path/mod.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils.ts"; +import {Post} from "./entity/Post.ts"; +import {Connection} from "../../../../../src/connection/Connection.ts"; +import {runIfMain} from "../../../../deps/mocha.ts"; describe("persistence > persistence options > chunks", () => { @@ -10,7 +11,8 @@ describe("persistence > persistence options > chunks", () => { // ------------------------------------------------------------------------- let connections: Connection[]; - before(async () => connections = await createTestingConnections({ __dirname, enabledDrivers: ["postgres"] })); + const __dirname = getDirnameOfCurrentModule(import.meta); + before(async () => connections = await createTestingConnections({ entities: [joinPaths(__dirname, "/entity/*.ts")], enabledDrivers: ["postgres"] })); beforeEach(() => reloadTestingDatabases(connections)); after(() => closeTestingConnections(connections)); @@ -30,3 +32,5 @@ describe("persistence > persistence options > chunks", () => { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/persistence/persistence-options/listeners/entity/Post.ts b/test/functional/persistence/persistence-options/listeners/entity/Post.ts index 7d66f60a1..b9c31954b 100644 --- a/test/functional/persistence/persistence-options/listeners/entity/Post.ts +++ b/test/functional/persistence/persistence-options/listeners/entity/Post.ts @@ -1,8 +1,8 @@ -import {BeforeInsert} from "../../../../../../src/decorator/listeners/BeforeInsert"; -import {Entity} from "../../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../../src/decorator/columns/Column"; -import {AfterRemove} from "../../../../../../src/decorator/listeners/AfterRemove"; +import {BeforeInsert} from "../../../../../../src/decorator/listeners/BeforeInsert.ts"; +import {Entity} from "../../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../../src/decorator/columns/Column.ts"; +import {AfterRemove} from "../../../../../../src/decorator/listeners/AfterRemove.ts"; @Entity() export class Post { @@ -10,10 +10,10 @@ export class Post { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) title: string; - @Column() + @Column({ type: String }) description: string; isRemoved: boolean = false; @@ -28,4 +28,4 @@ export class Post { this.isRemoved = true; } -} \ No newline at end of file +} diff --git a/test/functional/persistence/persistence-options/listeners/persistence-options-listeners.ts b/test/functional/persistence/persistence-options/listeners/persistence-options-listeners.ts index 1a42b6af5..f291dce13 100644 --- a/test/functional/persistence/persistence-options/listeners/persistence-options-listeners.ts +++ b/test/functional/persistence/persistence-options/listeners/persistence-options-listeners.ts @@ -1,7 +1,9 @@ -import "reflect-metadata"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils"; -import {Post} from "./entity/Post"; -import {Connection} from "../../../../../src/connection/Connection"; +import {join as joinPaths} from "../../../../../vendor/https/deno.land/std/path/mod.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils.ts"; +import {Post} from "./entity/Post.ts"; +import {Connection} from "../../../../../src/connection/Connection.ts"; +import "../../../../deps/chai.ts"; +import {runIfMain} from "../../../../deps/mocha.ts"; // import {expect} from "chai"; describe("persistence > persistence options > listeners", () => { @@ -11,7 +13,8 @@ describe("persistence > persistence options > listeners", () => { // ------------------------------------------------------------------------- let connections: Connection[]; - before(async () => connections = await createTestingConnections({ __dirname })); + const __dirname = getDirnameOfCurrentModule(import.meta); + before(async () => connections = await createTestingConnections({ entities: [joinPaths(__dirname, "/entity/*.ts")] })); beforeEach(() => reloadTestingDatabases(connections)); after(() => closeTestingConnections(connections)); @@ -54,3 +57,5 @@ describe("persistence > persistence options > listeners", () => { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/persistence/persistence-options/transaction/entity/Post.ts b/test/functional/persistence/persistence-options/transaction/entity/Post.ts index 02719a6f8..37dfa5b2a 100644 --- a/test/functional/persistence/persistence-options/transaction/entity/Post.ts +++ b/test/functional/persistence/persistence-options/transaction/entity/Post.ts @@ -1,6 +1,6 @@ -import {Entity} from "../../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../../src/decorator/columns/Column"; +import {Entity} from "../../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../../src/decorator/columns/Column.ts"; @Entity() export class Post { @@ -8,10 +8,10 @@ export class Post { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) title: string; - @Column() + @Column({ type: String }) description: string; -} \ No newline at end of file +} diff --git a/test/functional/persistence/persistence-options/transaction/persistence-options-transaction.ts b/test/functional/persistence/persistence-options/transaction/persistence-options-transaction.ts index 54ff32790..4f5704e4e 100644 --- a/test/functional/persistence/persistence-options/transaction/persistence-options-transaction.ts +++ b/test/functional/persistence/persistence-options/transaction/persistence-options-transaction.ts @@ -1,7 +1,8 @@ -import "reflect-metadata"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils"; -import {Post} from "./entity/Post"; -import {Connection} from "../../../../../src/connection/Connection"; +import {join as joinPaths} from "../../../../../vendor/https/deno.land/std/path/mod.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils.ts"; +import {Post} from "./entity/Post.ts"; +import {Connection} from "../../../../../src/connection/Connection.ts"; +import {runIfMain} from "../../../../deps/mocha.ts"; // import {expect} from "chai"; describe("persistence > persistence options > transaction", () => { @@ -11,7 +12,8 @@ describe("persistence > persistence options > transaction", () => { // ------------------------------------------------------------------------- let connections: Connection[]; - before(async () => connections = await createTestingConnections({ __dirname })); + const __dirname = getDirnameOfCurrentModule(import.meta); + before(async () => connections = await createTestingConnections({ entities: [joinPaths(__dirname, "/entity/*.ts")] })); beforeEach(() => reloadTestingDatabases(connections)); after(() => closeTestingConnections(connections)); @@ -28,3 +30,5 @@ describe("persistence > persistence options > transaction", () => { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/persistence/persistence-order/entity/Category.ts b/test/functional/persistence/persistence-order/entity/Category.ts index 31f1f6b64..bfe75d7de 100644 --- a/test/functional/persistence/persistence-order/entity/Category.ts +++ b/test/functional/persistence/persistence-order/entity/Category.ts @@ -1,8 +1,8 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {Post} from "./Post"; -import {OneToOne} from "../../../../../src/decorator/relations/OneToOne"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {Post} from "./Post.ts"; +import {OneToOne} from "../../../../../src/decorator/relations/OneToOne.ts"; @Entity() export class Category { @@ -10,10 +10,10 @@ export class Category { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) name: string; @OneToOne(type => Post, post => post.category) post: Post; -} \ No newline at end of file +} diff --git a/test/functional/persistence/persistence-order/entity/Details.ts b/test/functional/persistence/persistence-order/entity/Details.ts index 1441f1a7a..925e64c5f 100644 --- a/test/functional/persistence/persistence-order/entity/Details.ts +++ b/test/functional/persistence/persistence-order/entity/Details.ts @@ -1,10 +1,10 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {OneToOne} from "../../../../../src/decorator/relations/OneToOne"; -import {Post} from "./Post"; -import {Photo} from "./Photo"; -import {JoinColumn} from "../../../../../src/decorator/relations/JoinColumn"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {OneToOne} from "../../../../../src/decorator/relations/OneToOne.ts"; +import {Post} from "./Post.ts"; +import {Photo} from "./Photo.ts"; +import {JoinColumn} from "../../../../../src/decorator/relations/JoinColumn.ts"; @Entity() export class Details { @@ -12,7 +12,7 @@ export class Details { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) title: string; @OneToOne(type => Post, post => post.details) @@ -24,4 +24,4 @@ export class Details { @JoinColumn() photo: Photo; -} \ No newline at end of file +} diff --git a/test/functional/persistence/persistence-order/entity/Photo.ts b/test/functional/persistence/persistence-order/entity/Photo.ts index 508e11707..f4beaf7e5 100644 --- a/test/functional/persistence/persistence-order/entity/Photo.ts +++ b/test/functional/persistence/persistence-order/entity/Photo.ts @@ -1,11 +1,11 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {Post} from "./Post"; -import {OneToOne} from "../../../../../src/decorator/relations/OneToOne"; -import {JoinColumn} from "../../../../../src/decorator/relations/JoinColumn"; -import {Details} from "./Details"; -import {Category} from "./Category"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {Post} from "./Post.ts"; +import {OneToOne} from "../../../../../src/decorator/relations/OneToOne.ts"; +import {JoinColumn} from "../../../../../src/decorator/relations/JoinColumn.ts"; +import {Details} from "./Details.ts"; +import {Category} from "./Category.ts"; @Entity() export class Photo { @@ -13,7 +13,7 @@ export class Photo { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) name: string; @OneToOne(type => Details, details => details.photo) @@ -31,4 +31,4 @@ export class Photo { @JoinColumn() category: Category; -} \ No newline at end of file +} diff --git a/test/functional/persistence/persistence-order/entity/Post.ts b/test/functional/persistence/persistence-order/entity/Post.ts index 04dda0733..e92ba3933 100644 --- a/test/functional/persistence/persistence-order/entity/Post.ts +++ b/test/functional/persistence/persistence-order/entity/Post.ts @@ -1,11 +1,11 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {Category} from "./Category"; -import {OneToOne} from "../../../../../src/decorator/relations/OneToOne"; -import {JoinColumn} from "../../../../../src/decorator/relations/JoinColumn"; -import {Details} from "./Details"; -import {Photo} from "./Photo"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {Category} from "./Category.ts"; +import {OneToOne} from "../../../../../src/decorator/relations/OneToOne.ts"; +import {JoinColumn} from "../../../../../src/decorator/relations/JoinColumn.ts"; +import {Details} from "./Details.ts"; +import {Photo} from "./Photo.ts"; @Entity() export class Post { @@ -13,7 +13,7 @@ export class Post { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) title: string; @OneToOne(type => Category, category => category.post, { @@ -31,4 +31,4 @@ export class Post { @OneToOne(type => Photo, photo => photo.post) photo: Photo; -} \ No newline at end of file +} diff --git a/test/functional/persistence/persistence-order/persistence-order.ts b/test/functional/persistence/persistence-order/persistence-order.ts index 7fb27e42c..132e8c6b2 100644 --- a/test/functional/persistence/persistence-order/persistence-order.ts +++ b/test/functional/persistence/persistence-order/persistence-order.ts @@ -1,27 +1,35 @@ -import "reflect-metadata"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils"; -import {Connection} from "../../../../src/connection/Connection"; -import {Post} from "./entity/Post"; -import {Category} from "./entity/Category"; -import {ConnectionMetadataBuilder} from "../../../../src/connection/ConnectionMetadataBuilder"; -import {EntityMetadataValidator} from "../../../../src/metadata-builder/EntityMetadataValidator"; -import {expect} from "chai"; +import {join as joinPaths} from "../../../../vendor/https/deno.land/std/path/mod.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils.ts"; +import {Connection} from "../../../../src/connection/Connection.ts"; +import {Post} from "./entity/Post.ts"; +import {Category} from "./entity/Category.ts"; +import {ConnectionMetadataBuilder} from "../../../../src/connection/ConnectionMetadataBuilder.ts"; +import {EntityMetadataValidator} from "../../../../src/metadata-builder/EntityMetadataValidator.ts"; +import {expect} from "../../../deps/chai.ts"; +import {runIfMain} from "../../../deps/mocha.ts"; describe("persistence > order of persistence execution operations", () => { + const __dirname = getDirnameOfCurrentModule(import.meta); + describe("should throw exception when non-resolvable circular relations found", function() { - it("should throw CircularRelationsError", () => { + it("should throw CircularRelationsError", async () => { const connection = new Connection({ // dummy connection options, connection won't be established anyway + // TODO(uki00a) uncomment this when MysqlDriver is implemented. + /* type: "mysql", host: "localhost", username: "test", password: "test", database: "test", - entities: [__dirname + "/entity/*{.js,.ts}"] + */ + type: "sqlite", + database: ":memory:", + entities: [joinPaths(__dirname, "/entity/*.ts}")] }); const connectionMetadataBuilder = new ConnectionMetadataBuilder(connection); - const entityMetadatas = connectionMetadataBuilder.buildEntityMetadatas([__dirname + "/entity/*{.js,.ts}"]); + const entityMetadatas = await connectionMetadataBuilder.buildEntityMetadatas([joinPaths(__dirname, "/entity/*.ts")]); const entityMetadataValidator = new EntityMetadataValidator(); expect(() => entityMetadataValidator.validateMany(entityMetadatas, connection.driver)).to.throw(Error); }); @@ -33,7 +41,7 @@ describe("persistence > order of persistence execution operations", () => { let connections: Connection[]; before(async () => connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], })); beforeEach(() => reloadTestingDatabases(connections)); after(() => closeTestingConnections(connections)); @@ -81,3 +89,5 @@ describe("persistence > order of persistence execution operations", () => { }); + +runIfMain(import.meta); diff --git a/test/functional/persistence/remove-topological-order/entity/Category.ts b/test/functional/persistence/remove-topological-order/entity/Category.ts index 08bceebd0..2535ac8c9 100644 --- a/test/functional/persistence/remove-topological-order/entity/Category.ts +++ b/test/functional/persistence/remove-topological-order/entity/Category.ts @@ -1,8 +1,8 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Post} from "./Post"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {ManyToOne} from "../../../../../src/decorator/relations/ManyToOne"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Post} from "./Post.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {ManyToOne} from "../../../../../src/decorator/relations/ManyToOne.ts"; @Entity() export class Category { @@ -10,10 +10,10 @@ export class Category { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) name: string; - + @ManyToOne(type => Post, post => post.categories) post: Post; -} \ No newline at end of file +} diff --git a/test/functional/persistence/remove-topological-order/entity/Post.ts b/test/functional/persistence/remove-topological-order/entity/Post.ts index f25242b2a..9b1c2d817 100644 --- a/test/functional/persistence/remove-topological-order/entity/Post.ts +++ b/test/functional/persistence/remove-topological-order/entity/Post.ts @@ -1,8 +1,8 @@ -import {Category} from "./Category"; -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {OneToMany} from "../../../../../src/decorator/relations/OneToMany"; +import {Category} from "./Category.ts"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {OneToMany} from "../../../../../src/decorator/relations/OneToMany.ts"; @Entity() export class Post { @@ -10,10 +10,10 @@ export class Post { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) title: string; @OneToMany(type => Category, category => category.post, { cascade: ["insert"] }) categories: Category[]; -} \ No newline at end of file +} diff --git a/test/functional/persistence/remove-topological-order/remove-topolotical-order.ts b/test/functional/persistence/remove-topological-order/remove-topolotical-order.ts index f0b5f9b5a..c4469310b 100644 --- a/test/functional/persistence/remove-topological-order/remove-topolotical-order.ts +++ b/test/functional/persistence/remove-topological-order/remove-topolotical-order.ts @@ -1,8 +1,9 @@ -import "reflect-metadata"; -import {Connection} from "../../../../src/connection/Connection"; -import {Post} from "./entity/Post"; -import {Category} from "./entity/Category"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils"; +import {join as joinPaths} from "../../../../vendor/https/deno.land/std/path/mod.ts"; +import {Connection} from "../../../../src/connection/Connection.ts"; +import {Post} from "./entity/Post.ts"; +import {Category} from "./entity/Category.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils.ts"; +import {runIfMain} from "../../../deps/mocha.ts"; // import {expect} from "chai"; describe("persistence > remove-topological-order", function() { @@ -12,7 +13,8 @@ describe("persistence > remove-topological-order", function() { // ------------------------------------------------------------------------- let connections: Connection[]; - before(async () => connections = await createTestingConnections({ __dirname })); + const __dirname = getDirnameOfCurrentModule(import.meta); + before(async () => connections = await createTestingConnections({ entities: [joinPaths(__dirname, "/entity/*.ts")] })); beforeEach(() => reloadTestingDatabases(connections)); after(() => closeTestingConnections(connections)); @@ -43,3 +45,5 @@ describe("persistence > remove-topological-order", function() { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/query-builder/brackets/entity/User.ts b/test/functional/query-builder/brackets/entity/User.ts index c92894439..946a94450 100644 --- a/test/functional/query-builder/brackets/entity/User.ts +++ b/test/functional/query-builder/brackets/entity/User.ts @@ -1,6 +1,6 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../src/decorator/columns/Column"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; @Entity() export class User { @@ -8,13 +8,13 @@ export class User { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) firstName: string; - @Column() + @Column({ type: String }) lastName: string; - @Column() + @Column({ type: Boolean }) isAdmin: boolean; -} \ No newline at end of file +} diff --git a/test/functional/query-builder/brackets/query-builder-brackets.ts b/test/functional/query-builder/brackets/query-builder-brackets.ts index 5d653c617..bebd94bdc 100644 --- a/test/functional/query-builder/brackets/query-builder-brackets.ts +++ b/test/functional/query-builder/brackets/query-builder-brackets.ts @@ -1,15 +1,17 @@ -import "reflect-metadata"; -import {expect} from "chai"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils"; -import {Connection} from "../../../../src/connection/Connection"; -import {User} from "./entity/User"; -import {Brackets} from "../../../../src/query-builder/Brackets"; +import {join as joinPaths} from "../../../../vendor/https/deno.land/std/path/mod.ts"; +import {expect} from "../../../deps/chai.ts"; +import {runIfMain} from "../../../deps/mocha.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils.ts"; +import {Connection} from "../../../../src/connection/Connection.ts"; +import {User} from "./entity/User.ts"; +import {Brackets} from "../../../../src/query-builder/Brackets.ts"; describe("query builder > brackets", () => { - + let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], })); beforeEach(() => reloadTestingDatabases(connections)); after(() => closeTestingConnections(connections)); @@ -50,4 +52,6 @@ describe("query builder > brackets", () => { }))); -}); \ No newline at end of file +}); + +runIfMain(import.meta); diff --git a/test/functional/query-builder/cache/entity/User.ts b/test/functional/query-builder/cache/entity/User.ts index c92894439..946a94450 100644 --- a/test/functional/query-builder/cache/entity/User.ts +++ b/test/functional/query-builder/cache/entity/User.ts @@ -1,6 +1,6 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../src/decorator/columns/Column"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; @Entity() export class User { @@ -8,13 +8,13 @@ export class User { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) firstName: string; - @Column() + @Column({ type: String }) lastName: string; - @Column() + @Column({ type: Boolean }) isAdmin: boolean; -} \ No newline at end of file +} diff --git a/test/functional/query-builder/cache/query-builder-cache.ts b/test/functional/query-builder/cache/query-builder-cache.ts index 87bcc8f9a..e50f3af27 100644 --- a/test/functional/query-builder/cache/query-builder-cache.ts +++ b/test/functional/query-builder/cache/query-builder-cache.ts @@ -1,19 +1,21 @@ -import "reflect-metadata"; -import {expect} from "chai"; +import {join as joinPaths} from "../../../../vendor/https/deno.land/std/path/mod.ts"; +import {expect} from "../../../deps/chai.ts"; +import {runIfMain} from "../../../deps/mocha.ts"; import { + getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases, sleep -} from "../../../utils/test-utils"; -import {Connection} from "../../../../src/connection/Connection"; -import {User} from "./entity/User"; - -describe("query builder > cache", () => { +} from "../../../utils/test-utils.ts"; +import {Connection} from "../../../../src/connection/Connection.ts"; +import {User} from "./entity/User.ts"; +describe("query builder > cache", function() { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], cache: true, // cache: { // type: "redis", @@ -309,3 +311,5 @@ describe("query builder > cache", () => { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/query-builder/delete/entity/Counters.ts b/test/functional/query-builder/delete/entity/Counters.ts index d7383302b..8a3e2da4d 100644 --- a/test/functional/query-builder/delete/entity/Counters.ts +++ b/test/functional/query-builder/delete/entity/Counters.ts @@ -1,14 +1,14 @@ -import {Column} from "../../../../../src/decorator/columns/Column"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; export class Counters { - @Column({ default: 1 }) + @Column({ default: 1, type: Number }) likes: number; - @Column({ nullable: true }) + @Column({ nullable: true, type: Number }) favorites: number; - @Column({ default: 0 }) + @Column({ default: 0, type: Number }) comments: number; -} \ No newline at end of file +} diff --git a/test/functional/query-builder/delete/entity/Photo.ts b/test/functional/query-builder/delete/entity/Photo.ts index cf5f5aa76..42f5be225 100644 --- a/test/functional/query-builder/delete/entity/Photo.ts +++ b/test/functional/query-builder/delete/entity/Photo.ts @@ -1,7 +1,7 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {Counters} from "./Counters"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {Counters} from "./Counters.ts"; @Entity() export class Photo { @@ -9,7 +9,7 @@ export class Photo { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) url: string; @Column(type => Counters) diff --git a/test/functional/query-builder/delete/entity/User.ts b/test/functional/query-builder/delete/entity/User.ts index 4f0544bf7..6b1da56d2 100644 --- a/test/functional/query-builder/delete/entity/User.ts +++ b/test/functional/query-builder/delete/entity/User.ts @@ -1,6 +1,6 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../src/decorator/columns/Column"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; @Entity() export class User { @@ -8,7 +8,7 @@ export class User { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) name: string; } diff --git a/test/functional/query-builder/delete/query-builder-delete.ts b/test/functional/query-builder/delete/query-builder-delete.ts index 6bc071130..e34426d13 100644 --- a/test/functional/query-builder/delete/query-builder-delete.ts +++ b/test/functional/query-builder/delete/query-builder-delete.ts @@ -1,15 +1,17 @@ -import "reflect-metadata"; -import {expect} from "chai"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils"; -import {Connection} from "../../../../src/connection/Connection"; -import {User} from "./entity/User"; -import {Photo} from "./entity/Photo"; +import {join as joinPaths} from "../../../../vendor/https/deno.land/std/path/mod.ts"; +import {expect} from "../../../deps/chai.ts"; +import {runIfMain} from "../../../deps/mocha.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils.ts"; +import {Connection} from "../../../../src/connection/Connection.ts"; +import {User} from "./entity/User.ts"; +import {Photo} from "./entity/Photo.ts"; describe("query builder > delete", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], })); beforeEach(() => reloadTestingDatabases(connections)); after(() => closeTestingConnections(connections)); @@ -114,3 +116,5 @@ describe("query builder > delete", () => { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/query-builder/distinct-on/entity/Category.ts b/test/functional/query-builder/distinct-on/entity/Category.ts index 7ac492947..8ec10485f 100644 --- a/test/functional/query-builder/distinct-on/entity/Category.ts +++ b/test/functional/query-builder/distinct-on/entity/Category.ts @@ -1,6 +1,6 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../src/decorator/columns/Column"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; @Entity() export class Category { @@ -8,10 +8,10 @@ export class Category { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) title: string; - @Column() + @Column({ type: String }) author: string; } diff --git a/test/functional/query-builder/distinct-on/entity/Post.ts b/test/functional/query-builder/distinct-on/entity/Post.ts index 7707568cb..371479b4a 100644 --- a/test/functional/query-builder/distinct-on/entity/Post.ts +++ b/test/functional/query-builder/distinct-on/entity/Post.ts @@ -1,6 +1,6 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../src/decorator/columns/Column"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; @Entity() export class Post { @@ -8,13 +8,13 @@ export class Post { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) title: string; - @Column() + @Column({ type: String }) author: string; - @Column() + @Column({ type: String }) moderator: string; } diff --git a/test/functional/query-builder/distinct-on/entity/User.ts b/test/functional/query-builder/distinct-on/entity/User.ts index 162453b92..364a8f898 100644 --- a/test/functional/query-builder/distinct-on/entity/User.ts +++ b/test/functional/query-builder/distinct-on/entity/User.ts @@ -1,6 +1,6 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../src/decorator/columns/Column"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; @Entity() export class User { @@ -8,7 +8,7 @@ export class User { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) name: string; } diff --git a/test/functional/query-builder/distinct-on/query-builder-distinct-on.ts b/test/functional/query-builder/distinct-on/query-builder-distinct-on.ts index e47315d02..197753079 100644 --- a/test/functional/query-builder/distinct-on/query-builder-distinct-on.ts +++ b/test/functional/query-builder/distinct-on/query-builder-distinct-on.ts @@ -1,16 +1,18 @@ -import "reflect-metadata"; -import {expect} from "chai"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils"; -import {Connection} from "../../../../src/connection/Connection"; -import {Category} from "./entity/Category"; -import {User} from "./entity/User"; -import {Post} from "./entity/Post"; +import {join as joinPaths} from "../../../../vendor/https/deno.land/std/path/mod.ts"; +import {expect} from "../../../deps/chai.ts"; +import {runIfMain} from "../../../deps/mocha.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils.ts"; +import {Connection} from "../../../../src/connection/Connection.ts"; +import {Category} from "./entity/Category.ts"; +import {User} from "./entity/User.ts"; +import {Post} from "./entity/Post.ts"; describe("query builder > distinct on", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], enabledDrivers: ["postgres"] })); beforeEach(() => reloadTestingDatabases(connections)); @@ -146,3 +148,5 @@ describe("query builder > distinct on", () => { ))); }); + +runIfMain(import.meta); diff --git a/test/functional/query-builder/enabling-transaction/enabling-transaction.ts b/test/functional/query-builder/enabling-transaction/enabling-transaction.ts index 2c7018b7e..4fb45b5b6 100644 --- a/test/functional/query-builder/enabling-transaction/enabling-transaction.ts +++ b/test/functional/query-builder/enabling-transaction/enabling-transaction.ts @@ -1,12 +1,14 @@ -import "reflect-metadata"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils"; -import {Connection} from "../../../../src/connection/Connection"; -import {Post} from "./entity/Post"; +import {join as joinPaths} from "../../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../../deps/mocha.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils.ts"; +import {Connection} from "../../../../src/connection/Connection.ts"; +import {Post} from "./entity/Post.ts"; describe("query builder > enabling transaction", () => { - + let connections: Connection[]; - before(async () => connections = await createTestingConnections({ __dirname })); + const __dirname = getDirnameOfCurrentModule(import.meta); + before(async () => connections = await createTestingConnections({ entities: [joinPaths(__dirname, "/entity/*.ts")] })); beforeEach(() => reloadTestingDatabases(connections)); after(() => closeTestingConnections(connections)); @@ -28,4 +30,6 @@ describe("query builder > enabling transaction", () => { // todo: add tests for update and remove queries as well -}); \ No newline at end of file +}); + +runIfMain(import.meta); diff --git a/test/functional/query-builder/enabling-transaction/entity/Post.ts b/test/functional/query-builder/enabling-transaction/entity/Post.ts index b65476c52..f09d1969a 100644 --- a/test/functional/query-builder/enabling-transaction/entity/Post.ts +++ b/test/functional/query-builder/enabling-transaction/entity/Post.ts @@ -1,6 +1,6 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../src/decorator/columns/Column"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; @Entity() export class Post { @@ -8,7 +8,7 @@ export class Post { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) title: string; -} \ No newline at end of file +} diff --git a/test/functional/query-builder/entity-updation/entity-updation.ts b/test/functional/query-builder/entity-updation/entity-updation.ts index f170a815a..d8482f2e6 100644 --- a/test/functional/query-builder/entity-updation/entity-updation.ts +++ b/test/functional/query-builder/entity-updation/entity-updation.ts @@ -1,13 +1,18 @@ -import "reflect-metadata"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils"; -import {Connection} from "../../../../src/connection/Connection"; -import {Post} from "./entity/Post"; -import {expect} from "chai"; +import {join as joinPaths} from "../../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../../deps/mocha.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils.ts"; +import {Connection} from "../../../../src/connection/Connection.ts"; +import {Post} from "./entity/Post.ts"; +import {expect} from "../../../deps/chai.ts"; describe("query builder > entity updation", () => { let connections: Connection[]; - before(async () => connections = await createTestingConnections({ __dirname })); + const __dirname = getDirnameOfCurrentModule(import.meta); + before(async () => connections = await createTestingConnections({ + entities: [joinPaths(__dirname, "/entity/*.ts")], + enabledDrivers: ["postgres", "mysql", "mssql", "oracle", "cockroachdb", "mongodb"] // TODO(uki00a) Remove `enabledDrivers` when deno-sqlite supports `datetime('now')`. + })); beforeEach(() => reloadTestingDatabases(connections)); after(() => closeTestingConnections(connections)); @@ -117,3 +122,5 @@ describe("query builder > entity updation", () => { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/query-builder/entity-updation/entity/Post.ts b/test/functional/query-builder/entity-updation/entity/Post.ts index 7222d7e9f..00ee27921 100644 --- a/test/functional/query-builder/entity-updation/entity/Post.ts +++ b/test/functional/query-builder/entity-updation/entity/Post.ts @@ -1,9 +1,9 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {CreateDateColumn} from "../../../../../src/decorator/columns/CreateDateColumn"; -import {UpdateDateColumn} from "../../../../../src/decorator/columns/UpdateDateColumn"; -import {VersionColumn} from "../../../../../src/decorator/columns/VersionColumn"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {CreateDateColumn} from "../../../../../src/decorator/columns/CreateDateColumn.ts"; +import {UpdateDateColumn} from "../../../../../src/decorator/columns/UpdateDateColumn.ts"; +import {VersionColumn} from "../../../../../src/decorator/columns/VersionColumn.ts"; @Entity() export class Post { @@ -11,19 +11,19 @@ export class Post { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) title: string; - @CreateDateColumn() + @CreateDateColumn({ type: String }) createDate: string; - @UpdateDateColumn() + @UpdateDateColumn({ type: String }) updateDate: string; - @Column({ default: 100 }) + @Column({ default: 100, type: Number }) order: number; @VersionColumn() version: number; -} \ No newline at end of file +} diff --git a/test/functional/query-builder/insert-on-conflict/entity/Post.ts b/test/functional/query-builder/insert-on-conflict/entity/Post.ts index ece88f3cc..e2610a7c4 100644 --- a/test/functional/query-builder/insert-on-conflict/entity/Post.ts +++ b/test/functional/query-builder/insert-on-conflict/entity/Post.ts @@ -1,14 +1,14 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn.ts"; @Entity() export class Post { - @PrimaryColumn() + @PrimaryColumn({ type: String }) id: string; - @Column() + @Column({ type: String }) title: string; -} \ No newline at end of file +} diff --git a/test/functional/query-builder/insert-on-conflict/query-builder-insert-on-conflict.ts b/test/functional/query-builder/insert-on-conflict/query-builder-insert-on-conflict.ts index 03ee8e50b..c418a42a6 100644 --- a/test/functional/query-builder/insert-on-conflict/query-builder-insert-on-conflict.ts +++ b/test/functional/query-builder/insert-on-conflict/query-builder-insert-on-conflict.ts @@ -1,13 +1,16 @@ -import "reflect-metadata"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils"; -import {Connection} from "../../../../src/connection/Connection"; -import {Post} from "./entity/Post"; +import {join as joinPaths} from "../../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../../deps/mocha.ts"; +import {expect} from "../../../deps/chai.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils.ts"; +import {Connection} from "../../../../src/connection/Connection.ts"; +import {Post} from "./entity/Post.ts"; describe("query builder > insertion > on conflict", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], enabledDrivers: ["postgres", "sqlite"] // since on conflict statement is only supported in postgres and sqlite >= 3.24.0 })); beforeEach(() => reloadTestingDatabases(connections)); @@ -36,7 +39,7 @@ describe("query builder > insertion > on conflict", () => { .onConflict(`("id") DO NOTHING`) .execute(); - await connection.manager.findOne(Post, "post#1").should.eventually.be.eql({ + expect(await connection.manager.findOne(Post, "post#1")).to.eql({ id: "post#1", title: "About post" }); @@ -49,10 +52,12 @@ describe("query builder > insertion > on conflict", () => { .setParameter("title", post2.title) .execute(); - await connection.manager.findOne(Post, "post#1").should.eventually.be.eql({ + expect(await connection.manager.findOne(Post, "post#1")).to.eql({ id: "post#1", title: "Again post" }); }))); -}); \ No newline at end of file +}); + +runIfMain(import.meta); diff --git a/test/functional/query-builder/insert/entity/Counters.ts b/test/functional/query-builder/insert/entity/Counters.ts index d7383302b..8a3e2da4d 100644 --- a/test/functional/query-builder/insert/entity/Counters.ts +++ b/test/functional/query-builder/insert/entity/Counters.ts @@ -1,14 +1,14 @@ -import {Column} from "../../../../../src/decorator/columns/Column"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; export class Counters { - @Column({ default: 1 }) + @Column({ default: 1, type: Number }) likes: number; - @Column({ nullable: true }) + @Column({ nullable: true, type: Number }) favorites: number; - @Column({ default: 0 }) + @Column({ default: 0, type: Number }) comments: number; -} \ No newline at end of file +} diff --git a/test/functional/query-builder/insert/entity/Photo.ts b/test/functional/query-builder/insert/entity/Photo.ts index 2a7124f21..42f5be225 100644 --- a/test/functional/query-builder/insert/entity/Photo.ts +++ b/test/functional/query-builder/insert/entity/Photo.ts @@ -1,7 +1,7 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {Counters} from "./Counters"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {Counters} from "./Counters.ts"; @Entity() export class Photo { @@ -9,10 +9,10 @@ export class Photo { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) url: string; @Column(type => Counters) counters: Counters; -} \ No newline at end of file +} diff --git a/test/functional/query-builder/insert/entity/Post.ts b/test/functional/query-builder/insert/entity/Post.ts index b65476c52..f09d1969a 100644 --- a/test/functional/query-builder/insert/entity/Post.ts +++ b/test/functional/query-builder/insert/entity/Post.ts @@ -1,6 +1,6 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../src/decorator/columns/Column"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; @Entity() export class Post { @@ -8,7 +8,7 @@ export class Post { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) title: string; -} \ No newline at end of file +} diff --git a/test/functional/query-builder/insert/entity/User.ts b/test/functional/query-builder/insert/entity/User.ts index 0e019207a..6b1da56d2 100644 --- a/test/functional/query-builder/insert/entity/User.ts +++ b/test/functional/query-builder/insert/entity/User.ts @@ -1,6 +1,6 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../src/decorator/columns/Column"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; @Entity() export class User { @@ -8,7 +8,7 @@ export class User { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) name: string; -} \ No newline at end of file +} diff --git a/test/functional/query-builder/insert/query-builder-insert.ts b/test/functional/query-builder/insert/query-builder-insert.ts index 118cb37f2..5b34a7364 100644 --- a/test/functional/query-builder/insert/query-builder-insert.ts +++ b/test/functional/query-builder/insert/query-builder-insert.ts @@ -1,19 +1,20 @@ -import "reflect-metadata"; -import {expect} from "chai"; -import {SapDriver} from "../../../../src/driver/sap/SapDriver"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils"; -import {Connection} from "../../../../src/connection/Connection"; -import {User} from "./entity/User"; -import {SqlServerDriver} from "../../../../src/driver/sqlserver/SqlServerDriver"; -import {Photo} from "./entity/Photo"; -import {AbstractSqliteDriver} from "../../../../src/driver/sqlite-abstract/AbstractSqliteDriver"; -import {OracleDriver} from "../../../../src/driver/oracle/OracleDriver"; - -describe("query builder > insert", () => { - +import {join as joinPaths} from "../../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../../deps/mocha.ts"; +import {expect} from "../../../deps/chai.ts"; +import {SapDriver} from "../../../../src/driver/sap/SapDriver.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils.ts"; +import {Connection} from "../../../../src/connection/Connection.ts"; +import {User} from "./entity/User.ts"; +import {SqlServerDriver} from "../../../../src/driver/sqlserver/SqlServerDriver.ts"; +import {Photo} from "./entity/Photo.ts"; +import {AbstractSqliteDriver} from "../../../../src/driver/sqlite-abstract/AbstractSqliteDriver.ts"; +import {OracleDriver} from "../../../../src/driver/oracle/OracleDriver.ts"; + +describe("query builder > insert", function() { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], dropSchema: true })); beforeEach(() => reloadTestingDatabases(connections)); @@ -142,3 +143,5 @@ describe("query builder > insert", () => { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/query-builder/join/entity/Category.ts b/test/functional/query-builder/join/entity/Category.ts index 25b92db3a..89987d4d0 100644 --- a/test/functional/query-builder/join/entity/Category.ts +++ b/test/functional/query-builder/join/entity/Category.ts @@ -1,10 +1,10 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {ManyToMany} from "../../../../../src/decorator/relations/ManyToMany"; -import {JoinTable} from "../../../../../src/decorator/relations/JoinTable"; -import {Post} from "./Post"; -import {Image} from "./Image"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {ManyToMany} from "../../../../../src/decorator/relations/ManyToMany.ts"; +import {JoinTable} from "../../../../../src/decorator/relations/JoinTable.ts"; +import {Post} from "./Post.ts"; +import {Image} from "./Image.ts"; @Entity() export class Category { @@ -12,10 +12,10 @@ export class Category { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) name: string; - @Column() + @Column({ type: Boolean }) isRemoved: boolean = false; @ManyToMany(type => Post, post => post.categories) @@ -29,4 +29,4 @@ export class Category { removedImages: Image[]; -} \ No newline at end of file +} diff --git a/test/functional/query-builder/join/entity/Image.ts b/test/functional/query-builder/join/entity/Image.ts index 0abf5cc80..fab0cf258 100644 --- a/test/functional/query-builder/join/entity/Image.ts +++ b/test/functional/query-builder/join/entity/Image.ts @@ -1,6 +1,6 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../src/decorator/columns/Column"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; @Entity() export class Image { @@ -8,10 +8,10 @@ export class Image { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) name: string; - @Column() + @Column({ type: Boolean }) isRemoved: boolean = false; -} \ No newline at end of file +} diff --git a/test/functional/query-builder/join/entity/Post.ts b/test/functional/query-builder/join/entity/Post.ts index 9e4075fef..64547962f 100644 --- a/test/functional/query-builder/join/entity/Post.ts +++ b/test/functional/query-builder/join/entity/Post.ts @@ -1,15 +1,15 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {ManyToOne} from "../../../../../src/decorator/relations/ManyToOne"; -import {ManyToMany} from "../../../../../src/decorator/relations/ManyToMany"; -import {JoinTable} from "../../../../../src/decorator/relations/JoinTable"; -import {OneToOne} from "../../../../../src/decorator/relations/OneToOne"; -import {JoinColumn} from "../../../../../src/decorator/relations/JoinColumn"; -import {User} from "./User"; -import {Category} from "./Category"; -import {Tag} from "./Tag"; -import {Image} from "./Image"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {ManyToOne} from "../../../../../src/decorator/relations/ManyToOne.ts"; +import {ManyToMany} from "../../../../../src/decorator/relations/ManyToMany.ts"; +import {JoinTable} from "../../../../../src/decorator/relations/JoinTable.ts"; +import {OneToOne} from "../../../../../src/decorator/relations/OneToOne.ts"; +import {JoinColumn} from "../../../../../src/decorator/relations/JoinColumn.ts"; +import {User} from "./User.ts"; +import {Category} from "./Category.ts"; +import {Tag} from "./Tag.ts"; +import {Image} from "./Image.ts"; @Entity() export class Post { @@ -17,9 +17,9 @@ export class Post { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) title: string; - + @ManyToOne(type => Tag) tag: Tag; @@ -37,4 +37,4 @@ export class Post { images: Image[]; -} \ No newline at end of file +} diff --git a/test/functional/query-builder/join/entity/Tag.ts b/test/functional/query-builder/join/entity/Tag.ts index 649ed21d4..bd73d662c 100644 --- a/test/functional/query-builder/join/entity/Tag.ts +++ b/test/functional/query-builder/join/entity/Tag.ts @@ -1,6 +1,6 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../src/decorator/columns/Column"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; @Entity() export class Tag { @@ -8,7 +8,7 @@ export class Tag { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) name: string; -} \ No newline at end of file +} diff --git a/test/functional/query-builder/join/entity/User.ts b/test/functional/query-builder/join/entity/User.ts index 0e019207a..6b1da56d2 100644 --- a/test/functional/query-builder/join/entity/User.ts +++ b/test/functional/query-builder/join/entity/User.ts @@ -1,6 +1,6 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../src/decorator/columns/Column"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; @Entity() export class User { @@ -8,7 +8,7 @@ export class User { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) name: string; -} \ No newline at end of file +} diff --git a/test/functional/query-builder/join/query-builder-joins.ts b/test/functional/query-builder/join/query-builder-joins.ts index 78bd1f154..6a78ded96 100644 --- a/test/functional/query-builder/join/query-builder-joins.ts +++ b/test/functional/query-builder/join/query-builder-joins.ts @@ -1,19 +1,22 @@ -import "reflect-metadata"; -import {expect} from "chai"; -import {CockroachDriver} from "../../../../src/driver/cockroachdb/CockroachDriver"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils"; -import {Connection} from "../../../../src/connection/Connection"; -import {Tag} from "./entity/Tag"; -import {Post} from "./entity/Post"; -import {Category} from "./entity/Category"; -import {Image} from "./entity/Image"; -import {User} from "./entity/User"; +import {join as joinPaths} from "../../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../../deps/mocha.ts"; +import {expect} from "../../../deps/chai.ts"; +// TODO(uki00a) uncomment this when CockroachDriver is implemented. +// import {CockroachDriver} from "../../../../src/driver/cockroachdb/CockroachDriver.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils.ts"; +import {Connection} from "../../../../src/connection/Connection.ts"; +import {Tag} from "./entity/Tag.ts"; +import {Post} from "./entity/Post.ts"; +import {Category} from "./entity/Category.ts"; +import {Image} from "./entity/Image.ts"; +import {User} from "./entity/User.ts"; describe("query builder > joins", () => { - + let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], })); beforeEach(() => reloadTestingDatabases(connections)); after(() => closeTestingConnections(connections)); @@ -178,7 +181,7 @@ describe("query builder > joins", () => { .where("post.id = :id", { id: post.id }) .getRawOne(); - if (connection.driver instanceof CockroachDriver) { + if (false/* connection.driver instanceof CockroachDriver */) { // TODO(uki00a) uncomment this when CockroachDriver is implemented. expect(loadedRawPost!["categories_id"]).to.be.equal("1"); } else { @@ -830,3 +833,5 @@ describe("query builder > joins", () => { }); }); + +runIfMain(import.meta); diff --git a/test/functional/query-builder/locking/entity/PostWithUpdateDate.ts b/test/functional/query-builder/locking/entity/PostWithUpdateDate.ts index 9404c5c1f..95c80da0a 100644 --- a/test/functional/query-builder/locking/entity/PostWithUpdateDate.ts +++ b/test/functional/query-builder/locking/entity/PostWithUpdateDate.ts @@ -1,7 +1,7 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {UpdateDateColumn} from "../../../../../src/decorator/columns/UpdateDateColumn"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {UpdateDateColumn} from "../../../../../src/decorator/columns/UpdateDateColumn.ts"; @Entity() export class PostWithUpdateDate { @@ -9,10 +9,10 @@ export class PostWithUpdateDate { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) title: string; @UpdateDateColumn() updateDate: Date; -} \ No newline at end of file +} diff --git a/test/functional/query-builder/locking/entity/PostWithVersion.ts b/test/functional/query-builder/locking/entity/PostWithVersion.ts index 2a1a4fe49..387f9c305 100644 --- a/test/functional/query-builder/locking/entity/PostWithVersion.ts +++ b/test/functional/query-builder/locking/entity/PostWithVersion.ts @@ -1,7 +1,7 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {VersionColumn} from "../../../../../src/decorator/columns/VersionColumn"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {VersionColumn} from "../../../../../src/decorator/columns/VersionColumn.ts"; @Entity() export class PostWithVersion { @@ -9,10 +9,10 @@ export class PostWithVersion { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) title: string; @VersionColumn() version: number; -} \ No newline at end of file +} diff --git a/test/functional/query-builder/locking/entity/PostWithVersionAndUpdatedDate.ts b/test/functional/query-builder/locking/entity/PostWithVersionAndUpdatedDate.ts index 53e998647..2445657f2 100644 --- a/test/functional/query-builder/locking/entity/PostWithVersionAndUpdatedDate.ts +++ b/test/functional/query-builder/locking/entity/PostWithVersionAndUpdatedDate.ts @@ -1,8 +1,8 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {VersionColumn} from "../../../../../src/decorator/columns/VersionColumn"; -import {UpdateDateColumn} from "../../../../../src/decorator/columns/UpdateDateColumn"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {VersionColumn} from "../../../../../src/decorator/columns/VersionColumn.ts"; +import {UpdateDateColumn} from "../../../../../src/decorator/columns/UpdateDateColumn.ts"; @Entity("post_with_v_ud") export class PostWithVersionAndUpdatedDate { @@ -10,7 +10,7 @@ export class PostWithVersionAndUpdatedDate { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) title: string; @VersionColumn() @@ -19,4 +19,4 @@ export class PostWithVersionAndUpdatedDate { @UpdateDateColumn() updateDate: Date; -} \ No newline at end of file +} diff --git a/test/functional/query-builder/locking/entity/PostWithoutVersionAndUpdateDate.ts b/test/functional/query-builder/locking/entity/PostWithoutVersionAndUpdateDate.ts index c38010787..ce7fd99af 100644 --- a/test/functional/query-builder/locking/entity/PostWithoutVersionAndUpdateDate.ts +++ b/test/functional/query-builder/locking/entity/PostWithoutVersionAndUpdateDate.ts @@ -1,6 +1,6 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../src/decorator/columns/Column"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; @Entity("post_without_v_ud") export class PostWithoutVersionAndUpdateDate { @@ -8,7 +8,7 @@ export class PostWithoutVersionAndUpdateDate { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) title: string; -} \ No newline at end of file +} diff --git a/test/functional/query-builder/locking/query-builder-locking.ts b/test/functional/query-builder/locking/query-builder-locking.ts index eefdddfd0..da64bd64e 100644 --- a/test/functional/query-builder/locking/query-builder-locking.ts +++ b/test/functional/query-builder/locking/query-builder-locking.ts @@ -1,29 +1,34 @@ -import "reflect-metadata"; -import {CockroachDriver} from "../../../../src/driver/cockroachdb/CockroachDriver"; -import {SapDriver} from "../../../../src/driver/sap/SapDriver"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils"; -import {Connection} from "../../../../src/connection/Connection"; -import {PostWithVersion} from "./entity/PostWithVersion"; -import {expect} from "chai"; -import {PostWithoutVersionAndUpdateDate} from "./entity/PostWithoutVersionAndUpdateDate"; -import {PostWithUpdateDate} from "./entity/PostWithUpdateDate"; -import {PostWithVersionAndUpdatedDate} from "./entity/PostWithVersionAndUpdatedDate"; -import {OptimisticLockVersionMismatchError} from "../../../../src/error/OptimisticLockVersionMismatchError"; -import {OptimisticLockCanNotBeUsedError} from "../../../../src/error/OptimisticLockCanNotBeUsedError"; -import {NoVersionOrUpdateDateColumnError} from "../../../../src/error/NoVersionOrUpdateDateColumnError"; -import {PessimisticLockTransactionRequiredError} from "../../../../src/error/PessimisticLockTransactionRequiredError"; -import {MysqlDriver} from "../../../../src/driver/mysql/MysqlDriver"; -import {PostgresDriver} from "../../../../src/driver/postgres/PostgresDriver"; -import {SqlServerDriver} from "../../../../src/driver/sqlserver/SqlServerDriver"; -import {AbstractSqliteDriver} from "../../../../src/driver/sqlite-abstract/AbstractSqliteDriver"; -import {OracleDriver} from "../../../../src/driver/oracle/OracleDriver"; -import {LockNotSupportedOnGivenDriverError} from "../../../../src/error/LockNotSupportedOnGivenDriverError"; +// TODO(uki00a) uncomment this when CockroachDriver is implemented. +// import {CockroachDriver} from "../../../../src/driver/cockroachdb/CockroachDriver.ts"; +import {SapDriver} from "../../../../src/driver/sap/SapDriver.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases, allSettled} from "../../../utils/test-utils.ts"; +import {Connection} from "../../../../src/connection/Connection.ts"; +import {PostWithVersion} from "./entity/PostWithVersion.ts"; +import {join as joinPaths} from "../../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../../deps/mocha.ts"; +import {expect} from "../../../deps/chai.ts"; +import {PostWithoutVersionAndUpdateDate} from "./entity/PostWithoutVersionAndUpdateDate.ts"; +import {PostWithUpdateDate} from "./entity/PostWithUpdateDate.ts"; +import {PostWithVersionAndUpdatedDate} from "./entity/PostWithVersionAndUpdatedDate.ts"; +import {OptimisticLockVersionMismatchError} from "../../../../src/error/OptimisticLockVersionMismatchError.ts"; +import {OptimisticLockCanNotBeUsedError} from "../../../../src/error/OptimisticLockCanNotBeUsedError.ts"; +import {NoVersionOrUpdateDateColumnError} from "../../../../src/error/NoVersionOrUpdateDateColumnError.ts"; +import {PessimisticLockTransactionRequiredError} from "../../../../src/error/PessimisticLockTransactionRequiredError.ts"; +import {MysqlDriver} from "../../../../src/driver/mysql/MysqlDriver.ts"; +// TODO(uki00a) uncomment this when PostgresDriver is implemented. +// import {PostgresDriver} from "../../../../src/driver/postgres/PostgresDriver.ts"; +import {SqlServerDriver} from "../../../../src/driver/sqlserver/SqlServerDriver.ts"; +import {AbstractSqliteDriver} from "../../../../src/driver/sqlite-abstract/AbstractSqliteDriver.ts"; +import {OracleDriver} from "../../../../src/driver/oracle/OracleDriver.ts"; +import {LockNotSupportedOnGivenDriverError} from "../../../../src/error/LockNotSupportedOnGivenDriverError.ts"; describe("query builder > locking", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], + enabledDrivers: ["postgres", "mysql", "mariadb", "cockroachdb", "mssql", "oracle", "sap"] // TODO(uki00a) Remove `enabledDrivers when deno-sqlite supports `datetime('now')`. })); beforeEach(() => reloadTestingDatabases(connections)); after(() => closeTestingConnections(connections)); @@ -45,21 +50,26 @@ describe("query builder > locking", () => { if (connection.driver instanceof AbstractSqliteDriver || connection.driver instanceof SapDriver) return; - return Promise.all([ + const results = await allSettled([ connection.createQueryBuilder(PostWithVersion, "post") .setLock("pessimistic_read") .where("post.id = :id", { id: 1 }) - .getOne().should.be.rejectedWith(PessimisticLockTransactionRequiredError), + .getOne(), connection.createQueryBuilder(PostWithVersion, "post") .setLock("pessimistic_write") .where("post.id = :id", { id: 1 }) - .getOne().should.be.rejectedWith(PessimisticLockTransactionRequiredError) + .getOne() ]); + expect(results[0].status).to.equal('rejected'); + expect(results[0].reason).to.be.instanceOf(PessimisticLockTransactionRequiredError); + expect(results[1].status).to.equal('rejected'); + expect(results[1].reason).to.be.instanceOf(PessimisticLockTransactionRequiredError); }))); it("should not throw error if pessimistic lock used with transaction", () => Promise.all(connections.map(async connection => { - if (connection.driver instanceof AbstractSqliteDriver || connection.driver instanceof CockroachDriver || connection.driver instanceof SapDriver) + // TODO(uki00a) uncomment this when CockroachDriver is implemented. + if (connection.driver instanceof AbstractSqliteDriver/* || connection.driver instanceof CockroachDriver*/ || connection.driver instanceof SapDriver) return; return connection.manager.transaction(entityManager => { @@ -67,18 +77,19 @@ describe("query builder > locking", () => { entityManager.createQueryBuilder(PostWithVersion, "post") .setLock("pessimistic_read") .where("post.id = :id", { id: 1 }) - .getOne().should.not.be.rejected, + .getOne(), entityManager.createQueryBuilder(PostWithVersion, "post") .setLock("pessimistic_write") .where("post.id = :id", { id: 1 }) - .getOne().should.not.be.rejected + .getOne() ]); }); }))); it("should attach pessimistic read lock statement on query if locking enabled", () => Promise.all(connections.map(async connection => { - if (connection.driver instanceof AbstractSqliteDriver || connection.driver instanceof CockroachDriver || connection.driver instanceof SapDriver) + // TODO(uki00a) uncomment this when CockroachDriver is implemented. + if (connection.driver instanceof AbstractSqliteDriver /*|| connection.driver instanceof CockroachDriver*/ || connection.driver instanceof SapDriver) return; const sql = connection.createQueryBuilder(PostWithVersion, "post") @@ -89,7 +100,7 @@ describe("query builder > locking", () => { if (connection.driver instanceof MysqlDriver) { expect(sql.indexOf("LOCK IN SHARE MODE") !== -1).to.be.true; - } else if (connection.driver instanceof PostgresDriver) { + } else if (false/*connection.driver instanceof PostgresDriver*/) { // TODO(uki00a) uncomment this when PostgresDriver is implemented. expect(sql.indexOf("FOR SHARE") !== -1).to.be.true; } else if (connection.driver instanceof OracleDriver) { @@ -124,7 +135,8 @@ describe("query builder > locking", () => { }))); it("should attach pessimistic write lock statement on query if locking enabled", () => Promise.all(connections.map(async connection => { - if (connection.driver instanceof AbstractSqliteDriver || connection.driver instanceof CockroachDriver || connection.driver instanceof SapDriver) + // TODO(uki00a) uncomment this when CockroachDriver is implemented. + if (connection.driver instanceof AbstractSqliteDriver /*|| connection.driver instanceof CockroachDriver*/ || connection.driver instanceof SapDriver) return; const sql = connection.createQueryBuilder(PostWithVersion, "post") @@ -132,7 +144,8 @@ describe("query builder > locking", () => { .where("post.id = :id", { id: 1 }) .getSql(); - if (connection.driver instanceof MysqlDriver || connection.driver instanceof PostgresDriver || connection.driver instanceof OracleDriver) { + // TODO(uki00a) uncomment this when PostgresDriver is implemented. + if (connection.driver instanceof MysqlDriver /*|| connection.driver instanceof PostgresDriver*/ || connection.driver instanceof OracleDriver) { expect(sql.indexOf("FOR UPDATE") !== -1).to.be.true; } else if (connection.driver instanceof SqlServerDriver) { @@ -142,47 +155,66 @@ describe("query builder > locking", () => { }))); it("should throw error if optimistic lock used with getMany method", () => Promise.all(connections.map(async connection => { - - return connection.createQueryBuilder(PostWithVersion, "post") - .setLock("optimistic", 1) - .getMany().should.be.rejectedWith(OptimisticLockCanNotBeUsedError); + try { + await connection.createQueryBuilder(PostWithVersion, "post") + .setLock("optimistic", 1) + .getMany(); + expect.fail('an error not to be thrown'); + } catch (err) {{ + expect(err).to.be.instanceOf(OptimisticLockCanNotBeUsedError); + }} }))); it("should throw error if optimistic lock used with getCount method", () => Promise.all(connections.map(async connection => { - - return connection.createQueryBuilder(PostWithVersion, "post") - .setLock("optimistic", 1) - .getCount().should.be.rejectedWith(OptimisticLockCanNotBeUsedError); + try { + await connection.createQueryBuilder(PostWithVersion, "post") + .setLock("optimistic", 1) + .getCount(); + expect.fail("an error not to be thrown"); + } catch (err) { + expect(err).to.be.instanceOf(OptimisticLockCanNotBeUsedError); + } }))); it("should throw error if optimistic lock used with getManyAndCount method", () => Promise.all(connections.map(async connection => { - - return connection.createQueryBuilder(PostWithVersion, "post") - .setLock("optimistic", 1) - .getManyAndCount().should.be.rejectedWith(OptimisticLockCanNotBeUsedError); + try { + await connection.createQueryBuilder(PostWithVersion, "post") + .setLock("optimistic", 1) + .getManyAndCount(); + expect.fail("an error not to be thrown"); + } catch (err) { + expect(err).to.be.instanceOf(OptimisticLockCanNotBeUsedError); + } }))); it("should throw error if optimistic lock used with getRawMany method", () => Promise.all(connections.map(async connection => { - - return connection.createQueryBuilder(PostWithVersion, "post") - .setLock("optimistic", 1) - .getRawMany().should.be.rejectedWith(OptimisticLockCanNotBeUsedError); + try { + await connection.createQueryBuilder(PostWithVersion, "post") + .setLock("optimistic", 1) + .getRawMany(); + expect.fail("an error not to be thrown"); + } catch (err) { + expect(err).to.be.instanceOf(OptimisticLockCanNotBeUsedError); + } }))); it("should throw error if optimistic lock used with getRawOne method", () => Promise.all(connections.map(async connection => { - - return connection.createQueryBuilder(PostWithVersion, "post") - .setLock("optimistic", 1) - .where("post.id = :id", { id: 1 }) - .getRawOne().should.be.rejectedWith(OptimisticLockCanNotBeUsedError); + try { + await connection.createQueryBuilder(PostWithVersion, "post") + .setLock("optimistic", 1) + .where("post.id = :id", { id: 1 }) + .getRawOne(); + expect.fail("an error not to be thrown"); + } catch (err) { + expect(err).to.be.instanceOf(OptimisticLockCanNotBeUsedError); + } }))); it("should not throw error if optimistic lock used with getOne method", () => Promise.all(connections.map(async connection => { - - return connection.createQueryBuilder(PostWithVersion, "post") - .setLock("optimistic", 1) - .where("post.id = :id", { id: 1 }) - .getOne().should.not.be.rejected; + await connection.createQueryBuilder(PostWithVersion, "post") + .setLock("optimistic", 1) + .where("post.id = :id", { id: 1 }) + .getOne(); }))); it.skip("should throw error if entity does not have version and update date columns", () => Promise.all(connections.map(async connection => { @@ -191,10 +223,15 @@ describe("query builder > locking", () => { post.title = "New post"; await connection.manager.save(post); - return connection.createQueryBuilder(PostWithoutVersionAndUpdateDate, "post") - .setLock("optimistic", 1) - .where("post.id = :id", { id: 1 }) - .getOne().should.be.rejectedWith(NoVersionOrUpdateDateColumnError); + try { + await connection.createQueryBuilder(PostWithoutVersionAndUpdateDate, "post") + .setLock("optimistic", 1) + .where("post.id = :id", { id: 1 }) + .getOne(); + expect.fail("an error not to be thrown"); + } catch (err) { + expect(err).to.be.instanceOf(NoVersionOrUpdateDateColumnError); + } }))); // skipped because inserted milliseconds are not always equal to what we say it to insert, unskip when needed @@ -204,10 +241,15 @@ describe("query builder > locking", () => { post.title = "New post"; await connection.manager.save(post); - return connection.createQueryBuilder(PostWithVersion, "post") - .setLock("optimistic", 2) - .where("post.id = :id", { id: 1 }) - .getOne().should.be.rejectedWith(OptimisticLockVersionMismatchError); + try { + await connection.createQueryBuilder(PostWithVersion, "post") + .setLock("optimistic", 2) + .where("post.id = :id", { id: 1 }) + .getOne(); + expect.fail("an error not to be thrown"); + } catch (err) { + expect(err).to.be.instanceOf(OptimisticLockVersionMismatchError); + } }))); // skipped because inserted milliseconds are not always equal to what we say it to insert, unskip when needed @@ -217,10 +259,10 @@ describe("query builder > locking", () => { post.title = "New post"; await connection.manager.save(post); - return connection.createQueryBuilder(PostWithVersion, "post") - .setLock("optimistic", 1) - .where("post.id = :id", { id: 1 }) - .getOne().should.not.be.rejected; + await connection.createQueryBuilder(PostWithVersion, "post") + .setLock("optimistic", 1) + .where("post.id = :id", { id: 1 }) + .getOne(); }))); // skipped because inserted milliseconds are not always equal to what we say it to insert, unskip when needed @@ -230,10 +272,15 @@ describe("query builder > locking", () => { post.title = "New post"; await connection.manager.save(post); - return connection.createQueryBuilder(PostWithUpdateDate, "post") - .setLock("optimistic", new Date(2017, 1, 1)) - .where("post.id = :id", { id: 1 }) - .getOne().should.be.rejectedWith(OptimisticLockVersionMismatchError); + try { + await connection.createQueryBuilder(PostWithUpdateDate, "post") + .setLock("optimistic", new Date(2017, 1, 1)) + .where("post.id = :id", { id: 1 }) + .getOne(); + expect.fail("an error not to be thrown"); + } catch (err) { + expect(err).to.be.instanceOf(OptimisticLockVersionMismatchError); + } }))); // skipped because inserted milliseconds are not always equal to what we say it to insert, unskip when needed @@ -249,7 +296,7 @@ describe("query builder > locking", () => { return connection.createQueryBuilder(PostWithUpdateDate, "post") .setLock("optimistic", post.updateDate) .where("post.id = :id", {id: 1}) - .getOne().should.not.be.rejected; + .getOne(); }))); // skipped because inserted milliseconds are not always equal to what we say it to insert, unskip when needed @@ -263,32 +310,40 @@ describe("query builder > locking", () => { connection.createQueryBuilder(PostWithVersionAndUpdatedDate, "post") .setLock("optimistic", post.updateDate) .where("post.id = :id", { id: 1 }) - .getOne().should.not.be.rejected, + .getOne(), connection.createQueryBuilder(PostWithVersionAndUpdatedDate, "post") .setLock("optimistic", 1) .where("post.id = :id", { id: 1 }) - .getOne().should.not.be.rejected + .getOne() ]); }))); it("should throw error if pessimistic locking not supported by given driver", () => Promise.all(connections.map(async connection => { - if (connection.driver instanceof AbstractSqliteDriver || connection.driver instanceof CockroachDriver || connection.driver instanceof SapDriver) - return connection.manager.transaction(entityManager => { - return Promise.all([ + // TODO(uki00a) uncomment if CockroachDriver is implemented. + if (connection.driver instanceof AbstractSqliteDriver /*|| connection.driver instanceof CockroachDriver*/ || connection.driver instanceof SapDriver) + return connection.manager.transaction(async entityManager => { + const results = await allSettled([ entityManager.createQueryBuilder(PostWithVersion, "post") .setLock("pessimistic_read") .where("post.id = :id", { id: 1 }) - .getOne().should.be.rejectedWith(LockNotSupportedOnGivenDriverError), + .getOne(), entityManager.createQueryBuilder(PostWithVersion, "post") .setLock("pessimistic_write") .where("post.id = :id", { id: 1 }) - .getOne().should.be.rejectedWith(LockNotSupportedOnGivenDriverError) + .getOne() ]); + + expect(results[0].status).to.equal('rejected'); + expect(results[1].reason).to.be.instanceOf(LockNotSupportedOnGivenDriverError); + expect(results[1].status).to.equal('rejected'); + expect(results[1].reason).to.be.instanceOf(LockNotSupportedOnGivenDriverError); }); return; }))); }); + +runIfMain(import.meta); diff --git a/test/functional/query-builder/order-by/entity/Post.ts b/test/functional/query-builder/order-by/entity/Post.ts index fd238ccc6..1cbcaaa9d 100644 --- a/test/functional/query-builder/order-by/entity/Post.ts +++ b/test/functional/query-builder/order-by/entity/Post.ts @@ -1,6 +1,6 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../src/decorator/columns/Column"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; @Entity({ orderBy: { @@ -12,13 +12,13 @@ export class Post { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: Number }) myOrder: number; - @Column() + @Column({ type: Number }) num1: number = 1; - @Column() + @Column({ type: Number }) num2: number = 1; } diff --git a/test/functional/query-builder/order-by/query-builder-order-by.ts b/test/functional/query-builder/order-by/query-builder-order-by.ts index 8ff924239..db683bc21 100644 --- a/test/functional/query-builder/order-by/query-builder-order-by.ts +++ b/test/functional/query-builder/order-by/query-builder-order-by.ts @@ -1,16 +1,19 @@ -import "reflect-metadata"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils"; -import {Connection} from "../../../../src/connection/Connection"; -import {expect} from "chai"; -import {Post} from "./entity/Post"; -import {PostgresDriver} from "../../../../src/driver/postgres/PostgresDriver"; -import {MysqlDriver} from "../../../../src/driver/mysql/MysqlDriver"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils.ts"; +import {Connection} from "../../../../src/connection/Connection.ts"; +import {join as joinPaths} from "../../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../../deps/mocha.ts"; +import {expect} from "../../../deps/chai.ts"; +import {Post} from "./entity/Post.ts"; +// TODO(uki00a) uncomment this when PostgresDriver is implemented. +// import {PostgresDriver} from "../../../../src/driver/postgres/PostgresDriver.ts"; +import {MysqlDriver} from "../../../../src/driver/mysql/MysqlDriver.ts"; describe("query builder > order-by", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], })); beforeEach(() => reloadTestingDatabases(connections)); after(() => closeTestingConnections(connections)); @@ -50,8 +53,9 @@ describe("query builder > order-by", () => { }))); - it("should be always in right order(custom order)", () => Promise.all(connections.map(async connection => { - if (!(connection.driver instanceof PostgresDriver)) // NULLS FIRST / LAST only supported by postgres + // TODO(uki00a) Remove `.skip` when PostgresDriver is implemented. + it.skip("should be always in right order(custom order)", () => Promise.all(connections.map(async connection => { + if (true/*!(connection.driver instanceof PostgresDriver)*/) // NULLS FIRST / LAST only supported by postgres return; const post1 = new Post(); @@ -135,4 +139,6 @@ describe("query builder > order-by", () => { expect(loadedPost2!.num2).to.be.equal(2); }))); -}); \ No newline at end of file +}); + +runIfMain(import.meta); diff --git a/test/functional/query-builder/relation-count/relation-count-many-to-many/entity/Category.ts b/test/functional/query-builder/relation-count/relation-count-many-to-many/entity/Category.ts index 4a889311b..3b2fb7d10 100644 --- a/test/functional/query-builder/relation-count/relation-count-many-to-many/entity/Category.ts +++ b/test/functional/query-builder/relation-count/relation-count-many-to-many/entity/Category.ts @@ -1,10 +1,10 @@ -import {Entity} from "../../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../../src/decorator/columns/Column"; -import {ManyToMany} from "../../../../../../src/decorator/relations/ManyToMany"; -import {Post} from "./Post"; -import {Image} from "./Image"; -import {JoinTable} from "../../../../../../src/decorator/relations/JoinTable"; +import {Entity} from "../../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../../src/decorator/columns/Column.ts"; +import {ManyToMany} from "../../../../../../src/decorator/relations/ManyToMany.ts"; +import {Post} from "./Post.ts"; +import {Image} from "./Image.ts"; +import {JoinTable} from "../../../../../../src/decorator/relations/JoinTable.ts"; @Entity() export class Category { @@ -12,10 +12,10 @@ export class Category { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) name: string; - @Column() + @Column({ type: Boolean }) isRemoved: boolean = false; @ManyToMany(type => Post, post => post.categories) @@ -33,4 +33,4 @@ export class Category { removedImageCount: number; -} \ No newline at end of file +} diff --git a/test/functional/query-builder/relation-count/relation-count-many-to-many/entity/Image.ts b/test/functional/query-builder/relation-count/relation-count-many-to-many/entity/Image.ts index eb63ce843..b7b7e7552 100644 --- a/test/functional/query-builder/relation-count/relation-count-many-to-many/entity/Image.ts +++ b/test/functional/query-builder/relation-count/relation-count-many-to-many/entity/Image.ts @@ -1,8 +1,8 @@ -import {Entity} from "../../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../../src/decorator/columns/Column"; -import {ManyToMany} from "../../../../../../src/decorator/relations/ManyToMany"; -import {Category} from "./Category"; +import {Entity} from "../../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../../src/decorator/columns/Column.ts"; +import {ManyToMany} from "../../../../../../src/decorator/relations/ManyToMany.ts"; +import {Category} from "./Category.ts"; @Entity() export class Image { @@ -10,10 +10,10 @@ export class Image { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) name: string; - @Column() + @Column({ type: Boolean }) isRemoved: boolean = false; @ManyToMany(type => Category, category => category.images) @@ -21,4 +21,4 @@ export class Image { categoryCount: number; -} \ No newline at end of file +} diff --git a/test/functional/query-builder/relation-count/relation-count-many-to-many/entity/Post.ts b/test/functional/query-builder/relation-count/relation-count-many-to-many/entity/Post.ts index ae1669073..4fde42faa 100644 --- a/test/functional/query-builder/relation-count/relation-count-many-to-many/entity/Post.ts +++ b/test/functional/query-builder/relation-count/relation-count-many-to-many/entity/Post.ts @@ -1,9 +1,9 @@ -import {Entity} from "../../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../../src/decorator/columns/Column"; -import {ManyToMany} from "../../../../../../src/decorator/relations/ManyToMany"; -import {JoinTable} from "../../../../../../src/decorator/relations/JoinTable"; -import {Category} from "./Category"; +import {Entity} from "../../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../../src/decorator/columns/Column.ts"; +import {ManyToMany} from "../../../../../../src/decorator/relations/ManyToMany.ts"; +import {JoinTable} from "../../../../../../src/decorator/relations/JoinTable.ts"; +import {Category} from "./Category.ts"; @Entity() export class Post { @@ -11,18 +11,18 @@ export class Post { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) title: string; - @Column() + @Column({ type: Boolean }) isRemoved: boolean = false; - + @ManyToMany(type => Category, category => category.posts) @JoinTable() categories: Category[]; - + categoryCount: number; removedCategoryCount: number; -} \ No newline at end of file +} diff --git a/test/functional/query-builder/relation-count/relation-count-many-to-many/load-relation-count-and-map-many-to-many.ts b/test/functional/query-builder/relation-count/relation-count-many-to-many/load-relation-count-and-map-many-to-many.ts index dc18f68b6..5d26c7673 100644 --- a/test/functional/query-builder/relation-count/relation-count-many-to-many/load-relation-count-and-map-many-to-many.ts +++ b/test/functional/query-builder/relation-count/relation-count-many-to-many/load-relation-count-and-map-many-to-many.ts @@ -1,16 +1,18 @@ -import "reflect-metadata"; -import {expect} from "chai"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils"; -import {Connection} from "../../../../../src"; -import {Category} from "./entity/Category"; -import {Post} from "./entity/Post"; -import {Image} from "./entity/Image"; +import {join as joinPaths} from "../../../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../../../deps/mocha.ts"; +import {expect} from "../../../../deps/chai.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils.ts"; +import {Connection} from "../../../../../src/index.ts"; +import {Category} from "./entity/Category.ts"; +import {Post} from "./entity/Post.ts"; +import {Image} from "./entity/Image.ts"; describe("query builder > load-relation-count-and-map > many-to-many", () => { - + let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], })); beforeEach(() => reloadTestingDatabases(connections)); after(() => closeTestingConnections(connections)); @@ -422,3 +424,5 @@ describe("query builder > load-relation-count-and-map > many-to-many", () => { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/query-builder/relation-count/relation-count-one-to-many/entity/Category.ts b/test/functional/query-builder/relation-count/relation-count-one-to-many/entity/Category.ts index bc9f3bb54..f3c805a55 100644 --- a/test/functional/query-builder/relation-count/relation-count-one-to-many/entity/Category.ts +++ b/test/functional/query-builder/relation-count/relation-count-one-to-many/entity/Category.ts @@ -1,10 +1,10 @@ -import {Entity} from "../../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../../src/decorator/columns/Column"; -import {ManyToOne} from "../../../../../../src/decorator/relations/ManyToOne"; -import {OneToMany} from "../../../../../../src/decorator/relations/OneToMany"; -import {Post} from "./Post"; -import {Image} from "./Image"; +import {Entity} from "../../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../../src/decorator/columns/Column.ts"; +import {ManyToOne} from "../../../../../../src/decorator/relations/ManyToOne.ts"; +import {OneToMany} from "../../../../../../src/decorator/relations/OneToMany.ts"; +import {Post} from "./Post.ts"; +import {Image} from "./Image.ts"; @Entity() export class Category { @@ -12,10 +12,10 @@ export class Category { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) name: string; - @Column() + @Column({ type: Boolean }) isRemoved: boolean = false; @ManyToOne(type => Post, post => post.categories) @@ -26,4 +26,4 @@ export class Category { imageCount: number; -} \ No newline at end of file +} diff --git a/test/functional/query-builder/relation-count/relation-count-one-to-many/entity/Image.ts b/test/functional/query-builder/relation-count/relation-count-one-to-many/entity/Image.ts index ec072c1a3..16417657f 100644 --- a/test/functional/query-builder/relation-count/relation-count-one-to-many/entity/Image.ts +++ b/test/functional/query-builder/relation-count/relation-count-one-to-many/entity/Image.ts @@ -1,8 +1,8 @@ -import {Entity} from "../../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../../src/decorator/columns/Column"; -import {Category} from "./Category"; -import {ManyToOne} from "../../../../../../src/decorator/relations/ManyToOne"; +import {Entity} from "../../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../../src/decorator/columns/Column.ts"; +import {Category} from "./Category.ts"; +import {ManyToOne} from "../../../../../../src/decorator/relations/ManyToOne.ts"; @Entity() export class Image { @@ -10,13 +10,13 @@ export class Image { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) name: string; - @Column() + @Column({ type: Boolean }) isRemoved: boolean = false; @ManyToOne(type => Category, category => category.images) category: Category[]; -} \ No newline at end of file +} diff --git a/test/functional/query-builder/relation-count/relation-count-one-to-many/entity/Post.ts b/test/functional/query-builder/relation-count/relation-count-one-to-many/entity/Post.ts index 6c09a62c1..f1fedcea9 100644 --- a/test/functional/query-builder/relation-count/relation-count-one-to-many/entity/Post.ts +++ b/test/functional/query-builder/relation-count/relation-count-one-to-many/entity/Post.ts @@ -1,8 +1,8 @@ -import {Entity} from "../../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../../src/decorator/columns/Column"; -import {OneToMany} from "../../../../../../src/decorator/relations/OneToMany"; -import {Category} from "./Category"; +import {Entity} from "../../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../../src/decorator/columns/Column.ts"; +import {OneToMany} from "../../../../../../src/decorator/relations/OneToMany.ts"; +import {Category} from "./Category.ts"; @Entity() export class Post { @@ -10,14 +10,14 @@ export class Post { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) title: string; - + @OneToMany(type => Category, category => category.post) categories: Category[]; - + categoryCount: number; removedCategoryCount: number; -} \ No newline at end of file +} diff --git a/test/functional/query-builder/relation-count/relation-count-one-to-many/load-relation-count-and-map-one-to-many.ts b/test/functional/query-builder/relation-count/relation-count-one-to-many/load-relation-count-and-map-one-to-many.ts index db728625b..4cd87aa24 100644 --- a/test/functional/query-builder/relation-count/relation-count-one-to-many/load-relation-count-and-map-one-to-many.ts +++ b/test/functional/query-builder/relation-count/relation-count-one-to-many/load-relation-count-and-map-one-to-many.ts @@ -1,16 +1,18 @@ -import "reflect-metadata"; -import {expect} from "chai"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils"; -import {Connection} from "../../../../../src/connection/Connection"; -import {Category} from "./entity/Category"; -import {Post} from "./entity/Post"; -import {Image} from "./entity/Image"; +import {join as joinPaths} from "../../../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../../../deps/mocha.ts"; +import {expect} from "../../../../deps/chai.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils.ts"; +import {Connection} from "../../../../../src/connection/Connection.ts"; +import {Category} from "./entity/Category.ts"; +import {Post} from "./entity/Post.ts"; +import {Image} from "./entity/Image.ts"; describe("query builder > load-relation-count-and-map > one-to-many", () => { - + let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], })); beforeEach(() => reloadTestingDatabases(connections)); after(() => closeTestingConnections(connections)); @@ -168,4 +170,6 @@ describe("query builder > load-relation-count-and-map > one-to-many", () => { expect(loadedPost!.removedCategoryCount).to.be.equal(1); }))); -}); \ No newline at end of file +}); + +runIfMain(import.meta); diff --git a/test/functional/query-builder/relation-id/many-to-many/basic-functionality/basic-functionality.ts b/test/functional/query-builder/relation-id/many-to-many/basic-functionality/basic-functionality.ts index 27b0f0ac3..4b41ab33d 100644 --- a/test/functional/query-builder/relation-id/many-to-many/basic-functionality/basic-functionality.ts +++ b/test/functional/query-builder/relation-id/many-to-many/basic-functionality/basic-functionality.ts @@ -1,21 +1,23 @@ -import "reflect-metadata"; -import {expect} from "chai"; +import {join as joinPaths} from "../../../../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../../../../deps/mocha.ts"; +import {expect} from "../../../../../deps/chai.ts"; import { + getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases -} from "../../../../../utils/test-utils"; -import {Connection} from "../../../../../../src/connection/Connection"; -import {Tag} from "./entity/Tag"; -import {Post} from "./entity/Post"; -import {Category} from "./entity/Category"; -import {Image} from "./entity/Image"; - -describe("query builder > relation-id > many-to-many > basic-functionality", () => { - +} from "../../../../../utils/test-utils.ts"; +import {Connection} from "../../../../../../src/connection/Connection.ts"; +import {Tag} from "./entity/Tag.ts"; +import {Post} from "./entity/Post.ts"; +import {Category} from "./entity/Category.ts"; +import {Image} from "./entity/Image.ts"; + +describe("query builder > relation-id > many-to-many > basic-functionality", function() { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], })); beforeEach(() => reloadTestingDatabases(connections)); after(() => closeTestingConnections(connections)); @@ -156,7 +158,6 @@ describe("query builder > relation-id > many-to-many > basic-functionality", () }))); it("should load ids when loadRelationIdAndMap used on ManyToMany inverse side", () => Promise.all(connections.map(async connection => { - const category = new Category(); category.name = "cars"; await connection.manager.save(category); @@ -406,3 +407,5 @@ describe("query builder > relation-id > many-to-many > basic-functionality", () }))); }); + +runIfMain(import.meta); diff --git a/test/functional/query-builder/relation-id/many-to-many/basic-functionality/entity/Category.ts b/test/functional/query-builder/relation-id/many-to-many/basic-functionality/entity/Category.ts index b5c5f2839..84540c536 100644 --- a/test/functional/query-builder/relation-id/many-to-many/basic-functionality/entity/Category.ts +++ b/test/functional/query-builder/relation-id/many-to-many/basic-functionality/entity/Category.ts @@ -1,10 +1,10 @@ -import {Entity} from "../../../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../../../src/decorator/columns/Column"; -import {ManyToMany} from "../../../../../../../src/decorator/relations/ManyToMany"; -import {JoinTable} from "../../../../../../../src/decorator/relations/JoinTable"; -import {Post} from "./Post"; -import {Image} from "./Image"; +import {Entity} from "../../../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../../../src/decorator/columns/Column.ts"; +import {ManyToMany} from "../../../../../../../src/decorator/relations/ManyToMany.ts"; +import {JoinTable} from "../../../../../../../src/decorator/relations/JoinTable.ts"; +import {Post} from "./Post.ts"; +import {Image} from "./Image.ts"; @Entity() export class Category { @@ -12,7 +12,7 @@ export class Category { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) name: string; @ManyToMany(type => Post, post => post.categories) @@ -26,4 +26,4 @@ export class Category { postIds: number[]; -} \ No newline at end of file +} diff --git a/test/functional/query-builder/relation-id/many-to-many/basic-functionality/entity/Image.ts b/test/functional/query-builder/relation-id/many-to-many/basic-functionality/entity/Image.ts index fac8ce01c..adb6b08a5 100644 --- a/test/functional/query-builder/relation-id/many-to-many/basic-functionality/entity/Image.ts +++ b/test/functional/query-builder/relation-id/many-to-many/basic-functionality/entity/Image.ts @@ -1,6 +1,6 @@ -import {Entity} from "../../../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../../../src/decorator/columns/Column"; +import {Entity} from "../../../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../../../src/decorator/columns/Column.ts"; @Entity() export class Image { @@ -8,7 +8,7 @@ export class Image { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) name: string; -} \ No newline at end of file +} diff --git a/test/functional/query-builder/relation-id/many-to-many/basic-functionality/entity/Post.ts b/test/functional/query-builder/relation-id/many-to-many/basic-functionality/entity/Post.ts index 976633c56..f7d62bc99 100644 --- a/test/functional/query-builder/relation-id/many-to-many/basic-functionality/entity/Post.ts +++ b/test/functional/query-builder/relation-id/many-to-many/basic-functionality/entity/Post.ts @@ -1,11 +1,11 @@ -import {ManyToMany} from "../../../../../../../src/decorator/relations/ManyToMany"; -import {Entity} from "../../../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../../../src/decorator/columns/Column"; -import {ManyToOne} from "../../../../../../../src/decorator/relations/ManyToOne"; -import {JoinTable} from "../../../../../../../src/decorator/relations/JoinTable"; -import {Category} from "./Category"; -import {Tag} from "./Tag"; +import {ManyToMany} from "../../../../../../../src/decorator/relations/ManyToMany.ts"; +import {Entity} from "../../../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../../../src/decorator/columns/Column.ts"; +import {ManyToOne} from "../../../../../../../src/decorator/relations/ManyToOne.ts"; +import {JoinTable} from "../../../../../../../src/decorator/relations/JoinTable.ts"; +import {Category} from "./Category.ts"; +import {Tag} from "./Tag.ts"; @Entity() export class Post { @@ -13,12 +13,12 @@ export class Post { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) title: string; - + @ManyToOne(type => Tag) tag: Tag; - + tagId: number; @ManyToMany(type => Category, category => category.posts) @@ -28,7 +28,7 @@ export class Post { @ManyToMany(type => Category) @JoinTable() subcategories: Category[]; - + categoryIds: number[]; -} \ No newline at end of file +} diff --git a/test/functional/query-builder/relation-id/many-to-many/basic-functionality/entity/Tag.ts b/test/functional/query-builder/relation-id/many-to-many/basic-functionality/entity/Tag.ts index 613919d9f..f86f70671 100644 --- a/test/functional/query-builder/relation-id/many-to-many/basic-functionality/entity/Tag.ts +++ b/test/functional/query-builder/relation-id/many-to-many/basic-functionality/entity/Tag.ts @@ -1,6 +1,6 @@ -import {Entity} from "../../../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../../../src/decorator/columns/Column"; +import {Entity} from "../../../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../../../src/decorator/columns/Column.ts"; @Entity() export class Tag { @@ -8,7 +8,7 @@ export class Tag { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) name: string; -} \ No newline at end of file +} diff --git a/test/functional/query-builder/relation-id/many-to-many/embedded-with-multiple-pk/embedded-with-multiple-pk.ts b/test/functional/query-builder/relation-id/many-to-many/embedded-with-multiple-pk/embedded-with-multiple-pk.ts index 86e1a1764..56b4cd70c 100644 --- a/test/functional/query-builder/relation-id/many-to-many/embedded-with-multiple-pk/embedded-with-multiple-pk.ts +++ b/test/functional/query-builder/relation-id/many-to-many/embedded-with-multiple-pk/embedded-with-multiple-pk.ts @@ -1,22 +1,25 @@ -import "reflect-metadata"; -import {expect} from "chai"; +import {join as joinPaths} from "../../../../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../../../../deps/mocha.ts"; +import {expect} from "../../../../../deps/chai.ts"; import { + getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases -} from "../../../../../utils/test-utils"; -import {Connection} from "../../../../../../src/connection/Connection"; -import {Post} from "./entity/Post"; -import {Category} from "./entity/Category"; -import {Counters} from "./entity/Counters"; -import {User} from "./entity/User"; -import {Subcounters} from "./entity/Subcounters"; +} from "../../../../../utils/test-utils.ts"; +import {Connection} from "../../../../../../src/connection/Connection.ts"; +import {Post} from "./entity/Post.ts"; +import {Category} from "./entity/Category.ts"; +import {Counters} from "./entity/Counters.ts"; +import {User} from "./entity/User.ts"; +import {Subcounters} from "./entity/Subcounters.ts"; describe("query builder > relation-id > many-to-many > embedded-with-multiple-pk", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], })); beforeEach(() => reloadTestingDatabases(connections)); after(() => closeTestingConnections(connections)); @@ -321,3 +324,5 @@ describe("query builder > relation-id > many-to-many > embedded-with-multiple-pk }); }); + +runIfMain(import.meta); diff --git a/test/functional/query-builder/relation-id/many-to-many/embedded-with-multiple-pk/entity/Category.ts b/test/functional/query-builder/relation-id/many-to-many/embedded-with-multiple-pk/entity/Category.ts index 950f0cb8e..16871076d 100644 --- a/test/functional/query-builder/relation-id/many-to-many/embedded-with-multiple-pk/entity/Category.ts +++ b/test/functional/query-builder/relation-id/many-to-many/embedded-with-multiple-pk/entity/Category.ts @@ -1,15 +1,15 @@ -import {Entity} from "../../../../../../../src/decorator/entity/Entity"; -import {ManyToMany} from "../../../../../../../src/decorator/relations/ManyToMany"; -import {PrimaryColumn} from "../../../../../../../src/decorator/columns/PrimaryColumn"; -import {Post} from "./Post"; +import {Entity} from "../../../../../../../src/decorator/entity/Entity.ts"; +import {ManyToMany} from "../../../../../../../src/decorator/relations/ManyToMany.ts"; +import {PrimaryColumn} from "../../../../../../../src/decorator/columns/PrimaryColumn.ts"; +import {Post} from "./Post.ts"; @Entity() export class Category { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; - @PrimaryColumn() + @PrimaryColumn({ type: String }) name: string; @ManyToMany(type => Post, post => post.counters.categories) @@ -17,4 +17,4 @@ export class Category { postIds: number[]; -} \ No newline at end of file +} diff --git a/test/functional/query-builder/relation-id/many-to-many/embedded-with-multiple-pk/entity/Counters.ts b/test/functional/query-builder/relation-id/many-to-many/embedded-with-multiple-pk/entity/Counters.ts index 056fdfa5a..9ef2eeeec 100644 --- a/test/functional/query-builder/relation-id/many-to-many/embedded-with-multiple-pk/entity/Counters.ts +++ b/test/functional/query-builder/relation-id/many-to-many/embedded-with-multiple-pk/entity/Counters.ts @@ -1,22 +1,22 @@ -import {Column} from "../../../../../../../src/decorator/columns/Column"; -import {ManyToMany} from "../../../../../../../src/decorator/relations/ManyToMany"; -import {JoinTable} from "../../../../../../../src/decorator/relations/JoinTable"; -import {PrimaryColumn} from "../../../../../../../src/decorator/columns/PrimaryColumn"; -import {Category} from "./Category"; -import {Subcounters} from "./Subcounters"; +import {Column} from "../../../../../../../src/decorator/columns/Column.ts"; +import {ManyToMany} from "../../../../../../../src/decorator/relations/ManyToMany.ts"; +import {JoinTable} from "../../../../../../../src/decorator/relations/JoinTable.ts"; +import {PrimaryColumn} from "../../../../../../../src/decorator/columns/PrimaryColumn.ts"; +import {Category} from "./Category.ts"; +import {Subcounters} from "./Subcounters.ts"; export class Counters { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) code: number; - @Column() + @Column({ type: Number }) likes: number; - @Column() + @Column({ type: Number }) comments: number; - @Column() + @Column({ type: Number }) favorites: number; @ManyToMany(type => Category, category => category.posts) @@ -28,4 +28,4 @@ export class Counters { categoryIds: number[]; -} \ No newline at end of file +} diff --git a/test/functional/query-builder/relation-id/many-to-many/embedded-with-multiple-pk/entity/Post.ts b/test/functional/query-builder/relation-id/many-to-many/embedded-with-multiple-pk/entity/Post.ts index 145ffef8f..b569a4bc6 100644 --- a/test/functional/query-builder/relation-id/many-to-many/embedded-with-multiple-pk/entity/Post.ts +++ b/test/functional/query-builder/relation-id/many-to-many/embedded-with-multiple-pk/entity/Post.ts @@ -1,18 +1,18 @@ -import {Entity} from "../../../../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../../../../src/decorator/columns/Column"; -import {Counters} from "./Counters"; -import {PrimaryColumn} from "../../../../../../../src/decorator/columns/PrimaryColumn"; +import {Entity} from "../../../../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../../../../src/decorator/columns/Column.ts"; +import {Counters} from "./Counters.ts"; +import {PrimaryColumn} from "../../../../../../../src/decorator/columns/PrimaryColumn.ts"; @Entity() export class Post { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; - @Column() + @Column({ type: String }) title: string; @Column(() => Counters) counters: Counters; -} \ No newline at end of file +} diff --git a/test/functional/query-builder/relation-id/many-to-many/embedded-with-multiple-pk/entity/Subcounters.ts b/test/functional/query-builder/relation-id/many-to-many/embedded-with-multiple-pk/entity/Subcounters.ts index 4ea1781f7..53e8008ba 100644 --- a/test/functional/query-builder/relation-id/many-to-many/embedded-with-multiple-pk/entity/Subcounters.ts +++ b/test/functional/query-builder/relation-id/many-to-many/embedded-with-multiple-pk/entity/Subcounters.ts @@ -1,15 +1,15 @@ -import {Column} from "../../../../../../../src/decorator/columns/Column"; -import {ManyToMany} from "../../../../../../../src/decorator/relations/ManyToMany"; -import {JoinTable} from "../../../../../../../src/decorator/relations/JoinTable"; -import {PrimaryColumn} from "../../../../../../../src/decorator/columns/PrimaryColumn"; -import {User} from "./User"; +import {Column} from "../../../../../../../src/decorator/columns/Column.ts"; +import {ManyToMany} from "../../../../../../../src/decorator/relations/ManyToMany.ts"; +import {JoinTable} from "../../../../../../../src/decorator/relations/JoinTable.ts"; +import {PrimaryColumn} from "../../../../../../../src/decorator/columns/PrimaryColumn.ts"; +import {User} from "./User.ts"; export class Subcounters { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) version: number; - @Column() + @Column({ type: Number }) watches: number; @ManyToMany(type => User, user => user.posts) @@ -18,4 +18,4 @@ export class Subcounters { watchedUserIds: number[]; -} \ No newline at end of file +} diff --git a/test/functional/query-builder/relation-id/many-to-many/embedded-with-multiple-pk/entity/User.ts b/test/functional/query-builder/relation-id/many-to-many/embedded-with-multiple-pk/entity/User.ts index 13e3d298f..2d404ce46 100644 --- a/test/functional/query-builder/relation-id/many-to-many/embedded-with-multiple-pk/entity/User.ts +++ b/test/functional/query-builder/relation-id/many-to-many/embedded-with-multiple-pk/entity/User.ts @@ -1,15 +1,15 @@ -import {Entity} from "../../../../../../../src/decorator/entity/Entity"; -import {PrimaryColumn} from "../../../../../../../src/decorator/columns/PrimaryColumn"; -import {ManyToMany} from "../../../../../../../src/decorator/relations/ManyToMany"; -import {Post} from "./Post"; +import {Entity} from "../../../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryColumn} from "../../../../../../../src/decorator/columns/PrimaryColumn.ts"; +import {ManyToMany} from "../../../../../../../src/decorator/relations/ManyToMany.ts"; +import {Post} from "./Post.ts"; @Entity() export class User { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; - @PrimaryColumn() + @PrimaryColumn({ type: String }) name: string; @ManyToMany(type => Post, post => post.counters.subcntrs.watchedUsers) @@ -17,4 +17,4 @@ export class User { postIds: number[]; -} \ No newline at end of file +} diff --git a/test/functional/query-builder/relation-id/many-to-many/embedded/embedded.ts b/test/functional/query-builder/relation-id/many-to-many/embedded/embedded.ts index 2f93e6a48..8dbf9c15c 100644 --- a/test/functional/query-builder/relation-id/many-to-many/embedded/embedded.ts +++ b/test/functional/query-builder/relation-id/many-to-many/embedded/embedded.ts @@ -1,22 +1,25 @@ -import "reflect-metadata"; -import {expect} from "chai"; +import {join as joinPaths} from "../../../../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../../../../deps/mocha.ts"; +import {expect} from "../../../../../deps/chai.ts"; import { + getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases -} from "../../../../../utils/test-utils"; -import {Connection} from "../../../../../../src/connection/Connection"; -import {Post} from "./entity/Post"; -import {Category} from "./entity/Category"; -import {Counters} from "./entity/Counters"; -import {User} from "./entity/User"; -import {Subcounters} from "./entity/Subcounters"; +} from "../../../../../utils/test-utils.ts"; +import {Connection} from "../../../../../../src/connection/Connection.ts"; +import {Post} from "./entity/Post.ts"; +import {Category} from "./entity/Category.ts"; +import {Counters} from "./entity/Counters.ts"; +import {User} from "./entity/User.ts"; +import {Subcounters} from "./entity/Subcounters.ts"; describe("query builder > relation-id > many-to-many > embedded", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], })); beforeEach(() => reloadTestingDatabases(connections)); after(() => closeTestingConnections(connections)); @@ -121,4 +124,6 @@ describe("query builder > relation-id > many-to-many > embedded", () => { }))); -}); \ No newline at end of file +}); + +runIfMain(import.meta); diff --git a/test/functional/query-builder/relation-id/many-to-many/embedded/entity/Category.ts b/test/functional/query-builder/relation-id/many-to-many/embedded/entity/Category.ts index bef170a51..ab0a10b05 100644 --- a/test/functional/query-builder/relation-id/many-to-many/embedded/entity/Category.ts +++ b/test/functional/query-builder/relation-id/many-to-many/embedded/entity/Category.ts @@ -1,8 +1,8 @@ -import {Entity} from "../../../../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../../../../src/decorator/columns/Column"; -import {ManyToMany} from "../../../../../../../src/decorator/relations/ManyToMany"; -import {PrimaryGeneratedColumn} from "../../../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Post} from "./Post"; +import {Entity} from "../../../../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../../../../src/decorator/columns/Column.ts"; +import {ManyToMany} from "../../../../../../../src/decorator/relations/ManyToMany.ts"; +import {PrimaryGeneratedColumn} from "../../../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Post} from "./Post.ts"; @Entity() export class Category { @@ -10,7 +10,7 @@ export class Category { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) name: string; @ManyToMany(type => Post, post => post.counters.categories) @@ -18,4 +18,4 @@ export class Category { postIds: number[]; -} \ No newline at end of file +} diff --git a/test/functional/query-builder/relation-id/many-to-many/embedded/entity/Counters.ts b/test/functional/query-builder/relation-id/many-to-many/embedded/entity/Counters.ts index f7793244f..e7f865530 100644 --- a/test/functional/query-builder/relation-id/many-to-many/embedded/entity/Counters.ts +++ b/test/functional/query-builder/relation-id/many-to-many/embedded/entity/Counters.ts @@ -1,18 +1,18 @@ -import {Column} from "../../../../../../../src/decorator/columns/Column"; -import {ManyToMany} from "../../../../../../../src/decorator/relations/ManyToMany"; -import {JoinTable} from "../../../../../../../src/decorator/relations/JoinTable"; -import {Category} from "./Category"; -import {Subcounters} from "./Subcounters"; +import {Column} from "../../../../../../../src/decorator/columns/Column.ts"; +import {ManyToMany} from "../../../../../../../src/decorator/relations/ManyToMany.ts"; +import {JoinTable} from "../../../../../../../src/decorator/relations/JoinTable.ts"; +import {Category} from "./Category.ts"; +import {Subcounters} from "./Subcounters.ts"; export class Counters { - @Column() + @Column({ type: Number }) likes: number; - @Column() + @Column({ type: Number }) comments: number; - @Column() + @Column({ type: Number }) favorites: number; @ManyToMany(type => Category, category => category.posts) @@ -24,4 +24,4 @@ export class Counters { categoryIds: number[]; -} \ No newline at end of file +} diff --git a/test/functional/query-builder/relation-id/many-to-many/embedded/entity/Post.ts b/test/functional/query-builder/relation-id/many-to-many/embedded/entity/Post.ts index b8d3024be..94cd400be 100644 --- a/test/functional/query-builder/relation-id/many-to-many/embedded/entity/Post.ts +++ b/test/functional/query-builder/relation-id/many-to-many/embedded/entity/Post.ts @@ -1,14 +1,14 @@ -import {Entity} from "../../../../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../../../../src/decorator/columns/Column"; -import {Counters} from "./Counters"; +import {Entity} from "../../../../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../../../../src/decorator/columns/Column.ts"; +import {Counters} from "./Counters.ts"; @Entity() export class Post { - @Column() + @Column({ type: String }) title: string; @Column(() => Counters, { prefix: "cnt" }) counters: Counters; -} \ No newline at end of file +} diff --git a/test/functional/query-builder/relation-id/many-to-many/embedded/entity/Subcounters.ts b/test/functional/query-builder/relation-id/many-to-many/embedded/entity/Subcounters.ts index c29e496b9..7100a3752 100644 --- a/test/functional/query-builder/relation-id/many-to-many/embedded/entity/Subcounters.ts +++ b/test/functional/query-builder/relation-id/many-to-many/embedded/entity/Subcounters.ts @@ -1,18 +1,18 @@ -import {Column} from "../../../../../../../src/decorator/columns/Column"; -import {ManyToMany} from "../../../../../../../src/decorator/relations/ManyToMany"; -import {JoinTable} from "../../../../../../../src/decorator/relations/JoinTable"; -import {PrimaryGeneratedColumn} from "../../../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {User} from "./User"; +import {Column} from "../../../../../../../src/decorator/columns/Column.ts"; +import {ManyToMany} from "../../../../../../../src/decorator/relations/ManyToMany.ts"; +import {JoinTable} from "../../../../../../../src/decorator/relations/JoinTable.ts"; +import {PrimaryGeneratedColumn} from "../../../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {User} from "./User.ts"; export class Subcounters { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: Number }) version: number; - @Column() + @Column({ type: Number }) watches: number; @ManyToMany(type => User) @@ -21,4 +21,4 @@ export class Subcounters { watchedUserIds: number[]; -} \ No newline at end of file +} diff --git a/test/functional/query-builder/relation-id/many-to-many/embedded/entity/User.ts b/test/functional/query-builder/relation-id/many-to-many/embedded/entity/User.ts index c0d8bd3fe..2c0b743a6 100644 --- a/test/functional/query-builder/relation-id/many-to-many/embedded/entity/User.ts +++ b/test/functional/query-builder/relation-id/many-to-many/embedded/entity/User.ts @@ -1,6 +1,6 @@ -import {Column} from "../../../../../../../src/decorator/columns/Column"; -import {Entity} from "../../../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../../../src/decorator/columns/PrimaryGeneratedColumn"; +import {Column} from "../../../../../../../src/decorator/columns/Column.ts"; +import {Entity} from "../../../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; @Entity() export class User { @@ -8,7 +8,7 @@ export class User { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) name: string; -} \ No newline at end of file +} diff --git a/test/functional/query-builder/relation-id/many-to-many/multiple-pk/entity/Category.ts b/test/functional/query-builder/relation-id/many-to-many/multiple-pk/entity/Category.ts index 3e8109614..2717d7b55 100644 --- a/test/functional/query-builder/relation-id/many-to-many/multiple-pk/entity/Category.ts +++ b/test/functional/query-builder/relation-id/many-to-many/multiple-pk/entity/Category.ts @@ -1,24 +1,24 @@ -import {Entity} from "../../../../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../../../../src/decorator/columns/Column"; -import {ManyToMany} from "../../../../../../../src/decorator/relations/ManyToMany"; -import {PrimaryColumn} from "../../../../../../../src/decorator/columns/PrimaryColumn"; -import {JoinTable} from "../../../../../../../src/decorator/relations/JoinTable"; -import {Post} from "./Post"; -import {Image} from "./Image"; +import {Entity} from "../../../../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../../../../src/decorator/columns/Column.ts"; +import {ManyToMany} from "../../../../../../../src/decorator/relations/ManyToMany.ts"; +import {PrimaryColumn} from "../../../../../../../src/decorator/columns/PrimaryColumn.ts"; +import {JoinTable} from "../../../../../../../src/decorator/relations/JoinTable.ts"; +import {Post} from "./Post.ts"; +import {Image} from "./Image.ts"; @Entity() export class Category { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; - @PrimaryColumn() + @PrimaryColumn({ type: Number }) code: number; - @Column() + @Column({ type: String }) name: string; - @Column() + @Column({ type: Boolean }) isRemoved: boolean = false; @ManyToMany(type => Post, post => post.categories) @@ -32,4 +32,4 @@ export class Category { imageIds: number[]; -} \ No newline at end of file +} diff --git a/test/functional/query-builder/relation-id/many-to-many/multiple-pk/entity/Image.ts b/test/functional/query-builder/relation-id/many-to-many/multiple-pk/entity/Image.ts index d781b2631..b3035f3ba 100644 --- a/test/functional/query-builder/relation-id/many-to-many/multiple-pk/entity/Image.ts +++ b/test/functional/query-builder/relation-id/many-to-many/multiple-pk/entity/Image.ts @@ -1,8 +1,8 @@ -import {Entity} from "../../../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../../../src/decorator/columns/Column"; -import {ManyToMany} from "../../../../../../../src/decorator/relations/ManyToMany"; -import {Category} from "./Category"; +import {Entity} from "../../../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../../../src/decorator/columns/Column.ts"; +import {ManyToMany} from "../../../../../../../src/decorator/relations/ManyToMany.ts"; +import {Category} from "./Category.ts"; @Entity() export class Image { @@ -10,7 +10,7 @@ export class Image { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) name: string; @ManyToMany(type => Category, category => category.images) @@ -18,4 +18,4 @@ export class Image { categoryIds: number[]; -} \ No newline at end of file +} diff --git a/test/functional/query-builder/relation-id/many-to-many/multiple-pk/entity/Post.ts b/test/functional/query-builder/relation-id/many-to-many/multiple-pk/entity/Post.ts index c80146d51..e8f20620b 100644 --- a/test/functional/query-builder/relation-id/many-to-many/multiple-pk/entity/Post.ts +++ b/test/functional/query-builder/relation-id/many-to-many/multiple-pk/entity/Post.ts @@ -1,23 +1,23 @@ -import {ManyToMany} from "../../../../../../../src/decorator/relations/ManyToMany"; -import {Entity} from "../../../../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../../../../src/decorator/columns/Column"; -import {JoinTable} from "../../../../../../../src/decorator/relations/JoinTable"; -import {PrimaryColumn} from "../../../../../../../src/decorator/columns/PrimaryColumn"; -import {Category} from "./Category"; +import {ManyToMany} from "../../../../../../../src/decorator/relations/ManyToMany.ts"; +import {Entity} from "../../../../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../../../../src/decorator/columns/Column.ts"; +import {JoinTable} from "../../../../../../../src/decorator/relations/JoinTable.ts"; +import {PrimaryColumn} from "../../../../../../../src/decorator/columns/PrimaryColumn.ts"; +import {Category} from "./Category.ts"; @Entity() export class Post { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; - @PrimaryColumn() + @PrimaryColumn({ type: Number }) authorId: number; - @Column() + @Column({ type: String }) title: string; - @Column() + @Column({ type: Boolean }) isRemoved: boolean = false; @ManyToMany(type => Category, category => category.posts) @@ -27,7 +27,7 @@ export class Post { @ManyToMany(type => Category) @JoinTable() subcategories: Category[]; - + categoryIds: number[]; -} \ No newline at end of file +} diff --git a/test/functional/query-builder/relation-id/many-to-many/multiple-pk/multiple-pk.ts b/test/functional/query-builder/relation-id/many-to-many/multiple-pk/multiple-pk.ts index 3e351ded0..d0ea8b7e5 100644 --- a/test/functional/query-builder/relation-id/many-to-many/multiple-pk/multiple-pk.ts +++ b/test/functional/query-builder/relation-id/many-to-many/multiple-pk/multiple-pk.ts @@ -1,20 +1,23 @@ -import "reflect-metadata"; -import {expect} from "chai"; +import {join as joinPaths} from "../../../../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../../../../deps/mocha.ts"; +import {expect} from "../../../../../deps/chai.ts"; import { + getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases -} from "../../../../../utils/test-utils"; -import {Connection} from "../../../../../../src/connection/Connection"; -import {Post} from "./entity/Post"; -import {Category} from "./entity/Category"; -import {Image} from "./entity/Image"; +} from "../../../../../utils/test-utils.ts"; +import {Connection} from "../../../../../../src/connection/Connection.ts"; +import {Post} from "./entity/Post.ts"; +import {Category} from "./entity/Category.ts"; +import {Image} from "./entity/Image.ts"; describe("query builder > relation-id > many-to-many > multiple-pk", () => { - + let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], })); beforeEach(() => reloadTestingDatabases(connections)); after(() => closeTestingConnections(connections)); @@ -726,3 +729,5 @@ describe("query builder > relation-id > many-to-many > multiple-pk", () => { }); }); + +runIfMain(import.meta); diff --git a/test/functional/query-builder/relation-id/many-to-one/basic-functionality/basic-functionality.ts b/test/functional/query-builder/relation-id/many-to-one/basic-functionality/basic-functionality.ts index d96d56c67..5f4f6c5a7 100644 --- a/test/functional/query-builder/relation-id/many-to-one/basic-functionality/basic-functionality.ts +++ b/test/functional/query-builder/relation-id/many-to-one/basic-functionality/basic-functionality.ts @@ -1,21 +1,24 @@ -import "reflect-metadata"; -import {expect} from "chai"; +import {join as joinPaths} from "../../../../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../../../../deps/mocha.ts"; +import {expect} from "../../../../../deps/chai.ts"; import { + getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases -} from "../../../../../utils/test-utils"; -import {Connection} from "../../../../../../src/connection/Connection"; -import {Post} from "./entity/Post"; -import {Category} from "./entity/Category"; -import {Image} from "./entity/Image"; -import {PostCategory} from "./entity/PostCategory"; +} from "../../../../../utils/test-utils.ts"; +import {Connection} from "../../../../../../src/connection/Connection.ts"; +import {Post} from "./entity/Post.ts"; +import {Category} from "./entity/Category.ts"; +import {Image} from "./entity/Image.ts"; +import {PostCategory} from "./entity/PostCategory.ts"; describe("query builder > relation-id > many-to-one > basic-functionality", () => { - + let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], })); beforeEach(() => reloadTestingDatabases(connections)); after(() => closeTestingConnections(connections)); @@ -135,3 +138,5 @@ describe("query builder > relation-id > many-to-one > basic-functionality", () = }); + +runIfMain(import.meta); diff --git a/test/functional/query-builder/relation-id/many-to-one/basic-functionality/entity/Category.ts b/test/functional/query-builder/relation-id/many-to-one/basic-functionality/entity/Category.ts index 30a82ac75..5660c9d32 100644 --- a/test/functional/query-builder/relation-id/many-to-one/basic-functionality/entity/Category.ts +++ b/test/functional/query-builder/relation-id/many-to-one/basic-functionality/entity/Category.ts @@ -1,8 +1,8 @@ -import {Entity} from "../../../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../../../src/decorator/columns/Column"; -import {OneToMany} from "../../../../../../../src/decorator/relations/OneToMany"; -import {PostCategory} from "./PostCategory"; +import {Entity} from "../../../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../../../src/decorator/columns/Column.ts"; +import {OneToMany} from "../../../../../../../src/decorator/relations/OneToMany.ts"; +import {PostCategory} from "./PostCategory.ts"; @Entity() export class Category { @@ -10,10 +10,10 @@ export class Category { @PrimaryGeneratedColumn() id: number; - @Column({ unique: true }) + @Column({ unique: true, type: String }) name: string; @OneToMany(type => PostCategory, postCategory => postCategory.category) posts: PostCategory[]; -} \ No newline at end of file +} diff --git a/test/functional/query-builder/relation-id/many-to-one/basic-functionality/entity/Image.ts b/test/functional/query-builder/relation-id/many-to-one/basic-functionality/entity/Image.ts index fac8ce01c..adb6b08a5 100644 --- a/test/functional/query-builder/relation-id/many-to-one/basic-functionality/entity/Image.ts +++ b/test/functional/query-builder/relation-id/many-to-one/basic-functionality/entity/Image.ts @@ -1,6 +1,6 @@ -import {Entity} from "../../../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../../../src/decorator/columns/Column"; +import {Entity} from "../../../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../../../src/decorator/columns/Column.ts"; @Entity() export class Image { @@ -8,7 +8,7 @@ export class Image { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) name: string; -} \ No newline at end of file +} diff --git a/test/functional/query-builder/relation-id/many-to-one/basic-functionality/entity/Post.ts b/test/functional/query-builder/relation-id/many-to-one/basic-functionality/entity/Post.ts index 5ff478eaa..b938039f6 100644 --- a/test/functional/query-builder/relation-id/many-to-one/basic-functionality/entity/Post.ts +++ b/test/functional/query-builder/relation-id/many-to-one/basic-functionality/entity/Post.ts @@ -1,11 +1,11 @@ -import {Entity} from "../../../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../../../src/decorator/columns/Column"; -import {ManyToOne} from "../../../../../../../src/decorator/relations/ManyToOne"; -import {JoinColumn} from "../../../../../../../src/decorator/relations/JoinColumn"; -import {OneToMany} from "../../../../../../../src/decorator/relations/OneToMany"; -import {Category} from "./Category"; -import {PostCategory} from "./PostCategory"; +import {Entity} from "../../../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../../../src/decorator/columns/Column.ts"; +import {ManyToOne} from "../../../../../../../src/decorator/relations/ManyToOne.ts"; +import {JoinColumn} from "../../../../../../../src/decorator/relations/JoinColumn.ts"; +import {OneToMany} from "../../../../../../../src/decorator/relations/OneToMany.ts"; +import {Category} from "./Category.ts"; +import {PostCategory} from "./PostCategory.ts"; @Entity() export class Post { @@ -13,9 +13,9 @@ export class Post { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) title: string; - + @ManyToOne(type => Category) @JoinColumn({ referencedColumnName: "name" }) categoryByName: Category; @@ -31,4 +31,4 @@ export class Post { categoryName: string; -} \ No newline at end of file +} diff --git a/test/functional/query-builder/relation-id/many-to-one/basic-functionality/entity/PostCategory.ts b/test/functional/query-builder/relation-id/many-to-one/basic-functionality/entity/PostCategory.ts index edc66dece..24f563b0b 100644 --- a/test/functional/query-builder/relation-id/many-to-one/basic-functionality/entity/PostCategory.ts +++ b/test/functional/query-builder/relation-id/many-to-one/basic-functionality/entity/PostCategory.ts @@ -1,8 +1,8 @@ -import {Entity} from "../../../../../../../src/decorator/entity/Entity"; -import {ManyToOne} from "../../../../../../../src/decorator/relations/ManyToOne"; -import {Post} from "./Post"; -import {Category} from "./Category"; -import {Image} from "./Image"; +import {Entity} from "../../../../../../../src/decorator/entity/Entity.ts"; +import {ManyToOne} from "../../../../../../../src/decorator/relations/ManyToOne.ts"; +import {Post} from "./Post.ts"; +import {Category} from "./Category.ts"; +import {Image} from "./Image.ts"; @Entity() export class PostCategory { @@ -26,4 +26,4 @@ export class PostCategory { imageId: number; -} \ No newline at end of file +} diff --git a/test/functional/query-builder/relation-id/many-to-one/embedded-with-multiple-pk/embedded-with-multiple-pk.ts b/test/functional/query-builder/relation-id/many-to-one/embedded-with-multiple-pk/embedded-with-multiple-pk.ts index 4fcf9d087..3260f2e3b 100644 --- a/test/functional/query-builder/relation-id/many-to-one/embedded-with-multiple-pk/embedded-with-multiple-pk.ts +++ b/test/functional/query-builder/relation-id/many-to-one/embedded-with-multiple-pk/embedded-with-multiple-pk.ts @@ -1,22 +1,25 @@ -import "reflect-metadata"; -import {expect} from "chai"; +import {join as joinPaths} from "../../../../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../../../../deps/mocha.ts"; +import {expect} from "../../../../../deps/chai.ts"; import { + getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases -} from "../../../../../utils/test-utils"; -import {Connection} from "../../../../../../src/connection/Connection"; -import {Post} from "./entity/Post"; -import {Category} from "./entity/Category"; -import {Counters} from "./entity/Counters"; -import {User} from "./entity/User"; -import {Subcounters} from "./entity/Subcounters"; +} from "../../../../../utils/test-utils.ts"; +import {Connection} from "../../../../../../src/connection/Connection.ts"; +import {Post} from "./entity/Post.ts"; +import {Category} from "./entity/Category.ts"; +import {Counters} from "./entity/Counters.ts"; +import {User} from "./entity/User.ts"; +import {Subcounters} from "./entity/Subcounters.ts"; describe("query builder > relation-id > many-to-one > embedded-with-multiple-pk", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], })); beforeEach(() => reloadTestingDatabases(connections)); after(() => closeTestingConnections(connections)); @@ -147,4 +150,6 @@ describe("query builder > relation-id > many-to-one > embedded-with-multiple-pk" }))); -}); \ No newline at end of file +}); + +runIfMain(import.meta); diff --git a/test/functional/query-builder/relation-id/many-to-one/embedded-with-multiple-pk/entity/Category.ts b/test/functional/query-builder/relation-id/many-to-one/embedded-with-multiple-pk/entity/Category.ts index 1cf0de5cd..948af766a 100644 --- a/test/functional/query-builder/relation-id/many-to-one/embedded-with-multiple-pk/entity/Category.ts +++ b/test/functional/query-builder/relation-id/many-to-one/embedded-with-multiple-pk/entity/Category.ts @@ -1,13 +1,13 @@ -import {Entity} from "../../../../../../../src/decorator/entity/Entity"; -import {PrimaryColumn} from "../../../../../../../src/decorator/columns/PrimaryColumn"; +import {Entity} from "../../../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryColumn} from "../../../../../../../src/decorator/columns/PrimaryColumn.ts"; @Entity() export class Category { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; - @PrimaryColumn() + @PrimaryColumn({ type: String }) name: string; -} \ No newline at end of file +} diff --git a/test/functional/query-builder/relation-id/many-to-one/embedded-with-multiple-pk/entity/Counters.ts b/test/functional/query-builder/relation-id/many-to-one/embedded-with-multiple-pk/entity/Counters.ts index a87d131a6..64486f6ef 100644 --- a/test/functional/query-builder/relation-id/many-to-one/embedded-with-multiple-pk/entity/Counters.ts +++ b/test/functional/query-builder/relation-id/many-to-one/embedded-with-multiple-pk/entity/Counters.ts @@ -1,21 +1,21 @@ -import {Column} from "../../../../../../../src/decorator/columns/Column"; -import {PrimaryColumn} from "../../../../../../../src/decorator/columns/PrimaryColumn"; -import {ManyToOne} from "../../../../../../../src/decorator/relations/ManyToOne"; -import {Category} from "./Category"; -import {Subcounters} from "./Subcounters"; +import {Column} from "../../../../../../../src/decorator/columns/Column.ts"; +import {PrimaryColumn} from "../../../../../../../src/decorator/columns/PrimaryColumn.ts"; +import {ManyToOne} from "../../../../../../../src/decorator/relations/ManyToOne.ts"; +import {Category} from "./Category.ts"; +import {Subcounters} from "./Subcounters.ts"; export class Counters { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) code: number; - @Column() + @Column({ type: Number }) likes: number; - @Column() + @Column({ type: Number }) comments: number; - @Column() + @Column({ type: Number }) favorites: number; @ManyToOne(type => Category) @@ -26,4 +26,4 @@ export class Counters { categoryId: number[]; -} \ No newline at end of file +} diff --git a/test/functional/query-builder/relation-id/many-to-one/embedded-with-multiple-pk/entity/Post.ts b/test/functional/query-builder/relation-id/many-to-one/embedded-with-multiple-pk/entity/Post.ts index 145ffef8f..b569a4bc6 100644 --- a/test/functional/query-builder/relation-id/many-to-one/embedded-with-multiple-pk/entity/Post.ts +++ b/test/functional/query-builder/relation-id/many-to-one/embedded-with-multiple-pk/entity/Post.ts @@ -1,18 +1,18 @@ -import {Entity} from "../../../../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../../../../src/decorator/columns/Column"; -import {Counters} from "./Counters"; -import {PrimaryColumn} from "../../../../../../../src/decorator/columns/PrimaryColumn"; +import {Entity} from "../../../../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../../../../src/decorator/columns/Column.ts"; +import {Counters} from "./Counters.ts"; +import {PrimaryColumn} from "../../../../../../../src/decorator/columns/PrimaryColumn.ts"; @Entity() export class Post { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; - @Column() + @Column({ type: String }) title: string; @Column(() => Counters) counters: Counters; -} \ No newline at end of file +} diff --git a/test/functional/query-builder/relation-id/many-to-one/embedded-with-multiple-pk/entity/Subcounters.ts b/test/functional/query-builder/relation-id/many-to-one/embedded-with-multiple-pk/entity/Subcounters.ts index 7d1bb6b5f..e1a907f15 100644 --- a/test/functional/query-builder/relation-id/many-to-one/embedded-with-multiple-pk/entity/Subcounters.ts +++ b/test/functional/query-builder/relation-id/many-to-one/embedded-with-multiple-pk/entity/Subcounters.ts @@ -1,14 +1,14 @@ -import {Column} from "../../../../../../../src/decorator/columns/Column"; -import {PrimaryColumn} from "../../../../../../../src/decorator/columns/PrimaryColumn"; -import {User} from "./User"; -import {ManyToOne} from "../../../../../../../src/decorator/relations/ManyToOne"; +import {Column} from "../../../../../../../src/decorator/columns/Column.ts"; +import {PrimaryColumn} from "../../../../../../../src/decorator/columns/PrimaryColumn.ts"; +import {User} from "./User.ts"; +import {ManyToOne} from "../../../../../../../src/decorator/relations/ManyToOne.ts"; export class Subcounters { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) version: number; - @Column() + @Column({ type: Number }) watches: number; @ManyToOne(type => User) @@ -16,4 +16,4 @@ export class Subcounters { watchedUserId: number; -} \ No newline at end of file +} diff --git a/test/functional/query-builder/relation-id/many-to-one/embedded-with-multiple-pk/entity/User.ts b/test/functional/query-builder/relation-id/many-to-one/embedded-with-multiple-pk/entity/User.ts index 5ba01dac6..78bbfb708 100644 --- a/test/functional/query-builder/relation-id/many-to-one/embedded-with-multiple-pk/entity/User.ts +++ b/test/functional/query-builder/relation-id/many-to-one/embedded-with-multiple-pk/entity/User.ts @@ -1,13 +1,13 @@ -import {Entity} from "../../../../../../../src/decorator/entity/Entity"; -import {PrimaryColumn} from "../../../../../../../src/decorator/columns/PrimaryColumn"; +import {Entity} from "../../../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryColumn} from "../../../../../../../src/decorator/columns/PrimaryColumn.ts"; @Entity() export class User { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; - @PrimaryColumn() + @PrimaryColumn({ type: String }) name: string; -} \ No newline at end of file +} diff --git a/test/functional/query-builder/relation-id/many-to-one/embedded/embedded.ts b/test/functional/query-builder/relation-id/many-to-one/embedded/embedded.ts index 62f7cce0e..a99e861a3 100644 --- a/test/functional/query-builder/relation-id/many-to-one/embedded/embedded.ts +++ b/test/functional/query-builder/relation-id/many-to-one/embedded/embedded.ts @@ -1,22 +1,25 @@ -import "reflect-metadata"; -import {expect} from "chai"; +import {join as joinPaths} from "../../../../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../../../../deps/mocha.ts"; +import {expect} from "../../../../../deps/chai.ts"; import { + getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases -} from "../../../../../utils/test-utils"; -import {Connection} from "../../../../../../src/connection/Connection"; -import {Post} from "./entity/Post"; -import {Category} from "./entity/Category"; -import {Counters} from "./entity/Counters"; -import {User} from "./entity/User"; -import {Subcounters} from "./entity/Subcounters"; +} from "../../../../../utils/test-utils.ts"; +import {Connection} from "../../../../../../src/connection/Connection.ts"; +import {Post} from "./entity/Post.ts"; +import {Category} from "./entity/Category.ts"; +import {Counters} from "./entity/Counters.ts"; +import {User} from "./entity/User.ts"; +import {Subcounters} from "./entity/Subcounters.ts"; describe("query builder > relation-id > many-to-one > embedded", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], })); beforeEach(() => reloadTestingDatabases(connections)); after(() => closeTestingConnections(connections)); @@ -110,3 +113,5 @@ describe("query builder > relation-id > many-to-one > embedded", () => { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/query-builder/relation-id/many-to-one/embedded/entity/Category.ts b/test/functional/query-builder/relation-id/many-to-one/embedded/entity/Category.ts index 8ad26e01f..0594c55a9 100644 --- a/test/functional/query-builder/relation-id/many-to-one/embedded/entity/Category.ts +++ b/test/functional/query-builder/relation-id/many-to-one/embedded/entity/Category.ts @@ -1,8 +1,8 @@ -import {Entity} from "../../../../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../../../../src/decorator/columns/Column"; -import {PrimaryGeneratedColumn} from "../../../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Post} from "./Post"; -import {OneToMany} from "../../../../../../../src/decorator/relations/OneToMany"; +import {Entity} from "../../../../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../../../../src/decorator/columns/Column.ts"; +import {PrimaryGeneratedColumn} from "../../../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Post} from "./Post.ts"; +import {OneToMany} from "../../../../../../../src/decorator/relations/OneToMany.ts"; @Entity() export class Category { @@ -10,7 +10,7 @@ export class Category { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) name: string; @OneToMany(type => Post, post => post.counters.category) @@ -18,4 +18,4 @@ export class Category { postIds: number[]; -} \ No newline at end of file +} diff --git a/test/functional/query-builder/relation-id/many-to-one/embedded/entity/Counters.ts b/test/functional/query-builder/relation-id/many-to-one/embedded/entity/Counters.ts index 28c26c525..0c9d0c450 100644 --- a/test/functional/query-builder/relation-id/many-to-one/embedded/entity/Counters.ts +++ b/test/functional/query-builder/relation-id/many-to-one/embedded/entity/Counters.ts @@ -1,17 +1,17 @@ -import {Column} from "../../../../../../../src/decorator/columns/Column"; -import {ManyToOne} from "../../../../../../../src/decorator/relations/ManyToOne"; -import {Category} from "./Category"; -import {Subcounters} from "./Subcounters"; +import {Column} from "../../../../../../../src/decorator/columns/Column.ts"; +import {ManyToOne} from "../../../../../../../src/decorator/relations/ManyToOne.ts"; +import {Category} from "./Category.ts"; +import {Subcounters} from "./Subcounters.ts"; export class Counters { - @Column() + @Column({ type: Number }) likes: number; - @Column() + @Column({ type: Number }) comments: number; - @Column() + @Column({ type: Number }) favorites: number; @ManyToOne(type => Category, category => category.posts) @@ -22,4 +22,4 @@ export class Counters { categoryId: number; -} \ No newline at end of file +} diff --git a/test/functional/query-builder/relation-id/many-to-one/embedded/entity/Post.ts b/test/functional/query-builder/relation-id/many-to-one/embedded/entity/Post.ts index 7ae2be8a6..1397f2c0f 100644 --- a/test/functional/query-builder/relation-id/many-to-one/embedded/entity/Post.ts +++ b/test/functional/query-builder/relation-id/many-to-one/embedded/entity/Post.ts @@ -1,14 +1,14 @@ -import {Entity} from "../../../../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../../../../src/decorator/columns/Column"; -import {Counters} from "./Counters"; +import {Entity} from "../../../../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../../../../src/decorator/columns/Column.ts"; +import {Counters} from "./Counters.ts"; @Entity() export class Post { - @Column() + @Column({ type: String }) title: string; @Column(() => Counters) counters: Counters; -} \ No newline at end of file +} diff --git a/test/functional/query-builder/relation-id/many-to-one/embedded/entity/Subcounters.ts b/test/functional/query-builder/relation-id/many-to-one/embedded/entity/Subcounters.ts index 4c143c4ef..b25d2e296 100644 --- a/test/functional/query-builder/relation-id/many-to-one/embedded/entity/Subcounters.ts +++ b/test/functional/query-builder/relation-id/many-to-one/embedded/entity/Subcounters.ts @@ -1,17 +1,17 @@ -import {Column} from "../../../../../../../src/decorator/columns/Column"; -import {ManyToOne} from "../../../../../../../src/decorator/relations/ManyToOne"; -import {PrimaryGeneratedColumn} from "../../../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {User} from "./User"; +import {Column} from "../../../../../../../src/decorator/columns/Column.ts"; +import {ManyToOne} from "../../../../../../../src/decorator/relations/ManyToOne.ts"; +import {PrimaryGeneratedColumn} from "../../../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {User} from "./User.ts"; export class Subcounters { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: Number }) version: number; - @Column() + @Column({ type: Number }) watches: number; @ManyToOne(type => User) @@ -19,4 +19,4 @@ export class Subcounters { watchedUserId: number; -} \ No newline at end of file +} diff --git a/test/functional/query-builder/relation-id/many-to-one/embedded/entity/User.ts b/test/functional/query-builder/relation-id/many-to-one/embedded/entity/User.ts index c0d8bd3fe..2c0b743a6 100644 --- a/test/functional/query-builder/relation-id/many-to-one/embedded/entity/User.ts +++ b/test/functional/query-builder/relation-id/many-to-one/embedded/entity/User.ts @@ -1,6 +1,6 @@ -import {Column} from "../../../../../../../src/decorator/columns/Column"; -import {Entity} from "../../../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../../../src/decorator/columns/PrimaryGeneratedColumn"; +import {Column} from "../../../../../../../src/decorator/columns/Column.ts"; +import {Entity} from "../../../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; @Entity() export class User { @@ -8,7 +8,7 @@ export class User { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) name: string; -} \ No newline at end of file +} diff --git a/test/functional/query-builder/relation-id/many-to-one/multiple-pk/entity/Category.ts b/test/functional/query-builder/relation-id/many-to-one/multiple-pk/entity/Category.ts index eb1bb3c32..8324044bb 100644 --- a/test/functional/query-builder/relation-id/many-to-one/multiple-pk/entity/Category.ts +++ b/test/functional/query-builder/relation-id/many-to-one/multiple-pk/entity/Category.ts @@ -1,25 +1,25 @@ -import {Entity} from "../../../../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../../../../src/decorator/columns/Column"; -import {PrimaryColumn} from "../../../../../../../src/decorator/columns/PrimaryColumn"; -import {JoinTable} from "../../../../../../../src/decorator/relations/JoinTable"; -import {OneToMany} from "../../../../../../../src/decorator/relations/OneToMany"; -import {ManyToOne} from "../../../../../../../src/decorator/relations/ManyToOne"; -import {Post} from "./Post"; -import {Image} from "./Image"; +import {Entity} from "../../../../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../../../../src/decorator/columns/Column.ts"; +import {PrimaryColumn} from "../../../../../../../src/decorator/columns/PrimaryColumn.ts"; +import {JoinTable} from "../../../../../../../src/decorator/relations/JoinTable.ts"; +import {OneToMany} from "../../../../../../../src/decorator/relations/OneToMany.ts"; +import {ManyToOne} from "../../../../../../../src/decorator/relations/ManyToOne.ts"; +import {Post} from "./Post.ts"; +import {Image} from "./Image.ts"; @Entity() export class Category { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; - @PrimaryColumn() + @PrimaryColumn({ type: Number }) code: number; - @Column() + @Column({ type: String }) name: string; - @Column() + @Column({ type: Boolean }) isRemoved: boolean = false; @OneToMany(type => Post, post => post.category) @@ -33,4 +33,4 @@ export class Category { imageId: number[]; -} \ No newline at end of file +} diff --git a/test/functional/query-builder/relation-id/many-to-one/multiple-pk/entity/Image.ts b/test/functional/query-builder/relation-id/many-to-one/multiple-pk/entity/Image.ts index 42a87cbec..0dc191a46 100644 --- a/test/functional/query-builder/relation-id/many-to-one/multiple-pk/entity/Image.ts +++ b/test/functional/query-builder/relation-id/many-to-one/multiple-pk/entity/Image.ts @@ -1,8 +1,8 @@ -import {Entity} from "../../../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../../../src/decorator/columns/Column"; -import {OneToMany} from "../../../../../../../src/decorator/relations/OneToMany"; -import {Category} from "./Category"; +import {Entity} from "../../../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../../../src/decorator/columns/Column.ts"; +import {OneToMany} from "../../../../../../../src/decorator/relations/OneToMany.ts"; +import {Category} from "./Category.ts"; @Entity() export class Image { @@ -10,7 +10,7 @@ export class Image { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) name: string; @OneToMany(type => Category, category => category.image) @@ -18,4 +18,4 @@ export class Image { categoryIds: number[]; -} \ No newline at end of file +} diff --git a/test/functional/query-builder/relation-id/many-to-one/multiple-pk/entity/Post.ts b/test/functional/query-builder/relation-id/many-to-one/multiple-pk/entity/Post.ts index 99c577a2c..f3817305e 100644 --- a/test/functional/query-builder/relation-id/many-to-one/multiple-pk/entity/Post.ts +++ b/test/functional/query-builder/relation-id/many-to-one/multiple-pk/entity/Post.ts @@ -1,22 +1,22 @@ -import {Entity} from "../../../../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../../../../src/decorator/columns/Column"; -import {PrimaryColumn} from "../../../../../../../src/decorator/columns/PrimaryColumn"; -import {Category} from "./Category"; -import {ManyToOne} from "../../../../../../../src/decorator/relations/ManyToOne"; +import {Entity} from "../../../../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../../../../src/decorator/columns/Column.ts"; +import {PrimaryColumn} from "../../../../../../../src/decorator/columns/PrimaryColumn.ts"; +import {Category} from "./Category.ts"; +import {ManyToOne} from "../../../../../../../src/decorator/relations/ManyToOne.ts"; @Entity() export class Post { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; - @PrimaryColumn() + @PrimaryColumn({ type: Number }) authorId: number; - @Column() + @Column({ type: String }) title: string; - @Column() + @Column({ type: Boolean }) isRemoved: boolean = false; @ManyToOne(type => Category, category => category.posts) @@ -24,7 +24,7 @@ export class Post { @ManyToOne(type => Category) subcategory: Category; - + categoryId: number; -} \ No newline at end of file +} diff --git a/test/functional/query-builder/relation-id/many-to-one/multiple-pk/multiple-pk.ts b/test/functional/query-builder/relation-id/many-to-one/multiple-pk/multiple-pk.ts index 71a6adb72..d21b6d442 100644 --- a/test/functional/query-builder/relation-id/many-to-one/multiple-pk/multiple-pk.ts +++ b/test/functional/query-builder/relation-id/many-to-one/multiple-pk/multiple-pk.ts @@ -1,20 +1,23 @@ -import "reflect-metadata"; -import {expect} from "chai"; +import {join as joinPaths} from "../../../../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../../../../deps/mocha.ts"; +import {expect} from "../../../../../deps/chai.ts"; import { + getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases -} from "../../../../../utils/test-utils"; -import {Connection} from "../../../../../../src/connection/Connection"; -import {Post} from "./entity/Post"; -import {Category} from "./entity/Category"; -import {Image} from "./entity/Image"; +} from "../../../../../utils/test-utils.ts"; +import {Connection} from "../../../../../../src/connection/Connection.ts"; +import {Post} from "./entity/Post.ts"; +import {Category} from "./entity/Category.ts"; +import {Image} from "./entity/Image.ts"; describe("query builder > relation-id > many-to-one > multiple-pk", () => { - + let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], })); beforeEach(() => reloadTestingDatabases(connections)); after(() => closeTestingConnections(connections)); @@ -236,4 +239,6 @@ describe("query builder > relation-id > many-to-one > multiple-pk", () => { }))); -}); \ No newline at end of file +}); + +runIfMain(import.meta); diff --git a/test/functional/query-builder/relation-id/one-to-many/basic-functionality/basic-functionality.ts b/test/functional/query-builder/relation-id/one-to-many/basic-functionality/basic-functionality.ts index 038d57bcb..323150a9c 100644 --- a/test/functional/query-builder/relation-id/one-to-many/basic-functionality/basic-functionality.ts +++ b/test/functional/query-builder/relation-id/one-to-many/basic-functionality/basic-functionality.ts @@ -1,20 +1,23 @@ -import "reflect-metadata"; -import {expect} from "chai"; +import {join as joinPaths} from "../../../../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../../../../deps/mocha.ts"; +import {expect} from "../../../../../deps/chai.ts"; import { + getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases -} from "../../../../../utils/test-utils"; -import {Connection} from "../../../../../../src/connection/Connection"; -import {Category} from "./entity/Category"; -import {Post} from "./entity/Post"; -import {Image} from "./entity/Image"; +} from "../../../../../utils/test-utils.ts"; +import {Connection} from "../../../../../../src/connection/Connection.ts"; +import {Category} from "./entity/Category.ts"; +import {Post} from "./entity/Post.ts"; +import {Image} from "./entity/Image.ts"; describe("query builder > relation-id > one-to-many > basic-functionality", () => { - + let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], })); beforeEach(() => reloadTestingDatabases(connections)); after(() => closeTestingConnections(connections)); @@ -235,3 +238,5 @@ describe("query builder > relation-id > one-to-many > basic-functionality", () = }))); }); + +runIfMain(import.meta); diff --git a/test/functional/query-builder/relation-id/one-to-many/basic-functionality/entity/Category.ts b/test/functional/query-builder/relation-id/one-to-many/basic-functionality/entity/Category.ts index 6d45e4d37..f64b416bb 100644 --- a/test/functional/query-builder/relation-id/one-to-many/basic-functionality/entity/Category.ts +++ b/test/functional/query-builder/relation-id/one-to-many/basic-functionality/entity/Category.ts @@ -1,10 +1,10 @@ -import {Entity} from "../../../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../../../src/decorator/columns/Column"; -import {ManyToOne} from "../../../../../../../src/decorator/relations/ManyToOne"; -import {OneToMany} from "../../../../../../../src/decorator/relations/OneToMany"; -import {Image} from "./Image"; -import {Post} from "./Post"; +import {Entity} from "../../../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../../../src/decorator/columns/Column.ts"; +import {ManyToOne} from "../../../../../../../src/decorator/relations/ManyToOne.ts"; +import {OneToMany} from "../../../../../../../src/decorator/relations/OneToMany.ts"; +import {Image} from "./Image.ts"; +import {Post} from "./Post.ts"; @Entity() export class Category { @@ -12,10 +12,10 @@ export class Category { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) name: string; - @Column() + @Column({ type: Boolean }) isRemoved: boolean = false; @OneToMany(type => Image, image => image.category) @@ -28,4 +28,4 @@ export class Category { postId: number; -} \ No newline at end of file +} diff --git a/test/functional/query-builder/relation-id/one-to-many/basic-functionality/entity/Image.ts b/test/functional/query-builder/relation-id/one-to-many/basic-functionality/entity/Image.ts index 1c2f6eb2b..e2c322a10 100644 --- a/test/functional/query-builder/relation-id/one-to-many/basic-functionality/entity/Image.ts +++ b/test/functional/query-builder/relation-id/one-to-many/basic-functionality/entity/Image.ts @@ -1,8 +1,8 @@ -import {Entity} from "../../../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../../../src/decorator/columns/Column"; -import {ManyToOne} from "../../../../../../../src/decorator/relations/ManyToOne"; -import {Category} from "./Category"; +import {Entity} from "../../../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../../../src/decorator/columns/Column.ts"; +import {ManyToOne} from "../../../../../../../src/decorator/relations/ManyToOne.ts"; +import {Category} from "./Category.ts"; @Entity() export class Image { @@ -10,7 +10,7 @@ export class Image { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) name: string; @ManyToOne(type => Category, category => category.images) @@ -18,4 +18,4 @@ export class Image { categoryId: number; -} \ No newline at end of file +} diff --git a/test/functional/query-builder/relation-id/one-to-many/basic-functionality/entity/Post.ts b/test/functional/query-builder/relation-id/one-to-many/basic-functionality/entity/Post.ts index 9d0e6cc71..8385f7b85 100644 --- a/test/functional/query-builder/relation-id/one-to-many/basic-functionality/entity/Post.ts +++ b/test/functional/query-builder/relation-id/one-to-many/basic-functionality/entity/Post.ts @@ -1,8 +1,8 @@ -import {Entity} from "../../../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../../../src/decorator/columns/Column"; -import {OneToMany} from "../../../../../../../src/decorator/relations/OneToMany"; -import {Category} from "./Category"; +import {Entity} from "../../../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../../../src/decorator/columns/Column.ts"; +import {OneToMany} from "../../../../../../../src/decorator/relations/OneToMany.ts"; +import {Category} from "./Category.ts"; @Entity() export class Post { @@ -10,12 +10,12 @@ export class Post { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) title: string; @OneToMany(type => Category, category => category.post) categories: Category[]; - + categoryIds: number[]; -} \ No newline at end of file +} diff --git a/test/functional/query-builder/relation-id/one-to-many/embedded-with-multiple-pk/embedded-with-multiple-pk.ts b/test/functional/query-builder/relation-id/one-to-many/embedded-with-multiple-pk/embedded-with-multiple-pk.ts index e1fe706cf..659668d62 100644 --- a/test/functional/query-builder/relation-id/one-to-many/embedded-with-multiple-pk/embedded-with-multiple-pk.ts +++ b/test/functional/query-builder/relation-id/one-to-many/embedded-with-multiple-pk/embedded-with-multiple-pk.ts @@ -1,22 +1,25 @@ -import "reflect-metadata"; -import {expect} from "chai"; +import {join as joinPaths} from "../../../../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../../../../deps/mocha.ts"; +import {expect} from "../../../../../deps/chai.ts"; import { + getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases -} from "../../../../../utils/test-utils"; -import {Connection} from "../../../../../../src/connection/Connection"; -import {Post} from "./entity/Post"; -import {Category} from "./entity/Category"; -import {Counters} from "./entity/Counters"; -import {User} from "./entity/User"; -import {Subcounters} from "./entity/Subcounters"; +} from "../../../../../utils/test-utils.ts"; +import {Connection} from "../../../../../../src/connection/Connection.ts"; +import {Post} from "./entity/Post.ts"; +import {Category} from "./entity/Category.ts"; +import {Counters} from "./entity/Counters.ts"; +import {User} from "./entity/User.ts"; +import {Subcounters} from "./entity/Subcounters.ts"; describe("query builder > relation-id > one-to-many > embedded-with-multiple-pk", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], })); beforeEach(() => reloadTestingDatabases(connections)); after(() => closeTestingConnections(connections)); @@ -179,4 +182,6 @@ describe("query builder > relation-id > one-to-many > embedded-with-multiple-pk" }))); -}); \ No newline at end of file +}); + +runIfMain(import.meta); diff --git a/test/functional/query-builder/relation-id/one-to-many/embedded-with-multiple-pk/entity/Category.ts b/test/functional/query-builder/relation-id/one-to-many/embedded-with-multiple-pk/entity/Category.ts index c9704164d..2850714e5 100644 --- a/test/functional/query-builder/relation-id/one-to-many/embedded-with-multiple-pk/entity/Category.ts +++ b/test/functional/query-builder/relation-id/one-to-many/embedded-with-multiple-pk/entity/Category.ts @@ -1,18 +1,18 @@ -import {Entity} from "../../../../../../../src/decorator/entity/Entity"; -import {PrimaryColumn} from "../../../../../../../src/decorator/columns/PrimaryColumn"; -import {Post} from "./Post"; -import {ManyToOne} from "../../../../../../../src/decorator/relations/ManyToOne"; +import {Entity} from "../../../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryColumn} from "../../../../../../../src/decorator/columns/PrimaryColumn.ts"; +import {Post} from "./Post.ts"; +import {ManyToOne} from "../../../../../../../src/decorator/relations/ManyToOne.ts"; @Entity() export class Category { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; - @PrimaryColumn() + @PrimaryColumn({ type: String }) name: string; @ManyToOne(type => Post, post => post.counters.categories) post: Post; -} \ No newline at end of file +} diff --git a/test/functional/query-builder/relation-id/one-to-many/embedded-with-multiple-pk/entity/Counters.ts b/test/functional/query-builder/relation-id/one-to-many/embedded-with-multiple-pk/entity/Counters.ts index 84d5b41f5..21f469315 100644 --- a/test/functional/query-builder/relation-id/one-to-many/embedded-with-multiple-pk/entity/Counters.ts +++ b/test/functional/query-builder/relation-id/one-to-many/embedded-with-multiple-pk/entity/Counters.ts @@ -1,21 +1,21 @@ -import {Column} from "../../../../../../../src/decorator/columns/Column"; -import {PrimaryColumn} from "../../../../../../../src/decorator/columns/PrimaryColumn"; -import {OneToMany} from "../../../../../../../src/decorator/relations/OneToMany"; -import {Category} from "./Category"; -import {Subcounters} from "./Subcounters"; +import {Column} from "../../../../../../../src/decorator/columns/Column.ts"; +import {PrimaryColumn} from "../../../../../../../src/decorator/columns/PrimaryColumn.ts"; +import {OneToMany} from "../../../../../../../src/decorator/relations/OneToMany.ts"; +import {Category} from "./Category.ts"; +import {Subcounters} from "./Subcounters.ts"; export class Counters { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) code: number; - @Column() + @Column({ type: Number }) likes: number; - @Column() + @Column({ type: Number }) comments: number; - @Column() + @Column({ type: Number }) favorites: number; @OneToMany(type => Category, category => category.post) @@ -26,4 +26,4 @@ export class Counters { categoryIds: number[]; -} \ No newline at end of file +} diff --git a/test/functional/query-builder/relation-id/one-to-many/embedded-with-multiple-pk/entity/Post.ts b/test/functional/query-builder/relation-id/one-to-many/embedded-with-multiple-pk/entity/Post.ts index 145ffef8f..b569a4bc6 100644 --- a/test/functional/query-builder/relation-id/one-to-many/embedded-with-multiple-pk/entity/Post.ts +++ b/test/functional/query-builder/relation-id/one-to-many/embedded-with-multiple-pk/entity/Post.ts @@ -1,18 +1,18 @@ -import {Entity} from "../../../../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../../../../src/decorator/columns/Column"; -import {Counters} from "./Counters"; -import {PrimaryColumn} from "../../../../../../../src/decorator/columns/PrimaryColumn"; +import {Entity} from "../../../../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../../../../src/decorator/columns/Column.ts"; +import {Counters} from "./Counters.ts"; +import {PrimaryColumn} from "../../../../../../../src/decorator/columns/PrimaryColumn.ts"; @Entity() export class Post { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; - @Column() + @Column({ type: String }) title: string; @Column(() => Counters) counters: Counters; -} \ No newline at end of file +} diff --git a/test/functional/query-builder/relation-id/one-to-many/embedded-with-multiple-pk/entity/Subcounters.ts b/test/functional/query-builder/relation-id/one-to-many/embedded-with-multiple-pk/entity/Subcounters.ts index fdd60cad4..c22909901 100644 --- a/test/functional/query-builder/relation-id/one-to-many/embedded-with-multiple-pk/entity/Subcounters.ts +++ b/test/functional/query-builder/relation-id/one-to-many/embedded-with-multiple-pk/entity/Subcounters.ts @@ -1,14 +1,14 @@ -import {Column} from "../../../../../../../src/decorator/columns/Column"; -import {PrimaryColumn} from "../../../../../../../src/decorator/columns/PrimaryColumn"; -import {OneToMany} from "../../../../../../../src/decorator/relations/OneToMany"; -import {User} from "./User"; +import {Column} from "../../../../../../../src/decorator/columns/Column.ts"; +import {PrimaryColumn} from "../../../../../../../src/decorator/columns/PrimaryColumn.ts"; +import {OneToMany} from "../../../../../../../src/decorator/relations/OneToMany.ts"; +import {User} from "./User.ts"; export class Subcounters { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) version: number; - @Column() + @Column({ type: Number }) watches: number; @OneToMany(type => User, user => user.post) @@ -16,4 +16,4 @@ export class Subcounters { watchedUserIds: number[]; -} \ No newline at end of file +} diff --git a/test/functional/query-builder/relation-id/one-to-many/embedded-with-multiple-pk/entity/User.ts b/test/functional/query-builder/relation-id/one-to-many/embedded-with-multiple-pk/entity/User.ts index 865e57773..0083fd775 100644 --- a/test/functional/query-builder/relation-id/one-to-many/embedded-with-multiple-pk/entity/User.ts +++ b/test/functional/query-builder/relation-id/one-to-many/embedded-with-multiple-pk/entity/User.ts @@ -1,18 +1,18 @@ -import {Entity} from "../../../../../../../src/decorator/entity/Entity"; -import {PrimaryColumn} from "../../../../../../../src/decorator/columns/PrimaryColumn"; -import {ManyToOne} from "../../../../../../../src/decorator/relations/ManyToOne"; -import {Post} from "./Post"; +import {Entity} from "../../../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryColumn} from "../../../../../../../src/decorator/columns/PrimaryColumn.ts"; +import {ManyToOne} from "../../../../../../../src/decorator/relations/ManyToOne.ts"; +import {Post} from "./Post.ts"; @Entity() export class User { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; - @PrimaryColumn() + @PrimaryColumn({ type: Number }) name: string; @ManyToOne(type => Post, post => post.counters.subcounters.watchedUsers) post: Post; -} \ No newline at end of file +} diff --git a/test/functional/query-builder/relation-id/one-to-many/embedded/embedded.ts b/test/functional/query-builder/relation-id/one-to-many/embedded/embedded.ts index 6ad6bd377..35c43abd2 100644 --- a/test/functional/query-builder/relation-id/one-to-many/embedded/embedded.ts +++ b/test/functional/query-builder/relation-id/one-to-many/embedded/embedded.ts @@ -1,22 +1,25 @@ -import "reflect-metadata"; -import {expect} from "chai"; +import {join as joinPaths} from "../../../../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../../../../deps/mocha.ts"; +import {expect} from "../../../../../deps/chai.ts"; import { + getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases -} from "../../../../../utils/test-utils"; -import {Connection} from "../../../../../../src/connection/Connection"; -import {Post} from "./entity/Post"; -import {Category} from "./entity/Category"; -import {Counters} from "./entity/Counters"; -import {User} from "./entity/User"; -import {Subcounters} from "./entity/Subcounters"; +} from "../../../../../utils/test-utils.ts"; +import {Connection} from "../../../../../../src/connection/Connection.ts"; +import {Post} from "./entity/Post.ts"; +import {Category} from "./entity/Category.ts"; +import {Counters} from "./entity/Counters.ts"; +import {User} from "./entity/User.ts"; +import {Subcounters} from "./entity/Subcounters.ts"; describe("query builder > relation-id > one-to-many > embedded", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], })); beforeEach(() => reloadTestingDatabases(connections)); after(() => closeTestingConnections(connections)); @@ -121,4 +124,6 @@ describe("query builder > relation-id > one-to-many > embedded", () => { }))); -}); \ No newline at end of file +}); + +runIfMain(import.meta); diff --git a/test/functional/query-builder/relation-id/one-to-many/embedded/entity/Category.ts b/test/functional/query-builder/relation-id/one-to-many/embedded/entity/Category.ts index ba59abb8b..471065081 100644 --- a/test/functional/query-builder/relation-id/one-to-many/embedded/entity/Category.ts +++ b/test/functional/query-builder/relation-id/one-to-many/embedded/entity/Category.ts @@ -1,9 +1,9 @@ -import {Entity} from "../../../../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../../../../src/decorator/columns/Column"; -import {PrimaryGeneratedColumn} from "../../../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Post} from "./Post"; -import {ManyToOne} from "../../../../../../../src/decorator/relations/ManyToOne"; -import {JoinColumn} from "../../../../../../../src/decorator/relations/JoinColumn"; +import {Entity} from "../../../../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../../../../src/decorator/columns/Column.ts"; +import {PrimaryGeneratedColumn} from "../../../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Post} from "./Post.ts"; +import {ManyToOne} from "../../../../../../../src/decorator/relations/ManyToOne.ts"; +import {JoinColumn} from "../../../../../../../src/decorator/relations/JoinColumn.ts"; @Entity() export class Category { @@ -11,7 +11,7 @@ export class Category { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) name: string; @ManyToOne(type => Post, post => post.counters.categories) @@ -20,4 +20,4 @@ export class Category { postIds: number[]; -} \ No newline at end of file +} diff --git a/test/functional/query-builder/relation-id/one-to-many/embedded/entity/Counters.ts b/test/functional/query-builder/relation-id/one-to-many/embedded/entity/Counters.ts index 6fe8d6ccf..63f8d046f 100644 --- a/test/functional/query-builder/relation-id/one-to-many/embedded/entity/Counters.ts +++ b/test/functional/query-builder/relation-id/one-to-many/embedded/entity/Counters.ts @@ -1,17 +1,17 @@ -import {Column} from "../../../../../../../src/decorator/columns/Column"; -import {Category} from "./Category"; -import {Subcounters} from "./Subcounters"; -import {OneToMany} from "../../../../../../../src/decorator/relations/OneToMany"; +import {Column} from "../../../../../../../src/decorator/columns/Column.ts"; +import {Category} from "./Category.ts"; +import {Subcounters} from "./Subcounters.ts"; +import {OneToMany} from "../../../../../../../src/decorator/relations/OneToMany.ts"; export class Counters { - @Column() + @Column({ type: Number }) likes: number; - @Column() + @Column({ type: Number }) comments: number; - @Column() + @Column({ type: Number }) favorites: number; @OneToMany(type => Category, category => category.posts) @@ -22,4 +22,4 @@ export class Counters { categoryIds: number[]; -} \ No newline at end of file +} diff --git a/test/functional/query-builder/relation-id/one-to-many/embedded/entity/Post.ts b/test/functional/query-builder/relation-id/one-to-many/embedded/entity/Post.ts index 7ae2be8a6..1397f2c0f 100644 --- a/test/functional/query-builder/relation-id/one-to-many/embedded/entity/Post.ts +++ b/test/functional/query-builder/relation-id/one-to-many/embedded/entity/Post.ts @@ -1,14 +1,14 @@ -import {Entity} from "../../../../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../../../../src/decorator/columns/Column"; -import {Counters} from "./Counters"; +import {Entity} from "../../../../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../../../../src/decorator/columns/Column.ts"; +import {Counters} from "./Counters.ts"; @Entity() export class Post { - @Column() + @Column({ type: String }) title: string; @Column(() => Counters) counters: Counters; -} \ No newline at end of file +} diff --git a/test/functional/query-builder/relation-id/one-to-many/embedded/entity/Subcounters.ts b/test/functional/query-builder/relation-id/one-to-many/embedded/entity/Subcounters.ts index 71118ee27..f3facf991 100644 --- a/test/functional/query-builder/relation-id/one-to-many/embedded/entity/Subcounters.ts +++ b/test/functional/query-builder/relation-id/one-to-many/embedded/entity/Subcounters.ts @@ -1,17 +1,17 @@ -import {Column} from "../../../../../../../src/decorator/columns/Column"; -import {OneToMany} from "../../../../../../../src/decorator/relations/OneToMany"; -import {PrimaryGeneratedColumn} from "../../../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {User} from "./User"; +import {Column} from "../../../../../../../src/decorator/columns/Column.ts"; +import {OneToMany} from "../../../../../../../src/decorator/relations/OneToMany.ts"; +import {PrimaryGeneratedColumn} from "../../../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {User} from "./User.ts"; export class Subcounters { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: Number }) version: number; - @Column() + @Column({ type: Number }) watches: number; @OneToMany(type => User, user => user.posts) @@ -19,4 +19,4 @@ export class Subcounters { watchedUserIds: number[]; -} \ No newline at end of file +} diff --git a/test/functional/query-builder/relation-id/one-to-many/embedded/entity/User.ts b/test/functional/query-builder/relation-id/one-to-many/embedded/entity/User.ts index 1a6fa60e9..a39fd7b47 100644 --- a/test/functional/query-builder/relation-id/one-to-many/embedded/entity/User.ts +++ b/test/functional/query-builder/relation-id/one-to-many/embedded/entity/User.ts @@ -1,9 +1,9 @@ -import {Column} from "../../../../../../../src/decorator/columns/Column"; -import {Entity} from "../../../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {ManyToOne} from "../../../../../../../src/decorator/relations/ManyToOne"; -import {JoinColumn} from "../../../../../../../src/decorator/relations/JoinColumn"; -import {Post} from "./Post"; +import {Column} from "../../../../../../../src/decorator/columns/Column.ts"; +import {Entity} from "../../../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {ManyToOne} from "../../../../../../../src/decorator/relations/ManyToOne.ts"; +import {JoinColumn} from "../../../../../../../src/decorator/relations/JoinColumn.ts"; +import {Post} from "./Post.ts"; @Entity() export class User { @@ -11,11 +11,11 @@ export class User { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) name: string; @ManyToOne(type => Post, post => post.counters.subcounters.watchedUsers) @JoinColumn() posts: Post[]; -} \ No newline at end of file +} diff --git a/test/functional/query-builder/relation-id/one-to-many/multiple-pk/entity/Category.ts b/test/functional/query-builder/relation-id/one-to-many/multiple-pk/entity/Category.ts index 9ea4546e3..f8dad6840 100644 --- a/test/functional/query-builder/relation-id/one-to-many/multiple-pk/entity/Category.ts +++ b/test/functional/query-builder/relation-id/one-to-many/multiple-pk/entity/Category.ts @@ -1,24 +1,24 @@ -import {Entity} from "../../../../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../../../../src/decorator/columns/Column"; -import {PrimaryColumn} from "../../../../../../../src/decorator/columns/PrimaryColumn"; -import {ManyToOne} from "../../../../../../../src/decorator/relations/ManyToOne"; -import {OneToMany} from "../../../../../../../src/decorator/relations/OneToMany"; -import {Post} from "./Post"; -import {Image} from "./Image"; +import {Entity} from "../../../../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../../../../src/decorator/columns/Column.ts"; +import {PrimaryColumn} from "../../../../../../../src/decorator/columns/PrimaryColumn.ts"; +import {ManyToOne} from "../../../../../../../src/decorator/relations/ManyToOne.ts"; +import {OneToMany} from "../../../../../../../src/decorator/relations/OneToMany.ts"; +import {Post} from "./Post.ts"; +import {Image} from "./Image.ts"; @Entity() export class Category { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; - @PrimaryColumn() + @PrimaryColumn({ type: Number }) code: number; - @Column() + @Column({ type: String }) name: string; - @Column() + @Column({ type: Boolean }) isRemoved: boolean = false; @ManyToOne(type => Post, post => post.categories) @@ -31,4 +31,4 @@ export class Category { imageIds: number[]; -} \ No newline at end of file +} diff --git a/test/functional/query-builder/relation-id/one-to-many/multiple-pk/entity/Image.ts b/test/functional/query-builder/relation-id/one-to-many/multiple-pk/entity/Image.ts index 1c2f6eb2b..e2c322a10 100644 --- a/test/functional/query-builder/relation-id/one-to-many/multiple-pk/entity/Image.ts +++ b/test/functional/query-builder/relation-id/one-to-many/multiple-pk/entity/Image.ts @@ -1,8 +1,8 @@ -import {Entity} from "../../../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../../../src/decorator/columns/Column"; -import {ManyToOne} from "../../../../../../../src/decorator/relations/ManyToOne"; -import {Category} from "./Category"; +import {Entity} from "../../../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../../../src/decorator/columns/Column.ts"; +import {ManyToOne} from "../../../../../../../src/decorator/relations/ManyToOne.ts"; +import {Category} from "./Category.ts"; @Entity() export class Image { @@ -10,7 +10,7 @@ export class Image { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) name: string; @ManyToOne(type => Category, category => category.images) @@ -18,4 +18,4 @@ export class Image { categoryId: number; -} \ No newline at end of file +} diff --git a/test/functional/query-builder/relation-id/one-to-many/multiple-pk/entity/Post.ts b/test/functional/query-builder/relation-id/one-to-many/multiple-pk/entity/Post.ts index 17ce6299a..755ac1127 100644 --- a/test/functional/query-builder/relation-id/one-to-many/multiple-pk/entity/Post.ts +++ b/test/functional/query-builder/relation-id/one-to-many/multiple-pk/entity/Post.ts @@ -1,24 +1,24 @@ -import {Entity} from "../../../../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../../../../src/decorator/columns/Column"; -import {PrimaryColumn} from "../../../../../../../src/decorator/columns/PrimaryColumn"; -import {Category} from "./Category"; -import {OneToMany} from "../../../../../../../src/decorator/relations/OneToMany"; +import {Entity} from "../../../../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../../../../src/decorator/columns/Column.ts"; +import {PrimaryColumn} from "../../../../../../../src/decorator/columns/PrimaryColumn.ts"; +import {Category} from "./Category.ts"; +import {OneToMany} from "../../../../../../../src/decorator/relations/OneToMany.ts"; @Entity() export class Post { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; - @PrimaryColumn() + @PrimaryColumn({ type: Number }) authorId: number; - @Column() + @Column({ type: String }) title: string; @OneToMany(type => Category, category => category.post) categories: Category[]; - + categoryIds: number[]; -} \ No newline at end of file +} diff --git a/test/functional/query-builder/relation-id/one-to-many/multiple-pk/multiple-pk.ts b/test/functional/query-builder/relation-id/one-to-many/multiple-pk/multiple-pk.ts index 8e1e93dc7..35b22d7fe 100644 --- a/test/functional/query-builder/relation-id/one-to-many/multiple-pk/multiple-pk.ts +++ b/test/functional/query-builder/relation-id/one-to-many/multiple-pk/multiple-pk.ts @@ -1,20 +1,23 @@ -import "reflect-metadata"; -import {expect} from "chai"; +import {join as joinPaths} from "../../../../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../../../../deps/mocha.ts"; +import {expect} from "../../../../../deps/chai.ts"; import { + getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases -} from "../../../../../utils/test-utils"; -import {Connection} from "../../../../../../src/connection/Connection"; -import {Post} from "./entity/Post"; -import {Category} from "./entity/Category"; -import {Image} from "./entity/Image"; +} from "../../../../../utils/test-utils.ts"; +import {Connection} from "../../../../../../src/connection/Connection.ts"; +import {Post} from "./entity/Post.ts"; +import {Category} from "./entity/Category.ts"; +import {Image} from "./entity/Image.ts"; describe("query builder > relation-id > one-to-many > multiple-pk", () => { - + let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], })); beforeEach(() => reloadTestingDatabases(connections)); after(() => closeTestingConnections(connections)); @@ -333,3 +336,5 @@ describe("query builder > relation-id > one-to-many > multiple-pk", () => { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/query-builder/relation-id/one-to-one/basic-functionality/basic-functionality.ts b/test/functional/query-builder/relation-id/one-to-one/basic-functionality/basic-functionality.ts index bf125ad1a..e893b7e02 100644 --- a/test/functional/query-builder/relation-id/one-to-one/basic-functionality/basic-functionality.ts +++ b/test/functional/query-builder/relation-id/one-to-one/basic-functionality/basic-functionality.ts @@ -1,19 +1,22 @@ -import "reflect-metadata"; -import {expect} from "chai"; +import {join as joinPaths} from "../../../../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../../../../deps/mocha.ts"; +import {expect} from "../../../../../deps/chai.ts"; import { + getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases -} from "../../../../../utils/test-utils"; -import {Connection} from "../../../../../../src/connection/Connection"; -import {Category} from "./entity/Category"; -import {Post} from "./entity/Post"; +} from "../../../../../utils/test-utils.ts"; +import {Connection} from "../../../../../../src/connection/Connection.ts"; +import {Category} from "./entity/Category.ts"; +import {Post} from "./entity/Post.ts"; describe("query builder > relation-id > one-to-one > basic-functionality", () => { - + let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], })); beforeEach(() => reloadTestingDatabases(connections)); after(() => closeTestingConnections(connections)); @@ -98,3 +101,5 @@ describe("query builder > relation-id > one-to-one > basic-functionality", () => }))); }); + +runIfMain(import.meta); diff --git a/test/functional/query-builder/relation-id/one-to-one/basic-functionality/entity/Category.ts b/test/functional/query-builder/relation-id/one-to-one/basic-functionality/entity/Category.ts index fd3322d17..eb32d51e2 100644 --- a/test/functional/query-builder/relation-id/one-to-one/basic-functionality/entity/Category.ts +++ b/test/functional/query-builder/relation-id/one-to-one/basic-functionality/entity/Category.ts @@ -1,8 +1,8 @@ -import {Entity} from "../../../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../../../src/decorator/columns/Column"; -import {OneToOne} from "../../../../../../../src/decorator/relations/OneToOne"; -import {Post} from "./Post"; +import {Entity} from "../../../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../../../src/decorator/columns/Column.ts"; +import {OneToOne} from "../../../../../../../src/decorator/relations/OneToOne.ts"; +import {Post} from "./Post.ts"; @Entity() export class Category { @@ -10,7 +10,7 @@ export class Category { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) name: string; @OneToOne(type => Post, post => post.category2) @@ -18,4 +18,4 @@ export class Category { postId: number; -} \ No newline at end of file +} diff --git a/test/functional/query-builder/relation-id/one-to-one/basic-functionality/entity/Post.ts b/test/functional/query-builder/relation-id/one-to-one/basic-functionality/entity/Post.ts index d5a5aff87..eb78ab23c 100644 --- a/test/functional/query-builder/relation-id/one-to-one/basic-functionality/entity/Post.ts +++ b/test/functional/query-builder/relation-id/one-to-one/basic-functionality/entity/Post.ts @@ -1,9 +1,9 @@ -import {Entity} from "../../../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../../../src/decorator/columns/Column"; -import {OneToOne} from "../../../../../../../src/decorator/relations/OneToOne"; -import {JoinColumn} from "../../../../../../../src/decorator/relations/JoinColumn"; -import {Category} from "./Category"; +import {Entity} from "../../../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../../../src/decorator/columns/Column.ts"; +import {OneToOne} from "../../../../../../../src/decorator/relations/OneToOne.ts"; +import {JoinColumn} from "../../../../../../../src/decorator/relations/JoinColumn.ts"; +import {Category} from "./Category.ts"; @Entity() export class Post { @@ -11,9 +11,9 @@ export class Post { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) title: string; - + @OneToOne(type => Category) @JoinColumn() category: Category; @@ -21,7 +21,7 @@ export class Post { @OneToOne(type => Category, category => category.post) @JoinColumn() category2: Category; - + categoryId: number; -} \ No newline at end of file +} diff --git a/test/functional/query-builder/relation-id/one-to-one/embedded-with-multiple-pk/embedded-with-multiple-pk.ts b/test/functional/query-builder/relation-id/one-to-one/embedded-with-multiple-pk/embedded-with-multiple-pk.ts index b1297de10..01fe4538b 100644 --- a/test/functional/query-builder/relation-id/one-to-one/embedded-with-multiple-pk/embedded-with-multiple-pk.ts +++ b/test/functional/query-builder/relation-id/one-to-one/embedded-with-multiple-pk/embedded-with-multiple-pk.ts @@ -1,22 +1,25 @@ -import "reflect-metadata"; -import {expect} from "chai"; +import {join as joinPaths} from "../../../../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../../../../deps/mocha.ts"; +import {expect} from "../../../../../deps/chai.ts"; import { + getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases -} from "../../../../../utils/test-utils"; -import {Connection} from "../../../../../../src/connection/Connection"; -import {Post} from "./entity/Post"; -import {Category} from "./entity/Category"; -import {Counters} from "./entity/Counters"; -import {User} from "./entity/User"; -import {Subcounters} from "./entity/Subcounters"; +} from "../../../../../utils/test-utils.ts"; +import {Connection} from "../../../../../../src/connection/Connection.ts"; +import {Post} from "./entity/Post.ts"; +import {Category} from "./entity/Category.ts"; +import {Counters} from "./entity/Counters.ts"; +import {User} from "./entity/User.ts"; +import {Subcounters} from "./entity/Subcounters.ts"; describe("query builder > relation-id > one-to-one > embedded-with-multiple-pk", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], })); beforeEach(() => reloadTestingDatabases(connections)); after(() => closeTestingConnections(connections)); @@ -147,4 +150,6 @@ describe("query builder > relation-id > one-to-one > embedded-with-multiple-pk", }))); -}); \ No newline at end of file +}); + +runIfMain(import.meta); diff --git a/test/functional/query-builder/relation-id/one-to-one/embedded-with-multiple-pk/entity/Category.ts b/test/functional/query-builder/relation-id/one-to-one/embedded-with-multiple-pk/entity/Category.ts index 1cf0de5cd..948af766a 100644 --- a/test/functional/query-builder/relation-id/one-to-one/embedded-with-multiple-pk/entity/Category.ts +++ b/test/functional/query-builder/relation-id/one-to-one/embedded-with-multiple-pk/entity/Category.ts @@ -1,13 +1,13 @@ -import {Entity} from "../../../../../../../src/decorator/entity/Entity"; -import {PrimaryColumn} from "../../../../../../../src/decorator/columns/PrimaryColumn"; +import {Entity} from "../../../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryColumn} from "../../../../../../../src/decorator/columns/PrimaryColumn.ts"; @Entity() export class Category { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; - @PrimaryColumn() + @PrimaryColumn({ type: String }) name: string; -} \ No newline at end of file +} diff --git a/test/functional/query-builder/relation-id/one-to-one/embedded-with-multiple-pk/entity/Counters.ts b/test/functional/query-builder/relation-id/one-to-one/embedded-with-multiple-pk/entity/Counters.ts index 9f92bbf50..e2a0c76df 100644 --- a/test/functional/query-builder/relation-id/one-to-one/embedded-with-multiple-pk/entity/Counters.ts +++ b/test/functional/query-builder/relation-id/one-to-one/embedded-with-multiple-pk/entity/Counters.ts @@ -1,22 +1,22 @@ -import {Column} from "../../../../../../../src/decorator/columns/Column"; -import {PrimaryColumn} from "../../../../../../../src/decorator/columns/PrimaryColumn"; -import {OneToOne} from "../../../../../../../src/decorator/relations/OneToOne"; -import {JoinColumn} from "../../../../../../../src/decorator/relations/JoinColumn"; -import {Category} from "./Category"; -import {Subcounters} from "./Subcounters"; +import {Column} from "../../../../../../../src/decorator/columns/Column.ts"; +import {PrimaryColumn} from "../../../../../../../src/decorator/columns/PrimaryColumn.ts"; +import {OneToOne} from "../../../../../../../src/decorator/relations/OneToOne.ts"; +import {JoinColumn} from "../../../../../../../src/decorator/relations/JoinColumn.ts"; +import {Category} from "./Category.ts"; +import {Subcounters} from "./Subcounters.ts"; export class Counters { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) code: number; - @Column() + @Column({ type: Number }) likes: number; - @Column() + @Column({ type: Number }) comments: number; - @Column() + @Column({ type: Number }) favorites: number; @OneToOne(type => Category) @@ -28,4 +28,4 @@ export class Counters { categoryId: number[]; -} \ No newline at end of file +} diff --git a/test/functional/query-builder/relation-id/one-to-one/embedded-with-multiple-pk/entity/Post.ts b/test/functional/query-builder/relation-id/one-to-one/embedded-with-multiple-pk/entity/Post.ts index 145ffef8f..b569a4bc6 100644 --- a/test/functional/query-builder/relation-id/one-to-one/embedded-with-multiple-pk/entity/Post.ts +++ b/test/functional/query-builder/relation-id/one-to-one/embedded-with-multiple-pk/entity/Post.ts @@ -1,18 +1,18 @@ -import {Entity} from "../../../../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../../../../src/decorator/columns/Column"; -import {Counters} from "./Counters"; -import {PrimaryColumn} from "../../../../../../../src/decorator/columns/PrimaryColumn"; +import {Entity} from "../../../../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../../../../src/decorator/columns/Column.ts"; +import {Counters} from "./Counters.ts"; +import {PrimaryColumn} from "../../../../../../../src/decorator/columns/PrimaryColumn.ts"; @Entity() export class Post { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; - @Column() + @Column({ type: String }) title: string; @Column(() => Counters) counters: Counters; -} \ No newline at end of file +} diff --git a/test/functional/query-builder/relation-id/one-to-one/embedded-with-multiple-pk/entity/Subcounters.ts b/test/functional/query-builder/relation-id/one-to-one/embedded-with-multiple-pk/entity/Subcounters.ts index a2d3f79d0..ff695eccd 100644 --- a/test/functional/query-builder/relation-id/one-to-one/embedded-with-multiple-pk/entity/Subcounters.ts +++ b/test/functional/query-builder/relation-id/one-to-one/embedded-with-multiple-pk/entity/Subcounters.ts @@ -1,15 +1,15 @@ -import {Column} from "../../../../../../../src/decorator/columns/Column"; -import {PrimaryColumn} from "../../../../../../../src/decorator/columns/PrimaryColumn"; -import {OneToOne} from "../../../../../../../src/decorator/relations/OneToOne"; -import {JoinColumn} from "../../../../../../../src/decorator/relations/JoinColumn"; -import {User} from "./User"; +import {Column} from "../../../../../../../src/decorator/columns/Column.ts"; +import {PrimaryColumn} from "../../../../../../../src/decorator/columns/PrimaryColumn.ts"; +import {OneToOne} from "../../../../../../../src/decorator/relations/OneToOne.ts"; +import {JoinColumn} from "../../../../../../../src/decorator/relations/JoinColumn.ts"; +import {User} from "./User.ts"; export class Subcounters { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) version: number; - @Column() + @Column({ type: Number }) watches: number; @OneToOne(type => User) @@ -18,4 +18,4 @@ export class Subcounters { watchedUserId: number; -} \ No newline at end of file +} diff --git a/test/functional/query-builder/relation-id/one-to-one/embedded-with-multiple-pk/entity/User.ts b/test/functional/query-builder/relation-id/one-to-one/embedded-with-multiple-pk/entity/User.ts index 5ba01dac6..78bbfb708 100644 --- a/test/functional/query-builder/relation-id/one-to-one/embedded-with-multiple-pk/entity/User.ts +++ b/test/functional/query-builder/relation-id/one-to-one/embedded-with-multiple-pk/entity/User.ts @@ -1,13 +1,13 @@ -import {Entity} from "../../../../../../../src/decorator/entity/Entity"; -import {PrimaryColumn} from "../../../../../../../src/decorator/columns/PrimaryColumn"; +import {Entity} from "../../../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryColumn} from "../../../../../../../src/decorator/columns/PrimaryColumn.ts"; @Entity() export class User { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; - @PrimaryColumn() + @PrimaryColumn({ type: String }) name: string; -} \ No newline at end of file +} diff --git a/test/functional/query-builder/relation-id/one-to-one/embedded/embedded.ts b/test/functional/query-builder/relation-id/one-to-one/embedded/embedded.ts index 674f4b8de..616586e26 100644 --- a/test/functional/query-builder/relation-id/one-to-one/embedded/embedded.ts +++ b/test/functional/query-builder/relation-id/one-to-one/embedded/embedded.ts @@ -1,22 +1,25 @@ -import "reflect-metadata"; -import {expect} from "chai"; +import {join as joinPaths} from "../../../../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../../../../deps/mocha.ts"; +import {expect} from "../../../../../deps/chai.ts"; import { + getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases -} from "../../../../../utils/test-utils"; -import {Connection} from "../../../../../../src/connection/Connection"; -import {Post} from "./entity/Post"; -import {Category} from "./entity/Category"; -import {Counters} from "./entity/Counters"; -import {User} from "./entity/User"; -import {Subcounters} from "./entity/Subcounters"; +} from "../../../../../utils/test-utils.ts"; +import {Connection} from "../../../../../../src/connection/Connection.ts"; +import {Post} from "./entity/Post.ts"; +import {Category} from "./entity/Category.ts"; +import {Counters} from "./entity/Counters.ts"; +import {User} from "./entity/User.ts"; +import {Subcounters} from "./entity/Subcounters.ts"; describe("query builder > relation-id > one-to-one > embedded", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], })); beforeEach(() => reloadTestingDatabases(connections)); after(() => closeTestingConnections(connections)); @@ -109,4 +112,6 @@ describe("query builder > relation-id > one-to-one > embedded", () => { }))); -}); \ No newline at end of file +}); + +runIfMain(import.meta); diff --git a/test/functional/query-builder/relation-id/one-to-one/embedded/entity/Category.ts b/test/functional/query-builder/relation-id/one-to-one/embedded/entity/Category.ts index 008f7970c..595c43cda 100644 --- a/test/functional/query-builder/relation-id/one-to-one/embedded/entity/Category.ts +++ b/test/functional/query-builder/relation-id/one-to-one/embedded/entity/Category.ts @@ -1,8 +1,8 @@ -import {Entity} from "../../../../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../../../../src/decorator/columns/Column"; -import {PrimaryGeneratedColumn} from "../../../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Post} from "./Post"; -import {OneToOne} from "../../../../../../../src/decorator/relations/OneToOne"; +import {Entity} from "../../../../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../../../../src/decorator/columns/Column.ts"; +import {PrimaryGeneratedColumn} from "../../../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Post} from "./Post.ts"; +import {OneToOne} from "../../../../../../../src/decorator/relations/OneToOne.ts"; @Entity() export class Category { @@ -10,7 +10,7 @@ export class Category { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) name: string; @OneToOne(type => Post, post => post.counters.category) @@ -18,4 +18,4 @@ export class Category { postId: number; -} \ No newline at end of file +} diff --git a/test/functional/query-builder/relation-id/one-to-one/embedded/entity/Counters.ts b/test/functional/query-builder/relation-id/one-to-one/embedded/entity/Counters.ts index 0570e558f..9df1d95f9 100644 --- a/test/functional/query-builder/relation-id/one-to-one/embedded/entity/Counters.ts +++ b/test/functional/query-builder/relation-id/one-to-one/embedded/entity/Counters.ts @@ -1,18 +1,18 @@ -import {Column} from "../../../../../../../src/decorator/columns/Column"; -import {Category} from "./Category"; -import {Subcounters} from "./Subcounters"; -import {OneToOne} from "../../../../../../../src/decorator/relations/OneToOne"; -import {JoinColumn} from "../../../../../../../src/decorator/relations/JoinColumn"; +import {Column} from "../../../../../../../src/decorator/columns/Column.ts"; +import {Category} from "./Category.ts"; +import {Subcounters} from "./Subcounters.ts"; +import {OneToOne} from "../../../../../../../src/decorator/relations/OneToOne.ts"; +import {JoinColumn} from "../../../../../../../src/decorator/relations/JoinColumn.ts"; export class Counters { - @Column() + @Column({ type: Number }) likes: number; - @Column() + @Column({ type: Number }) comments: number; - @Column() + @Column({ type: Number }) favorites: number; @OneToOne(type => Category, category => category.post) @@ -24,4 +24,4 @@ export class Counters { categoryId: number; -} \ No newline at end of file +} diff --git a/test/functional/query-builder/relation-id/one-to-one/embedded/entity/Post.ts b/test/functional/query-builder/relation-id/one-to-one/embedded/entity/Post.ts index 7ae2be8a6..1397f2c0f 100644 --- a/test/functional/query-builder/relation-id/one-to-one/embedded/entity/Post.ts +++ b/test/functional/query-builder/relation-id/one-to-one/embedded/entity/Post.ts @@ -1,14 +1,14 @@ -import {Entity} from "../../../../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../../../../src/decorator/columns/Column"; -import {Counters} from "./Counters"; +import {Entity} from "../../../../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../../../../src/decorator/columns/Column.ts"; +import {Counters} from "./Counters.ts"; @Entity() export class Post { - @Column() + @Column({ type: String }) title: string; @Column(() => Counters) counters: Counters; -} \ No newline at end of file +} diff --git a/test/functional/query-builder/relation-id/one-to-one/embedded/entity/Subcounters.ts b/test/functional/query-builder/relation-id/one-to-one/embedded/entity/Subcounters.ts index c7d1488ca..92048560a 100644 --- a/test/functional/query-builder/relation-id/one-to-one/embedded/entity/Subcounters.ts +++ b/test/functional/query-builder/relation-id/one-to-one/embedded/entity/Subcounters.ts @@ -1,18 +1,18 @@ -import {Column} from "../../../../../../../src/decorator/columns/Column"; -import {OneToOne} from "../../../../../../../src/decorator/relations/OneToOne"; -import {JoinColumn} from "../../../../../../../src/decorator/relations/JoinColumn"; -import {PrimaryGeneratedColumn} from "../../../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {User} from "./User"; +import {Column} from "../../../../../../../src/decorator/columns/Column.ts"; +import {OneToOne} from "../../../../../../../src/decorator/relations/OneToOne.ts"; +import {JoinColumn} from "../../../../../../../src/decorator/relations/JoinColumn.ts"; +import {PrimaryGeneratedColumn} from "../../../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {User} from "./User.ts"; export class Subcounters { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: Number }) version: number; - @Column() + @Column({ type: Number }) watches: number; @OneToOne(type => User) @@ -21,4 +21,4 @@ export class Subcounters { watchedUserId: number; -} \ No newline at end of file +} diff --git a/test/functional/query-builder/relation-id/one-to-one/embedded/entity/User.ts b/test/functional/query-builder/relation-id/one-to-one/embedded/entity/User.ts index c0d8bd3fe..2c0b743a6 100644 --- a/test/functional/query-builder/relation-id/one-to-one/embedded/entity/User.ts +++ b/test/functional/query-builder/relation-id/one-to-one/embedded/entity/User.ts @@ -1,6 +1,6 @@ -import {Column} from "../../../../../../../src/decorator/columns/Column"; -import {Entity} from "../../../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../../../src/decorator/columns/PrimaryGeneratedColumn"; +import {Column} from "../../../../../../../src/decorator/columns/Column.ts"; +import {Entity} from "../../../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; @Entity() export class User { @@ -8,7 +8,7 @@ export class User { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) name: string; -} \ No newline at end of file +} diff --git a/test/functional/query-builder/relation-id/one-to-one/multiple-pk/entity/Category.ts b/test/functional/query-builder/relation-id/one-to-one/multiple-pk/entity/Category.ts index 0dbac8d24..b83d4d66f 100644 --- a/test/functional/query-builder/relation-id/one-to-one/multiple-pk/entity/Category.ts +++ b/test/functional/query-builder/relation-id/one-to-one/multiple-pk/entity/Category.ts @@ -1,24 +1,24 @@ -import {Entity} from "../../../../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../../../../src/decorator/columns/Column"; -import {PrimaryColumn} from "../../../../../../../src/decorator/columns/PrimaryColumn"; -import {Post} from "./Post"; -import {Image} from "./Image"; -import {OneToOne} from "../../../../../../../src/decorator/relations/OneToOne"; -import {JoinColumn} from "../../../../../../../src/decorator/relations/JoinColumn"; +import {Entity} from "../../../../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../../../../src/decorator/columns/Column.ts"; +import {PrimaryColumn} from "../../../../../../../src/decorator/columns/PrimaryColumn.ts"; +import {Post} from "./Post.ts"; +import {Image} from "./Image.ts"; +import {OneToOne} from "../../../../../../../src/decorator/relations/OneToOne.ts"; +import {JoinColumn} from "../../../../../../../src/decorator/relations/JoinColumn.ts"; @Entity() export class Category { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; - @PrimaryColumn() + @PrimaryColumn({ type: Number }) code: number; - @Column() + @Column({ type: String }) name: string; - @Column() + @Column({ type: Boolean }) isRemoved: boolean = false; @OneToOne(type => Post, post => post.category) @@ -32,4 +32,4 @@ export class Category { imageId: number; -} \ No newline at end of file +} diff --git a/test/functional/query-builder/relation-id/one-to-one/multiple-pk/entity/Image.ts b/test/functional/query-builder/relation-id/one-to-one/multiple-pk/entity/Image.ts index 3bb1b26a0..da20df09d 100644 --- a/test/functional/query-builder/relation-id/one-to-one/multiple-pk/entity/Image.ts +++ b/test/functional/query-builder/relation-id/one-to-one/multiple-pk/entity/Image.ts @@ -1,8 +1,8 @@ -import {Entity} from "../../../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../../../src/decorator/columns/Column"; -import {OneToOne} from "../../../../../../../src/decorator/relations/OneToOne"; -import {Category} from "./Category"; +import {Entity} from "../../../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../../../src/decorator/columns/Column.ts"; +import {OneToOne} from "../../../../../../../src/decorator/relations/OneToOne.ts"; +import {Category} from "./Category.ts"; @Entity() export class Image { @@ -10,7 +10,7 @@ export class Image { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) name: string; @OneToOne(type => Category, category => category.image) @@ -18,4 +18,4 @@ export class Image { categoryId: number; -} \ No newline at end of file +} diff --git a/test/functional/query-builder/relation-id/one-to-one/multiple-pk/entity/Post.ts b/test/functional/query-builder/relation-id/one-to-one/multiple-pk/entity/Post.ts index 7a2b59d75..849595322 100644 --- a/test/functional/query-builder/relation-id/one-to-one/multiple-pk/entity/Post.ts +++ b/test/functional/query-builder/relation-id/one-to-one/multiple-pk/entity/Post.ts @@ -1,23 +1,23 @@ -import {Entity} from "../../../../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../../../../src/decorator/columns/Column"; -import {PrimaryColumn} from "../../../../../../../src/decorator/columns/PrimaryColumn"; -import {OneToOne} from "../../../../../../../src/decorator/relations/OneToOne"; -import {JoinColumn} from "../../../../../../../src/decorator/relations/JoinColumn"; -import {Category} from "./Category"; +import {Entity} from "../../../../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../../../../src/decorator/columns/Column.ts"; +import {PrimaryColumn} from "../../../../../../../src/decorator/columns/PrimaryColumn.ts"; +import {OneToOne} from "../../../../../../../src/decorator/relations/OneToOne.ts"; +import {JoinColumn} from "../../../../../../../src/decorator/relations/JoinColumn.ts"; +import {Category} from "./Category.ts"; @Entity() export class Post { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; - @PrimaryColumn() + @PrimaryColumn({ type: Number }) authorId: number; - @Column() + @Column({ type: String }) title: string; - @Column() + @Column({ type: Boolean }) isRemoved: boolean = false; @OneToOne(type => Category, category => category.post) @@ -27,7 +27,7 @@ export class Post { @OneToOne(type => Category) @JoinColumn() subcategory: Category; - + categoryId: number; -} \ No newline at end of file +} diff --git a/test/functional/query-builder/relation-id/one-to-one/multiple-pk/multiple-pk.ts b/test/functional/query-builder/relation-id/one-to-one/multiple-pk/multiple-pk.ts index 0b47ad5e3..463864d5e 100644 --- a/test/functional/query-builder/relation-id/one-to-one/multiple-pk/multiple-pk.ts +++ b/test/functional/query-builder/relation-id/one-to-one/multiple-pk/multiple-pk.ts @@ -1,20 +1,23 @@ -import "reflect-metadata"; -import {expect} from "chai"; +import {join as joinPaths} from "../../../../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../../../../deps/mocha.ts"; +import {expect} from "../../../../../deps/chai.ts"; import { + getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases -} from "../../../../../utils/test-utils"; -import {Connection} from "../../../../../../src/connection/Connection"; -import {Post} from "./entity/Post"; -import {Category} from "./entity/Category"; -import {Image} from "./entity/Image"; +} from "../../../../../utils/test-utils.ts"; +import {Connection} from "../../../../../../src/connection/Connection.ts"; +import {Post} from "./entity/Post.ts"; +import {Category} from "./entity/Category.ts"; +import {Image} from "./entity/Image.ts"; describe("query builder > relation-id > one-to-one > multiple-pk", () => { - + let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], })); beforeEach(() => reloadTestingDatabases(connections)); after(() => closeTestingConnections(connections)); @@ -379,4 +382,6 @@ describe("query builder > relation-id > one-to-one > multiple-pk", () => { }); -}); \ No newline at end of file +}); + +runIfMain(import.meta); diff --git a/test/functional/query-builder/relational/with-many/entity/Category.ts b/test/functional/query-builder/relational/with-many/entity/Category.ts index b8f117810..d886fa857 100644 --- a/test/functional/query-builder/relational/with-many/entity/Category.ts +++ b/test/functional/query-builder/relational/with-many/entity/Category.ts @@ -1,8 +1,8 @@ -import {Entity} from "../../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../../src/decorator/columns/Column"; -import {OneToMany} from "../../../../../../src/decorator/relations/OneToMany"; -import {Post} from "./Post"; +import {Entity} from "../../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../../src/decorator/columns/Column.ts"; +import {OneToMany} from "../../../../../../src/decorator/relations/OneToMany.ts"; +import {Post} from "./Post.ts"; @Entity() export class Category { @@ -10,10 +10,10 @@ export class Category { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) name: string; @OneToMany(type => Post, post => post.category) posts: Post[]; -} \ No newline at end of file +} diff --git a/test/functional/query-builder/relational/with-many/entity/Image.ts b/test/functional/query-builder/relational/with-many/entity/Image.ts index 89dd72262..cc18cbaf4 100644 --- a/test/functional/query-builder/relational/with-many/entity/Image.ts +++ b/test/functional/query-builder/relational/with-many/entity/Image.ts @@ -1,8 +1,8 @@ -import {Entity} from "../../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../../src/decorator/columns/Column"; -import {Post} from "./Post"; -import {ManyToMany} from "../../../../../../src/decorator/relations/ManyToMany"; +import {Entity} from "../../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../../src/decorator/columns/Column.ts"; +import {Post} from "./Post.ts"; +import {ManyToMany} from "../../../../../../src/decorator/relations/ManyToMany.ts"; @Entity() export class Image { @@ -10,10 +10,10 @@ export class Image { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) url: string; @ManyToMany(type => Post, post => post.images) posts: Post[]; -} \ No newline at end of file +} diff --git a/test/functional/query-builder/relational/with-many/entity/Post.ts b/test/functional/query-builder/relational/with-many/entity/Post.ts index eb26a7fee..4862d1961 100644 --- a/test/functional/query-builder/relational/with-many/entity/Post.ts +++ b/test/functional/query-builder/relational/with-many/entity/Post.ts @@ -1,11 +1,11 @@ -import {Entity} from "../../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../../src/decorator/columns/Column"; -import {ManyToOne} from "../../../../../../src/decorator/relations/ManyToOne"; -import {Category} from "./Category"; -import {Image} from "./Image"; -import {ManyToMany} from "../../../../../../src/decorator/relations/ManyToMany"; -import {JoinTable} from "../../../../../../src/decorator/relations/JoinTable"; +import {Entity} from "../../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../../src/decorator/columns/Column.ts"; +import {ManyToOne} from "../../../../../../src/decorator/relations/ManyToOne.ts"; +import {Category} from "./Category.ts"; +import {Image} from "./Image.ts"; +import {ManyToMany} from "../../../../../../src/decorator/relations/ManyToMany.ts"; +import {JoinTable} from "../../../../../../src/decorator/relations/JoinTable.ts"; @Entity() export class Post { @@ -13,7 +13,7 @@ export class Post { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) title: string; @ManyToOne(type => Category, category => category.posts) @@ -23,4 +23,4 @@ export class Post { @JoinTable() images: Image[]; -} \ No newline at end of file +} diff --git a/test/functional/query-builder/relational/with-many/query-builder-relational-add-remove-many-to-many-inverse.ts b/test/functional/query-builder/relational/with-many/query-builder-relational-add-remove-many-to-many-inverse.ts index cae1020fb..b1cc764df 100644 --- a/test/functional/query-builder/relational/with-many/query-builder-relational-add-remove-many-to-many-inverse.ts +++ b/test/functional/query-builder/relational/with-many/query-builder-relational-add-remove-many-to-many-inverse.ts @@ -1,15 +1,17 @@ -import "reflect-metadata"; -import {Post} from "./entity/Post"; -import {Image} from "./entity/Image"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils"; -import {expect} from "chai"; -import {Connection} from "../../../../../src/connection/Connection"; +import {join as joinPaths} from "../../../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../../../deps/mocha.ts"; +import {expect} from "../../../../deps/chai.ts"; +import {Post} from "./entity/Post.ts"; +import {Image} from "./entity/Image.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils.ts"; +import {Connection} from "../../../../../src/connection/Connection.ts"; describe("query builder > relational with many > add and remove many to many inverse", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], })); beforeEach(() => reloadTestingDatabases(connections)); after(() => closeTestingConnections(connections)); @@ -303,3 +305,5 @@ describe("query builder > relational with many > add and remove many to many inv }))); }); + +runIfMain(import.meta); diff --git a/test/functional/query-builder/relational/with-many/query-builder-relational-add-remove-many-to-many.ts b/test/functional/query-builder/relational/with-many/query-builder-relational-add-remove-many-to-many.ts index a37dbb67d..23a324c7a 100644 --- a/test/functional/query-builder/relational/with-many/query-builder-relational-add-remove-many-to-many.ts +++ b/test/functional/query-builder/relational/with-many/query-builder-relational-add-remove-many-to-many.ts @@ -1,15 +1,17 @@ -import "reflect-metadata"; -import {Post} from "./entity/Post"; -import {Image} from "./entity/Image"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils"; -import {expect} from "chai"; -import {Connection} from "../../../../../src/connection/Connection"; +import {join as joinPaths} from "../../../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../../../deps/mocha.ts"; +import {expect} from "../../../../deps/chai.ts"; +import {Post} from "./entity/Post.ts"; +import {Image} from "./entity/Image.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils.ts"; +import {Connection} from "../../../../../src/connection/Connection.ts"; describe("query builder > relational with many > add and remove many to many", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], })); beforeEach(() => reloadTestingDatabases(connections)); after(() => closeTestingConnections(connections)); @@ -302,3 +304,5 @@ describe("query builder > relational with many > add and remove many to many", ( }))); }); + +runIfMain(import.meta); diff --git a/test/functional/query-builder/relational/with-many/query-builder-relational-add-remove-one-to-many.ts b/test/functional/query-builder/relational/with-many/query-builder-relational-add-remove-one-to-many.ts index 96a34af29..8b4098240 100644 --- a/test/functional/query-builder/relational/with-many/query-builder-relational-add-remove-one-to-many.ts +++ b/test/functional/query-builder/relational/with-many/query-builder-relational-add-remove-one-to-many.ts @@ -1,15 +1,17 @@ -import "reflect-metadata"; -import {Post} from "./entity/Post"; -import {Category} from "./entity/Category"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils"; -import {expect} from "chai"; -import {Connection} from "../../../../../src/connection/Connection"; +import {join as joinPaths} from "../../../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../../../deps/mocha.ts"; +import {expect} from "../../../../deps/chai.ts"; +import {Post} from "./entity/Post.ts"; +import {Category} from "./entity/Category.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils.ts"; +import {Connection} from "../../../../../src/connection/Connection.ts"; describe("query builder > relational query builder > add operation > one to many relation", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], })); beforeEach(() => reloadTestingDatabases(connections)); after(() => closeTestingConnections(connections)); @@ -302,3 +304,5 @@ describe("query builder > relational query builder > add operation > one to many }))); }); + +runIfMain(import.meta); diff --git a/test/functional/query-builder/relational/with-many/query-builder-relational-load-many.ts b/test/functional/query-builder/relational/with-many/query-builder-relational-load-many.ts index 2d914e120..9a1376561 100644 --- a/test/functional/query-builder/relational/with-many/query-builder-relational-load-many.ts +++ b/test/functional/query-builder/relational/with-many/query-builder-relational-load-many.ts @@ -1,15 +1,17 @@ -import "reflect-metadata"; -import {Post} from "./entity/Post"; -import {Image} from "./entity/Image"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils"; -import {expect} from "chai"; -import {Connection} from "../../../../../src/connection/Connection"; +import {join as joinPaths} from "../../../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../../../deps/mocha.ts"; +import {expect} from "../../../../deps/chai.ts"; +import {Post} from "./entity/Post.ts"; +import {Image} from "./entity/Image.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils.ts"; +import {Connection} from "../../../../../src/connection/Connection.ts"; describe("query builder > relational with many > load many", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], })); beforeEach(() => reloadTestingDatabases(connections)); after(() => closeTestingConnections(connections)); @@ -138,3 +140,5 @@ describe("query builder > relational with many > load many", () => { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/query-builder/relational/with-one/entity/Category.ts b/test/functional/query-builder/relational/with-one/entity/Category.ts index 80e1b6e5a..d52a72560 100644 --- a/test/functional/query-builder/relational/with-one/entity/Category.ts +++ b/test/functional/query-builder/relational/with-one/entity/Category.ts @@ -1,6 +1,6 @@ -import {Entity} from "../../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../../src/decorator/columns/Column"; +import {Entity} from "../../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../../src/decorator/columns/Column.ts"; @Entity() export class Category { @@ -8,7 +8,7 @@ export class Category { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) name: string; -} \ No newline at end of file +} diff --git a/test/functional/query-builder/relational/with-one/entity/Image.ts b/test/functional/query-builder/relational/with-one/entity/Image.ts index e8b2b6bd7..1872a1a50 100644 --- a/test/functional/query-builder/relational/with-one/entity/Image.ts +++ b/test/functional/query-builder/relational/with-one/entity/Image.ts @@ -1,8 +1,8 @@ -import {Entity} from "../../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../../src/decorator/columns/Column"; -import {OneToOne} from "../../../../../../src/decorator/relations/OneToOne"; -import {Post} from "./Post"; +import {Entity} from "../../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../../src/decorator/columns/Column.ts"; +import {OneToOne} from "../../../../../../src/decorator/relations/OneToOne.ts"; +import {Post} from "./Post.ts"; @Entity() export class Image { @@ -10,10 +10,10 @@ export class Image { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) url: string; @OneToOne(type => Post, post => post.image) post: Post; -} \ No newline at end of file +} diff --git a/test/functional/query-builder/relational/with-one/entity/Post.ts b/test/functional/query-builder/relational/with-one/entity/Post.ts index a89d3c71b..90fbf4977 100644 --- a/test/functional/query-builder/relational/with-one/entity/Post.ts +++ b/test/functional/query-builder/relational/with-one/entity/Post.ts @@ -1,11 +1,11 @@ -import {Entity} from "../../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../../src/decorator/columns/Column"; -import {ManyToOne} from "../../../../../../src/decorator/relations/ManyToOne"; -import {Category} from "./Category"; -import {Image} from "./Image"; -import {OneToOne} from "../../../../../../src/decorator/relations/OneToOne"; -import {JoinColumn} from "../../../../../../src/decorator/relations/JoinColumn"; +import {Entity} from "../../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../../src/decorator/columns/Column.ts"; +import {ManyToOne} from "../../../../../../src/decorator/relations/ManyToOne.ts"; +import {Category} from "./Category.ts"; +import {Image} from "./Image.ts"; +import {OneToOne} from "../../../../../../src/decorator/relations/OneToOne.ts"; +import {JoinColumn} from "../../../../../../src/decorator/relations/JoinColumn.ts"; @Entity() export class Post { @@ -13,7 +13,7 @@ export class Post { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) title: string; @ManyToOne(type => Category) @@ -23,4 +23,4 @@ export class Post { @JoinColumn() image: Image; -} \ No newline at end of file +} diff --git a/test/functional/query-builder/relational/with-one/query-builder-relational-load-one.ts b/test/functional/query-builder/relational/with-one/query-builder-relational-load-one.ts index 85d05efce..c904d3120 100644 --- a/test/functional/query-builder/relational/with-one/query-builder-relational-load-one.ts +++ b/test/functional/query-builder/relational/with-one/query-builder-relational-load-one.ts @@ -1,15 +1,17 @@ -import "reflect-metadata"; -import {Post} from "./entity/Post"; -import {Category} from "./entity/Category"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils"; -import {expect} from "chai"; -import {Connection} from "../../../../../src/connection/Connection"; +import {join as joinPaths} from "../../../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../../../deps/mocha.ts"; +import {expect} from "../../../../deps/chai.ts"; +import {Post} from "./entity/Post.ts"; +import {Category} from "./entity/Category.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils.ts"; +import {Connection} from "../../../../../src/connection/Connection.ts"; describe("query builder > relational query builder > load operation > many-to-one and one-to-one relations", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], })); beforeEach(() => reloadTestingDatabases(connections)); after(() => closeTestingConnections(connections)); @@ -195,3 +197,5 @@ describe("query builder > relational query builder > load operation > many-to-on }))); }); + +runIfMain(import.meta); diff --git a/test/functional/query-builder/relational/with-one/query-builder-relational-set-many-to-one.ts b/test/functional/query-builder/relational/with-one/query-builder-relational-set-many-to-one.ts index 144f92a5a..9126de874 100644 --- a/test/functional/query-builder/relational/with-one/query-builder-relational-set-many-to-one.ts +++ b/test/functional/query-builder/relational/with-one/query-builder-relational-set-many-to-one.ts @@ -1,15 +1,17 @@ -import "reflect-metadata"; -import {Post} from "./entity/Post"; -import {Category} from "./entity/Category"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils"; -import {expect} from "chai"; -import {Connection} from "../../../../../src/connection/Connection"; +import {join as joinPaths} from "../../../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../../../deps/mocha.ts"; +import {expect} from "../../../../deps/chai.ts"; +import {Post} from "./entity/Post.ts"; +import {Category} from "./entity/Category.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils.ts"; +import {Connection} from "../../../../../src/connection/Connection.ts"; describe("query builder > relational query builder > set operation > many to one relation", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], })); beforeEach(() => reloadTestingDatabases(connections)); after(() => closeTestingConnections(connections)); @@ -243,3 +245,5 @@ describe("query builder > relational query builder > set operation > many to one }))); }); + +runIfMain(import.meta); diff --git a/test/functional/query-builder/relational/with-one/query-builder-relational-set-one-to-one-inverse.ts b/test/functional/query-builder/relational/with-one/query-builder-relational-set-one-to-one-inverse.ts index 7fb1bf022..aa1583f7d 100644 --- a/test/functional/query-builder/relational/with-one/query-builder-relational-set-one-to-one-inverse.ts +++ b/test/functional/query-builder/relational/with-one/query-builder-relational-set-one-to-one-inverse.ts @@ -1,15 +1,17 @@ -import "reflect-metadata"; -import {Post} from "./entity/Post"; -import {Image} from "./entity/Image"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils"; -import {expect} from "chai"; -import {Connection} from "../../../../../src/connection/Connection"; +import {join as joinPaths} from "../../../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../../../deps/mocha.ts"; +import {expect} from "../../../../deps/chai.ts"; +import {Post} from "./entity/Post.ts"; +import {Image} from "./entity/Image.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils.ts"; +import {Connection} from "../../../../../src/connection/Connection.ts"; describe("query builder > relational query builder > set operation > one-to-one non owner side", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], })); beforeEach(() => reloadTestingDatabases(connections)); after(() => closeTestingConnections(connections)); @@ -235,3 +237,5 @@ describe("query builder > relational query builder > set operation > one-to-one }))); }); + +runIfMain(import.meta); diff --git a/test/functional/query-builder/relational/with-one/query-builder-relational-set-one-to-one.ts b/test/functional/query-builder/relational/with-one/query-builder-relational-set-one-to-one.ts index 6cf753f81..f57136cfc 100644 --- a/test/functional/query-builder/relational/with-one/query-builder-relational-set-one-to-one.ts +++ b/test/functional/query-builder/relational/with-one/query-builder-relational-set-one-to-one.ts @@ -1,15 +1,17 @@ -import "reflect-metadata"; -import {Post} from "./entity/Post"; -import {Image} from "./entity/Image"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils"; -import {expect} from "chai"; -import {Connection} from "../../../../../src/connection/Connection"; +import {join as joinPaths} from "../../../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../../../deps/mocha.ts"; +import {expect} from "../../../../deps/chai.ts"; +import {Post} from "./entity/Post.ts"; +import {Image} from "./entity/Image.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils.ts"; +import {Connection} from "../../../../../src/connection/Connection.ts"; describe("query builder > relational query builder > set operation > one-to-one relation", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], })); beforeEach(() => reloadTestingDatabases(connections)); after(() => closeTestingConnections(connections)); @@ -235,3 +237,5 @@ describe("query builder > relational query builder > set operation > one-to-one }))); }); + +runIfMain(import.meta); diff --git a/test/functional/query-builder/select/entity/Category.ts b/test/functional/query-builder/select/entity/Category.ts index 561d01285..cc20a69d0 100644 --- a/test/functional/query-builder/select/entity/Category.ts +++ b/test/functional/query-builder/select/entity/Category.ts @@ -1,7 +1,7 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {VersionColumn} from "../../../../../src/decorator/columns/VersionColumn"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {VersionColumn} from "../../../../../src/decorator/columns/VersionColumn.ts"; @Entity() export class Category { @@ -9,13 +9,13 @@ export class Category { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) name: string; - @Column() + @Column({ type: String }) description: string; @VersionColumn() version: string; -} \ No newline at end of file +} diff --git a/test/functional/query-builder/select/entity/Post.ts b/test/functional/query-builder/select/entity/Post.ts index 3f1f1d34b..44b5c725c 100644 --- a/test/functional/query-builder/select/entity/Post.ts +++ b/test/functional/query-builder/select/entity/Post.ts @@ -1,9 +1,9 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {VersionColumn} from "../../../../../src/decorator/columns/VersionColumn"; -import {Category} from "./Category"; -import {ManyToOne} from "../../../../../src/decorator/relations/ManyToOne"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {VersionColumn} from "../../../../../src/decorator/columns/VersionColumn.ts"; +import {Category} from "./Category.ts"; +import {ManyToOne} from "../../../../../src/decorator/relations/ManyToOne.ts"; @Entity() export class Post { @@ -11,13 +11,13 @@ export class Post { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) title: string; - @Column() + @Column({ type: String }) description: string; - @Column() + @Column({ type: Number }) rating: number; @VersionColumn() @@ -26,4 +26,4 @@ export class Post { @ManyToOne(type => Category) category: Category; -} \ No newline at end of file +} diff --git a/test/functional/query-builder/select/query-builder-select.ts b/test/functional/query-builder/select/query-builder-select.ts index 6b1ba78e8..42dec0985 100644 --- a/test/functional/query-builder/select/query-builder-select.ts +++ b/test/functional/query-builder/select/query-builder-select.ts @@ -1,14 +1,16 @@ -import "reflect-metadata"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils"; -import {Connection} from "../../../../src/connection/Connection"; -import {Post} from "./entity/Post"; -import {expect} from "chai"; +import {join as joinPaths} from "../../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../../deps/mocha.ts"; +import {expect} from "../../../deps/chai.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils.ts"; +import {Connection} from "../../../../src/connection/Connection.ts"; +import {Post} from "./entity/Post.ts"; describe("query builder > select", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], })); beforeEach(() => reloadTestingDatabases(connections)); after(() => closeTestingConnections(connections)); @@ -111,3 +113,5 @@ describe("query builder > select", () => { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/query-builder/subquery/entity/Category.ts b/test/functional/query-builder/subquery/entity/Category.ts index 0095127bd..fdbf6b325 100644 --- a/test/functional/query-builder/subquery/entity/Category.ts +++ b/test/functional/query-builder/subquery/entity/Category.ts @@ -1,6 +1,6 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../src/decorator/columns/Column"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; @Entity() export class Category { @@ -8,7 +8,7 @@ export class Category { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) name: string; -} \ No newline at end of file +} diff --git a/test/functional/query-builder/subquery/entity/Post.ts b/test/functional/query-builder/subquery/entity/Post.ts index 5ecf2bd66..f938c0f41 100644 --- a/test/functional/query-builder/subquery/entity/Post.ts +++ b/test/functional/query-builder/subquery/entity/Post.ts @@ -1,9 +1,9 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {Category} from "./Category"; -import {ManyToMany} from "../../../../../src/decorator/relations/ManyToMany"; -import {JoinTable} from "../../../../../src/decorator/relations/JoinTable"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {Category} from "./Category.ts"; +import {ManyToMany} from "../../../../../src/decorator/relations/ManyToMany.ts"; +import {JoinTable} from "../../../../../src/decorator/relations/JoinTable.ts"; @Entity() export class Post { @@ -11,11 +11,11 @@ export class Post { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) title: string; @ManyToMany(type => Category) @JoinTable() categories: Category[]; -} \ No newline at end of file +} diff --git a/test/functional/query-builder/subquery/entity/User.ts b/test/functional/query-builder/subquery/entity/User.ts index b7e6aad97..2005c5bb9 100644 --- a/test/functional/query-builder/subquery/entity/User.ts +++ b/test/functional/query-builder/subquery/entity/User.ts @@ -1,6 +1,6 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../src/decorator/columns/Column"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; @Entity() export class User { @@ -8,10 +8,10 @@ export class User { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) name: string; - @Column() + @Column({ type: Boolean }) registered: boolean; -} \ No newline at end of file +} diff --git a/test/functional/query-builder/subquery/query-builder-subquery.ts b/test/functional/query-builder/subquery/query-builder-subquery.ts index e6ba2e4ce..cdcb93ce6 100644 --- a/test/functional/query-builder/subquery/query-builder-subquery.ts +++ b/test/functional/query-builder/subquery/query-builder-subquery.ts @@ -1,10 +1,13 @@ -import "reflect-metadata"; -import {CockroachDriver} from "../../../../src/driver/cockroachdb/CockroachDriver"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils"; -import {Connection} from "../../../../src/connection/Connection"; -import {User} from "./entity/User"; -import {Post} from "./entity/Post"; -import {Category} from "./entity/Category"; +import {join as joinPaths} from "../../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../../deps/mocha.ts"; +import "../../../deps/chai.ts"; +// TODO(uki00a) uncomment this when CockroachDriver is implemented. +// import {CockroachDriver} from "../../../../src/driver/cockroachdb/CockroachDriver"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils.ts"; +import {Connection} from "../../../../src/connection/Connection.ts"; +import {User} from "./entity/User.ts"; +import {Post} from "./entity/Post.ts"; +import {Category} from "./entity/Category.ts"; describe("query builder > sub-query", () => { @@ -13,8 +16,9 @@ describe("query builder > sub-query", () => { // ------------------------------------------------------------------------- let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], })); beforeEach(() => reloadTestingDatabases(connections)); after(() => closeTestingConnections(connections)); @@ -266,7 +270,7 @@ describe("query builder > sub-query", () => { .getRawMany(); // CockroachDB returns numeric data types as string - if (connection.driver instanceof CockroachDriver) { + if (false/* connection.driver instanceof CockroachDriver */) { // TODO(uki00a) uncomment this when CockroachDriver is implemented. posts.should.be.eql([ { id: "1", name: "Alex Messer" }, { id: "2", name: "Alex Messer" }, @@ -300,7 +304,7 @@ describe("query builder > sub-query", () => { .getRawMany(); // CockroachDB returns numeric data types as string - if (connection.driver instanceof CockroachDriver) { + if (false/* connection.driver instanceof CockroachDriver */) { // TODO(uki00a) uncomment this when CockroachDriver is implemented. posts.should.be.eql([ { id: "1", name: "Alex Messer" }, { id: "2", name: "Alex Messer" }, @@ -393,3 +397,5 @@ describe("query builder > sub-query", () => { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/query-builder/update/entity/Counters.ts b/test/functional/query-builder/update/entity/Counters.ts index d7383302b..8a3e2da4d 100644 --- a/test/functional/query-builder/update/entity/Counters.ts +++ b/test/functional/query-builder/update/entity/Counters.ts @@ -1,14 +1,14 @@ -import {Column} from "../../../../../src/decorator/columns/Column"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; export class Counters { - @Column({ default: 1 }) + @Column({ default: 1, type: Number }) likes: number; - @Column({ nullable: true }) + @Column({ nullable: true, type: Number }) favorites: number; - @Column({ default: 0 }) + @Column({ default: 0, type: Number }) comments: number; -} \ No newline at end of file +} diff --git a/test/functional/query-builder/update/entity/Photo.ts b/test/functional/query-builder/update/entity/Photo.ts index 9e94e26eb..59761f309 100644 --- a/test/functional/query-builder/update/entity/Photo.ts +++ b/test/functional/query-builder/update/entity/Photo.ts @@ -1,7 +1,7 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {Counters} from "./Counters"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {Counters} from "./Counters.ts"; @Entity() export class Photo { @@ -9,9 +9,9 @@ export class Photo { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) url: string; @Column(type => Counters) counters: Counters; -} \ No newline at end of file +} diff --git a/test/functional/query-builder/update/entity/User.ts b/test/functional/query-builder/update/entity/User.ts index 3d22aad15..9d262ab88 100644 --- a/test/functional/query-builder/update/entity/User.ts +++ b/test/functional/query-builder/update/entity/User.ts @@ -1,6 +1,6 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../src/decorator/columns/Column"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; @Entity() export class User { @@ -8,10 +8,10 @@ export class User { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: Number }) name: string; - @Column() + @Column({ type: Number }) likesCount: number = 0; -} \ No newline at end of file +} diff --git a/test/functional/query-builder/update/query-builder-update.ts b/test/functional/query-builder/update/query-builder-update.ts index 17c55ee50..63a999fe3 100644 --- a/test/functional/query-builder/update/query-builder-update.ts +++ b/test/functional/query-builder/update/query-builder-update.ts @@ -1,20 +1,22 @@ -import "reflect-metadata"; -import {expect} from "chai"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils"; -import {Connection} from "../../../../src/connection/Connection"; -import {User} from "./entity/User"; -import {MysqlDriver} from "../../../../src/driver/mysql/MysqlDriver"; -import {SqlServerDriver} from "../../../../src/driver/sqlserver/SqlServerDriver"; -import {LimitOnUpdateNotSupportedError} from "../../../../src/error/LimitOnUpdateNotSupportedError"; -import {Photo} from "./entity/Photo"; -import {EntityColumnNotFound} from "../../../../src/error/EntityColumnNotFound"; -import {UpdateValuesMissingError} from "../../../../src/error/UpdateValuesMissingError"; +import {join as joinPaths} from "../../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../../deps/mocha.ts"; +import {expect} from "../../../deps/chai.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils.ts"; +import {Connection} from "../../../../src/connection/Connection.ts"; +import {User} from "./entity/User.ts"; +import {MysqlDriver} from "../../../../src/driver/mysql/MysqlDriver.ts"; +import {SqlServerDriver} from "../../../../src/driver/sqlserver/SqlServerDriver.ts"; +import {LimitOnUpdateNotSupportedError} from "../../../../src/error/LimitOnUpdateNotSupportedError.ts"; +import {Photo} from "./entity/Photo.ts"; +import {EntityColumnNotFound} from "../../../../src/error/EntityColumnNotFound.ts"; +import {UpdateValuesMissingError} from "../../../../src/error/UpdateValuesMissingError.ts"; describe("query builder > update", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], })); beforeEach(() => reloadTestingDatabases(connections)); after(() => closeTestingConnections(connections)); @@ -180,11 +182,16 @@ describe("query builder > update", () => { expect(loadedUsers).to.exist; loadedUsers!.length.should.be.equal(limitNum); } else { - await connection.createQueryBuilder() - .update(User) - .set({ name: nameToFind }) - .limit(limitNum) - .execute().should.be.rejectedWith(LimitOnUpdateNotSupportedError); + try { + await connection.createQueryBuilder() + .update(User) + .set({ name: nameToFind }) + .limit(limitNum) + .execute(); + expect.fail("an error not to be thrown."); + } catch (err) { + expect(err).to.be.instanceOf(LimitOnUpdateNotSupportedError); + } } }))); @@ -250,3 +257,5 @@ describe("query builder > update", () => { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/query-runner/add-column.ts b/test/functional/query-runner/add-column.ts index 36f4d6363..38532bf3b 100644 --- a/test/functional/query-runner/add-column.ts +++ b/test/functional/query-runner/add-column.ts @@ -1,18 +1,20 @@ -import {expect} from "chai"; -import "reflect-metadata"; -import {Connection} from "../../../src/connection/Connection"; -import {CockroachDriver} from "../../../src/driver/cockroachdb/CockroachDriver"; -import {MysqlDriver} from "../../../src/driver/mysql/MysqlDriver"; -import {AbstractSqliteDriver} from "../../../src/driver/sqlite-abstract/AbstractSqliteDriver"; -import {TableColumn} from "../../../src/schema-builder/table/TableColumn"; -import {closeTestingConnections, createTestingConnections} from "../../utils/test-utils"; - -describe("query runner > add column", () => { - +import {join as joinPaths} from "../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../deps/mocha.ts"; +import {expect} from "../../deps/chai.ts"; +import {Connection} from "../../../src/connection/Connection.ts"; +// TODO(uki00a) uncomment this when CockroachDriver is implemented. +// import {CockroachDriver} from "../../../src/driver/cockroachdb/CockroachDriver.ts"; +import {MysqlDriver} from "../../../src/driver/mysql/MysqlDriver.ts"; +import {AbstractSqliteDriver} from "../../../src/driver/sqlite-abstract/AbstractSqliteDriver.ts"; +import {TableColumn} from "../../../src/schema-builder/table/TableColumn.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections} from "../../utils/test-utils.ts"; + +describe("query runner > add column", function() { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => { connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], schemaCreate: true, dropSchema: true, }); @@ -32,11 +34,11 @@ describe("query runner > add column", () => { }); // CockroachDB does not support altering primary key constraint - if (!(connection.driver instanceof CockroachDriver)) + if (true/* !(connection.driver instanceof CockroachDriver) */) // TODO(uki00a) uncomment this when CockroachDriver is implemented. column1.isPrimary = true; // MySql and Sqlite does not supports autoincrement composite primary keys. - if (!(connection.driver instanceof MysqlDriver) && !(connection.driver instanceof AbstractSqliteDriver) && !(connection.driver instanceof CockroachDriver)) { + if (!(connection.driver instanceof MysqlDriver) && !(connection.driver instanceof AbstractSqliteDriver) && true/*!(connection.driver instanceof CockroachDriver)*/) { // TODO(uki00a) uncomment this when CockroachDriver is implemented. column1.isGenerated = true; column1.generationStrategy = "increment"; } @@ -58,11 +60,11 @@ describe("query runner > add column", () => { column1!.isNullable.should.be.false; // CockroachDB does not support altering primary key constraint - if (!(connection.driver instanceof CockroachDriver)) + if (true/*!(connection.driver instanceof CockroachDriver)*/) // TODO(uki00a) uncomment this when CockroachDriver is implemented. column1!.isPrimary.should.be.true; // MySql and Sqlite does not supports autoincrement composite primary keys. - if (!(connection.driver instanceof MysqlDriver) && !(connection.driver instanceof AbstractSqliteDriver) && !(connection.driver instanceof CockroachDriver)) { + if (!(connection.driver instanceof MysqlDriver) && !(connection.driver instanceof AbstractSqliteDriver) && true/*!(connection.driver instanceof CockroachDriver)*/) { // TODO(uki00a) uncomment this when CockroachDriver is impelemented. column1!.isGenerated.should.be.true; column1!.generationStrategy!.should.be.equal("increment"); } @@ -82,3 +84,5 @@ describe("query runner > add column", () => { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/query-runner/change-column.ts b/test/functional/query-runner/change-column.ts index 732dbfd71..025ec1f1e 100644 --- a/test/functional/query-runner/change-column.ts +++ b/test/functional/query-runner/change-column.ts @@ -1,16 +1,19 @@ -import "reflect-metadata"; -import {expect} from "chai"; -import {Connection} from "../../../src/connection/Connection"; -import {CockroachDriver} from "../../../src/driver/cockroachdb/CockroachDriver"; -import {closeTestingConnections, createTestingConnections} from "../../utils/test-utils"; -import {AbstractSqliteDriver} from "../../../src/driver/sqlite-abstract/AbstractSqliteDriver"; +import {join as joinPaths} from "../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../deps/mocha.ts"; +import {expect} from "../../deps/chai.ts"; +import {Connection} from "../../../src/connection/Connection.ts"; +// TODO(uki00a) uncomment this when CockroachDriver is implemented. +// import {CockroachDriver} from "../../../src/driver/cockroachdb/CockroachDriver"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections} from "../../utils/test-utils.ts"; +import {AbstractSqliteDriver} from "../../../src/driver/sqlite-abstract/AbstractSqliteDriver.ts"; describe("query runner > change column", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => { connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], schemaCreate: true, dropSchema: true, }); @@ -20,7 +23,7 @@ describe("query runner > change column", () => { it("should correctly change column and revert change", () => Promise.all(connections.map(async connection => { // CockroachDB does not allow changing primary columns and renaming constraints - if (connection.driver instanceof CockroachDriver) + if (false/* connection.driver instanceof CockroachDriver */) // TODO(uki00a) uncomment this when CockroachDriver is implemented. return; const queryRunner = connection.createQueryRunner(); @@ -82,7 +85,7 @@ describe("query runner > change column", () => { it("should correctly change column 'isGenerated' property and revert change", () => Promise.all(connections.map(async connection => { // CockroachDB does not allow changing generated columns in existent tables - if (connection.driver instanceof CockroachDriver) + if (false/* connection.driver instanceof CockroachDriver */) // TODO(uki00a) uncomment this when CockroachDriver is implemented. return; const queryRunner = connection.createQueryRunner(); @@ -136,3 +139,5 @@ describe("query runner > change column", () => { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/query-runner/create-and-drop-database.ts b/test/functional/query-runner/create-and-drop-database.ts index 30e60f0b8..01db5278c 100644 --- a/test/functional/query-runner/create-and-drop-database.ts +++ b/test/functional/query-runner/create-and-drop-database.ts @@ -1,13 +1,16 @@ -import "reflect-metadata"; -import {Connection} from "../../../src/connection/Connection"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../utils/test-utils"; +import {join as joinPaths} from "../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../deps/mocha.ts"; +import "../../deps/chai.ts"; +import {Connection} from "../../../src/connection/Connection.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../utils/test-utils.ts"; describe("query runner > create and drop database", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => { connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], enabledDrivers: ["mysql", "mssql", "cockroachdb"], dropSchema: true, }); @@ -36,3 +39,5 @@ describe("query runner > create and drop database", () => { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/query-runner/create-and-drop-schema.ts b/test/functional/query-runner/create-and-drop-schema.ts index d156e1ce0..e72a01788 100644 --- a/test/functional/query-runner/create-and-drop-schema.ts +++ b/test/functional/query-runner/create-and-drop-schema.ts @@ -1,13 +1,16 @@ -import "reflect-metadata"; -import {Connection} from "../../../src"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../utils/test-utils"; +import {join as joinPaths} from "../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../deps/mocha.ts"; +import "../../deps/chai.ts"; +import {Connection} from "../../../src/index.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../utils/test-utils.ts"; describe("query runner > create and drop schema", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => { connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], enabledDrivers: ["mssql", "postgres", "sap"], dropSchema: true, }); @@ -36,3 +39,5 @@ describe("query runner > create and drop schema", () => { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/query-runner/create-check-constraint.ts b/test/functional/query-runner/create-check-constraint.ts index 8a706aee7..f61ce3779 100644 --- a/test/functional/query-runner/create-check-constraint.ts +++ b/test/functional/query-runner/create-check-constraint.ts @@ -1,16 +1,19 @@ -import "reflect-metadata"; -import {Connection} from "../../../src"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../utils/test-utils"; -import {Table} from "../../../src"; -import {TableCheck} from "../../../src/schema-builder/table/TableCheck"; -import {MysqlDriver} from "../../../src/driver/mysql/MysqlDriver"; +import {join as joinPaths} from "../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../deps/mocha.ts"; +import "../../deps/chai.ts"; +import {Connection} from "../../../src/index.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../utils/test-utils.ts"; +import {Table} from "../../../src/index.ts"; +import {TableCheck} from "../../../src/schema-builder/table/TableCheck.ts"; +import {MysqlDriver} from "../../../src/driver/mysql/MysqlDriver.ts"; describe("query runner > create check constraint", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => { connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], schemaCreate: true, dropSchema: true, }); @@ -69,3 +72,5 @@ describe("query runner > create check constraint", () => { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/query-runner/create-exclusion-constraint.ts b/test/functional/query-runner/create-exclusion-constraint.ts index c9b9e4f20..9fc1477e8 100644 --- a/test/functional/query-runner/create-exclusion-constraint.ts +++ b/test/functional/query-runner/create-exclusion-constraint.ts @@ -1,15 +1,18 @@ -import "reflect-metadata"; -import {Connection} from "../../../src"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../utils/test-utils"; -import {Table} from "../../../src"; -import {TableExclusion} from "../../../src/schema-builder/table/TableExclusion"; +import {join as joinPaths} from "../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../deps/mocha.ts"; +import "../../deps/chai.ts"; +import {Connection} from "../../../src/index.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../utils/test-utils.ts"; +import {Table} from "../../../src/index.ts"; +import {TableExclusion} from "../../../src/schema-builder/table/TableExclusion.ts"; describe("query runner > create exclusion constraint", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => { connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], enabledDrivers: ["postgres"], // Only PostgreSQL supports exclusion constraints. schemaCreate: true, dropSchema: true, @@ -64,3 +67,5 @@ describe("query runner > create exclusion constraint", () => { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/query-runner/create-foreign-key.ts b/test/functional/query-runner/create-foreign-key.ts index 8119f9598..155a4f615 100644 --- a/test/functional/query-runner/create-foreign-key.ts +++ b/test/functional/query-runner/create-foreign-key.ts @@ -1,16 +1,20 @@ -import "reflect-metadata"; -import {Connection} from "../../../src/connection/Connection"; -import {CockroachDriver} from "../../../src/driver/cockroachdb/CockroachDriver"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../utils/test-utils"; -import {Table} from "../../../src/schema-builder/table/Table"; -import {TableForeignKey} from "../../../src/schema-builder/table/TableForeignKey"; +import {join as joinPaths} from "../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../deps/mocha.ts"; +import "../../deps/chai.ts"; +import {Connection} from "../../../src/connection/Connection.ts"; +// TODO(uki00a) uncomment this when CockroachDriver is implemented. +// import {CockroachDriver} from "../../../src/driver/cockroachdb/CockroachDriver.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../utils/test-utils.ts"; +import {Table} from "../../../src/schema-builder/table/Table.ts"; +import {TableForeignKey} from "../../../src/schema-builder/table/TableForeignKey.ts"; describe("query runner > create foreign key", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => { connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], schemaCreate: true, dropSchema: true, }); @@ -50,7 +54,8 @@ describe("query runner > create foreign key", () => { }, { name: "questionId", - isUnique: connection.driver instanceof CockroachDriver, // CockroachDB requires UNIQUE constraints on referenced columns + // TODO(uki00a) uncomment this when CockroachDriver is implemented. + isUnique: false/*connection.driver instanceof CockroachDriver*/, // CockroachDB requires UNIQUE constraints on referenced columns type: "int", } ] @@ -78,3 +83,5 @@ describe("query runner > create foreign key", () => { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/query-runner/create-index.ts b/test/functional/query-runner/create-index.ts index f72502e0c..c8d2de60e 100644 --- a/test/functional/query-runner/create-index.ts +++ b/test/functional/query-runner/create-index.ts @@ -1,16 +1,20 @@ -import "reflect-metadata"; -import {Connection} from "../../../src/connection/Connection"; -import {CockroachDriver} from "../../../src/driver/cockroachdb/CockroachDriver"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../utils/test-utils"; -import {Table} from "../../../src/schema-builder/table/Table"; -import {TableIndex} from "../../../src/schema-builder/table/TableIndex"; +import {join as joinPaths} from "../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../deps/mocha.ts"; +import "../../deps/chai.ts"; +import {Connection} from "../../../src/connection/Connection.ts"; +// TODO(uki00a) uncomment this when CockroachDriver is implemented. +// import {CockroachDriver} from "../../../src/driver/cockroachdb/CockroachDriver.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../utils/test-utils.ts"; +import {Table} from "../../../src/schema-builder/table/Table.ts"; +import {TableIndex} from "../../../src/schema-builder/table/TableIndex.ts"; describe("query runner > create index", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => { connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], schemaCreate: true, dropSchema: true, }); @@ -52,7 +56,7 @@ describe("query runner > create index", () => { let table = await queryRunner.getTable("question"); // CockroachDB stores unique indices as UNIQUE constraints - if (connection.driver instanceof CockroachDriver) { + if (false/*connection.driver instanceof CockroachDriver*/) { // TODO(uki00a) uncomment this when CockroachDriver is implemented. table!.indices.length.should.be.equal(1); table!.uniques.length.should.be.equal(1); @@ -70,3 +74,5 @@ describe("query runner > create index", () => { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/query-runner/create-primary-key.ts b/test/functional/query-runner/create-primary-key.ts index 1af1170bf..25e5cdf92 100644 --- a/test/functional/query-runner/create-primary-key.ts +++ b/test/functional/query-runner/create-primary-key.ts @@ -1,15 +1,19 @@ -import "reflect-metadata"; -import {Connection} from "../../../src/connection/Connection"; -import {CockroachDriver} from "../../../src/driver/cockroachdb/CockroachDriver"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../utils/test-utils"; -import {Table} from "../../../src/schema-builder/table/Table"; +import {join as joinPaths} from "../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../deps/mocha.ts"; +import "../../deps/chai.ts"; +import {Connection} from "../../../src/connection/Connection.ts"; +// TODO(uki00a) uncomment this when CockroachDriver is implemented. +// import {CockroachDriver} from "../../../src/driver/cockroachdb/CockroachDriver.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../utils/test-utils.ts"; +import {Table} from "../../../src/schema-builder/table/Table.ts"; describe("query runner > create primary key", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => { connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], schemaCreate: true, dropSchema: true, }); @@ -20,7 +24,7 @@ describe("query runner > create primary key", () => { it("should correctly create primary key and revert creation", () => Promise.all(connections.map(async connection => { // CockroachDB does not allow altering primary key - if (connection.driver instanceof CockroachDriver) + if (false/*connection.driver instanceof CockroachDriver*/) // TODO(uki00a) uncomment this when CockroachDriver is implemented. return; const queryRunner = connection.createQueryRunner(); @@ -82,3 +86,5 @@ describe("query runner > create primary key", () => { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/query-runner/create-table.ts b/test/functional/query-runner/create-table.ts index f940faf7e..6e88fc681 100644 --- a/test/functional/query-runner/create-table.ts +++ b/test/functional/query-runner/create-table.ts @@ -1,25 +1,28 @@ -import "reflect-metadata"; -import {expect} from "chai"; -import {Connection} from "../../../src/connection/Connection"; -import {CockroachDriver} from "../../../src/driver/cockroachdb/CockroachDriver"; -import {SapDriver} from "../../../src/driver/sap/SapDriver"; -import {closeTestingConnections, createTestingConnections} from "../../utils/test-utils"; -import {Table} from "../../../src/schema-builder/table/Table"; -import {TableOptions} from "../../../src/schema-builder/options/TableOptions"; -import {Post} from "./entity/Post"; -import {MysqlDriver} from "../../../src/driver/mysql/MysqlDriver"; -import {AbstractSqliteDriver} from "../../../src/driver/sqlite-abstract/AbstractSqliteDriver"; -import {OracleDriver} from "../../../src/driver/oracle/OracleDriver"; -import {Photo} from "./entity/Photo"; -import {Book2, Book} from "./entity/Book"; -import {SqliteDriver} from "../../../src/driver/sqlite/SqliteDriver"; +import {join as joinPaths} from "../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../deps/mocha.ts"; +import {expect} from "../../deps/chai.ts"; +import {Connection} from "../../../src/connection/Connection.ts"; +// TODO(uki00a) uncomment this when CockroachDriver is implemented. +// import {CockroachDriver} from "../../../src/driver/cockroachdb/CockroachDriver.ts"; +import {SapDriver} from "../../../src/driver/sap/SapDriver.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections} from "../../utils/test-utils.ts"; +import {Table} from "../../../src/schema-builder/table/Table.ts"; +import {TableOptions} from "../../../src/schema-builder/options/TableOptions.ts"; +import {Post} from "./entity/Post.ts"; +import {MysqlDriver} from "../../../src/driver/mysql/MysqlDriver.ts"; +import {AbstractSqliteDriver} from "../../../src/driver/sqlite-abstract/AbstractSqliteDriver.ts"; +import {OracleDriver} from "../../../src/driver/oracle/OracleDriver.ts"; +import {Photo} from "./entity/Photo.ts"; +import {Book2, Book} from "./entity/Book.ts"; +import {SqliteDriver} from "../../../src/driver/sqlite/SqliteDriver.ts"; describe("query runner > create table", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => { connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], dropSchema: true, }); }); @@ -232,7 +235,7 @@ describe("query runner > create table", () => { questionTable!.uniques.length.should.be.equal(0); questionTable!.indices.length.should.be.equal(2); - } else if (connection.driver instanceof CockroachDriver) { + } else if (false/*connection.driver instanceof CockroachDriver*/) { // TODO(uki00a) uncomment this when CockroachDriver is implemented. // CockroachDB stores unique indices as UNIQUE constraints questionTable!.uniques.length.should.be.equal(2); questionTable!.uniques[0].columnNames.length.should.be.equal(2); @@ -308,7 +311,7 @@ describe("query runner > create table", () => { tagColumn!.isUnique.should.be.true; textColumn!.isUnique.should.be.true; - } else if (connection.driver instanceof CockroachDriver) { + } else if (false/*connection.driver instanceof CockroachDriver*/) { // TODO(uki00a) uncomment this when CockroachDriver is implemented. // CockroachDB stores unique indices as UNIQUE constraints table!.uniques.length.should.be.equal(4); table!.indices.length.should.be.equal(0); @@ -358,7 +361,10 @@ describe("query runner > create table", () => { try { await connection.manager.query("SELECT rowid FROM book2"); } catch (e) { - expect(e.message).equal("SQLITE_ERROR: no such column: rowid"); + expect(e.message).to.be.oneOf([ + "SQLITE_ERROR: no such column: rowid", // node-sqlite3's format + "SqliteError: no such column: rowid" // deno-sqlite's format + ]); } await queryRunner.dropTable("book2"); @@ -370,3 +376,5 @@ describe("query runner > create table", () => { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/query-runner/create-unique-constraint.ts b/test/functional/query-runner/create-unique-constraint.ts index ba39b2aa9..48b602ff0 100644 --- a/test/functional/query-runner/create-unique-constraint.ts +++ b/test/functional/query-runner/create-unique-constraint.ts @@ -1,15 +1,18 @@ -import "reflect-metadata"; -import {Connection} from "../../../src/connection/Connection"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../utils/test-utils"; -import {Table} from "../../../src/schema-builder/table/Table"; -import {TableUnique} from "../../../src/schema-builder/table/TableUnique"; +import {join as joinPaths} from "../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../deps/mocha.ts"; +import "../../deps/chai.ts"; +import {Connection} from "../../../src/connection/Connection.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../utils/test-utils.ts"; +import {Table} from "../../../src/schema-builder/table/Table.ts"; +import {TableUnique} from "../../../src/schema-builder/table/TableUnique.ts"; describe("query runner > create unique constraint", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => { connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], enabledDrivers: ["mssql", "postgres", "sqlite", "oracle", "cockroachdb"], // mysql and sap does not supports unique constraints schemaCreate: true, dropSchema: true, @@ -90,3 +93,5 @@ describe("query runner > create unique constraint", () => { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/query-runner/drop-check-constraint.ts b/test/functional/query-runner/drop-check-constraint.ts index f0d24d6b0..23b24aa95 100644 --- a/test/functional/query-runner/drop-check-constraint.ts +++ b/test/functional/query-runner/drop-check-constraint.ts @@ -1,14 +1,17 @@ -import "reflect-metadata"; -import {Connection} from "../../../src/connection/Connection"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../utils/test-utils"; -import {MysqlDriver} from "../../../src/driver/mysql/MysqlDriver"; +import {join as joinPaths} from "../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../deps/mocha.ts"; +import "../../deps/chai.ts"; +import {Connection} from "../../../src/connection/Connection.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../utils/test-utils.ts"; +import {MysqlDriver} from "../../../src/driver/mysql/MysqlDriver.ts"; describe("query runner > drop check constraint", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => { connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], schemaCreate: true, dropSchema: true, }); @@ -41,3 +44,5 @@ describe("query runner > drop check constraint", () => { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/query-runner/drop-column.ts b/test/functional/query-runner/drop-column.ts index 5e03628ee..fbbb8ede9 100644 --- a/test/functional/query-runner/drop-column.ts +++ b/test/functional/query-runner/drop-column.ts @@ -1,15 +1,19 @@ -import "reflect-metadata"; -import {expect} from "chai"; -import {Connection} from "../../../src/connection/Connection"; -import {CockroachDriver} from "../../../src/driver/cockroachdb/CockroachDriver"; -import {closeTestingConnections, createTestingConnections} from "../../utils/test-utils"; +import {join as joinPaths} from "../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../deps/mocha.ts"; +import {expect} from "../../deps/chai.ts"; +import {Connection} from "../../../src/connection/Connection.ts"; +// TODO(uki00a) uncomment this when CockroachDriver is implemented. +// import {CockroachDriver} from "../../../src/driver/cockroachdb/CockroachDriver.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections} from "../../utils/test-utils.ts"; +import {SqliteDriver} from "../../../src/driver/sqlite/SqliteDriver.ts"; describe("query runner > drop column", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => { connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], schemaCreate: true, dropSchema: true, }); @@ -17,6 +21,11 @@ describe("query runner > drop column", () => { after(() => closeTestingConnections(connections)); it("should correctly drop column and revert drop", () => Promise.all(connections.map(async connection => { + // TODO(uki00a) Fix this problem. See https://github.com/denolib/typeorm/issues/14. + if (connection.driver instanceof SqliteDriver) { + console.warn("This test is skipped because of the issue #14. See https://github.com/denolib/typeorm/issues/14."); + return; + } const queryRunner = connection.createQueryRunner(); @@ -32,7 +41,7 @@ describe("query runner > drop column", () => { // without all removed columns. In other drivers it's no difference between these methods, because 'dropColumns' // calls 'dropColumn' method for each removed column. // CockroachDB does not support changing pk. - if (connection.driver instanceof CockroachDriver) { + if (false/*connection.driver instanceof CockroachDriver*/) { // TODO(uki00a) uncomment this when CockroachDriver is implemented. await queryRunner.dropColumns(table!, [nameColumn, versionColumn]); } else { await queryRunner.dropColumns(table!, [idColumn, nameColumn, versionColumn]); @@ -41,7 +50,7 @@ describe("query runner > drop column", () => { table = await queryRunner.getTable("post"); expect(table!.findColumnByName("name")).to.be.undefined; expect(table!.findColumnByName("version")).to.be.undefined; - if (!(connection.driver instanceof CockroachDriver)) + if (true/*!(connection.driver instanceof CockroachDriver)*/) // TODO(uki00a) uncomment this when CockroachDriver is implemented. expect(table!.findColumnByName("id")).to.be.undefined; await queryRunner.executeMemoryDownSql(); @@ -55,3 +64,5 @@ describe("query runner > drop column", () => { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/query-runner/drop-exclusion-constraint.ts b/test/functional/query-runner/drop-exclusion-constraint.ts index d4a984346..f275de187 100644 --- a/test/functional/query-runner/drop-exclusion-constraint.ts +++ b/test/functional/query-runner/drop-exclusion-constraint.ts @@ -1,13 +1,16 @@ -import "reflect-metadata"; -import {Connection} from "../../../src/connection/Connection"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../utils/test-utils"; +import {join as joinPaths} from "../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../deps/mocha.ts"; +import "../../deps/chai.ts"; +import {Connection} from "../../../src/connection/Connection.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../utils/test-utils.ts"; describe("query runner > drop exclusion constraint", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => { connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], enabledDrivers: ["postgres"], // Only PostgreSQL supports exclusion constraints. schemaCreate: true, dropSchema: true, @@ -37,3 +40,5 @@ describe("query runner > drop exclusion constraint", () => { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/query-runner/drop-foreign-key.ts b/test/functional/query-runner/drop-foreign-key.ts index e024b660e..133f6ab53 100644 --- a/test/functional/query-runner/drop-foreign-key.ts +++ b/test/functional/query-runner/drop-foreign-key.ts @@ -1,13 +1,16 @@ -import "reflect-metadata"; -import {Connection} from "../../../src/connection/Connection"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../utils/test-utils"; +import {join as joinPaths} from "../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../deps/mocha.ts"; +import "../../deps/chai.ts"; +import {Connection} from "../../../src/connection/Connection.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../utils/test-utils.ts"; describe("query runner > drop foreign key", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => { connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], schemaCreate: true, dropSchema: true, }); @@ -36,3 +39,5 @@ describe("query runner > drop foreign key", () => { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/query-runner/drop-index.ts b/test/functional/query-runner/drop-index.ts index b36c89a90..33f48798b 100644 --- a/test/functional/query-runner/drop-index.ts +++ b/test/functional/query-runner/drop-index.ts @@ -1,14 +1,18 @@ -import "reflect-metadata"; -import {Connection} from "../../../src/connection/Connection"; -import {CockroachDriver} from "../../../src/driver/cockroachdb/CockroachDriver"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../utils/test-utils"; +import {join as joinPaths} from "../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../deps/mocha.ts"; +import "../../deps/chai.ts"; +import {Connection} from "../../../src/connection/Connection.ts"; +// TODO(uki00a) uncomment this when CockroachDriver is implemented. +// import {CockroachDriver} from "../../../src/driver/cockroachdb/CockroachDriver.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../utils/test-utils.ts"; describe("query runner > drop index", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => { connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], schemaCreate: true, dropSchema: true, }); @@ -22,7 +26,7 @@ describe("query runner > drop index", () => { let table = await queryRunner.getTable("student"); // CockroachDB also stores indices for relation columns - if (connection.driver instanceof CockroachDriver) { + if (false/* connection.driver instanceof CockroachDriver */) { // TODO(uki00a) uncomment this when CockroachDriver is implemented. table!.indices.length.should.be.equal(3); } else { table!.indices.length.should.be.equal(1); @@ -32,7 +36,7 @@ describe("query runner > drop index", () => { table = await queryRunner.getTable("student"); // CockroachDB also stores indices for relation columns - if (connection.driver instanceof CockroachDriver) { + if (false/* connection.driver instanceof CockroachDriver */) { // TODO(uki00a) uncomment this when CockroachDriver is implemented. table!.indices.length.should.be.equal(2); } else { table!.indices.length.should.be.equal(0); @@ -42,7 +46,7 @@ describe("query runner > drop index", () => { table = await queryRunner.getTable("student"); // CockroachDB also stores indices for relation columns - if (connection.driver instanceof CockroachDriver) { + if (false/* connection.driver instanceof CockroachDriver */) { // TODO(uki00a) uncomment this when CockroachDriver is implemented. table!.indices.length.should.be.equal(3); } else { table!.indices.length.should.be.equal(1); @@ -52,3 +56,5 @@ describe("query runner > drop index", () => { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/query-runner/drop-primary-key.ts b/test/functional/query-runner/drop-primary-key.ts index f6f6f519b..f3105ced0 100644 --- a/test/functional/query-runner/drop-primary-key.ts +++ b/test/functional/query-runner/drop-primary-key.ts @@ -1,14 +1,18 @@ -import "reflect-metadata"; -import {Connection} from "../../../src/connection/Connection"; -import {CockroachDriver} from "../../../src/driver/cockroachdb/CockroachDriver"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../utils/test-utils"; +import {join as joinPaths} from "../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../deps/mocha.ts"; +import "../../deps/chai.ts"; +import {Connection} from "../../../src/connection/Connection.ts"; +// TODO(uki00a) uncomment this when CockroachDriver is implemented. +// import {CockroachDriver} from "../../../src/driver/cockroachdb/CockroachDriver.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../utils/test-utils.ts"; describe("query runner > drop primary key", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => { connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], schemaCreate: true, dropSchema: true, }); @@ -19,7 +23,7 @@ describe("query runner > drop primary key", () => { it("should correctly drop primary key and revert drop", () => Promise.all(connections.map(async connection => { // CockroachDB does not allow dropping primary key - if (connection.driver instanceof CockroachDriver) + if (false/* connection.driver instanceof CockroachDriver */) // TODO(uki00a) uncomment this when CockroachDriver is implemented. return; const queryRunner = connection.createQueryRunner(); @@ -41,3 +45,5 @@ describe("query runner > drop primary key", () => { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/query-runner/drop-table.ts b/test/functional/query-runner/drop-table.ts index 94670a86d..63c704d80 100644 --- a/test/functional/query-runner/drop-table.ts +++ b/test/functional/query-runner/drop-table.ts @@ -1,14 +1,16 @@ -import "reflect-metadata"; -import {expect} from "chai"; -import {Connection} from "../../../src/connection/Connection"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../utils/test-utils"; +import {join as joinPaths} from "../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../deps/mocha.ts"; +import {expect} from "../../deps/chai.ts"; +import {Connection} from "../../../src/connection/Connection.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../utils/test-utils.ts"; describe("query runner > drop table", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => { connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], schemaCreate: true, }); }); @@ -70,3 +72,5 @@ describe("query runner > drop table", () => { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/query-runner/drop-unique-constraint.ts b/test/functional/query-runner/drop-unique-constraint.ts index fd00a7952..47188e5de 100644 --- a/test/functional/query-runner/drop-unique-constraint.ts +++ b/test/functional/query-runner/drop-unique-constraint.ts @@ -1,13 +1,16 @@ -import "reflect-metadata"; -import {Connection} from "../../../src/connection/Connection"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../utils/test-utils"; +import {join as joinPaths} from "../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../deps/mocha.ts"; +import "../../deps/chai.ts"; +import {Connection} from "../../../src/connection/Connection.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../utils/test-utils.ts"; describe("query runner > drop unique constraint", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => { connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], enabledDrivers: ["mssql", "postgres", "sqlite", "oracle", "cockroachdb"], // mysql and sap does not supports unique constraints schemaCreate: true, dropSchema: true, @@ -39,3 +42,5 @@ describe("query runner > drop unique constraint", () => { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/query-runner/entity/Book.ts b/test/functional/query-runner/entity/Book.ts index 8ddd0c595..683024dc9 100644 --- a/test/functional/query-runner/entity/Book.ts +++ b/test/functional/query-runner/entity/Book.ts @@ -1,10 +1,10 @@ -import { PrimaryColumn } from "../../../../src/decorator/columns/PrimaryColumn"; -import { Entity } from "../../../../src/decorator/entity/Entity"; +import { PrimaryColumn } from "../../../../src/decorator/columns/PrimaryColumn.ts"; +import { Entity } from "../../../../src/decorator/entity/Entity.ts"; @Entity() export class Book { - @PrimaryColumn() + @PrimaryColumn({ type: String }) ean: string; } @@ -12,7 +12,7 @@ export class Book { @Entity({ withoutRowid: true }) export class Book2 { - @PrimaryColumn() + @PrimaryColumn({ type: String }) ean: string; } diff --git a/test/functional/query-runner/entity/Faculty.ts b/test/functional/query-runner/entity/Faculty.ts index b2b4715b8..ca461b987 100644 --- a/test/functional/query-runner/entity/Faculty.ts +++ b/test/functional/query-runner/entity/Faculty.ts @@ -1,6 +1,6 @@ -import {Entity} from "../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../src/decorator/columns/Column"; -import {PrimaryGeneratedColumn} from "../../../../src/decorator/columns/PrimaryGeneratedColumn"; +import {Entity} from "../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../src/decorator/columns/Column.ts"; +import {PrimaryGeneratedColumn} from "../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; @Entity() export class Faculty { @@ -8,7 +8,7 @@ export class Faculty { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) name: string; -} \ No newline at end of file +} diff --git a/test/functional/query-runner/entity/Photo.ts b/test/functional/query-runner/entity/Photo.ts index ea4053868..fcc57a94b 100644 --- a/test/functional/query-runner/entity/Photo.ts +++ b/test/functional/query-runner/entity/Photo.ts @@ -1,28 +1,28 @@ -import {Entity} from "../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../src/decorator/columns/Column"; -import {Unique} from "../../../../src/decorator/Unique"; -import {PrimaryColumn} from "../../../../src/decorator/columns/PrimaryColumn"; -import {Index} from "../../../../src/decorator/Index"; +import {Entity} from "../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../src/decorator/columns/Column.ts"; +import {Unique} from "../../../../src/decorator/Unique.ts"; +import {PrimaryColumn} from "../../../../src/decorator/columns/PrimaryColumn.ts"; +import {Index} from "../../../../src/decorator/Index.ts"; @Entity() @Unique(["name"]) @Index(["text"], { unique: true }) export class Photo { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; - @Column() + @Column({ type: String }) name: string; - @Column() + @Column({ type: String }) @Index({ unique: true }) tag: string; - @Column({ unique: true }) + @Column({ unique: true, type: String }) description: string; - @Column() + @Column({ type: String }) text: string; -} \ No newline at end of file +} diff --git a/test/functional/query-runner/entity/Post.ts b/test/functional/query-runner/entity/Post.ts index ba7bf1327..b43376133 100644 --- a/test/functional/query-runner/entity/Post.ts +++ b/test/functional/query-runner/entity/Post.ts @@ -1,9 +1,9 @@ -import {Entity} from "../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../src/decorator/columns/Column"; -import {Unique} from "../../../../src/decorator/Unique"; -import {PrimaryColumn} from "../../../../src/decorator/columns/PrimaryColumn"; -import {Check} from "../../../../src/decorator/Check"; -import {Exclusion} from "../../../../src/decorator/Exclusion"; +import {Entity} from "../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../src/decorator/columns/Column.ts"; +import {Unique} from "../../../../src/decorator/Unique.ts"; +import {PrimaryColumn} from "../../../../src/decorator/columns/PrimaryColumn.ts"; +import {Check} from "../../../../src/decorator/Check.ts"; +import {Exclusion} from "../../../../src/decorator/Exclusion.ts"; @Entity() @Unique(["text", "tag"]) @@ -11,19 +11,19 @@ import {Exclusion} from "../../../../src/decorator/Exclusion"; @Check(`"version" < 999`) export class Post { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; - @Column({ unique: true }) + @Column({ unique: true, type: Number }) version: number; - @Column({ default: "My post" }) + @Column({ default: "My post", type: String }) name: string; - @Column() + @Column({ type: String }) text: string; - @Column() + @Column({ type: String }) tag: string; } diff --git a/test/functional/query-runner/entity/Student.ts b/test/functional/query-runner/entity/Student.ts index 4ad96493d..ee3cdd921 100644 --- a/test/functional/query-runner/entity/Student.ts +++ b/test/functional/query-runner/entity/Student.ts @@ -1,10 +1,10 @@ -import {Entity} from "../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../src/decorator/columns/Column"; -import {PrimaryGeneratedColumn} from "../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Faculty} from "./Faculty"; -import {ManyToOne} from "../../../../src/decorator/relations/ManyToOne"; -import {Teacher} from "./Teacher"; -import {Index} from "../../../../src/decorator/Index"; +import {Entity} from "../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../src/decorator/columns/Column.ts"; +import {PrimaryGeneratedColumn} from "../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Faculty} from "./Faculty.ts"; +import {ManyToOne} from "../../../../src/decorator/relations/ManyToOne.ts"; +import {Teacher} from "./Teacher.ts"; +import {Index} from "../../../../src/decorator/Index.ts"; @Entity() @Index("student_name_index", ["name"]) @@ -13,7 +13,7 @@ export class Student { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) name: string; @ManyToOne(type => Faculty) @@ -22,4 +22,4 @@ export class Student { @ManyToOne(type => Teacher) teacher: Teacher; -} \ No newline at end of file +} diff --git a/test/functional/query-runner/entity/Teacher.ts b/test/functional/query-runner/entity/Teacher.ts index f4860963a..408afc23e 100644 --- a/test/functional/query-runner/entity/Teacher.ts +++ b/test/functional/query-runner/entity/Teacher.ts @@ -1,8 +1,8 @@ -import {Entity} from "../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../src/decorator/columns/Column"; -import {PrimaryGeneratedColumn} from "../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Student} from "./Student"; -import {OneToMany} from "../../../../src/decorator/relations/OneToMany"; +import {Entity} from "../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../src/decorator/columns/Column.ts"; +import {PrimaryGeneratedColumn} from "../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Student} from "./Student.ts"; +import {OneToMany} from "../../../../src/decorator/relations/OneToMany.ts"; @Entity() export class Teacher { @@ -10,10 +10,10 @@ export class Teacher { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) name: string; @OneToMany(type => Student, student => student.teacher) students: Student[]; -} \ No newline at end of file +} diff --git a/test/functional/query-runner/rename-column.ts b/test/functional/query-runner/rename-column.ts index b033a46fb..e2de49d06 100644 --- a/test/functional/query-runner/rename-column.ts +++ b/test/functional/query-runner/rename-column.ts @@ -1,21 +1,25 @@ -import "reflect-metadata"; -import {expect} from "chai"; -import {Connection} from "../../../src"; -import {CockroachDriver} from "../../../src/driver/cockroachdb/CockroachDriver"; -import {SapDriver} from "../../../src/driver/sap/SapDriver"; -import {closeTestingConnections, createTestingConnections} from "../../utils/test-utils"; -import {Table} from "../../../src"; -import {SqlServerDriver} from "../../../src/driver/sqlserver/SqlServerDriver"; -import {PostgresDriver} from "../../../src/driver/postgres/PostgresDriver"; -import {AbstractSqliteDriver} from "../../../src/driver/sqlite-abstract/AbstractSqliteDriver"; -import {MysqlDriver} from "../../../src/driver/mysql/MysqlDriver"; +import {join as joinPaths} from "../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../deps/mocha.ts"; +import {expect} from "../../deps/chai.ts"; +import {Connection} from "../../../src/index.ts"; +// TODO(uki00a) uncomment this when CockroachDriver is implemented. +// import {CockroachDriver} from "../../../src/driver/cockroachdb/CockroachDriver.ts"; +import {SapDriver} from "../../../src/driver/sap/SapDriver.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections} from "../../utils/test-utils.ts"; +import {Table} from "../../../src/index.ts"; +import {SqlServerDriver} from "../../../src/driver/sqlserver/SqlServerDriver.ts"; +// TODO(uki00a) uncomment this when PostgresDriver is implemented. +// import {PostgresDriver} from "../../../src/driver/postgres/PostgresDriver.ts"; +import {AbstractSqliteDriver} from "../../../src/driver/sqlite-abstract/AbstractSqliteDriver.ts"; +import {MysqlDriver} from "../../../src/driver/mysql/MysqlDriver.ts"; describe("query runner > rename column", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => { connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], schemaCreate: true, dropSchema: true, }); @@ -25,7 +29,7 @@ describe("query runner > rename column", () => { it("should correctly rename column and revert rename", () => Promise.all(connections.map(async connection => { // TODO: https://github.com/cockroachdb/cockroach/issues/32555 - if (connection.driver instanceof CockroachDriver) + if (false/* connection.driver instanceof CockroachDriver*/) // TOOD(uki00a) uncomment this when CockroachDriver is implemented. return; const queryRunner = connection.createQueryRunner(); @@ -59,7 +63,7 @@ describe("query runner > rename column", () => { it("should correctly rename column with all constraints and revert rename", () => Promise.all(connections.map(async connection => { // TODO: https://github.com/cockroachdb/cockroach/issues/32555 - if (connection.driver instanceof CockroachDriver) + if (false/* connection.driver instanceof CockroachDriver */) // TODO(uki00a) uncomment this when CockroachDriver is implemented. return; const queryRunner = connection.createQueryRunner(); @@ -70,7 +74,7 @@ describe("query runner > rename column", () => { // should successfully drop pk if pk constraint was correctly renamed. // CockroachDB does not allow to drop PK - if (!(connection.driver instanceof CockroachDriver)) + if (true/* !(connection.driver instanceof CockroachDriver) */) // TODO(uki00a) uncomment this when CockroachDriver is implemented. await queryRunner.dropPrimaryKey(table!); table = await queryRunner.getTable("post"); @@ -107,7 +111,7 @@ describe("query runner > rename column", () => { it("should correctly rename column with all constraints in custom table schema and database and revert rename", () => Promise.all(connections.map(async connection => { // TODO: https://github.com/cockroachdb/cockroach/issues/32555 - if (connection.driver instanceof CockroachDriver) + if (false/* connection.driver instanceof CockroachDriver */) // TODO(uki00a) uncomment this when CockroachDriver is implemented. return; const queryRunner = connection.createQueryRunner(); @@ -123,7 +127,7 @@ describe("query runner > rename column", () => { await queryRunner.createDatabase("testDB", true); await queryRunner.createSchema("testDB.testSchema", true); - } else if (connection.driver instanceof PostgresDriver) { + } else if (false/* connection.driver instanceof PostgresDriver */) { // TODO(uki00a) uncomment this when PostgresDriver is implemented. questionTableName = "testSchema.question"; categoryTableName = "testSchema.category"; await queryRunner.createSchema("testSchema", true); @@ -204,3 +208,5 @@ describe("query runner > rename column", () => { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/query-runner/rename-table.ts b/test/functional/query-runner/rename-table.ts index 15fbd5264..3c3fa7558 100644 --- a/test/functional/query-runner/rename-table.ts +++ b/test/functional/query-runner/rename-table.ts @@ -1,20 +1,25 @@ -import "reflect-metadata"; -import {Connection} from "../../../src/connection/Connection"; -import {CockroachDriver} from "../../../src/driver/cockroachdb/CockroachDriver"; -import {SapDriver} from "../../../src/driver/sap/SapDriver"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../utils/test-utils"; -import {SqlServerDriver} from "../../../src/driver/sqlserver/SqlServerDriver"; -import {Table} from "../../../src/schema-builder/table/Table"; -import {AbstractSqliteDriver} from "../../../src/driver/sqlite-abstract/AbstractSqliteDriver"; -import {PostgresDriver} from "../../../src/driver/postgres/PostgresDriver"; -import {MysqlDriver} from "../../../src/driver/mysql/MysqlDriver"; +import {join as joinPaths} from "../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../deps/mocha.ts"; +import "../../deps/chai.ts"; +import {Connection} from "../../../src/connection/Connection.ts"; +// TODO(uki00a) uncomment this when CockroachDriver is implemented. +// import {CockroachDriver} from "../../../src/driver/cockroachdb/CockroachDriver.ts"; +import {SapDriver} from "../../../src/driver/sap/SapDriver.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../utils/test-utils.ts"; +import {SqlServerDriver} from "../../../src/driver/sqlserver/SqlServerDriver.ts"; +import {Table} from "../../../src/schema-builder/table/Table.ts"; +import {AbstractSqliteDriver} from "../../../src/driver/sqlite-abstract/AbstractSqliteDriver.ts"; +// TODO(uki00a) uncomment this when PostgresDriver is implemented. +// import {PostgresDriver} from "../../../src/driver/postgres/PostgresDriver.ts"; +import {MysqlDriver} from "../../../src/driver/mysql/MysqlDriver.ts"; describe("query runner > rename table", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => { connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], schemaCreate: true, dropSchema: true, }); @@ -25,7 +30,7 @@ describe("query runner > rename table", () => { it("should correctly rename table and revert rename", () => Promise.all(connections.map(async connection => { // CockroachDB does not support renaming constraints and removing PK. - if (connection.driver instanceof CockroachDriver) + if (false/* connection.driver instanceof CockroachDriver */) // TODO(uki00a) uncomment this when CockroachDriver is implemented. return; const queryRunner = connection.createQueryRunner(); @@ -51,7 +56,7 @@ describe("query runner > rename table", () => { it("should correctly rename table with all constraints depend to that table and revert rename", () => Promise.all(connections.map(async connection => { // CockroachDB does not support renaming constraints and removing PK. - if (connection.driver instanceof CockroachDriver) + if (false/* connection.driver instanceof CockroachDriver */) // TODO(uki00a) uncomment this when CockroachDriver is implemented. return; const queryRunner = connection.createQueryRunner(); @@ -85,7 +90,7 @@ describe("query runner > rename table", () => { it("should correctly rename table with custom schema and database and all its dependencies and revert rename", () => Promise.all(connections.map(async connection => { // CockroachDB does not support renaming constraints and removing PK. - if (connection.driver instanceof CockroachDriver) + if (false/* connection.driver instanceof CockroachDriver */) // TODO(uki00a) uncomment this when CockroachDriver is implemented. return; const queryRunner = connection.createQueryRunner(); @@ -105,7 +110,7 @@ describe("query runner > rename table", () => { await queryRunner.createDatabase("testDB", true); await queryRunner.createSchema("testDB.testSchema", true); - } else if (connection.driver instanceof PostgresDriver || connection.driver instanceof SapDriver) { + } else if (false/* connection.driver instanceof PostgresDriver*/ || connection.driver instanceof SapDriver) { // TODO(uki00a) uncomment this when PostgresDriver is implemented. questionTableName = "testSchema.question"; renamedQuestionTableName = "testSchema.renamedQuestion"; categoryTableName = "testSchema.category"; @@ -188,3 +193,5 @@ describe("query runner > rename table", () => { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/relations/custom-referenced-column-name/custom-referenced-column-name.ts b/test/functional/relations/custom-referenced-column-name/custom-referenced-column-name.ts index 3f3836e85..3f2864ab2 100644 --- a/test/functional/relations/custom-referenced-column-name/custom-referenced-column-name.ts +++ b/test/functional/relations/custom-referenced-column-name/custom-referenced-column-name.ts @@ -1,16 +1,18 @@ -import "reflect-metadata"; -import {expect} from "chai"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils"; -import {Connection} from "../../../../src/connection/Connection"; -import {Post} from "./entity/Post"; -import {Category} from "./entity/Category"; -import {Tag} from "./entity/Tag"; +import {join as joinPaths} from "../../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../../deps/mocha.ts"; +import {expect} from "../../../deps/chai.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils.ts"; +import {Connection} from "../../../../src/connection/Connection.ts"; +import {Post} from "./entity/Post.ts"; +import {Category} from "./entity/Category.ts"; +import {Tag} from "./entity/Tag.ts"; describe("relations > custom-referenced-column-name", () => { - + let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], })); beforeEach(() => reloadTestingDatabases(connections)); after(() => closeTestingConnections(connections)); @@ -488,3 +490,5 @@ describe("relations > custom-referenced-column-name", () => { }); }); + +runIfMain(import.meta); diff --git a/test/functional/relations/custom-referenced-column-name/entity/Category.ts b/test/functional/relations/custom-referenced-column-name/entity/Category.ts index c599b96e3..fa76b0917 100644 --- a/test/functional/relations/custom-referenced-column-name/entity/Category.ts +++ b/test/functional/relations/custom-referenced-column-name/entity/Category.ts @@ -1,6 +1,6 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../src/decorator/columns/Column"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; @Entity() export class Category { @@ -8,7 +8,7 @@ export class Category { @PrimaryGeneratedColumn() id: number; - @Column({ unique: true }) + @Column({ unique: true, type: String }) name: string; -} \ No newline at end of file +} diff --git a/test/functional/relations/custom-referenced-column-name/entity/Post.ts b/test/functional/relations/custom-referenced-column-name/entity/Post.ts index 8df31aa17..d2b421619 100644 --- a/test/functional/relations/custom-referenced-column-name/entity/Post.ts +++ b/test/functional/relations/custom-referenced-column-name/entity/Post.ts @@ -1,11 +1,11 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {ManyToOne} from "../../../../../src/decorator/relations/ManyToOne"; -import {JoinColumn} from "../../../../../src/decorator/relations/JoinColumn"; -import {Category} from "./Category"; -import {OneToOne} from "../../../../../src/decorator/relations/OneToOne"; -import {Tag} from "./Tag"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {ManyToOne} from "../../../../../src/decorator/relations/ManyToOne.ts"; +import {JoinColumn} from "../../../../../src/decorator/relations/JoinColumn.ts"; +import {Category} from "./Category.ts"; +import {OneToOne} from "../../../../../src/decorator/relations/OneToOne.ts"; +import {Tag} from "./Tag.ts"; @Entity() export class Post { @@ -13,16 +13,16 @@ export class Post { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) title: string; - @Column({ nullable: true }) + @Column({ nullable: true, type: String }) categoryName: string; @Column({ type: "int", nullable: true }) categoryId: number; - @Column({ nullable: true }) + @Column({ nullable: true, type: String }) tagName: string; @Column({ type: "int", nullable: true }) @@ -68,4 +68,4 @@ export class Post { @JoinColumn({ name: "tagName", referencedColumnName: "name" }) tag: Tag; -} \ No newline at end of file +} diff --git a/test/functional/relations/custom-referenced-column-name/entity/Tag.ts b/test/functional/relations/custom-referenced-column-name/entity/Tag.ts index 91b3821b4..7584a44b5 100644 --- a/test/functional/relations/custom-referenced-column-name/entity/Tag.ts +++ b/test/functional/relations/custom-referenced-column-name/entity/Tag.ts @@ -1,6 +1,6 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../src/decorator/columns/Column"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; @Entity() export class Tag { @@ -8,7 +8,7 @@ export class Tag { @PrimaryGeneratedColumn() id: number; - @Column({ unique: true }) + @Column({ unique: true, type: String }) name: string; -} \ No newline at end of file +} diff --git a/test/functional/relations/eager-relations/basic-eager-relations/basic-eager-relations.ts b/test/functional/relations/eager-relations/basic-eager-relations/basic-eager-relations.ts index bf4b59847..66de62fa0 100644 --- a/test/functional/relations/eager-relations/basic-eager-relations/basic-eager-relations.ts +++ b/test/functional/relations/eager-relations/basic-eager-relations/basic-eager-relations.ts @@ -1,17 +1,20 @@ -import "reflect-metadata"; -import {Connection} from "../../../../../src/connection/Connection"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils"; -import {User} from "./entity/User"; -import {Profile} from "./entity/Profile"; -import {Editor} from "./entity/Editor"; -import {Post} from "./entity/Post"; -import {Category} from "./entity/Category"; +import {join as joinPaths} from "../../../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../../../deps/mocha.ts"; +import "../../../../deps/chai.ts"; +import {Connection} from "../../../../../src/connection/Connection.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils.ts"; +import {User} from "./entity/User.ts"; +import {Profile} from "./entity/Profile.ts"; +import {Editor} from "./entity/Editor.ts"; +import {Post} from "./entity/Post.ts"; +import {Category} from "./entity/Category.ts"; describe("relations > eager relations > basic", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], })); beforeEach(() => reloadTestingDatabases(connections)); after(() => closeTestingConnections(connections)); @@ -116,3 +119,5 @@ describe("relations > eager relations > basic", () => { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/relations/eager-relations/basic-eager-relations/entity/Category.ts b/test/functional/relations/eager-relations/basic-eager-relations/entity/Category.ts index 6769601e2..0ecb9ae51 100644 --- a/test/functional/relations/eager-relations/basic-eager-relations/entity/Category.ts +++ b/test/functional/relations/eager-relations/basic-eager-relations/entity/Category.ts @@ -1,9 +1,9 @@ -import {Entity} from "../../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../../src/decorator/columns/Column"; -import {ManyToMany} from "../../../../../../src/decorator/relations/ManyToMany"; -import {JoinTable} from "../../../../../../src/decorator/relations/JoinTable"; -import {Post} from "./Post"; +import {Entity} from "../../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../../src/decorator/columns/Column.ts"; +import {ManyToMany} from "../../../../../../src/decorator/relations/ManyToMany.ts"; +import {JoinTable} from "../../../../../../src/decorator/relations/JoinTable.ts"; +import {Post} from "./Post.ts"; @Entity() export class Category { @@ -11,11 +11,11 @@ export class Category { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) name: string; @ManyToMany(type => Post, post => post.categories2) @JoinTable() posts2: Post[]; -} \ No newline at end of file +} diff --git a/test/functional/relations/eager-relations/basic-eager-relations/entity/Editor.ts b/test/functional/relations/eager-relations/basic-eager-relations/entity/Editor.ts index 74990c8a4..828353157 100644 --- a/test/functional/relations/eager-relations/basic-eager-relations/entity/Editor.ts +++ b/test/functional/relations/eager-relations/basic-eager-relations/entity/Editor.ts @@ -1,9 +1,9 @@ -import {Entity} from "../../../../../../src/decorator/entity/Entity"; -import {OneToOne} from "../../../../../../src/decorator/relations/OneToOne"; -import {JoinColumn} from "../../../../../../src/decorator/relations/JoinColumn"; -import {User} from "./User"; -import {ManyToOne} from "../../../../../../src/decorator/relations/ManyToOne"; -import {Post} from "./Post"; +import {Entity} from "../../../../../../src/decorator/entity/Entity.ts"; +import {OneToOne} from "../../../../../../src/decorator/relations/OneToOne.ts"; +import {JoinColumn} from "../../../../../../src/decorator/relations/JoinColumn.ts"; +import {User} from "./User.ts"; +import {ManyToOne} from "../../../../../../src/decorator/relations/ManyToOne.ts"; +import {Post} from "./Post.ts"; @Entity() export class Editor { @@ -15,4 +15,4 @@ export class Editor { @ManyToOne(type => Post, { primary: true }) post: Post; -} \ No newline at end of file +} diff --git a/test/functional/relations/eager-relations/basic-eager-relations/entity/Post.ts b/test/functional/relations/eager-relations/basic-eager-relations/entity/Post.ts index 1c753e978..0078997fb 100644 --- a/test/functional/relations/eager-relations/basic-eager-relations/entity/Post.ts +++ b/test/functional/relations/eager-relations/basic-eager-relations/entity/Post.ts @@ -1,13 +1,13 @@ -import {Entity} from "../../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../../src/decorator/columns/Column"; -import {ManyToMany} from "../../../../../../src/decorator/relations/ManyToMany"; -import {JoinTable} from "../../../../../../src/decorator/relations/JoinTable"; -import {Category} from "./Category"; -import {User} from "./User"; -import {ManyToOne} from "../../../../../../src/decorator/relations/ManyToOne"; -import {OneToMany} from "../../../../../../src/decorator/relations/OneToMany"; -import {Editor} from "./Editor"; +import {Entity} from "../../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../../src/decorator/columns/Column.ts"; +import {ManyToMany} from "../../../../../../src/decorator/relations/ManyToMany.ts"; +import {JoinTable} from "../../../../../../src/decorator/relations/JoinTable.ts"; +import {Category} from "./Category.ts"; +import {User} from "./User.ts"; +import {ManyToOne} from "../../../../../../src/decorator/relations/ManyToOne.ts"; +import {OneToMany} from "../../../../../../src/decorator/relations/OneToMany.ts"; +import {Editor} from "./Editor.ts"; @Entity() export class Post { @@ -15,7 +15,7 @@ export class Post { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) title: string; @ManyToMany(type => Category, { eager: true }) @@ -31,4 +31,4 @@ export class Post { @OneToMany(type => Editor, editor => editor.post, { eager: true }) editors: Editor[]; -} \ No newline at end of file +} diff --git a/test/functional/relations/eager-relations/basic-eager-relations/entity/Profile.ts b/test/functional/relations/eager-relations/basic-eager-relations/entity/Profile.ts index d2b2971e7..0535fd54b 100644 --- a/test/functional/relations/eager-relations/basic-eager-relations/entity/Profile.ts +++ b/test/functional/relations/eager-relations/basic-eager-relations/entity/Profile.ts @@ -1,6 +1,6 @@ -import {Entity} from "../../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../../src/decorator/columns/Column"; +import {Entity} from "../../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../../src/decorator/columns/Column.ts"; @Entity() export class Profile { @@ -8,7 +8,7 @@ export class Profile { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) about: string; -} \ No newline at end of file +} diff --git a/test/functional/relations/eager-relations/basic-eager-relations/entity/User.ts b/test/functional/relations/eager-relations/basic-eager-relations/entity/User.ts index 065efaa73..c8ae5bfce 100644 --- a/test/functional/relations/eager-relations/basic-eager-relations/entity/User.ts +++ b/test/functional/relations/eager-relations/basic-eager-relations/entity/User.ts @@ -1,9 +1,9 @@ -import {Entity} from "../../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../../src/decorator/columns/Column"; -import {OneToOne} from "../../../../../../src/decorator/relations/OneToOne"; -import {JoinColumn} from "../../../../../../src/decorator/relations/JoinColumn"; -import {Profile} from "./Profile"; +import {Entity} from "../../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../../src/decorator/columns/Column.ts"; +import {OneToOne} from "../../../../../../src/decorator/relations/OneToOne.ts"; +import {JoinColumn} from "../../../../../../src/decorator/relations/JoinColumn.ts"; +import {Profile} from "./Profile.ts"; @Entity() export class User { @@ -11,14 +11,14 @@ export class User { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) firstName: string; - @Column() + @Column({ type: String }) lastName: string; @OneToOne(type => Profile, { eager: true }) @JoinColumn() profile: Profile; -} \ No newline at end of file +} diff --git a/test/functional/relations/eager-relations/circular-eager-relations/circular-eager-relations.ts b/test/functional/relations/eager-relations/circular-eager-relations/circular-eager-relations.ts index fd77638ea..e8986749f 100644 --- a/test/functional/relations/eager-relations/circular-eager-relations/circular-eager-relations.ts +++ b/test/functional/relations/eager-relations/circular-eager-relations/circular-eager-relations.ts @@ -1,24 +1,34 @@ -import "reflect-metadata"; -import {Connection} from "../../../../../src/connection/Connection"; -import {EntityMetadataValidator} from "../../../../../src/metadata-builder/EntityMetadataValidator"; -import {ConnectionMetadataBuilder} from "../../../../../src/connection/ConnectionMetadataBuilder"; -import {expect} from "chai"; +import {join as joinPaths} from "../../../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../../../deps/mocha.ts"; +import {expect} from "../../../../deps/chai.ts"; +import {getDirnameOfCurrentModule} from "../../../../utils/test-utils.ts"; +import {Connection} from "../../../../../src/connection/Connection.ts"; +import {EntityMetadataValidator} from "../../../../../src/metadata-builder/EntityMetadataValidator.ts"; +import {ConnectionMetadataBuilder} from "../../../../../src/connection/ConnectionMetadataBuilder.ts"; describe("relations > eager relations > circular eager relations", () => { - it("should throw error if eager: true is set on both sides of relationship", () => { + const __dirname = getDirnameOfCurrentModule(import.meta); + it("should throw error if eager: true is set on both sides of relationship", async () => { const connection = new Connection({ // dummy connection options, connection won't be established anyway + // TODO(uki00a) Replace sqlite with mysql when MysqlDriver is implemeneted. + /* type: "mysql", host: "localhost", username: "test", password: "test", database: "test", - entities: [__dirname + "/entity/*{.js,.ts}"] + */ + type: "sqlite", + database: ":memory:", + entities: [joinPaths(__dirname, "/entity/*.ts")] }); const connectionMetadataBuilder = new ConnectionMetadataBuilder(connection); - const entityMetadatas = connectionMetadataBuilder.buildEntityMetadatas([__dirname + "/entity/*{.js,.ts}"]); + const entityMetadatas = await connectionMetadataBuilder.buildEntityMetadatas([joinPaths(__dirname, "/entity/*.ts")]); const entityMetadataValidator = new EntityMetadataValidator(); expect(() => entityMetadataValidator.validateMany(entityMetadatas, connection.driver)).to.throw(Error); }); }); + +runIfMain(import.meta); diff --git a/test/functional/relations/eager-relations/circular-eager-relations/entity/Post.ts b/test/functional/relations/eager-relations/circular-eager-relations/entity/Post.ts index 48e897757..304ce4458 100644 --- a/test/functional/relations/eager-relations/circular-eager-relations/entity/Post.ts +++ b/test/functional/relations/eager-relations/circular-eager-relations/entity/Post.ts @@ -1,8 +1,8 @@ -import {Entity} from "../../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../../src/decorator/columns/Column"; -import {User} from "./User"; -import {ManyToOne} from "../../../../../../src/decorator/relations/ManyToOne"; +import {Entity} from "../../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../../src/decorator/columns/Column.ts"; +import {User} from "./User.ts"; +import {ManyToOne} from "../../../../../../src/decorator/relations/ManyToOne.ts"; @Entity() export class Post { @@ -10,10 +10,10 @@ export class Post { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) title: string; @ManyToOne(type => User, { eager: true }) author: User; -} \ No newline at end of file +} diff --git a/test/functional/relations/eager-relations/circular-eager-relations/entity/Profile.ts b/test/functional/relations/eager-relations/circular-eager-relations/entity/Profile.ts index 3d2031c3f..15227cad4 100644 --- a/test/functional/relations/eager-relations/circular-eager-relations/entity/Profile.ts +++ b/test/functional/relations/eager-relations/circular-eager-relations/entity/Profile.ts @@ -1,8 +1,8 @@ -import {Entity} from "../../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../../src/decorator/columns/Column"; -import {OneToOne} from "../../../../../../src/decorator/relations/OneToOne"; -import {User} from "./User"; +import {Entity} from "../../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../../src/decorator/columns/Column.ts"; +import {OneToOne} from "../../../../../../src/decorator/relations/OneToOne.ts"; +import {User} from "./User.ts"; @Entity() export class Profile { @@ -10,10 +10,10 @@ export class Profile { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) about: string; @OneToOne(type => User, user => user.profile, { eager: true }) user: User; -} \ No newline at end of file +} diff --git a/test/functional/relations/eager-relations/circular-eager-relations/entity/User.ts b/test/functional/relations/eager-relations/circular-eager-relations/entity/User.ts index 0479a9f53..fffabece0 100644 --- a/test/functional/relations/eager-relations/circular-eager-relations/entity/User.ts +++ b/test/functional/relations/eager-relations/circular-eager-relations/entity/User.ts @@ -1,9 +1,9 @@ -import {Entity} from "../../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../../src/decorator/columns/Column"; -import {OneToOne} from "../../../../../../src/decorator/relations/OneToOne"; -import {JoinColumn} from "../../../../../../src/decorator/relations/JoinColumn"; -import {Profile} from "./Profile"; +import {Entity} from "../../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../../src/decorator/columns/Column.ts"; +import {OneToOne} from "../../../../../../src/decorator/relations/OneToOne.ts"; +import {JoinColumn} from "../../../../../../src/decorator/relations/JoinColumn.ts"; +import {Profile} from "./Profile.ts"; @Entity() export class User { @@ -11,14 +11,14 @@ export class User { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) firstName: string; - @Column() + @Column({ type: String }) lastName: string; @OneToOne(type => Profile, profile => profile.user, { eager: true }) @JoinColumn() profile: Profile; -} \ No newline at end of file +} diff --git a/test/functional/relations/lazy-relations/basic-lazy-relation/basic-lazy-relations.ts b/test/functional/relations/lazy-relations/basic-lazy-relation/basic-lazy-relations.ts index 3c0d8fe7d..12744949b 100644 --- a/test/functional/relations/lazy-relations/basic-lazy-relation/basic-lazy-relations.ts +++ b/test/functional/relations/lazy-relations/basic-lazy-relation/basic-lazy-relations.ts @@ -1,13 +1,16 @@ -import "reflect-metadata"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils"; -import {Connection} from "../../../../../src/connection/Connection"; +import {runIfMain} from "../../../../deps/mocha.ts"; +import {expect} from "../../../../deps/chai.ts"; +import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils.ts"; +import {Connection} from "../../../../../src/connection/Connection.ts"; import { Post, -} from "./entity/Post"; +} from "./entity/Post.ts"; import { Category, -} from "./entity/Category"; -import {EntitySchema} from "../../../../../src"; +} from "./entity/Category.ts"; +import {EntitySchema} from "../../../../../src/index.ts"; +import UserSchemaJSON from "./schema/user.json"; +import ProfileSchemaJSON from "./schema/profile.json"; /** * Because lazy relations are overriding prototype is impossible to run these tests on multiple connections. @@ -16,10 +19,8 @@ import {EntitySchema} from "../../../../../src"; describe("basic-lazy-relations", () => { let UserSchema: any, ProfileSchema: any; - const appRoot = require("app-root-path"); - const resourceDir = appRoot + "/test/functional/relations/lazy-relations/basic-lazy-relation/"; - UserSchema = new EntitySchema(require(resourceDir + "schema/user.json")); - ProfileSchema = new EntitySchema(require(resourceDir + "schema/profile.json")); + UserSchema = new EntitySchema(UserSchemaJSON as any); + ProfileSchema = new EntitySchema(ProfileSchemaJSON as any); let connections: Connection[]; before(async () => connections = await createTestingConnections({ @@ -58,7 +59,7 @@ describe("basic-lazy-relations", () => { await postRepository.save(savedPost); - await savedPost.categories.should.eventually.be.eql([savedCategory1, savedCategory2, savedCategory3]); + expect(await savedPost.categories).to.eql([savedCategory1, savedCategory2, savedCategory3]); const post = (await postRepository.findOne(1))!; post.title.should.be.equal("Hello post"); @@ -96,7 +97,7 @@ describe("basic-lazy-relations", () => { await postRepository.save(savedPost); - await savedPost.twoSideCategories.should.eventually.be.eql([savedCategory1, savedCategory2, savedCategory3]); + expect(await savedPost.twoSideCategories).to.eql([savedCategory1, savedCategory2, savedCategory3]); const post = (await postRepository.findOne(1))!; post.title.should.be.equal("Hello post"); @@ -331,7 +332,7 @@ describe("basic-lazy-relations", () => { const category = new Category(); category.name = "category of great post"; await manager.save(category); - + const post = new Post(); post.title = "post with great category"; post.text = "post with great category and great text"; @@ -349,7 +350,7 @@ describe("basic-lazy-relations", () => { const category = new Category(); category.name = "category of great post"; await manager.save(category); - + const post = new Post(); post.title = "post with great category"; post.text = "post with great category and great text"; @@ -362,3 +363,5 @@ describe("basic-lazy-relations", () => { loadedPost.title.should.be.equal("post with great category"); }))); }); + +runIfMain(import.meta); diff --git a/test/functional/relations/lazy-relations/basic-lazy-relation/entity/Category.ts b/test/functional/relations/lazy-relations/basic-lazy-relation/entity/Category.ts index 0bbf73626..b878dcdbf 100644 --- a/test/functional/relations/lazy-relations/basic-lazy-relation/entity/Category.ts +++ b/test/functional/relations/lazy-relations/basic-lazy-relation/entity/Category.ts @@ -1,12 +1,12 @@ -import { Entity } from "../../../../../../src/decorator/entity/Entity"; -import { PrimaryGeneratedColumn } from "../../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import { Column } from "../../../../../../src/decorator/columns/Column"; -import { ManyToMany } from "../../../../../../src/decorator/relations/ManyToMany"; -import { OneToMany } from "../../../../../../src/decorator/relations/OneToMany"; -import { OneToOne } from "../../../../../../src/decorator/relations/OneToOne"; +import { Entity } from "../../../../../../src/decorator/entity/Entity.ts"; +import { PrimaryGeneratedColumn } from "../../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import { Column } from "../../../../../../src/decorator/columns/Column.ts"; +import { ManyToMany } from "../../../../../../src/decorator/relations/ManyToMany.ts"; +import { OneToMany } from "../../../../../../src/decorator/relations/OneToMany.ts"; +import { OneToOne } from "../../../../../../src/decorator/relations/OneToOne.ts"; import { Post, -} from "./Post"; +} from "./Post.ts"; @Entity() export class Category { @@ -14,7 +14,7 @@ export class Category { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) name: string; @OneToOne(type => Post, post => post.oneCategory) diff --git a/test/functional/relations/lazy-relations/basic-lazy-relation/entity/Post.ts b/test/functional/relations/lazy-relations/basic-lazy-relation/entity/Post.ts index adef88df3..0ef619ac5 100644 --- a/test/functional/relations/lazy-relations/basic-lazy-relation/entity/Post.ts +++ b/test/functional/relations/lazy-relations/basic-lazy-relation/entity/Post.ts @@ -1,14 +1,14 @@ -import { Entity } from "../../../../../../src/decorator/entity/Entity"; -import { PrimaryGeneratedColumn } from "../../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import { Column } from "../../../../../../src/decorator/columns/Column"; -import { ManyToMany } from "../../../../../../src/decorator/relations/ManyToMany"; -import { JoinTable } from "../../../../../../src/decorator/relations/JoinTable"; -import { ManyToOne } from "../../../../../../src/decorator/relations/ManyToOne"; -import { OneToOne } from "../../../../../../src/decorator/relations/OneToOne"; -import { JoinColumn } from "../../../../../../src/decorator/relations/JoinColumn"; +import { Entity } from "../../../../../../src/decorator/entity/Entity.ts"; +import { PrimaryGeneratedColumn } from "../../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import { Column } from "../../../../../../src/decorator/columns/Column.ts"; +import { ManyToMany } from "../../../../../../src/decorator/relations/ManyToMany.ts"; +import { JoinTable } from "../../../../../../src/decorator/relations/JoinTable.ts"; +import { ManyToOne } from "../../../../../../src/decorator/relations/ManyToOne.ts"; +import { OneToOne } from "../../../../../../src/decorator/relations/OneToOne.ts"; +import { JoinColumn } from "../../../../../../src/decorator/relations/JoinColumn.ts"; import { Category, -} from "./Category"; +} from "./Category.ts"; @Entity() export class Post { @@ -16,10 +16,10 @@ export class Post { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) title: string; - @Column() + @Column({ type: String }) text: string; @ManyToMany(type => Category) @@ -30,7 +30,7 @@ export class Post { @JoinTable() twoSideCategories: Promise; - @Column() + @Column({ type: Number }) viewCount: number = 0; @ManyToOne(type => Category) diff --git a/test/functional/relations/lazy-relations/named-columns/entity/Category.ts b/test/functional/relations/lazy-relations/named-columns/entity/Category.ts index b12f17e38..2b24751bb 100644 --- a/test/functional/relations/lazy-relations/named-columns/entity/Category.ts +++ b/test/functional/relations/lazy-relations/named-columns/entity/Category.ts @@ -1,12 +1,12 @@ -import { Entity } from "../../../../../../src/decorator/entity/Entity"; -import { PrimaryGeneratedColumn } from "../../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import { Column } from "../../../../../../src/decorator/columns/Column"; -import { ManyToMany } from "../../../../../../src/decorator/relations/ManyToMany"; -import { OneToMany } from "../../../../../../src/decorator/relations/OneToMany"; -import { OneToOne } from "../../../../../../src/decorator/relations/OneToOne"; +import { Entity } from "../../../../../../src/decorator/entity/Entity.ts"; +import { PrimaryGeneratedColumn } from "../../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import { Column } from "../../../../../../src/decorator/columns/Column.ts"; +import { ManyToMany } from "../../../../../../src/decorator/relations/ManyToMany.ts"; +import { OneToMany } from "../../../../../../src/decorator/relations/OneToMany.ts"; +import { OneToOne } from "../../../../../../src/decorator/relations/OneToOne.ts"; import { Post, -} from "./Post"; +} from "./Post.ts"; @Entity() export class Category { @@ -16,7 +16,7 @@ export class Category { }) id: number; - @Column() + @Column({ type: String }) name: string; @OneToOne(type => Post, post => post.oneCategory) @@ -39,4 +39,4 @@ export class Category { // OneToOne with named properties @OneToOne(type => Post, post => post.oneCategoryNamedColumn) onePostNamedColumn: Promise; -} \ No newline at end of file +} diff --git a/test/functional/relations/lazy-relations/named-columns/entity/Post.ts b/test/functional/relations/lazy-relations/named-columns/entity/Post.ts index 1ea9273f3..b5111ba4d 100644 --- a/test/functional/relations/lazy-relations/named-columns/entity/Post.ts +++ b/test/functional/relations/lazy-relations/named-columns/entity/Post.ts @@ -1,14 +1,14 @@ -import { Entity } from "../../../../../../src/decorator/entity/Entity"; -import { PrimaryGeneratedColumn } from "../../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import { Column } from "../../../../../../src/decorator/columns/Column"; -import { ManyToMany } from "../../../../../../src/decorator/relations/ManyToMany"; -import { JoinTable } from "../../../../../../src/decorator/relations/JoinTable"; -import { ManyToOne } from "../../../../../../src/decorator/relations/ManyToOne"; -import { OneToOne } from "../../../../../../src/decorator/relations/OneToOne"; -import { JoinColumn } from "../../../../../../src/decorator/relations/JoinColumn"; +import { Entity } from "../../../../../../src/decorator/entity/Entity.ts"; +import { PrimaryGeneratedColumn } from "../../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import { Column } from "../../../../../../src/decorator/columns/Column.ts"; +import { ManyToMany } from "../../../../../../src/decorator/relations/ManyToMany.ts"; +import { JoinTable } from "../../../../../../src/decorator/relations/JoinTable.ts"; +import { ManyToOne } from "../../../../../../src/decorator/relations/ManyToOne.ts"; +import { OneToOne } from "../../../../../../src/decorator/relations/OneToOne.ts"; +import { JoinColumn } from "../../../../../../src/decorator/relations/JoinColumn.ts"; import { Category, -} from "./Category"; +} from "./Category.ts"; @Entity() export class Post { @@ -18,10 +18,10 @@ export class Post { }) id: number; - @Column() + @Column({ type: String }) title: string; - @Column() + @Column({ type: String }) text: string; @ManyToMany(type => Category) @@ -32,7 +32,7 @@ export class Post { @JoinTable() twoSideCategories: Promise; - @Column() + @Column({ type: Number }) viewCount: number = 0; @ManyToOne(type => Category) @@ -63,4 +63,4 @@ export class Post { name: "s_one_category_named_column_id" }) oneCategoryNamedColumn: Promise; -} \ No newline at end of file +} diff --git a/test/functional/relations/lazy-relations/named-columns/named-columns-lazy-relations.ts b/test/functional/relations/lazy-relations/named-columns/named-columns-lazy-relations.ts index bd1246f59..eaeda9b81 100644 --- a/test/functional/relations/lazy-relations/named-columns/named-columns-lazy-relations.ts +++ b/test/functional/relations/lazy-relations/named-columns/named-columns-lazy-relations.ts @@ -1,12 +1,13 @@ -import "reflect-metadata"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils"; -import {Connection} from "../../../../../src/connection/Connection"; +import {runIfMain} from "../../../../deps/mocha.ts"; +import {expect} from "../../../../deps/chai.ts"; +import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils.ts"; +import {Connection} from "../../../../../src/connection/Connection.ts"; import { Post, -} from "./entity/Post"; +} from "./entity/Post.ts"; import { Category, -} from "./entity/Category"; +} from "./entity/Category.ts"; /** * Because lazy relations are overriding prototype is impossible to run these tests on multiple connections. @@ -49,7 +50,7 @@ describe("named-columns-lazy-relations", () => { await postRepository.save(savedPost); - await savedPost.categories.should.eventually.be.eql([savedCategory1, savedCategory2, savedCategory3]); + expect(await savedPost.categories).to.eql([savedCategory1, savedCategory2, savedCategory3]); const post = (await postRepository.findOne(1))!; post.title.should.be.equal("Hello post"); @@ -87,7 +88,7 @@ describe("named-columns-lazy-relations", () => { await postRepository.save(savedPost); - await savedPost.twoSideCategories.should.eventually.be.eql([savedCategory1, savedCategory2, savedCategory3]); + expect(await savedPost.twoSideCategories).to.eql([savedCategory1, savedCategory2, savedCategory3]); const post = (await postRepository.findOne(1))!; post.title.should.be.equal("Hello post"); @@ -293,3 +294,5 @@ describe("named-columns-lazy-relations", () => { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/relations/lazy-relations/named-tables-and-columns/entity/Category.ts b/test/functional/relations/lazy-relations/named-tables-and-columns/entity/Category.ts index 79fecf306..a6eac807e 100644 --- a/test/functional/relations/lazy-relations/named-tables-and-columns/entity/Category.ts +++ b/test/functional/relations/lazy-relations/named-tables-and-columns/entity/Category.ts @@ -1,12 +1,12 @@ -import { Entity } from "../../../../../../src/decorator/entity/Entity"; -import { PrimaryGeneratedColumn } from "../../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import { Column } from "../../../../../../src/decorator/columns/Column"; -import { ManyToMany } from "../../../../../../src/decorator/relations/ManyToMany"; -import { OneToMany } from "../../../../../../src/decorator/relations/OneToMany"; -import { OneToOne } from "../../../../../../src/decorator/relations/OneToOne"; +import { Entity } from "../../../../../../src/decorator/entity/Entity.ts"; +import { PrimaryGeneratedColumn } from "../../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import { Column } from "../../../../../../src/decorator/columns/Column.ts"; +import { ManyToMany } from "../../../../../../src/decorator/relations/ManyToMany.ts"; +import { OneToMany } from "../../../../../../src/decorator/relations/OneToMany.ts"; +import { OneToOne } from "../../../../../../src/decorator/relations/OneToOne.ts"; import { Post, -} from "./Post"; +} from "./Post.ts"; @Entity("s_category_named_all", { orderBy: { @@ -20,7 +20,7 @@ export class Category { }) id: number; - @Column() + @Column({ type: String }) name: string; @OneToOne(type => Post, post => post.oneCategory) @@ -43,4 +43,4 @@ export class Category { // OneToOne with named properties @OneToOne(type => Post, post => post.oneCategoryNamedAll) onePostNamedAll: Promise; -} \ No newline at end of file +} diff --git a/test/functional/relations/lazy-relations/named-tables-and-columns/entity/Post.ts b/test/functional/relations/lazy-relations/named-tables-and-columns/entity/Post.ts index d8f2470d6..bb3070716 100644 --- a/test/functional/relations/lazy-relations/named-tables-and-columns/entity/Post.ts +++ b/test/functional/relations/lazy-relations/named-tables-and-columns/entity/Post.ts @@ -1,14 +1,14 @@ -import { Entity } from "../../../../../../src/decorator/entity/Entity"; -import { PrimaryGeneratedColumn } from "../../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import { Column } from "../../../../../../src/decorator/columns/Column"; -import { ManyToMany } from "../../../../../../src/decorator/relations/ManyToMany"; -import { JoinTable } from "../../../../../../src/decorator/relations/JoinTable"; -import { ManyToOne } from "../../../../../../src/decorator/relations/ManyToOne"; -import { OneToOne } from "../../../../../../src/decorator/relations/OneToOne"; -import { JoinColumn } from "../../../../../../src/decorator/relations/JoinColumn"; +import { Entity } from "../../../../../../src/decorator/entity/Entity.ts"; +import { PrimaryGeneratedColumn } from "../../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import { Column } from "../../../../../../src/decorator/columns/Column.ts"; +import { ManyToMany } from "../../../../../../src/decorator/relations/ManyToMany.ts"; +import { JoinTable } from "../../../../../../src/decorator/relations/JoinTable.ts"; +import { ManyToOne } from "../../../../../../src/decorator/relations/ManyToOne.ts"; +import { OneToOne } from "../../../../../../src/decorator/relations/OneToOne.ts"; +import { JoinColumn } from "../../../../../../src/decorator/relations/JoinColumn.ts"; import { Category, -} from "./Category"; +} from "./Category.ts"; @Entity("s_post_named_all", { orderBy: { @@ -23,10 +23,10 @@ export class Post { }) id: number; - @Column() + @Column({ type: String }) title: string; - @Column() + @Column({ type: String }) text: string; @ManyToMany(type => Category) @@ -37,7 +37,7 @@ export class Post { @JoinTable() twoSideCategories: Promise; - @Column() + @Column({ type: Number }) viewCount: number = 0; @ManyToOne(type => Category) @@ -68,4 +68,4 @@ export class Post { name: "s_one_category_named_all_id" }) oneCategoryNamedAll: Promise; -} \ No newline at end of file +} diff --git a/test/functional/relations/lazy-relations/named-tables-and-columns/named-tables-and-columns-lazy-relations.ts b/test/functional/relations/lazy-relations/named-tables-and-columns/named-tables-and-columns-lazy-relations.ts index 99411085a..2199dc40e 100644 --- a/test/functional/relations/lazy-relations/named-tables-and-columns/named-tables-and-columns-lazy-relations.ts +++ b/test/functional/relations/lazy-relations/named-tables-and-columns/named-tables-and-columns-lazy-relations.ts @@ -1,12 +1,13 @@ -import "reflect-metadata"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils"; -import {Connection} from "../../../../../src/connection/Connection"; +import {runIfMain} from "../../../../deps/mocha.ts"; +import {expect} from "../../../../deps/chai.ts"; +import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils.ts"; +import {Connection} from "../../../../../src/connection/Connection.ts"; import { Post, -} from "./entity/Post"; +} from "./entity/Post.ts"; import { Category, -} from "./entity/Category"; +} from "./entity/Category.ts"; /** * Because lazy relations are overriding prototype is impossible to run these tests on multiple connections. @@ -49,7 +50,7 @@ describe("named-tables-and-columns-lazy-relations", () => { await postRepository.save(savedPost); - await savedPost.categories.should.eventually.be.eql([savedCategory1, savedCategory2, savedCategory3]); + expect(await savedPost.categories).to.eql([savedCategory1, savedCategory2, savedCategory3]); const post = (await postRepository.findOne(1))!; post.title.should.be.equal("Hello post"); @@ -87,7 +88,7 @@ describe("named-tables-and-columns-lazy-relations", () => { await postRepository.save(savedPost); - await savedPost.twoSideCategories.should.eventually.be.eql([savedCategory1, savedCategory2, savedCategory3]); + expect(await savedPost.twoSideCategories).to.eql([savedCategory1, savedCategory2, savedCategory3]); const post = (await postRepository.findOne(1))!; post.title.should.be.equal("Hello post"); @@ -293,3 +294,5 @@ describe("named-tables-and-columns-lazy-relations", () => { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/relations/lazy-relations/named-tables/entity/Category.ts b/test/functional/relations/lazy-relations/named-tables/entity/Category.ts index 799aa9aef..c11a5539b 100644 --- a/test/functional/relations/lazy-relations/named-tables/entity/Category.ts +++ b/test/functional/relations/lazy-relations/named-tables/entity/Category.ts @@ -1,12 +1,12 @@ -import { Entity } from "../../../../../../src/decorator/entity/Entity"; -import { PrimaryGeneratedColumn } from "../../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import { Column } from "../../../../../../src/decorator/columns/Column"; -import { ManyToMany } from "../../../../../../src/decorator/relations/ManyToMany"; -import { OneToMany } from "../../../../../../src/decorator/relations/OneToMany"; -import { OneToOne } from "../../../../../../src/decorator/relations/OneToOne"; +import { Entity } from "../../../../../../src/decorator/entity/Entity.ts"; +import { PrimaryGeneratedColumn } from "../../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import { Column } from "../../../../../../src/decorator/columns/Column.ts"; +import { ManyToMany } from "../../../../../../src/decorator/relations/ManyToMany.ts"; +import { OneToMany } from "../../../../../../src/decorator/relations/OneToMany.ts"; +import { OneToOne } from "../../../../../../src/decorator/relations/OneToOne.ts"; import { Post, -} from "./Post"; +} from "./Post.ts"; @Entity("s_category", { orderBy: { @@ -18,7 +18,7 @@ export class Category { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) name: string; @OneToOne(type => Post, post => post.oneCategory) diff --git a/test/functional/relations/lazy-relations/named-tables/entity/Post.ts b/test/functional/relations/lazy-relations/named-tables/entity/Post.ts index 30e801e33..e1d13c1f4 100644 --- a/test/functional/relations/lazy-relations/named-tables/entity/Post.ts +++ b/test/functional/relations/lazy-relations/named-tables/entity/Post.ts @@ -1,14 +1,14 @@ -import { Entity } from "../../../../../../src/decorator/entity/Entity"; -import { PrimaryGeneratedColumn } from "../../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import { Column } from "../../../../../../src/decorator/columns/Column"; -import { ManyToMany } from "../../../../../../src/decorator/relations/ManyToMany"; -import { JoinTable } from "../../../../../../src/decorator/relations/JoinTable"; -import { ManyToOne } from "../../../../../../src/decorator/relations/ManyToOne"; -import { OneToOne } from "../../../../../../src/decorator/relations/OneToOne"; -import { JoinColumn } from "../../../../../../src/decorator/relations/JoinColumn"; +import { Entity } from "../../../../../../src/decorator/entity/Entity.ts"; +import { PrimaryGeneratedColumn } from "../../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import { Column } from "../../../../../../src/decorator/columns/Column.ts"; +import { ManyToMany } from "../../../../../../src/decorator/relations/ManyToMany.ts"; +import { JoinTable } from "../../../../../../src/decorator/relations/JoinTable.ts"; +import { ManyToOne } from "../../../../../../src/decorator/relations/ManyToOne.ts"; +import { OneToOne } from "../../../../../../src/decorator/relations/OneToOne.ts"; +import { JoinColumn } from "../../../../../../src/decorator/relations/JoinColumn.ts"; import { Category, -} from "./Category"; +} from "./Category.ts"; @Entity("s_post", { orderBy: { @@ -21,10 +21,10 @@ export class Post { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) title: string; - @Column() + @Column({ type: String }) text: string; @ManyToMany(type => Category) @@ -35,7 +35,7 @@ export class Post { @JoinTable() twoSideCategories: Promise; - @Column() + @Column({ type: Number }) viewCount: number = 0; @ManyToOne(type => Category) diff --git a/test/functional/relations/lazy-relations/named-tables/named-tables-lazy-relations.ts b/test/functional/relations/lazy-relations/named-tables/named-tables-lazy-relations.ts index e460f2106..683f17e8d 100644 --- a/test/functional/relations/lazy-relations/named-tables/named-tables-lazy-relations.ts +++ b/test/functional/relations/lazy-relations/named-tables/named-tables-lazy-relations.ts @@ -1,12 +1,13 @@ -import "reflect-metadata"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils"; -import {Connection} from "../../../../../src/connection/Connection"; +import {runIfMain} from "../../../../deps/mocha.ts"; +import {expect} from "../../../../deps/chai.ts"; +import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils.ts"; +import {Connection} from "../../../../../src/connection/Connection.ts"; import { Post, -} from "./entity/Post"; +} from "./entity/Post.ts"; import { Category, -} from "./entity/Category"; +} from "./entity/Category.ts"; /** * Because lazy relations are overriding prototype is impossible to run these tests on multiple connections. @@ -49,7 +50,7 @@ describe("named-tables-lazy-relations", () => { await postRepository.save(savedPost); - await savedPost.categories.should.eventually.be.eql([savedCategory1, savedCategory2, savedCategory3]); + expect(await savedPost.categories).to.be.eql([savedCategory1, savedCategory2, savedCategory3]); const post = (await postRepository.findOne(1))!; post.title.should.be.equal("Hello post"); @@ -87,7 +88,7 @@ describe("named-tables-lazy-relations", () => { await postRepository.save(savedPost); - await savedPost.twoSideCategories.should.eventually.be.eql([savedCategory1, savedCategory2, savedCategory3]); + expect(await savedPost.twoSideCategories).to.eql([savedCategory1, savedCategory2, savedCategory3]); const post = (await postRepository.findOne(1))!; post.title.should.be.equal("Hello post"); @@ -293,3 +294,5 @@ describe("named-tables-lazy-relations", () => { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/relations/multiple-primary-keys/multiple-primary-keys-many-to-many/entity/Category.ts b/test/functional/relations/multiple-primary-keys/multiple-primary-keys-many-to-many/entity/Category.ts index f07912c2c..ffae9eb18 100644 --- a/test/functional/relations/multiple-primary-keys/multiple-primary-keys-many-to-many/entity/Category.ts +++ b/test/functional/relations/multiple-primary-keys/multiple-primary-keys-many-to-many/entity/Category.ts @@ -1,28 +1,28 @@ -import {Entity} from "../../../../../../src/decorator/entity/Entity"; -import {PrimaryColumn} from "../../../../../../src/decorator/columns/PrimaryColumn"; -import {Column} from "../../../../../../src/decorator/columns/Column"; -import {Post} from "./Post"; -import {ManyToMany} from "../../../../../../src/decorator/relations/ManyToMany"; -import {Tag} from "./Tag"; -import {Unique} from "../../../../../../src"; +import {Entity} from "../../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryColumn} from "../../../../../../src/decorator/columns/PrimaryColumn.ts"; +import {Column} from "../../../../../../src/decorator/columns/Column.ts"; +import {Post} from "./Post.ts"; +import {ManyToMany} from "../../../../../../src/decorator/relations/ManyToMany.ts"; +import {Tag} from "./Tag.ts"; +import {Unique} from "../../../../../../src/index.ts"; @Entity() @Unique(["code", "version", "description"]) export class Category { - @PrimaryColumn() + @PrimaryColumn({type: String}) name: string; - @PrimaryColumn() + @PrimaryColumn({type: String}) type: string; - @Column() + @Column({type: Number}) code: number; - @Column() + @Column({type: Number}) version: number; - @Column({nullable: true}) + @Column({nullable: true, type: String}) description: string; @ManyToMany(type => Post, post => post.categories) @@ -43,4 +43,4 @@ export class Category { @ManyToMany(type => Tag, tag => tag.categoriesWithNonPKColumns) tagsWithNonPKColumns: Tag[]; -} \ No newline at end of file +} diff --git a/test/functional/relations/multiple-primary-keys/multiple-primary-keys-many-to-many/entity/Post.ts b/test/functional/relations/multiple-primary-keys/multiple-primary-keys-many-to-many/entity/Post.ts index 860fc67b3..fa70d849c 100644 --- a/test/functional/relations/multiple-primary-keys/multiple-primary-keys-many-to-many/entity/Post.ts +++ b/test/functional/relations/multiple-primary-keys/multiple-primary-keys-many-to-many/entity/Post.ts @@ -1,9 +1,9 @@ -import {Entity} from "../../../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../../../src/decorator/columns/Column"; -import {PrimaryGeneratedColumn} from "../../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {ManyToMany} from "../../../../../../src/decorator/relations/ManyToMany"; -import {JoinTable} from "../../../../../../src/decorator/relations/JoinTable"; -import {Category} from "./Category"; +import {Entity} from "../../../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../../../src/decorator/columns/Column.ts"; +import {PrimaryGeneratedColumn} from "../../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {ManyToMany} from "../../../../../../src/decorator/relations/ManyToMany.ts"; +import {JoinTable} from "../../../../../../src/decorator/relations/JoinTable.ts"; +import {Category} from "./Category.ts"; @Entity() export class Post { @@ -11,7 +11,7 @@ export class Post { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({type: String}) title: string; @ManyToMany(type => Category, category => category.posts) @@ -55,4 +55,4 @@ export class Post { }) categoriesWithNonPKColumns: Category[]; -} \ No newline at end of file +} diff --git a/test/functional/relations/multiple-primary-keys/multiple-primary-keys-many-to-many/entity/Tag.ts b/test/functional/relations/multiple-primary-keys/multiple-primary-keys-many-to-many/entity/Tag.ts index 71453dbc5..8167abde0 100644 --- a/test/functional/relations/multiple-primary-keys/multiple-primary-keys-many-to-many/entity/Tag.ts +++ b/test/functional/relations/multiple-primary-keys/multiple-primary-keys-many-to-many/entity/Tag.ts @@ -1,20 +1,20 @@ -import {Entity} from "../../../../../../src/decorator/entity/Entity"; -import {ManyToMany} from "../../../../../../src/decorator/relations/ManyToMany"; -import {JoinTable} from "../../../../../../src/decorator/relations/JoinTable"; -import {PrimaryColumn} from "../../../../../../src/decorator/columns/PrimaryColumn"; -import {Category} from "./Category"; -import {Column} from "../../../../../../src/decorator/columns/Column"; +import {Entity} from "../../../../../../src/decorator/entity/Entity.ts"; +import {ManyToMany} from "../../../../../../src/decorator/relations/ManyToMany.ts"; +import {JoinTable} from "../../../../../../src/decorator/relations/JoinTable.ts"; +import {PrimaryColumn} from "../../../../../../src/decorator/columns/PrimaryColumn.ts"; +import {Category} from "./Category.ts"; +import {Column} from "../../../../../../src/decorator/columns/Column.ts"; @Entity() export class Tag { - @Column() + @Column({type: Number}) code: number; - @PrimaryColumn() + @PrimaryColumn({type: String}) title: string; - @PrimaryColumn() + @PrimaryColumn({type: String}) description: string; @ManyToMany(type => Category, category => category.tags) @@ -64,4 +64,4 @@ export class Tag { }) categoriesWithNonPKColumns: Category[]; -} \ No newline at end of file +} diff --git a/test/functional/relations/multiple-primary-keys/multiple-primary-keys-many-to-many/multiple-primary-keys-many-to-many.ts b/test/functional/relations/multiple-primary-keys/multiple-primary-keys-many-to-many/multiple-primary-keys-many-to-many.ts index a4f881141..2a0e7f49c 100644 --- a/test/functional/relations/multiple-primary-keys/multiple-primary-keys-many-to-many/multiple-primary-keys-many-to-many.ts +++ b/test/functional/relations/multiple-primary-keys/multiple-primary-keys-many-to-many/multiple-primary-keys-many-to-many.ts @@ -1,16 +1,18 @@ -import "reflect-metadata"; -import {expect} from "chai"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils"; -import {Connection} from "../../../../../src/connection/Connection"; -import {Post} from "./entity/Post"; -import {Category} from "./entity/Category"; -import {Tag} from "./entity/Tag"; +import {join as joinPaths} from "../../../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../../../deps/mocha.ts"; +import {expect} from "../../../../deps/chai.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils.ts"; +import {Connection} from "../../../../../src/connection/Connection.ts"; +import {Post} from "./entity/Post.ts"; +import {Category} from "./entity/Category.ts"; +import {Tag} from "./entity/Tag.ts"; describe("relations > multiple-primary-keys > many-to-many", () => { - + let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], })); beforeEach(() => reloadTestingDatabases(connections)); after(() => closeTestingConnections(connections)); @@ -777,3 +779,5 @@ describe("relations > multiple-primary-keys > many-to-many", () => { }); }); + +runIfMain(import.meta); diff --git a/test/functional/relations/multiple-primary-keys/multiple-primary-keys-many-to-one/entity/Category.ts b/test/functional/relations/multiple-primary-keys/multiple-primary-keys-many-to-one/entity/Category.ts index a983f7e7e..af6eb4ef1 100644 --- a/test/functional/relations/multiple-primary-keys/multiple-primary-keys-many-to-one/entity/Category.ts +++ b/test/functional/relations/multiple-primary-keys/multiple-primary-keys-many-to-one/entity/Category.ts @@ -1,27 +1,27 @@ -import {Entity} from "../../../../../../src/decorator/entity/Entity"; -import {PrimaryColumn} from "../../../../../../src/decorator/columns/PrimaryColumn"; -import {Column} from "../../../../../../src/decorator/columns/Column"; -import {OneToMany} from "../../../../../../src/decorator/relations/OneToMany"; -import {Post} from "./Post"; -import {Unique} from "../../../../../../src"; +import {Entity} from "../../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryColumn} from "../../../../../../src/decorator/columns/PrimaryColumn.ts"; +import {Column} from "../../../../../../src/decorator/columns/Column.ts"; +import {OneToMany} from "../../../../../../src/decorator/relations/OneToMany.ts"; +import {Post} from "./Post.ts"; +import {Unique} from "../../../../../../src/index.ts"; @Entity() @Unique(["code", "version", "description"]) export class Category { - @PrimaryColumn() + @PrimaryColumn({type: String}) name: string; - @PrimaryColumn() + @PrimaryColumn({type: String}) type: string; - @Column() + @Column({type: Number}) code: number; - @Column() + @Column({type: Number}) version: number; - @Column({nullable: true}) + @Column({nullable: true, type: String}) description: string; @OneToMany(type => Post, post => post.category) @@ -36,4 +36,4 @@ export class Category { @OneToMany(type => Post, post => post.categoryWithNonPKColumns) postsWithNonPKColumns: Post[]; -} \ No newline at end of file +} diff --git a/test/functional/relations/multiple-primary-keys/multiple-primary-keys-many-to-one/entity/Post.ts b/test/functional/relations/multiple-primary-keys/multiple-primary-keys-many-to-one/entity/Post.ts index 22246051d..fbd74856a 100644 --- a/test/functional/relations/multiple-primary-keys/multiple-primary-keys-many-to-one/entity/Post.ts +++ b/test/functional/relations/multiple-primary-keys/multiple-primary-keys-many-to-one/entity/Post.ts @@ -1,9 +1,9 @@ -import {Entity} from "../../../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../../../src/decorator/columns/Column"; -import {PrimaryGeneratedColumn} from "../../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {ManyToOne} from "../../../../../../src/decorator/relations/ManyToOne"; -import {JoinColumn} from "../../../../../../src/decorator/relations/JoinColumn"; -import {Category} from "./Category"; +import {Entity} from "../../../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../../../src/decorator/columns/Column.ts"; +import {PrimaryGeneratedColumn} from "../../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {ManyToOne} from "../../../../../../src/decorator/relations/ManyToOne.ts"; +import {JoinColumn} from "../../../../../../src/decorator/relations/JoinColumn.ts"; +import {Category} from "./Category.ts"; @Entity() export class Post { @@ -11,7 +11,7 @@ export class Post { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({type: String}) title: string; @ManyToOne(type => Category) @@ -36,4 +36,4 @@ export class Post { ]) categoryWithNonPKColumns: Category; -} \ No newline at end of file +} diff --git a/test/functional/relations/multiple-primary-keys/multiple-primary-keys-many-to-one/multiple-primary-keys-many-to-one.ts b/test/functional/relations/multiple-primary-keys/multiple-primary-keys-many-to-one/multiple-primary-keys-many-to-one.ts index 575a9661f..c09a2a941 100644 --- a/test/functional/relations/multiple-primary-keys/multiple-primary-keys-many-to-one/multiple-primary-keys-many-to-one.ts +++ b/test/functional/relations/multiple-primary-keys/multiple-primary-keys-many-to-one/multiple-primary-keys-many-to-one.ts @@ -1,15 +1,17 @@ -import "reflect-metadata"; -import {expect} from "chai"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils"; -import {Connection} from "../../../../../src/connection/Connection"; -import {Post} from "./entity/Post"; -import {Category} from "./entity/Category"; +import {join as joinPaths} from "../../../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../../../deps/mocha.ts"; +import {expect} from "../../../../deps/chai.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils.ts"; +import {Connection} from "../../../../../src/connection/Connection.ts"; +import {Post} from "./entity/Post.ts"; +import {Category} from "./entity/Category.ts"; describe("relations > multiple-primary-keys > many-to-one", () => { - + let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], })); beforeEach(() => reloadTestingDatabases(connections)); after(() => closeTestingConnections(connections)); @@ -472,3 +474,5 @@ describe("relations > multiple-primary-keys > many-to-one", () => { }); }); + +runIfMain(import.meta); diff --git a/test/functional/relations/multiple-primary-keys/multiple-primary-keys-one-to-one/entity/Category.ts b/test/functional/relations/multiple-primary-keys/multiple-primary-keys-one-to-one/entity/Category.ts index 9b417e17c..028071a99 100644 --- a/test/functional/relations/multiple-primary-keys/multiple-primary-keys-one-to-one/entity/Category.ts +++ b/test/functional/relations/multiple-primary-keys/multiple-primary-keys-one-to-one/entity/Category.ts @@ -1,28 +1,28 @@ -import {Entity} from "../../../../../../src/decorator/entity/Entity"; -import {PrimaryColumn} from "../../../../../../src/decorator/columns/PrimaryColumn"; -import {Column} from "../../../../../../src/decorator/columns/Column"; -import {OneToOne} from "../../../../../../src/decorator/relations/OneToOne"; -import {Post} from "./Post"; -import {Tag} from "./Tag"; -import {Unique} from "../../../../../../src"; +import {Entity} from "../../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryColumn} from "../../../../../../src/decorator/columns/PrimaryColumn.ts"; +import {Column} from "../../../../../../src/decorator/columns/Column.ts"; +import {OneToOne} from "../../../../../../src/decorator/relations/OneToOne.ts"; +import {Post} from "./Post.ts"; +import {Tag} from "./Tag.ts"; +import {Unique} from "../../../../../../src/index.ts"; @Entity() @Unique(["code", "version", "description"]) export class Category { - @PrimaryColumn() + @PrimaryColumn({type: String}) name: string; - @PrimaryColumn() + @PrimaryColumn({type: String}) type: string; - @Column() + @Column({type: Number}) code: number; - @Column() + @Column({type: Number}) version: number; - @Column({nullable: true}) + @Column({nullable: true, type: String}) description: string; @OneToOne(type => Post, post => post.category) @@ -43,4 +43,4 @@ export class Category { @OneToOne(type => Tag, tag => tag.categoryWithNonPKColumns) tagWithNonPKColumns: Tag; -} \ No newline at end of file +} diff --git a/test/functional/relations/multiple-primary-keys/multiple-primary-keys-one-to-one/entity/Post.ts b/test/functional/relations/multiple-primary-keys/multiple-primary-keys-one-to-one/entity/Post.ts index d22626d44..f5a7cfdb9 100644 --- a/test/functional/relations/multiple-primary-keys/multiple-primary-keys-one-to-one/entity/Post.ts +++ b/test/functional/relations/multiple-primary-keys/multiple-primary-keys-one-to-one/entity/Post.ts @@ -1,9 +1,9 @@ -import {Entity} from "../../../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../../../src/decorator/columns/Column"; -import {PrimaryGeneratedColumn} from "../../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {JoinColumn} from "../../../../../../src/decorator/relations/JoinColumn"; -import {OneToOne} from "../../../../../../src/decorator/relations/OneToOne"; -import {Category} from "./Category"; +import {Entity} from "../../../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../../../src/decorator/columns/Column.ts"; +import {PrimaryGeneratedColumn} from "../../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {JoinColumn} from "../../../../../../src/decorator/relations/JoinColumn.ts"; +import {OneToOne} from "../../../../../../src/decorator/relations/OneToOne.ts"; +import {Category} from "./Category.ts"; @Entity() export class Post { @@ -11,7 +11,7 @@ export class Post { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({type: String}) title: string; @OneToOne(type => Category, category => category.post) @@ -33,4 +33,4 @@ export class Post { ]) categoryWithNonPKColumns: Category; -} \ No newline at end of file +} diff --git a/test/functional/relations/multiple-primary-keys/multiple-primary-keys-one-to-one/entity/Tag.ts b/test/functional/relations/multiple-primary-keys/multiple-primary-keys-one-to-one/entity/Tag.ts index 6dac2bf5f..b95064a68 100644 --- a/test/functional/relations/multiple-primary-keys/multiple-primary-keys-one-to-one/entity/Tag.ts +++ b/test/functional/relations/multiple-primary-keys/multiple-primary-keys-one-to-one/entity/Tag.ts @@ -1,20 +1,20 @@ -import {Entity} from "../../../../../../src/decorator/entity/Entity"; -import {PrimaryColumn} from "../../../../../../src/decorator/columns/PrimaryColumn"; -import {Column} from "../../../../../../src/decorator/columns/Column"; -import {OneToOne} from "../../../../../../src/decorator/relations/OneToOne"; -import {JoinColumn} from "../../../../../../src/decorator/relations/JoinColumn"; -import {Category} from "./Category"; +import {Entity} from "../../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryColumn} from "../../../../../../src/decorator/columns/PrimaryColumn.ts"; +import {Column} from "../../../../../../src/decorator/columns/Column.ts"; +import {OneToOne} from "../../../../../../src/decorator/relations/OneToOne.ts"; +import {JoinColumn} from "../../../../../../src/decorator/relations/JoinColumn.ts"; +import {Category} from "./Category.ts"; @Entity() export class Tag { - @Column() + @Column({type: Number}) code: number; - @PrimaryColumn() + @PrimaryColumn({type: String}) title: string; - @PrimaryColumn() + @PrimaryColumn({type: String}) description: string; @OneToOne(type => Category, category => category.tag) @@ -36,4 +36,4 @@ export class Tag { ]) categoryWithNonPKColumns: Category; -} \ No newline at end of file +} diff --git a/test/functional/relations/multiple-primary-keys/multiple-primary-keys-one-to-one/multiple-primary-keys-one-to-one.ts b/test/functional/relations/multiple-primary-keys/multiple-primary-keys-one-to-one/multiple-primary-keys-one-to-one.ts index f09372a21..8e7a7f9aa 100644 --- a/test/functional/relations/multiple-primary-keys/multiple-primary-keys-one-to-one/multiple-primary-keys-one-to-one.ts +++ b/test/functional/relations/multiple-primary-keys/multiple-primary-keys-one-to-one/multiple-primary-keys-one-to-one.ts @@ -1,16 +1,18 @@ -import "reflect-metadata"; -import {expect} from "chai"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils"; -import {Connection} from "../../../../../src/connection/Connection"; -import {Category} from "./entity/Category"; -import {Post} from "./entity/Post"; -import {Tag} from "./entity/Tag"; +import {join as joinPaths} from "../../../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../../../deps/mocha.ts"; +import {expect} from "../../../../deps/chai.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils.ts"; +import {Connection} from "../../../../../src/connection/Connection.ts"; +import {Category} from "./entity/Category.ts"; +import {Post} from "./entity/Post.ts"; +import {Tag} from "./entity/Tag.ts"; describe("relations > multiple-primary-keys > one-to-one", () => { - + let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], })); beforeEach(() => reloadTestingDatabases(connections)); after(() => closeTestingConnections(connections)); @@ -684,3 +686,5 @@ describe("relations > multiple-primary-keys > one-to-one", () => { }); }); + +runIfMain(import.meta); diff --git a/test/functional/relations/multiple-primary-keys/multiple-primary-keys-other-cases/entity/Event.ts b/test/functional/relations/multiple-primary-keys/multiple-primary-keys-other-cases/entity/Event.ts index ee0b87f52..5f9cd471e 100644 --- a/test/functional/relations/multiple-primary-keys/multiple-primary-keys-other-cases/entity/Event.ts +++ b/test/functional/relations/multiple-primary-keys/multiple-primary-keys-other-cases/entity/Event.ts @@ -1,10 +1,10 @@ -import {Entity} from "../../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {OneToMany} from "../../../../../../src/decorator/relations/OneToMany"; -import {Column} from "../../../../../../src/decorator/columns/Column"; -import {ManyToOne} from "../../../../../../src/decorator/relations/ManyToOne"; -import {EventMember} from "./EventMember"; -import {Person} from "./Person"; +import {Entity} from "../../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {OneToMany} from "../../../../../../src/decorator/relations/OneToMany.ts"; +import {Column} from "../../../../../../src/decorator/columns/Column.ts"; +import {ManyToOne} from "../../../../../../src/decorator/relations/ManyToOne.ts"; +import {EventMember} from "./EventMember.ts"; +import {Person} from "./Person.ts"; @Entity() export class Event { @@ -12,7 +12,7 @@ export class Event { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) name: string; @ManyToOne(type => Person) @@ -21,4 +21,4 @@ export class Event { @OneToMany(type => EventMember, member => member.event) members: EventMember[]; -} \ No newline at end of file +} diff --git a/test/functional/relations/multiple-primary-keys/multiple-primary-keys-other-cases/entity/EventMember.ts b/test/functional/relations/multiple-primary-keys/multiple-primary-keys-other-cases/entity/EventMember.ts index e56dcf1ab..9f3d26708 100644 --- a/test/functional/relations/multiple-primary-keys/multiple-primary-keys-other-cases/entity/EventMember.ts +++ b/test/functional/relations/multiple-primary-keys/multiple-primary-keys-other-cases/entity/EventMember.ts @@ -1,7 +1,7 @@ -import {Entity} from "../../../../../../src/decorator/entity/Entity"; -import {ManyToOne} from "../../../../../../src/decorator/relations/ManyToOne"; -import {Event} from "./Event"; -import {User} from "./User"; +import {Entity} from "../../../../../../src/decorator/entity/Entity.ts"; +import {ManyToOne} from "../../../../../../src/decorator/relations/ManyToOne.ts"; +import {Event} from "./Event.ts"; +import {User} from "./User.ts"; @Entity() export class EventMember { @@ -12,4 +12,4 @@ export class EventMember { @ManyToOne(type => User, user => user.members, { primary: true }) user: User; -} \ No newline at end of file +} diff --git a/test/functional/relations/multiple-primary-keys/multiple-primary-keys-other-cases/entity/Person.ts b/test/functional/relations/multiple-primary-keys/multiple-primary-keys-other-cases/entity/Person.ts index d72180bcb..343184d5b 100644 --- a/test/functional/relations/multiple-primary-keys/multiple-primary-keys-other-cases/entity/Person.ts +++ b/test/functional/relations/multiple-primary-keys/multiple-primary-keys-other-cases/entity/Person.ts @@ -1,17 +1,17 @@ -import {Entity} from "../../../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../../../src/decorator/columns/Column"; -import {OneToOne} from "../../../../../../src/decorator/relations/OneToOne"; -import {JoinColumn} from "../../../../../../src/decorator/relations/JoinColumn"; -import {User} from "./User"; +import {Entity} from "../../../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../../../src/decorator/columns/Column.ts"; +import {OneToOne} from "../../../../../../src/decorator/relations/OneToOne.ts"; +import {JoinColumn} from "../../../../../../src/decorator/relations/JoinColumn.ts"; +import {User} from "./User.ts"; @Entity() export class Person { - @Column() + @Column({ type: String }) fullName: string; @OneToOne(type => User, { primary: true }) @JoinColumn() user: User; -} \ No newline at end of file +} diff --git a/test/functional/relations/multiple-primary-keys/multiple-primary-keys-other-cases/entity/User.ts b/test/functional/relations/multiple-primary-keys/multiple-primary-keys-other-cases/entity/User.ts index 1af1f6e71..a85f10507 100644 --- a/test/functional/relations/multiple-primary-keys/multiple-primary-keys-other-cases/entity/User.ts +++ b/test/functional/relations/multiple-primary-keys/multiple-primary-keys-other-cases/entity/User.ts @@ -1,8 +1,8 @@ -import {Entity} from "../../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {OneToMany} from "../../../../../../src/decorator/relations/OneToMany"; -import {Column} from "../../../../../../src/decorator/columns/Column"; -import {EventMember} from "./EventMember"; +import {Entity} from "../../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {OneToMany} from "../../../../../../src/decorator/relations/OneToMany.ts"; +import {Column} from "../../../../../../src/decorator/columns/Column.ts"; +import {EventMember} from "./EventMember.ts"; @Entity() export class User { @@ -10,10 +10,10 @@ export class User { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) name: string; @OneToMany(type => EventMember, member => member.user) members: EventMember[]; -} \ No newline at end of file +} diff --git a/test/functional/relations/multiple-primary-keys/multiple-primary-keys-other-cases/multiple-primary-keys-other-cases.ts b/test/functional/relations/multiple-primary-keys/multiple-primary-keys-other-cases/multiple-primary-keys-other-cases.ts index 20f7e548b..2793d185e 100644 --- a/test/functional/relations/multiple-primary-keys/multiple-primary-keys-other-cases/multiple-primary-keys-other-cases.ts +++ b/test/functional/relations/multiple-primary-keys/multiple-primary-keys-other-cases/multiple-primary-keys-other-cases.ts @@ -1,17 +1,19 @@ -import "reflect-metadata"; -import {expect} from "chai"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils"; -import {Connection} from "../../../../../src/connection/Connection"; -import {User} from "./entity/User"; -import {EventMember} from "./entity/EventMember"; -import {Event} from "./entity/Event"; -import {Person} from "./entity/Person"; +import {join as joinPaths} from "../../../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../../../deps/mocha.ts"; +import {expect} from "../../../../deps/chai.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils.ts"; +import {Connection} from "../../../../../src/connection/Connection.ts"; +import {User} from "./entity/User.ts"; +import {EventMember} from "./entity/EventMember.ts"; +import {Event} from "./entity/Event.ts"; +import {Person} from "./entity/Person.ts"; describe("relations > multiple-primary-keys > other-cases", () => { - + let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], })); beforeEach(() => reloadTestingDatabases(connections)); after(() => closeTestingConnections(connections)); @@ -120,3 +122,5 @@ describe("relations > multiple-primary-keys > other-cases", () => { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/relations/relation-mapped-to-different-name-column/entity/Post.ts b/test/functional/relations/relation-mapped-to-different-name-column/entity/Post.ts index 62b4206e5..0216a1611 100644 --- a/test/functional/relations/relation-mapped-to-different-name-column/entity/Post.ts +++ b/test/functional/relations/relation-mapped-to-different-name-column/entity/Post.ts @@ -1,9 +1,9 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {PostDetails} from "./PostDetails"; -import {OneToOne} from "../../../../../src/decorator/relations/OneToOne"; -import {JoinColumn} from "../../../../../src/decorator/relations/JoinColumn"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {PostDetails} from "./PostDetails.ts"; +import {OneToOne} from "../../../../../src/decorator/relations/OneToOne.ts"; +import {JoinColumn} from "../../../../../src/decorator/relations/JoinColumn.ts"; @Entity() export class Post { @@ -15,7 +15,7 @@ export class Post { @JoinColumn() details: PostDetails; - @Column() + @Column({ type: String }) title: string; -} \ No newline at end of file +} diff --git a/test/functional/relations/relation-mapped-to-different-name-column/entity/PostDetails.ts b/test/functional/relations/relation-mapped-to-different-name-column/entity/PostDetails.ts index f161350e1..a300f7992 100644 --- a/test/functional/relations/relation-mapped-to-different-name-column/entity/PostDetails.ts +++ b/test/functional/relations/relation-mapped-to-different-name-column/entity/PostDetails.ts @@ -1,10 +1,10 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn.ts"; @Entity() export class PostDetails { - @PrimaryColumn() + @PrimaryColumn({ type: String }) keyword: string; -} \ No newline at end of file +} diff --git a/test/functional/relations/relation-mapped-to-different-name-column/relation-mapped-to-different-name-column.ts b/test/functional/relations/relation-mapped-to-different-name-column/relation-mapped-to-different-name-column.ts index 9c25ff1e9..43014deec 100644 --- a/test/functional/relations/relation-mapped-to-different-name-column/relation-mapped-to-different-name-column.ts +++ b/test/functional/relations/relation-mapped-to-different-name-column/relation-mapped-to-different-name-column.ts @@ -1,14 +1,17 @@ -import "reflect-metadata"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils"; -import {Connection} from "../../../../src/connection/Connection"; -import {Post} from "./entity/Post"; -import {PostDetails} from "./entity/PostDetails"; +import {join as joinPaths} from "../../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../../deps/mocha.ts"; +import "../../../deps/chai.ts"; +import {closeTestingConnections, createTestingConnections, reloadTestingDatabases, getDirnameOfCurrentModule} from "../../../utils/test-utils.ts"; +import {Connection} from "../../../../src/connection/Connection.ts"; +import {Post} from "./entity/Post.ts"; +import {PostDetails} from "./entity/PostDetails.ts"; describe.skip("relations > relation mapped to relation with different name (#56)", () => { // skipped because of CI error. todo: needs investigation let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], })); beforeEach(() => reloadTestingDatabases(connections)); after(() => closeTestingConnections(connections)); @@ -46,3 +49,5 @@ describe.skip("relations > relation mapped to relation with different name (#56) }))); }); + +runIfMain(import.meta); diff --git a/test/functional/relations/relation-with-primary-key/entity/Category.ts b/test/functional/relations/relation-with-primary-key/entity/Category.ts index 98b1a805f..cc4254fa9 100644 --- a/test/functional/relations/relation-with-primary-key/entity/Category.ts +++ b/test/functional/relations/relation-with-primary-key/entity/Category.ts @@ -1,8 +1,8 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {Post} from "./Post"; -import {OneToMany} from "../../../../../src/decorator/relations/OneToMany"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {Post} from "./Post.ts"; +import {OneToMany} from "../../../../../src/decorator/relations/OneToMany.ts"; @Entity() export class Category { @@ -10,7 +10,7 @@ export class Category { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) name: string; @OneToMany(type => Post, post => post.category, { @@ -18,4 +18,4 @@ export class Category { }) posts: Post[]; -} \ No newline at end of file +} diff --git a/test/functional/relations/relation-with-primary-key/entity/Post.ts b/test/functional/relations/relation-with-primary-key/entity/Post.ts index 7456c2e75..2380f3d0e 100644 --- a/test/functional/relations/relation-with-primary-key/entity/Post.ts +++ b/test/functional/relations/relation-with-primary-key/entity/Post.ts @@ -1,7 +1,7 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {ManyToOne} from "../../../../../src/decorator/relations/ManyToOne"; -import {Category} from "./Category"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {ManyToOne} from "../../../../../src/decorator/relations/ManyToOne.ts"; +import {Category} from "./Category.ts"; @Entity() export class Post { @@ -12,7 +12,7 @@ export class Post { }) category: Category; - @Column() + @Column({ type: String }) title: string; -} \ No newline at end of file +} diff --git a/test/functional/relations/relation-with-primary-key/relation-with-primary-key.ts b/test/functional/relations/relation-with-primary-key/relation-with-primary-key.ts index 2839a2c66..d74fddbd8 100644 --- a/test/functional/relations/relation-with-primary-key/relation-with-primary-key.ts +++ b/test/functional/relations/relation-with-primary-key/relation-with-primary-key.ts @@ -1,14 +1,17 @@ -import "reflect-metadata"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils"; -import {Connection} from "../../../../src/connection/Connection"; -import {Post} from "./entity/Post"; -import {Category} from "./entity/Category"; +import {join as joinPaths} from "../../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../../deps/mocha.ts"; +import "../../../deps/chai.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils.ts"; +import {Connection} from "../../../../src/connection/Connection.ts"; +import {Post} from "./entity/Post.ts"; +import {Category} from "./entity/Category.ts"; describe("relations > relation with primary key", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], })); beforeEach(() => reloadTestingDatabases(connections)); after(() => closeTestingConnections(connections)); @@ -68,3 +71,5 @@ describe("relations > relation with primary key", () => { }); }); + +runIfMain(import.meta); diff --git a/test/functional/repository/basic-methods/entity/Blog.ts b/test/functional/repository/basic-methods/entity/Blog.ts index 5c3324c94..264cdab00 100644 --- a/test/functional/repository/basic-methods/entity/Blog.ts +++ b/test/functional/repository/basic-methods/entity/Blog.ts @@ -1,9 +1,9 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {Category} from "./Category"; -import {ManyToMany} from "../../../../../src/decorator/relations/ManyToMany"; -import {JoinTable} from "../../../../../src/decorator/relations/JoinTable"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {Category} from "./Category.ts"; +import {ManyToMany} from "../../../../../src/decorator/relations/ManyToMany.ts"; +import {JoinTable} from "../../../../../src/decorator/relations/JoinTable.ts"; @Entity() export class Blog { @@ -11,17 +11,17 @@ export class Blog { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) title: string; - @Column() + @Column({ type: String }) text: string; - + @ManyToMany(type => Category) @JoinTable() categories: Category[]; - @Column() + @Column({ type: Number }) counter: number = 0; -} \ No newline at end of file +} diff --git a/test/functional/repository/basic-methods/entity/Category.ts b/test/functional/repository/basic-methods/entity/Category.ts index 0095127bd..fdbf6b325 100644 --- a/test/functional/repository/basic-methods/entity/Category.ts +++ b/test/functional/repository/basic-methods/entity/Category.ts @@ -1,6 +1,6 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../src/decorator/columns/Column"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; @Entity() export class Category { @@ -8,7 +8,7 @@ export class Category { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) name: string; -} \ No newline at end of file +} diff --git a/test/functional/repository/basic-methods/entity/Post.ts b/test/functional/repository/basic-methods/entity/Post.ts index 63d10c818..1d7641835 100644 --- a/test/functional/repository/basic-methods/entity/Post.ts +++ b/test/functional/repository/basic-methods/entity/Post.ts @@ -1,6 +1,6 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../src/decorator/columns/Column"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; @Entity() export class Post { @@ -8,7 +8,7 @@ export class Post { @PrimaryGeneratedColumn() id: number|undefined|null|string; - @Column() + @Column({ type: String }) title: string; @Column({ @@ -19,4 +19,4 @@ export class Post { } }) dateAdded: Date; -} \ No newline at end of file +} diff --git a/test/functional/repository/basic-methods/repository-basic-methods.ts b/test/functional/repository/basic-methods/repository-basic-methods.ts index 677b5a4c6..d259098fc 100644 --- a/test/functional/repository/basic-methods/repository-basic-methods.ts +++ b/test/functional/repository/basic-methods/repository-basic-methods.ts @@ -1,27 +1,21 @@ -import "reflect-metadata"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils"; -import {Connection} from "../../../../src/connection/Connection"; -import {Post} from "./entity/Post"; -import {QueryBuilder} from "../../../../src/query-builder/QueryBuilder"; -import {User} from "./model/User"; -import questionSchema from "./model-schema/QuestionSchema"; -import {Question} from "./model/Question"; -import {Blog} from "./entity/Blog"; -import {Category} from "./entity/Category"; -import {DeepPartial} from "../../../../src/common/DeepPartial"; -import {EntitySchema} from "../../../../src"; +import {runIfMain} from "../../../deps/mocha.ts"; +import "../../../deps/chai.ts"; +import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils.ts"; +import {Connection} from "../../../../src/connection/Connection.ts"; +import {Post} from "./entity/Post.ts"; +import {QueryBuilder} from "../../../../src/query-builder/QueryBuilder.ts"; +import {User} from "./model/User.ts"; +import questionSchema from "./model-schema/QuestionSchema.ts"; +import {Question} from "./model/Question.ts"; +import {Blog} from "./entity/Blog.ts"; +import {Category} from "./entity/Category.ts"; +import {DeepPartial} from "../../../../src/common/DeepPartial.ts"; +import {EntitySchema} from "../../../../src/index.ts"; +import userSchema from "./schema/user.json"; describe("repository > basic methods", () => { - let userSchema: any; - try { - const resourceDir = __dirname + "/../../../../../../test/functional/repository/basic-methods/"; - userSchema = require(resourceDir + "schema/user.json"); - } catch (err) { - const resourceDir = __dirname + "/"; - userSchema = require(resourceDir + "schema/user.json"); - } - const UserEntity = new EntitySchema(userSchema); + const UserEntity = new EntitySchema(userSchema as any); const QuestionEntity = new EntitySchema(questionSchema as any); let connections: Connection[]; @@ -43,7 +37,7 @@ describe("repository > basic methods", () => { })); }); - + describe("hasId", function() { it("should return true if entity has an id", () => connections.forEach(connection => { @@ -222,7 +216,7 @@ describe("repository > basic methods", () => { blog.text = "Blog about good people"; blog.categories = [category]; await blogRepository.save(blog); - + // and preload it const plainBlogWithId = { id: 1 }; const preloadedBlog = await blogRepository.preload(plainBlogWithId); @@ -247,7 +241,7 @@ describe("repository > basic methods", () => { blog.text = "Blog about good people"; blog.categories = [category]; await blogRepository.save(blog); - + // and preload it const plainBlogWithId = { id: 1, categories: [{ id: 1 }] }; const preloadedBlog = await blogRepository.preload(plainBlogWithId); @@ -349,7 +343,7 @@ describe("repository > basic methods", () => { const saved = await postRepository.save(dbPost); saved.should.be.instanceOf(Post); - + saved.id!.should.be.equal(1); saved.title.should.be.equal("New title"); saved.dateAdded.should.be.instanceof(Date); @@ -496,3 +490,5 @@ describe("repository > basic methods", () => { });*/ }); + +runIfMain(import.meta); diff --git a/test/functional/repository/clear/entity/Post.ts b/test/functional/repository/clear/entity/Post.ts index 980daa78c..277f563bd 100644 --- a/test/functional/repository/clear/entity/Post.ts +++ b/test/functional/repository/clear/entity/Post.ts @@ -1,6 +1,6 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn.ts"; @Entity() export class Post { @@ -8,7 +8,7 @@ export class Post { @PrimaryColumn("int") id: number; - @Column() + @Column({ type: String }) title: string; -} \ No newline at end of file +} diff --git a/test/functional/repository/clear/repository-clear.ts b/test/functional/repository/clear/repository-clear.ts index f51b2dd80..2b74c8535 100644 --- a/test/functional/repository/clear/repository-clear.ts +++ b/test/functional/repository/clear/repository-clear.ts @@ -1,7 +1,8 @@ -import "reflect-metadata"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils"; -import {Connection} from "../../../../src/connection/Connection"; -import {Post} from "./entity/Post"; +import {runIfMain} from "../../../deps/mocha.ts"; +import "../../../deps/chai.ts"; +import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils.ts"; +import {Connection} from "../../../../src/connection/Connection.ts"; +import {Post} from "./entity/Post.ts"; describe("repository > clear method", () => { @@ -63,3 +64,5 @@ describe("repository > clear method", () => { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/repository/decrement/entity/Post.ts b/test/functional/repository/decrement/entity/Post.ts index f1f3d94ae..7fc405ae4 100644 --- a/test/functional/repository/decrement/entity/Post.ts +++ b/test/functional/repository/decrement/entity/Post.ts @@ -1,6 +1,6 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn.ts"; @Entity() export class Post { @@ -8,10 +8,10 @@ export class Post { @PrimaryColumn("int") id: number; - @Column() + @Column({ type: String }) title: string; - @Column() + @Column({ type: Number }) counter: number; -} \ No newline at end of file +} diff --git a/test/functional/repository/decrement/entity/PostBigInt.ts b/test/functional/repository/decrement/entity/PostBigInt.ts index 1f9ea38ad..4abde8c83 100644 --- a/test/functional/repository/decrement/entity/PostBigInt.ts +++ b/test/functional/repository/decrement/entity/PostBigInt.ts @@ -1,14 +1,14 @@ -import { Entity } from "../../../../../src/decorator/entity/Entity"; -import { Column } from "../../../../../src/decorator/columns/Column"; -import { PrimaryColumn } from "../../../../../src/decorator/columns/PrimaryColumn"; +import { Entity } from "../../../../../src/decorator/entity/Entity.ts"; +import { Column } from "../../../../../src/decorator/columns/Column.ts"; +import { PrimaryColumn } from "../../../../../src/decorator/columns/PrimaryColumn.ts"; @Entity() export class PostBigInt { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; - @Column() + @Column({ type: String }) title: string; @Column("bigint", { diff --git a/test/functional/repository/decrement/entity/UserWithEmbededEntity.ts b/test/functional/repository/decrement/entity/UserWithEmbededEntity.ts index bc904767b..e217767cd 100644 --- a/test/functional/repository/decrement/entity/UserWithEmbededEntity.ts +++ b/test/functional/repository/decrement/entity/UserWithEmbededEntity.ts @@ -1,20 +1,20 @@ -import { Column, Entity, PrimaryColumn } from "../../../../../src"; +import { Column, Entity, PrimaryColumn } from "../../../../../src/index.ts"; class FriendStats { - @Column({ default: 0 }) + @Column({ default: 0, type: Number }) count: number; - @Column({ default: 0 }) + @Column({ default: 0, type: Number }) sent: number; - @Column({ default: 0 }) + @Column({ default: 0 , type: Number}) received: number; } @Entity() export class UserWithEmbededEntity { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; @Column(type => FriendStats) diff --git a/test/functional/repository/decrement/repository-decrement.ts b/test/functional/repository/decrement/repository-decrement.ts index d931d918a..b57fa9005 100644 --- a/test/functional/repository/decrement/repository-decrement.ts +++ b/test/functional/repository/decrement/repository-decrement.ts @@ -1,10 +1,11 @@ -import "reflect-metadata"; -import { closeTestingConnections, createTestingConnections, reloadTestingDatabases } from "../../../utils/test-utils"; -import { Connection } from "../../../../src/connection/Connection"; -import { UpdateResult } from "../../../../src"; -import { Post } from "./entity/Post"; -import { PostBigInt } from "./entity/PostBigInt"; -import { UserWithEmbededEntity } from "./entity/UserWithEmbededEntity"; +import { runIfMain } from "../../../deps/mocha.ts"; +import { expect } from "../../../deps/chai.ts"; +import { closeTestingConnections, createTestingConnections, reloadTestingDatabases } from "../../../utils/test-utils.ts"; +import { Connection } from "../../../../src/connection/Connection.ts"; +import { UpdateResult } from "../../../../src/index.ts"; +import { Post } from "./entity/Post.ts"; +import { PostBigInt } from "./entity/PostBigInt.ts"; +import { UserWithEmbededEntity } from "./entity/UserWithEmbededEntity.ts"; describe("repository > decrement method", () => { @@ -111,10 +112,15 @@ describe("repository > decrement method", () => { await connection.manager.save([post1, post2]); // decrement counter of post 1 - await connection - .getRepository(Post) - .decrement({ id: 1 }, "unknownProperty", 1) - .should.be.rejected; + let error; + try { + await connection + .getRepository(Post) + .decrement({ id: 1 }, "unknownProperty", 1); + } catch (err) { + error = err; + } + expect(error).to.be.instanceOf(Error); }))); @@ -132,10 +138,15 @@ describe("repository > decrement method", () => { await connection.manager.save([post1, post2]); // decrement counter of post 1 - await connection - .getRepository(Post) - .decrement({ id: 1 }, "counter", "12abc") - .should.be.rejected; + let error; + try { + await connection + .getRepository(Post) + .decrement({ id: 1 }, "counter", "12abc"); + } catch (err) { + error = err; + } + expect(error).to.be.instanceOf(Error); }))); @@ -214,3 +225,5 @@ describe("repository > decrement method", () => { }); }); + +runIfMain(import.meta); diff --git a/test/functional/repository/delete-by-id-and-ids/entity/Post.ts b/test/functional/repository/delete-by-id-and-ids/entity/Post.ts index b65476c52..f09d1969a 100644 --- a/test/functional/repository/delete-by-id-and-ids/entity/Post.ts +++ b/test/functional/repository/delete-by-id-and-ids/entity/Post.ts @@ -1,6 +1,6 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../src/decorator/columns/Column"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; @Entity() export class Post { @@ -8,7 +8,7 @@ export class Post { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) title: string; -} \ No newline at end of file +} diff --git a/test/functional/repository/delete-by-id-and-ids/repository-remove-by-id-and-ids.ts b/test/functional/repository/delete-by-id-and-ids/repository-remove-by-id-and-ids.ts index 2d27906db..bcba2b068 100644 --- a/test/functional/repository/delete-by-id-and-ids/repository-remove-by-id-and-ids.ts +++ b/test/functional/repository/delete-by-id-and-ids/repository-remove-by-id-and-ids.ts @@ -1,8 +1,9 @@ -import "reflect-metadata"; -import {expect} from "chai"; -import {Connection} from "../../../../src/connection/Connection"; -import {Post} from "./entity/Post"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils"; +import {join as joinPaths} from "../../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../../deps/mocha.ts"; +import {expect} from "../../../deps/chai.ts"; +import {Connection} from "../../../../src/connection/Connection.ts"; +import {Post} from "./entity/Post.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils.ts"; describe("repository > deleteById methods", function() { @@ -11,8 +12,9 @@ describe("repository > deleteById methods", function() { // ------------------------------------------------------------------------- let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], })); beforeEach(() => reloadTestingDatabases(connections)); after(() => closeTestingConnections(connections)); @@ -90,3 +92,5 @@ describe("repository > deleteById methods", function() { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/repository/find-methods/entity/Post.ts b/test/functional/repository/find-methods/entity/Post.ts index a8314f594..4f52e8268 100644 --- a/test/functional/repository/find-methods/entity/Post.ts +++ b/test/functional/repository/find-methods/entity/Post.ts @@ -1,20 +1,20 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn.ts"; @Entity() export class Post { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; - @Column() + @Column({ type: String }) title: string; - - @Column() + + @Column({ type: String }) categoryName: string; - - @Column() + + @Column({ type: Boolean }) isNew: boolean = false; } diff --git a/test/functional/repository/find-methods/repostiory-find-methods.ts b/test/functional/repository/find-methods/repostiory-find-methods.ts index 35c70dd45..3617f51be 100644 --- a/test/functional/repository/find-methods/repostiory-find-methods.ts +++ b/test/functional/repository/find-methods/repostiory-find-methods.ts @@ -1,11 +1,11 @@ -import "reflect-metadata"; -import {expect} from "chai"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils"; -import {Connection} from "../../../../src/connection/Connection"; -import {Post} from "./entity/Post"; -import {User} from "./model/User"; -import {EntityNotFoundError} from "../../../../src/error/EntityNotFoundError"; -import {UserEntity} from "./schema/UserEntity"; +import {runIfMain} from "../../../deps/mocha.ts"; +import {expect} from "../../../deps/chai.ts"; +import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils.ts"; +import {Connection} from "../../../../src/connection/Connection.ts"; +import {Post} from "./entity/Post.ts"; +import {User} from "./model/User.ts"; +import {EntityNotFoundError} from "../../../../src/error/EntityNotFoundError.ts"; +import {UserEntity} from "./schema/UserEntity.ts"; describe("repository > find methods", () => { @@ -125,7 +125,7 @@ describe("repository > find methods", () => { }); count.should.be.equal(5); }))); - + }); describe("find and findAndCount", function() { @@ -574,11 +574,18 @@ describe("repository > find methods", () => { loadedUser!.firstName.should.be.equal("name #0"); loadedUser!.secondName.should.be.equal("Doe"); - await userRepository.findOneOrFail(1, { - where: { - secondName: "Dorian" - } - }).should.eventually.be.rejectedWith(EntityNotFoundError); + let error; + try { + await userRepository.findOneOrFail(1, { + where: { + secondName: "Dorian" + } + }); + } catch (err) { + error = err; + } + + expect(error).to.be.instanceOf(EntityNotFoundError); }))); it("should throw an error if nothing was found", () => Promise.all(connections.map(async connection => { @@ -596,8 +603,16 @@ describe("repository > find methods", () => { const savedUsers = await Promise.all(promises); savedUsers.length.should.be.equal(100); // check if they all are saved - await userRepository.findOneOrFail(100).should.eventually.be.rejectedWith(EntityNotFoundError); + let error; + try { + await userRepository.findOneOrFail(100); + } catch (err) { + error = err; + } + expect(error).to.be.instanceOf(EntityNotFoundError); }))); }); }); + +runIfMain(import.meta); diff --git a/test/functional/repository/find-methods/schema/UserEntity.ts b/test/functional/repository/find-methods/schema/UserEntity.ts index e3a0606cc..5d3e51a1c 100644 --- a/test/functional/repository/find-methods/schema/UserEntity.ts +++ b/test/functional/repository/find-methods/schema/UserEntity.ts @@ -1,4 +1,4 @@ -import {EntitySchema} from "../../../../../src"; +import {EntitySchema} from "../../../../../src/index.ts"; export const UserEntity = new EntitySchema({ "name": "User", diff --git a/test/functional/repository/find-options-locking/entity/PostWithUpdateDate.ts b/test/functional/repository/find-options-locking/entity/PostWithUpdateDate.ts index 9404c5c1f..95c80da0a 100644 --- a/test/functional/repository/find-options-locking/entity/PostWithUpdateDate.ts +++ b/test/functional/repository/find-options-locking/entity/PostWithUpdateDate.ts @@ -1,7 +1,7 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {UpdateDateColumn} from "../../../../../src/decorator/columns/UpdateDateColumn"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {UpdateDateColumn} from "../../../../../src/decorator/columns/UpdateDateColumn.ts"; @Entity() export class PostWithUpdateDate { @@ -9,10 +9,10 @@ export class PostWithUpdateDate { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) title: string; @UpdateDateColumn() updateDate: Date; -} \ No newline at end of file +} diff --git a/test/functional/repository/find-options-locking/entity/PostWithVersion.ts b/test/functional/repository/find-options-locking/entity/PostWithVersion.ts index 2a1a4fe49..387f9c305 100644 --- a/test/functional/repository/find-options-locking/entity/PostWithVersion.ts +++ b/test/functional/repository/find-options-locking/entity/PostWithVersion.ts @@ -1,7 +1,7 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {VersionColumn} from "../../../../../src/decorator/columns/VersionColumn"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {VersionColumn} from "../../../../../src/decorator/columns/VersionColumn.ts"; @Entity() export class PostWithVersion { @@ -9,10 +9,10 @@ export class PostWithVersion { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) title: string; @VersionColumn() version: number; -} \ No newline at end of file +} diff --git a/test/functional/repository/find-options-locking/entity/PostWithVersionAndUpdatedDate.ts b/test/functional/repository/find-options-locking/entity/PostWithVersionAndUpdatedDate.ts index 53e998647..2445657f2 100644 --- a/test/functional/repository/find-options-locking/entity/PostWithVersionAndUpdatedDate.ts +++ b/test/functional/repository/find-options-locking/entity/PostWithVersionAndUpdatedDate.ts @@ -1,8 +1,8 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {VersionColumn} from "../../../../../src/decorator/columns/VersionColumn"; -import {UpdateDateColumn} from "../../../../../src/decorator/columns/UpdateDateColumn"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {VersionColumn} from "../../../../../src/decorator/columns/VersionColumn.ts"; +import {UpdateDateColumn} from "../../../../../src/decorator/columns/UpdateDateColumn.ts"; @Entity("post_with_v_ud") export class PostWithVersionAndUpdatedDate { @@ -10,7 +10,7 @@ export class PostWithVersionAndUpdatedDate { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) title: string; @VersionColumn() @@ -19,4 +19,4 @@ export class PostWithVersionAndUpdatedDate { @UpdateDateColumn() updateDate: Date; -} \ No newline at end of file +} diff --git a/test/functional/repository/find-options-locking/entity/PostWithoutVersionAndUpdateDate.ts b/test/functional/repository/find-options-locking/entity/PostWithoutVersionAndUpdateDate.ts index c38010787..ce7fd99af 100644 --- a/test/functional/repository/find-options-locking/entity/PostWithoutVersionAndUpdateDate.ts +++ b/test/functional/repository/find-options-locking/entity/PostWithoutVersionAndUpdateDate.ts @@ -1,6 +1,6 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../src/decorator/columns/Column"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; @Entity("post_without_v_ud") export class PostWithoutVersionAndUpdateDate { @@ -8,7 +8,7 @@ export class PostWithoutVersionAndUpdateDate { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) title: string; -} \ No newline at end of file +} diff --git a/test/functional/repository/find-options-locking/find-options-locking.ts b/test/functional/repository/find-options-locking/find-options-locking.ts index 876c67ff2..9e71a2621 100644 --- a/test/functional/repository/find-options-locking/find-options-locking.ts +++ b/test/functional/repository/find-options-locking/find-options-locking.ts @@ -1,71 +1,80 @@ -import "reflect-metadata"; -import {CockroachDriver} from "../../../../src/driver/cockroachdb/CockroachDriver"; -import {SapDriver} from "../../../../src/driver/sap/SapDriver"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils"; -import {Connection} from "../../../../src"; -import {PostWithVersion} from "./entity/PostWithVersion"; -import {expect} from "chai"; -import {PostWithoutVersionAndUpdateDate} from "./entity/PostWithoutVersionAndUpdateDate"; -import {PostWithUpdateDate} from "./entity/PostWithUpdateDate"; -import {PostWithVersionAndUpdatedDate} from "./entity/PostWithVersionAndUpdatedDate"; -import {OptimisticLockVersionMismatchError} from "../../../../src/error/OptimisticLockVersionMismatchError"; -import {OptimisticLockCanNotBeUsedError} from "../../../../src/error/OptimisticLockCanNotBeUsedError"; -import {NoVersionOrUpdateDateColumnError} from "../../../../src/error/NoVersionOrUpdateDateColumnError"; -import {PessimisticLockTransactionRequiredError} from "../../../../src/error/PessimisticLockTransactionRequiredError"; -import {MysqlDriver} from "../../../../src/driver/mysql/MysqlDriver"; -import {PostgresDriver} from "../../../../src/driver/postgres/PostgresDriver"; -import {SqlServerDriver} from "../../../../src/driver/sqlserver/SqlServerDriver"; -import {AbstractSqliteDriver} from "../../../../src/driver/sqlite-abstract/AbstractSqliteDriver"; -import {OracleDriver} from "../../../../src/driver/oracle/OracleDriver"; -import {LockNotSupportedOnGivenDriverError} from "../../../../src/error/LockNotSupportedOnGivenDriverError"; +import {join as joinPaths} from "../../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../../deps/mocha.ts"; +import {expect} from "../../../deps/chai.ts"; +// TODO(uki00a) uncomment this when CockroachDriver is implemented. +// import {CockroachDriver} from "../../../../src/driver/cockroachdb/CockroachDriver.ts"; +import {SapDriver} from "../../../../src/driver/sap/SapDriver.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases, allSettled} from "../../../utils/test-utils.ts"; +import {Connection} from "../../../../src/index.ts"; +import {PostWithVersion} from "./entity/PostWithVersion.ts"; +import {PostWithoutVersionAndUpdateDate} from "./entity/PostWithoutVersionAndUpdateDate.ts"; +import {PostWithUpdateDate} from "./entity/PostWithUpdateDate.ts"; +import {PostWithVersionAndUpdatedDate} from "./entity/PostWithVersionAndUpdatedDate.ts"; +import {OptimisticLockVersionMismatchError} from "../../../../src/error/OptimisticLockVersionMismatchError.ts"; +import {OptimisticLockCanNotBeUsedError} from "../../../../src/error/OptimisticLockCanNotBeUsedError.ts"; +import {NoVersionOrUpdateDateColumnError} from "../../../../src/error/NoVersionOrUpdateDateColumnError.ts"; +import {PessimisticLockTransactionRequiredError} from "../../../../src/error/PessimisticLockTransactionRequiredError.ts"; +import {MysqlDriver} from "../../../../src/driver/mysql/MysqlDriver.ts"; +// TODO(uki00a) uncomment this when PostgresDriver is implemented. +// import {PostgresDriver} from "../../../../src/driver/postgres/PostgresDriver.ts"; +import {SqlServerDriver} from "../../../../src/driver/sqlserver/SqlServerDriver.ts"; +import {AbstractSqliteDriver} from "../../../../src/driver/sqlite-abstract/AbstractSqliteDriver.ts"; +import {OracleDriver} from "../../../../src/driver/oracle/OracleDriver.ts"; +import {LockNotSupportedOnGivenDriverError} from "../../../../src/error/LockNotSupportedOnGivenDriverError.ts"; describe("repository > find options > locking", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], + enabledDrivers: ["postgres", "mysql", "mariadb", "mssql", "oracle", "mongodb"] // TODO(uki00a) Remove `enabledDrivers` when deno-sqlite supports `datetime('now')`. })); beforeEach(() => reloadTestingDatabases(connections)); after(() => closeTestingConnections(connections)); it("should throw error if pessimistic lock used without transaction", () => Promise.all(connections.map(async connection => { - if (connection.driver instanceof AbstractSqliteDriver || connection.driver instanceof CockroachDriver || connection.driver instanceof SapDriver) + // TODO(uki00a) uncomment this when CockroachDriver is implemented. + if (connection.driver instanceof AbstractSqliteDriver || /*connection.driver instanceof CockroachDriver ||*/ connection.driver instanceof SapDriver) return; - return Promise.all([ + const results = await allSettled([ connection .getRepository(PostWithVersion) - .findOne(1, { lock: { mode: "pessimistic_read" } }) - .should.be.rejectedWith(PessimisticLockTransactionRequiredError), + .findOne(1, { lock: { mode: "pessimistic_read" } }), connection .getRepository(PostWithVersion) .findOne(1, { lock: { mode: "pessimistic_write" } }) - .should.be.rejectedWith(PessimisticLockTransactionRequiredError), ]); + + expect(results[0].status).to.equal('rejected'); + expect(results[0].reason).to.be.instanceOf(PessimisticLockTransactionRequiredError); + expect(results[1].status).to.equal('rejected'); + expect(results[1].status).to.equal(PessimisticLockTransactionRequiredError); }))); it("should not throw error if pessimistic lock used with transaction", () => Promise.all(connections.map(async connection => { - if (connection.driver instanceof AbstractSqliteDriver || connection.driver instanceof CockroachDriver || connection.driver instanceof SapDriver) + // TODO(uki00a) uncomment this when CockroachDriver is implemented. + if (connection.driver instanceof AbstractSqliteDriver || /*connection.driver instanceof CockroachDriver ||*/ connection.driver instanceof SapDriver) return; - return connection.manager.transaction(entityManager => { - return Promise.all([ + return connection.manager.transaction(async entityManager => { + await Promise.all([ entityManager .getRepository(PostWithVersion) - .findOne(1, { lock: { mode: "pessimistic_read" } }) - .should.not.be.rejected, + .findOne(1, { lock: { mode: "pessimistic_read" } }), entityManager .getRepository(PostWithVersion) .findOne(1, { lock: { mode: "pessimistic_write" } }) - .should.not.be.rejected ]); }); }))); it("should attach pessimistic read lock statement on query if locking enabled", () => Promise.all(connections.map(async connection => { - if (connection.driver instanceof AbstractSqliteDriver || connection.driver instanceof CockroachDriver || connection.driver instanceof SapDriver) + // TODO(uki00a) uncomment this when CockroachDriver is implemented. + if (connection.driver instanceof AbstractSqliteDriver || /*connection.driver instanceof CockroachDriver ||*/ connection.driver instanceof SapDriver) return; const executedSql: string[] = []; @@ -85,7 +94,7 @@ describe("repository > find options > locking", () => { if (connection.driver instanceof MysqlDriver) { expect(executedSql[0].indexOf("LOCK IN SHARE MODE") !== -1).to.be.true; - } else if (connection.driver instanceof PostgresDriver) { + } else if (false/*connection.driver instanceof PostgresDriver*/) { // TODO(uki00a) uncomment this when PostgresDriver is implemented. expect(executedSql[0].indexOf("FOR SHARE") !== -1).to.be.true; } else if (connection.driver instanceof OracleDriver) { @@ -98,7 +107,8 @@ describe("repository > find options > locking", () => { }))); it("should attach pessimistic write lock statement on query if locking enabled", () => Promise.all(connections.map(async connection => { - if (connection.driver instanceof AbstractSqliteDriver || connection.driver instanceof CockroachDriver || connection.driver instanceof SapDriver) + // TODO(uki00a) uncomment this when CockroachDriver is implemented. + if (connection.driver instanceof AbstractSqliteDriver || /*connection.driver instanceof CockroachDriver ||*/ connection.driver instanceof SapDriver) return; const executedSql: string[] = []; @@ -115,7 +125,7 @@ describe("repository > find options > locking", () => { .findOne(1, {lock: {mode: "pessimistic_write"}}); }); - if (connection.driver instanceof MysqlDriver || connection.driver instanceof PostgresDriver || connection.driver instanceof OracleDriver) { + if (connection.driver instanceof MysqlDriver || false/*connection.driver instanceof PostgresDriver*/ || connection.driver instanceof OracleDriver) { // TODO(uki00a) uncomment this when PostgresDriver is implemented. expect(executedSql[0].indexOf("FOR UPDATE") !== -1).to.be.true; } else if (connection.driver instanceof SqlServerDriver) { @@ -146,17 +156,21 @@ describe("repository > find options > locking", () => { }))); it("should throw error if optimistic lock used with `find` method", () => Promise.all(connections.map(async connection => { - return connection - .getRepository(PostWithVersion) - .find({lock: {mode: "optimistic", version: 1}}) - .should.be.rejectedWith(OptimisticLockCanNotBeUsedError); + let error; + try { + await connection + .getRepository(PostWithVersion) + .find({lock: {mode: "optimistic", version: 1}}); + } catch (err) { + error = err; + } + expect(error).to.be.instanceOf(OptimisticLockCanNotBeUsedError); }))); it("should not throw error if optimistic lock used with `findOne` method", () => Promise.all(connections.map(async connection => { - return connection + await connection .getRepository(PostWithVersion) - .findOne(1, {lock: {mode: "optimistic", version: 1}}) - .should.not.be.rejected; + .findOne(1, {lock: {mode: "optimistic", version: 1}}); }))); it("should throw error if entity does not have version and update date columns", () => Promise.all(connections.map(async connection => { @@ -165,10 +179,15 @@ describe("repository > find options > locking", () => { post.title = "New post"; await connection.manager.save(post); - return connection - .getRepository(PostWithoutVersionAndUpdateDate) - .findOne(1, {lock: {mode: "optimistic", version: 1}}) - .should.be.rejectedWith(NoVersionOrUpdateDateColumnError); + let error; + try { + await connection + .getRepository(PostWithoutVersionAndUpdateDate) + .findOne(1, {lock: {mode: "optimistic", version: 1}}); + } catch (err) { + error = err; + } + expect(error).to.be.instanceOf(NoVersionOrUpdateDateColumnError); }))); it("should throw error if actual version does not equal expected version", () => Promise.all(connections.map(async connection => { @@ -177,10 +196,15 @@ describe("repository > find options > locking", () => { post.title = "New post"; await connection.manager.save(post); - return connection - .getRepository(PostWithVersion) - .findOne(1, {lock: {mode: "optimistic", version: 2}}) - .should.be.rejectedWith(OptimisticLockVersionMismatchError); + let error; + try { + await connection + .getRepository(PostWithVersion) + .findOne(1, {lock: {mode: "optimistic", version: 2}}); + } catch (err) { + error = err; + } + expect(error).to.be.instanceOf(OptimisticLockVersionMismatchError); }))); it("should not throw error if actual version and expected versions are equal", () => Promise.all(connections.map(async connection => { @@ -189,10 +213,9 @@ describe("repository > find options > locking", () => { post.title = "New post"; await connection.manager.save(post); - return connection + await connection .getRepository(PostWithVersion) - .findOne(1, {lock: {mode: "optimistic", version: 1}}) - .should.not.be.rejected; + .findOne(1, {lock: {mode: "optimistic", version: 1}}); }))); it("should throw error if actual updated date does not equal expected updated date", () => Promise.all(connections.map(async connection => { @@ -205,10 +228,15 @@ describe("repository > find options > locking", () => { post.title = "New post"; await connection.manager.save(post); - return connection - .getRepository(PostWithUpdateDate) - .findOne(1, {lock: {mode: "optimistic", version: new Date(2017, 1, 1)}}) - .should.be.rejectedWith(OptimisticLockVersionMismatchError); + let error; + try { + await connection + .getRepository(PostWithUpdateDate) + .findOne(1, {lock: {mode: "optimistic", version: new Date(2017, 1, 1)}}); + } catch (err) { + error = err; + } + expect(error).to.be.instanceOf(OptimisticLockVersionMismatchError); }))); it("should not throw error if actual updated date and expected updated date are equal", () => Promise.all(connections.map(async connection => { @@ -221,10 +249,9 @@ describe("repository > find options > locking", () => { post.title = "New post"; await connection.manager.save(post); - return connection + await connection .getRepository(PostWithUpdateDate) - .findOne(1, {lock: {mode: "optimistic", version: post.updateDate}}) - .should.not.be.rejected; + .findOne(1, {lock: {mode: "optimistic", version: post.updateDate}}); }))); it("should work if both version and update date columns applied", () => Promise.all(connections.map(async connection => { @@ -240,32 +267,34 @@ describe("repository > find options > locking", () => { return Promise.all([ connection .getRepository(PostWithVersionAndUpdatedDate) - .findOne(1, {lock: {mode: "optimistic", version: post.updateDate}}) - .should.not.be.rejected, + .findOne(1, {lock: {mode: "optimistic", version: post.updateDate}}), connection .getRepository(PostWithVersionAndUpdatedDate) - .findOne(1, {lock: {mode: "optimistic", version: 1}}) - .should.not.be.rejected, + .findOne(1, {lock: {mode: "optimistic", version: 1}}), ]); }))); it("should throw error if pessimistic locking not supported by given driver", () => Promise.all(connections.map(async connection => { - if (connection.driver instanceof AbstractSqliteDriver || connection.driver instanceof CockroachDriver || connection.driver instanceof SapDriver) - return connection.manager.transaction(entityManager => { - return Promise.all([ + if (connection.driver instanceof AbstractSqliteDriver || /*connection.driver instanceof CockroachDriver ||*/ connection.driver instanceof SapDriver) // TODO(uki00a) uncomment this when PostgresDriver is implemented. + return connection.manager.transaction(async entityManager => { + const results = await allSettled([ entityManager .getRepository(PostWithVersion) - .findOne(1, { lock: { mode: "pessimistic_read" } }) - .should.be.rejectedWith(LockNotSupportedOnGivenDriverError), + .findOne(1, { lock: { mode: "pessimistic_read" } }), entityManager .getRepository(PostWithVersion) - .findOne(1, { lock: { mode: "pessimistic_write" } }) - .should.be.rejectedWith(LockNotSupportedOnGivenDriverError), + .findOne(1, { lock: { mode: "pessimistic_write" } }), ]); + expect(results[0].status).to.equal('rejected'); + expect(results[0].reason).to.be.instanceOf(LockNotSupportedOnGivenDriverError); + expect(results[1].status).to.equal('rejected'); + expect(results[1].reason).to.be.instanceOf(LockNotSupportedOnGivenDriverError); }); return; }))); }); + +runIfMain(import.meta); diff --git a/test/functional/repository/find-options-operators/entity/PersonAR.ts b/test/functional/repository/find-options-operators/entity/PersonAR.ts index 764b1bc74..18b959786 100644 --- a/test/functional/repository/find-options-operators/entity/PersonAR.ts +++ b/test/functional/repository/find-options-operators/entity/PersonAR.ts @@ -1,7 +1,7 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {BaseEntity} from "../../../../../src"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {BaseEntity} from "../../../../../src/index.ts"; @Entity() export class PersonAR extends BaseEntity { @@ -9,7 +9,7 @@ export class PersonAR extends BaseEntity { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) name: string; } diff --git a/test/functional/repository/find-options-operators/entity/Post.ts b/test/functional/repository/find-options-operators/entity/Post.ts index 509eca92d..690b26b78 100644 --- a/test/functional/repository/find-options-operators/entity/Post.ts +++ b/test/functional/repository/find-options-operators/entity/Post.ts @@ -1,4 +1,4 @@ -import {Column, Entity, PrimaryGeneratedColumn} from "../../../../../src"; +import {Column, Entity, PrimaryGeneratedColumn} from "../../../../../src/index.ts"; @Entity() export class Post { @@ -6,10 +6,10 @@ export class Post { @PrimaryGeneratedColumn() id: number; - @Column({ nullable: true }) + @Column({ nullable: true, type: String }) title: string; - @Column() + @Column({ type: Number }) likes: number; -} \ No newline at end of file +} diff --git a/test/functional/repository/find-options-operators/repository-find-operators.ts b/test/functional/repository/find-options-operators/repository-find-operators.ts index 4434721fb..bb73c97fa 100644 --- a/test/functional/repository/find-options-operators/repository-find-operators.ts +++ b/test/functional/repository/find-options-operators/repository-find-operators.ts @@ -1,5 +1,7 @@ -import "reflect-metadata"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils"; +import {join as joinPaths} from "../../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../../deps/mocha.ts"; +import {expect} from "../../../deps/chai.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils.ts"; import { Any, Between, @@ -14,18 +16,19 @@ import { MoreThanOrEqual, Not, PromiseUtils -} from "../../../../src"; -import {Post} from "./entity/Post"; -import {PostgresDriver} from "../../../../src/driver/postgres/PostgresDriver"; -import {Raw} from "../../../../src/find-options/operator/Raw"; -import {PersonAR} from "./entity/PersonAR"; -import {expect} from "chai"; +} from "../../../../src/index.ts"; +import {Post} from "./entity/Post.ts"; +// TODO(uki00a) uncomment this when PostgresDriver is implemented. +// import {PostgresDriver} from "../../../../src/driver/postgres/PostgresDriver.ts"; +import {Raw} from "../../../../src/find-options/operator/Raw.ts"; +import {PersonAR} from "./entity/PersonAR.ts"; describe("repository > find options > operators", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], })); beforeEach(() => reloadTestingDatabases(connections)); after(() => closeTestingConnections(connections)); @@ -412,7 +415,7 @@ describe("repository > find options > operators", () => { }))); it("any", () => Promise.all(connections.map(async connection => { - if (!(connection.driver instanceof PostgresDriver)) + if (true/*!(connection.driver instanceof PostgresDriver)*/) // TODO(uki00a) uncomment this when PostgresDriver is implemented. return; // insert some fake data @@ -434,7 +437,7 @@ describe("repository > find options > operators", () => { }))); it("not(any)", () => Promise.all(connections.map(async connection => { - if (!(connection.driver instanceof PostgresDriver)) + if (true/*!(connection.driver instanceof PostgresDriver)*/) // TODO(uki00a) uncomment this when PostgresDriver is implemented. return; // insert some fake data @@ -550,3 +553,5 @@ describe("repository > find options > operators", () => { })); }); + +runIfMain(import.meta); diff --git a/test/functional/repository/find-options-relations/entity/Category.ts b/test/functional/repository/find-options-relations/entity/Category.ts index 0095127bd..fdbf6b325 100644 --- a/test/functional/repository/find-options-relations/entity/Category.ts +++ b/test/functional/repository/find-options-relations/entity/Category.ts @@ -1,6 +1,6 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../src/decorator/columns/Column"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; @Entity() export class Category { @@ -8,7 +8,7 @@ export class Category { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) name: string; -} \ No newline at end of file +} diff --git a/test/functional/repository/find-options-relations/entity/Counters.ts b/test/functional/repository/find-options-relations/entity/Counters.ts index 6aecdc270..9d98ac4eb 100644 --- a/test/functional/repository/find-options-relations/entity/Counters.ts +++ b/test/functional/repository/find-options-relations/entity/Counters.ts @@ -1,16 +1,16 @@ -import {Column} from "../../../../../src/decorator/columns/Column"; -import {ManyToOne} from "../../../../../src/decorator/relations/ManyToOne"; -import {User} from "./User"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {ManyToOne} from "../../../../../src/decorator/relations/ManyToOne.ts"; +import {User} from "./User.ts"; export class Counters { - @Column() + @Column({ type: Number }) stars: number; - @Column() + @Column({ type: Number }) commentCount: number; @ManyToOne(type => User) author: User; -} \ No newline at end of file +} diff --git a/test/functional/repository/find-options-relations/entity/Photo.ts b/test/functional/repository/find-options-relations/entity/Photo.ts index 10fb13cfa..5b3958edf 100644 --- a/test/functional/repository/find-options-relations/entity/Photo.ts +++ b/test/functional/repository/find-options-relations/entity/Photo.ts @@ -1,10 +1,10 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../src/index"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {ManyToOne} from "../../../../../src/decorator/relations/ManyToOne"; -import {Post} from "./Post"; -import {Counters} from "./Counters"; -import {User} from "./User"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/index.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {ManyToOne} from "../../../../../src/decorator/relations/ManyToOne.ts"; +import {Post} from "./Post.ts"; +import {Counters} from "./Counters.ts"; +import {User} from "./User.ts"; @Entity() export class Photo { @@ -12,7 +12,7 @@ export class Photo { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) filename: string; @ManyToOne(type => User) @@ -24,4 +24,4 @@ export class Photo { @Column(type => Counters) counters: Counters; -} \ No newline at end of file +} diff --git a/test/functional/repository/find-options-relations/entity/Post.ts b/test/functional/repository/find-options-relations/entity/Post.ts index 1ac237d9b..ea31efe3d 100644 --- a/test/functional/repository/find-options-relations/entity/Post.ts +++ b/test/functional/repository/find-options-relations/entity/Post.ts @@ -1,14 +1,14 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {ManyToMany} from "../../../../../src/decorator/relations/ManyToMany"; -import {JoinTable} from "../../../../../src/decorator/relations/JoinTable"; -import {OneToMany} from "../../../../../src/decorator/relations/OneToMany"; -import {Category} from "./Category"; -import {User} from "./User"; -import {Photo} from "./Photo"; -import {ManyToOne} from "../../../../../src/decorator/relations/ManyToOne"; -import {Counters} from "./Counters"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {ManyToMany} from "../../../../../src/decorator/relations/ManyToMany.ts"; +import {JoinTable} from "../../../../../src/decorator/relations/JoinTable.ts"; +import {OneToMany} from "../../../../../src/decorator/relations/OneToMany.ts"; +import {Category} from "./Category.ts"; +import {User} from "./User.ts"; +import {Photo} from "./Photo.ts"; +import {ManyToOne} from "../../../../../src/decorator/relations/ManyToOne.ts"; +import {Counters} from "./Counters.ts"; @Entity() export class Post { @@ -16,7 +16,7 @@ export class Post { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) title: string; @OneToMany(type => Photo, photo => photo.post) @@ -32,4 +32,4 @@ export class Post { @Column(type => Counters) counters: Counters; -} \ No newline at end of file +} diff --git a/test/functional/repository/find-options-relations/entity/User.ts b/test/functional/repository/find-options-relations/entity/User.ts index 0e019207a..6b1da56d2 100644 --- a/test/functional/repository/find-options-relations/entity/User.ts +++ b/test/functional/repository/find-options-relations/entity/User.ts @@ -1,6 +1,6 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../src/decorator/columns/Column"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; @Entity() export class User { @@ -8,7 +8,7 @@ export class User { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) name: string; -} \ No newline at end of file +} diff --git a/test/functional/repository/find-options-relations/repository-find-options-relations.ts b/test/functional/repository/find-options-relations/repository-find-options-relations.ts index 82913eed4..67e58f569 100644 --- a/test/functional/repository/find-options-relations/repository-find-options-relations.ts +++ b/test/functional/repository/find-options-relations/repository-find-options-relations.ts @@ -1,12 +1,14 @@ -import "reflect-metadata"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils"; -import {Connection} from "../../../../src/connection/Connection"; -import {User} from "./entity/User"; -import {Category} from "./entity/Category"; -import {Post} from "./entity/Post"; -import {Photo} from "./entity/Photo"; -import {Counters} from "./entity/Counters"; -import {FindRelationsNotFoundError} from "../../../../src/error/FindRelationsNotFoundError"; +import {join as joinPaths} from "../../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../../deps/mocha.ts"; +import {expect} from "../../../deps/chai.ts"; +import {closeTestingConnections, createTestingConnections, reloadTestingDatabases, getDirnameOfCurrentModule} from "../../../utils/test-utils.ts"; +import {Connection} from "../../../../src/connection/Connection.ts"; +import {User} from "./entity/User.ts"; +import {Category} from "./entity/Category.ts"; +import {Post} from "./entity/Post.ts"; +import {Photo} from "./entity/Photo.ts"; +import {Counters} from "./entity/Counters.ts"; +import {FindRelationsNotFoundError} from "../../../../src/error/FindRelationsNotFoundError.ts"; describe("repository > find options > relations", () => { @@ -15,8 +17,9 @@ describe("repository > find options > relations", () => { // ------------------------------------------------------------------------- let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], })); beforeEach(() => reloadTestingDatabases(connections)); after(() => closeTestingConnections(connections)); @@ -322,27 +325,65 @@ describe("repository > find options > relations", () => { }))); it("should throw error if specified relations were not found case 1", () => Promise.all(connections.map(async connection => { - await connection.getRepository(Post).findOne(1, { relations: ["photos2"] }).should.eventually.be.rejectedWith(FindRelationsNotFoundError); + let error; + try { + await connection.getRepository(Post).findOne(1, { relations: ["photos2"] }); + } catch (err) { + error = err; + } + expect(error).to.be.instanceOf(FindRelationsNotFoundError); }))); it("should throw error if specified relations were not found case 2", () => Promise.all(connections.map(async connection => { - await connection.getRepository(Post).findOne(1, { relations: ["photos", "counters.author2"] }).should.eventually.be.rejectedWith(FindRelationsNotFoundError); + let error; + try { + await connection.getRepository(Post).findOne(1, { relations: ["photos", "counters.author2"] }); + } catch (err) { + error = err; + } + expect(error).to.be.instanceOf(FindRelationsNotFoundError); }))); it("should throw error if specified relations were not found case 3", () => Promise.all(connections.map(async connection => { - await connection.getRepository(Post).findOne(1, { relations: ["photos", "counters2.author"] }).should.eventually.be.rejectedWith(FindRelationsNotFoundError); + let error; + try { + await connection.getRepository(Post).findOne(1, { relations: ["photos", "counters2.author"] }); + } catch (err) { + error = err; + } + expect(error).to.be.instanceOf(FindRelationsNotFoundError); }))); it("should throw error if specified relations were not found case 4", () => Promise.all(connections.map(async connection => { - await connection.getRepository(Post).findOne(1, { relations: ["photos", "photos.user.haha"] }).should.eventually.be.rejectedWith(FindRelationsNotFoundError); + let error; + try { + await connection.getRepository(Post).findOne(1, { relations: ["photos", "photos.user.haha"] }); + } catch (err) { + error = err; + } + expect(error).to.be.instanceOf(FindRelationsNotFoundError); }))); it("should throw error if specified relations were not found case 5", () => Promise.all(connections.map(async connection => { - await connection.getRepository(Post).findOne(1, { relations: ["questions"] }).should.eventually.be.rejectedWith(FindRelationsNotFoundError); + let error; + try { + await connection.getRepository(Post).findOne(1, { relations: ["questions"] }); + } catch (err) { + error = err; + } + expect(error).to.be.instanceOf(FindRelationsNotFoundError); }))); it("should throw error if specified relations were not found case 6", () => Promise.all(connections.map(async connection => { - await connection.getRepository(Post).findOne(1, { relations: ["questions.haha"] }).should.eventually.be.rejectedWith(FindRelationsNotFoundError); + let error; + try { + await connection.getRepository(Post).findOne(1, { relations: ["questions.haha"] }); + } catch (err) { + error = err; + } + expect(error).to.be.instanceOf(FindRelationsNotFoundError); }))); }); + +runIfMain(import.meta); diff --git a/test/functional/repository/find-options/entity/Category.ts b/test/functional/repository/find-options/entity/Category.ts index 0095127bd..fdbf6b325 100644 --- a/test/functional/repository/find-options/entity/Category.ts +++ b/test/functional/repository/find-options/entity/Category.ts @@ -1,6 +1,6 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../src/decorator/columns/Column"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; @Entity() export class Category { @@ -8,7 +8,7 @@ export class Category { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) name: string; -} \ No newline at end of file +} diff --git a/test/functional/repository/find-options/entity/Photo.ts b/test/functional/repository/find-options/entity/Photo.ts index f4e200a66..ec6c29ca0 100644 --- a/test/functional/repository/find-options/entity/Photo.ts +++ b/test/functional/repository/find-options/entity/Photo.ts @@ -1,11 +1,11 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; import { PrimaryGeneratedColumn, ManyToMany, JoinTable -} from "../../../../../src/index"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {Category} from "./Category"; +} from "../../../../../src/index.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {Category} from "./Category.ts"; @Entity() export class Photo { @@ -14,24 +14,25 @@ export class Photo { id: number; @Column({ + type: String, length: 500 }) name: string; - @Column() + @Column({ type: String }) description: string; - @Column() + @Column({ type: String }) filename: string; - @Column() + @Column({ type: Number }) views: number; - @Column() + @Column({ type: Boolean }) isPublished: boolean; @ManyToMany(type => Category) @JoinTable() categories: Category[]; -} \ No newline at end of file +} diff --git a/test/functional/repository/find-options/entity/Post.ts b/test/functional/repository/find-options/entity/Post.ts index 265fa0352..6d02ad50e 100644 --- a/test/functional/repository/find-options/entity/Post.ts +++ b/test/functional/repository/find-options/entity/Post.ts @@ -1,11 +1,11 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {ManyToMany} from "../../../../../src/decorator/relations/ManyToMany"; -import {Category} from "./Category"; -import {ManyToOne} from "../../../../../src/decorator/relations/ManyToOne"; -import {User} from "./User"; -import {JoinTable} from "../../../../../src/decorator/relations/JoinTable"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {ManyToMany} from "../../../../../src/decorator/relations/ManyToMany.ts"; +import {Category} from "./Category.ts"; +import {ManyToOne} from "../../../../../src/decorator/relations/ManyToOne.ts"; +import {User} from "./User.ts"; +import {JoinTable} from "../../../../../src/decorator/relations/JoinTable.ts"; @Entity() export class Post { @@ -13,7 +13,7 @@ export class Post { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) title: string; @ManyToOne(type => User) @@ -23,4 +23,4 @@ export class Post { @JoinTable() categories: Category[]; -} \ No newline at end of file +} diff --git a/test/functional/repository/find-options/entity/User.ts b/test/functional/repository/find-options/entity/User.ts index 0e019207a..6b1da56d2 100644 --- a/test/functional/repository/find-options/entity/User.ts +++ b/test/functional/repository/find-options/entity/User.ts @@ -1,6 +1,6 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../src/decorator/columns/Column"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; @Entity() export class User { @@ -8,7 +8,7 @@ export class User { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) name: string; -} \ No newline at end of file +} diff --git a/test/functional/repository/find-options/repository-find-options.ts b/test/functional/repository/find-options/repository-find-options.ts index 42bffc16e..19bd1f741 100644 --- a/test/functional/repository/find-options/repository-find-options.ts +++ b/test/functional/repository/find-options/repository-find-options.ts @@ -1,17 +1,19 @@ -import "reflect-metadata"; -import {expect} from "chai"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases, sleep} from "../../../utils/test-utils"; -import {Connection} from "../../../../src/connection/Connection"; -import {User} from "./entity/User"; -import {Category} from "./entity/Category"; -import {Post} from "./entity/Post"; -import {Photo} from "./entity/Photo"; +import {join as joinPaths} from "../../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../../deps/mocha.ts"; +import {expect} from "../../../deps/chai.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases, sleep} from "../../../utils/test-utils.ts"; +import {Connection} from "../../../../src/connection/Connection.ts"; +import {User} from "./entity/User.ts"; +import {Category} from "./entity/Category.ts"; +import {Post} from "./entity/Post.ts"; +import {Photo} from "./entity/Photo.ts"; describe("repository > find options", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], enabledDrivers: ["sqlite"] })); beforeEach(() => reloadTestingDatabases(connections)); @@ -166,8 +168,9 @@ describe("repository > find options", () => { describe("repository > find options > cache", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], cache: true })); beforeEach(() => reloadTestingDatabases(connections)); @@ -219,3 +222,5 @@ describe("repository > find options > cache", () => { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/repository/increment/entity/Post.ts b/test/functional/repository/increment/entity/Post.ts index f1f3d94ae..7fc405ae4 100644 --- a/test/functional/repository/increment/entity/Post.ts +++ b/test/functional/repository/increment/entity/Post.ts @@ -1,6 +1,6 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {PrimaryColumn} from "../../../../../src/decorator/columns/PrimaryColumn.ts"; @Entity() export class Post { @@ -8,10 +8,10 @@ export class Post { @PrimaryColumn("int") id: number; - @Column() + @Column({ type: String }) title: string; - @Column() + @Column({ type: Number }) counter: number; -} \ No newline at end of file +} diff --git a/test/functional/repository/increment/entity/PostBigInt.ts b/test/functional/repository/increment/entity/PostBigInt.ts index 1f9ea38ad..4abde8c83 100644 --- a/test/functional/repository/increment/entity/PostBigInt.ts +++ b/test/functional/repository/increment/entity/PostBigInt.ts @@ -1,14 +1,14 @@ -import { Entity } from "../../../../../src/decorator/entity/Entity"; -import { Column } from "../../../../../src/decorator/columns/Column"; -import { PrimaryColumn } from "../../../../../src/decorator/columns/PrimaryColumn"; +import { Entity } from "../../../../../src/decorator/entity/Entity.ts"; +import { Column } from "../../../../../src/decorator/columns/Column.ts"; +import { PrimaryColumn } from "../../../../../src/decorator/columns/PrimaryColumn.ts"; @Entity() export class PostBigInt { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; - @Column() + @Column({ type: String }) title: string; @Column("bigint", { diff --git a/test/functional/repository/increment/entity/UserWithEmbededEntity.ts b/test/functional/repository/increment/entity/UserWithEmbededEntity.ts index bc904767b..7602f05bf 100644 --- a/test/functional/repository/increment/entity/UserWithEmbededEntity.ts +++ b/test/functional/repository/increment/entity/UserWithEmbededEntity.ts @@ -1,20 +1,20 @@ -import { Column, Entity, PrimaryColumn } from "../../../../../src"; +import { Column, Entity, PrimaryColumn } from "../../../../../src/index.ts"; class FriendStats { - @Column({ default: 0 }) + @Column({ default: 0, type: Number }) count: number; - @Column({ default: 0 }) + @Column({ default: 0, type: Number }) sent: number; - @Column({ default: 0 }) + @Column({ default: 0, type: Number }) received: number; } @Entity() export class UserWithEmbededEntity { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; @Column(type => FriendStats) diff --git a/test/functional/repository/increment/repository-increment.ts b/test/functional/repository/increment/repository-increment.ts index 95a799e74..d6095ddef 100644 --- a/test/functional/repository/increment/repository-increment.ts +++ b/test/functional/repository/increment/repository-increment.ts @@ -1,10 +1,11 @@ -import "reflect-metadata"; -import { closeTestingConnections, createTestingConnections, reloadTestingDatabases } from "../../../utils/test-utils"; -import { Connection } from "../../../../src/connection/Connection"; -import { UpdateResult } from "../../../../src"; -import { Post } from "./entity/Post"; -import { PostBigInt } from "./entity/PostBigInt"; -import { UserWithEmbededEntity } from "./entity/UserWithEmbededEntity"; +import {runIfMain} from "../../../deps/mocha.ts"; +import {expect} from "../../../deps/chai.ts"; +import { closeTestingConnections, createTestingConnections, reloadTestingDatabases } from "../../../utils/test-utils.ts"; +import { Connection } from "../../../../src/connection/Connection.ts"; +import { UpdateResult } from "../../../../src/index.ts"; +import { Post } from "./entity/Post.ts"; +import { PostBigInt } from "./entity/PostBigInt.ts"; +import { UserWithEmbededEntity } from "./entity/UserWithEmbededEntity.ts"; describe("repository > increment method", () => { @@ -111,10 +112,15 @@ describe("repository > increment method", () => { await connection.manager.save([post1, post2]); // increment counter of post 1 - await connection - .getRepository(Post) - .increment({ id: 1 }, "unknownProperty", 1) - .should.be.rejected; + let error; + try { + await connection + .getRepository(Post) + .increment({ id: 1 }, "unknownProperty", 1); + } catch (err) { + error = err; + } + expect(error).to.be.instanceOf(Error); }))); @@ -132,11 +138,15 @@ describe("repository > increment method", () => { await connection.manager.save([post1, post2]); // increment counter of post 1 - await connection - .getRepository(Post) - .increment({ id: 1 }, "counter", "12abc") - .should.be.rejected; - + let error; + try { + await connection + .getRepository(Post) + .increment({ id: 1 }, "counter", "12abc"); + } catch (err) { + error = err; + } + expect(error).to.be.instanceOf(Error); }))); }); @@ -214,3 +224,5 @@ describe("repository > increment method", () => { }); }); + +runIfMain(import.meta); diff --git a/test/functional/repository/set-add-remove-relations/entity/Category.ts b/test/functional/repository/set-add-remove-relations/entity/Category.ts index fbe239011..adf1456df 100644 --- a/test/functional/repository/set-add-remove-relations/entity/Category.ts +++ b/test/functional/repository/set-add-remove-relations/entity/Category.ts @@ -1,9 +1,9 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Post} from "./Post"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {ManyToOne} from "../../../../../src/decorator/relations/ManyToOne"; -import {ManyToMany} from "../../../../../src/decorator/relations/ManyToMany"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Post} from "./Post.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {ManyToOne} from "../../../../../src/decorator/relations/ManyToOne.ts"; +import {ManyToMany} from "../../../../../src/decorator/relations/ManyToMany.ts"; @Entity() export class Category { @@ -11,13 +11,13 @@ export class Category { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) name: string; - + @ManyToOne(type => Post, post => post.categories) post: Post; - + @ManyToMany(type => Post, post => post.manyCategories) manyPosts: Post[]; -} \ No newline at end of file +} diff --git a/test/functional/repository/set-add-remove-relations/entity/Post.ts b/test/functional/repository/set-add-remove-relations/entity/Post.ts index 5f19caae2..8b29c797a 100644 --- a/test/functional/repository/set-add-remove-relations/entity/Post.ts +++ b/test/functional/repository/set-add-remove-relations/entity/Post.ts @@ -1,10 +1,10 @@ -import {Category} from "./Category"; -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {OneToMany} from "../../../../../src/decorator/relations/OneToMany"; -import {ManyToMany} from "../../../../../src/decorator/relations/ManyToMany"; -import {JoinTable} from "../../../../../src/decorator/relations/JoinTable"; +import {Category} from "./Category.ts"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {OneToMany} from "../../../../../src/decorator/relations/OneToMany.ts"; +import {ManyToMany} from "../../../../../src/decorator/relations/ManyToMany.ts"; +import {JoinTable} from "../../../../../src/decorator/relations/JoinTable.ts"; @Entity() export class Post { @@ -12,7 +12,7 @@ export class Post { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) title: string; @OneToMany(type => Category, category => category.post) @@ -22,4 +22,4 @@ export class Post { @JoinTable() manyCategories: Category[]; -} \ No newline at end of file +} diff --git a/test/functional/repository/set-add-remove-relations/repository-set-add-remove-relations.ts b/test/functional/repository/set-add-remove-relations/repository-set-add-remove-relations.ts index 7f08f112f..7628fed5c 100644 --- a/test/functional/repository/set-add-remove-relations/repository-set-add-remove-relations.ts +++ b/test/functional/repository/set-add-remove-relations/repository-set-add-remove-relations.ts @@ -1,9 +1,10 @@ -import "reflect-metadata"; -import {expect} from "chai"; -import {Connection} from "../../../../src/connection/Connection"; -import {Post} from "./entity/Post"; -import {Category} from "./entity/Category"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils"; +import {join as joinPaths} from "../../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../../deps/mocha.ts"; +import {expect} from "../../../deps/chai.ts"; +import {Connection} from "../../../../src/connection/Connection.ts"; +import {Post} from "./entity/Post.ts"; +import {Category} from "./entity/Category.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils.ts"; // todo: fix this test later describe.skip("repository > set/add/remove relation methods", function() { @@ -13,8 +14,9 @@ describe.skip("repository > set/add/remove relation methods", function() { // ------------------------------------------------------------------------- let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], })); beforeEach(() => reloadTestingDatabases(connections)); after(() => closeTestingConnections(connections)); @@ -314,3 +316,5 @@ describe.skip("repository > set/add/remove relation methods", function() { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/schema-builder/add-column.ts b/test/functional/schema-builder/add-column.ts index 690c1cc6f..2b5526020 100644 --- a/test/functional/schema-builder/add-column.ts +++ b/test/functional/schema-builder/add-column.ts @@ -1,17 +1,21 @@ -import "reflect-metadata"; -import {Connection} from "../../../src"; -import {CockroachDriver} from "../../../src/driver/cockroachdb/CockroachDriver"; -import {ColumnMetadataArgs} from "../../../src/metadata-args/ColumnMetadataArgs"; -import {ColumnMetadata} from "../../../src/metadata/ColumnMetadata"; -import {closeTestingConnections, createTestingConnections} from "../../utils/test-utils"; -import {Post} from "./entity/Post"; +import {join as joinPaths} from "../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../deps/mocha.ts"; +import "../../deps/chai.ts"; +import {Connection} from "../../../src/index.ts"; +// TODO(uki00a) uncomment this when CockroachDriver is implemented. +// import {CockroachDriver} from "../../../src/driver/cockroachdb/CockroachDriver.ts"; +import {ColumnMetadataArgs} from "../../../src/metadata-args/ColumnMetadataArgs.ts"; +import {ColumnMetadata} from "../../../src/metadata/ColumnMetadata.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections} from "../../utils/test-utils.ts"; +import {Post} from "./entity/Post.ts"; describe("schema builder > add column", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => { connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], schemaCreate: true, dropSchema: true, }); @@ -32,7 +36,8 @@ describe("schema builder > add column", () => { options: { type: "int", name: "secondId", - primary: !(connection.driver instanceof CockroachDriver), // CockroachDB does not allow changing pk + // TODO(uki00a) uncomment this when CockroachDriver is implemented. + primary: true/*!(connection.driver instanceof CockroachDriver)*/, // CockroachDB does not allow changing pk nullable: false } } @@ -64,7 +69,7 @@ describe("schema builder > add column", () => { const column1 = table!.findColumnByName("secondId")!; column1.should.be.exist; column1.isNullable.should.be.false; - if (!(connection.driver instanceof CockroachDriver)) + if (true/*!(connection.driver instanceof CockroachDriver)*/) // TODO(uki00a) uncomment this when CockroachDriver is implemented. column1.isPrimary.should.be.true; const column2 = table!.findColumnByName("description")!; @@ -75,3 +80,5 @@ describe("schema builder > add column", () => { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/schema-builder/change-check-constraint.ts b/test/functional/schema-builder/change-check-constraint.ts index 5996b4eaf..e4e2aa661 100644 --- a/test/functional/schema-builder/change-check-constraint.ts +++ b/test/functional/schema-builder/change-check-constraint.ts @@ -1,18 +1,21 @@ -import "reflect-metadata"; -import {Connection} from "../../../src/connection/Connection"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../utils/test-utils"; -import {PromiseUtils} from "../../../src"; -import {Teacher} from "./entity/Teacher"; -import {Post} from "./entity/Post"; -import {CheckMetadata} from "../../../src/metadata/CheckMetadata"; -import {MysqlDriver} from "../../../src/driver/mysql/MysqlDriver"; +import {join as joinPaths} from "../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../deps/mocha.ts"; +import "../../deps/chai.ts"; +import {Connection} from "../../../src/connection/Connection.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../utils/test-utils.ts"; +import {PromiseUtils} from "../../../src/index.ts"; +import {Teacher} from "./entity/Teacher.ts"; +import {Post} from "./entity/Post.ts"; +import {CheckMetadata} from "../../../src/metadata/CheckMetadata.ts"; +import {MysqlDriver} from "../../../src/driver/mysql/MysqlDriver.ts"; describe("schema builder > change check constraint", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => { connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], schemaCreate: true, dropSchema: true, }); @@ -81,3 +84,5 @@ describe("schema builder > change check constraint", () => { })); }); + +runIfMain(import.meta); diff --git a/test/functional/schema-builder/change-column.ts b/test/functional/schema-builder/change-column.ts index 2372e4740..949fd6ad7 100644 --- a/test/functional/schema-builder/change-column.ts +++ b/test/functional/schema-builder/change-column.ts @@ -1,24 +1,28 @@ -import {expect} from "chai"; -import "reflect-metadata"; -import {Connection, PromiseUtils} from "../../../src"; -import {AuroraDataApiDriver} from "../../../src/driver/aurora-data-api/AuroraDataApiDriver"; -import {CockroachDriver} from "../../../src/driver/cockroachdb/CockroachDriver"; -import {MysqlDriver} from "../../../src/driver/mysql/MysqlDriver"; -import {OracleDriver} from "../../../src/driver/oracle/OracleDriver"; -import {PostgresDriver} from "../../../src/driver/postgres/PostgresDriver"; -import {SapDriver} from "../../../src/driver/sap/SapDriver"; -import {AbstractSqliteDriver} from "../../../src/driver/sqlite-abstract/AbstractSqliteDriver"; -import {SqlServerDriver} from "../../../src/driver/sqlserver/SqlServerDriver"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../utils/test-utils"; -import {Post} from "./entity/Post"; -import {PostVersion} from "./entity/PostVersion"; +import {join as joinPaths} from "../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../deps/mocha.ts"; +import {expect} from "../../deps/chai.ts"; +import {Connection, PromiseUtils} from "../../../src/index.ts"; +import {AuroraDataApiDriver} from "../../../src/driver/aurora-data-api/AuroraDataApiDriver.ts"; +// TODO(uki00a) uncomment this when CockroachDriver is implemented. +// import {CockroachDriver} from "../../../src/driver/cockroachdb/CockroachDriver.ts"; +import {MysqlDriver} from "../../../src/driver/mysql/MysqlDriver.ts"; +import {OracleDriver} from "../../../src/driver/oracle/OracleDriver.ts"; +// TODO(uki00a) uncomment this when PostgresDriver is implemented. +// import {PostgresDriver} from "../../../src/driver/postgres/PostgresDriver.ts"; +import {SapDriver} from "../../../src/driver/sap/SapDriver.ts"; +import {AbstractSqliteDriver} from "../../../src/driver/sqlite-abstract/AbstractSqliteDriver.ts"; +import {SqlServerDriver} from "../../../src/driver/sqlserver/SqlServerDriver.ts"; +import {closeTestingConnections, createTestingConnections, reloadTestingDatabases, getDirnameOfCurrentModule} from "../../utils/test-utils.ts"; +import {Post} from "./entity/Post.ts"; +import {PostVersion} from "./entity/PostVersion.ts"; describe("schema builder > change column", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => { connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], schemaCreate: true, dropSchema: true, }); @@ -99,7 +103,7 @@ describe("schema builder > change column", () => { it("should correctly make column primary and generated", () => PromiseUtils.runInSequence(connections, async connection => { // CockroachDB does not allow changing PK - if (connection.driver instanceof CockroachDriver) + if (false/*connection.driver instanceof CockroachDriver*/) // TODO(uki00a) uncomment this when CockroachDriver is implemented. return; const postMetadata = connection.getMetadata(Post); @@ -155,12 +159,12 @@ describe("schema builder > change column", () => { it("should correctly change non-generated column on to uuid-generated column", () => PromiseUtils.runInSequence(connections, async connection => { // CockroachDB does not allow changing PK - if (connection.driver instanceof CockroachDriver) + if (false/*connection.driver instanceof CockroachDriver*/) // TODO(uki00a) uncomment this when CockroachDriver is implemented. return; const queryRunner = connection.createQueryRunner(); - if (connection.driver instanceof PostgresDriver) + if (false/*connection.driver instanceof PostgresDriver*/) // TODO(uki00a) uncomment this when PostgresDriver is implemented. await queryRunner.query(`CREATE EXTENSION IF NOT EXISTS "uuid-ossp"`); const postMetadata = connection.getMetadata(Post); @@ -169,7 +173,9 @@ describe("schema builder > change column", () => { idColumn.generationStrategy = "uuid"; // depending on driver, we must change column and referenced column types - if (connection.driver instanceof PostgresDriver || connection.driver instanceof CockroachDriver) { + if (false/*connection.driver instanceof PostgresDriver || connection.driver instanceof CockroachDriver*/) { + // TODO(uki00a) uncomment this when PostgresDriver is implemented. + // TODO(uki00a) uncomment this when CockroachDriver is implemented. idColumn.type = "uuid"; } else if (connection.driver instanceof SqlServerDriver) { idColumn.type = "uniqueidentifier"; @@ -182,7 +188,9 @@ describe("schema builder > change column", () => { const postTable = await queryRunner.getTable("post"); await queryRunner.release(); - if (connection.driver instanceof PostgresDriver || connection.driver instanceof SqlServerDriver || connection.driver instanceof CockroachDriver) { + if (/*connection.driver instanceof PostgresDriver || */connection.driver instanceof SqlServerDriver/* || connection.driver instanceof CockroachDriver*/) { + // TODO(uki00a) uncomment this when PostgresDriver is implemented. + // TODO(uki00a) uncomment this when CockroachDriver is implemented. postTable!.findColumnByName("id")!.isGenerated.should.be.true; postTable!.findColumnByName("id")!.generationStrategy!.should.be.equal("uuid"); @@ -203,7 +211,7 @@ describe("schema builder > change column", () => { it("should correctly change generated column generation strategy", () => PromiseUtils.runInSequence(connections, async connection => { // CockroachDB does not allow changing PK - if (connection.driver instanceof CockroachDriver) + if (false/*connection.driver instanceof CockroachDriver*/) // TODO(uki00a) uncomment this when CockroachDriver is implemented. return; const teacherMetadata = connection.getMetadata("teacher"); @@ -213,7 +221,9 @@ describe("schema builder > change column", () => { idColumn.generationStrategy = "uuid"; // depending on driver, we must change column and referenced column types - if (connection.driver instanceof PostgresDriver || connection.driver instanceof CockroachDriver) { + if (false/*connection.driver instanceof PostgresDriver || connection.driver instanceof CockroachDriver*/) { + // TODO(uki00a) uncomment this when PostgresDriver is implemented. + // TODO(uki00a) uncomment this when CockroachDriver is implemented. idColumn.type = "uuid"; teacherColumn.type = "uuid"; } else if (connection.driver instanceof SqlServerDriver) { @@ -230,7 +240,7 @@ describe("schema builder > change column", () => { const teacherTable = await queryRunner.getTable("teacher"); await queryRunner.release(); - if (connection.driver instanceof PostgresDriver || connection.driver instanceof SqlServerDriver) { + if (/*connection.driver instanceof PostgresDriver || */connection.driver instanceof SqlServerDriver) { // TODO(uki00a) uncomment this when PostgresDriver is implemented. teacherTable!.findColumnByName("id")!.isGenerated.should.be.true; teacherTable!.findColumnByName("id")!.generationStrategy!.should.be.equal("uuid"); @@ -249,3 +259,5 @@ describe("schema builder > change column", () => { })); }); + +runIfMain(import.meta); diff --git a/test/functional/schema-builder/change-exclusion-constraint.ts b/test/functional/schema-builder/change-exclusion-constraint.ts index c390f64dc..d5db5e631 100644 --- a/test/functional/schema-builder/change-exclusion-constraint.ts +++ b/test/functional/schema-builder/change-exclusion-constraint.ts @@ -1,17 +1,20 @@ -import "reflect-metadata"; -import {Connection} from "../../../src/connection/Connection"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../utils/test-utils"; -import {PromiseUtils} from "../../../src"; -import {Teacher} from "./entity/Teacher"; -import {Post} from "./entity/Post"; -import {ExclusionMetadata} from "../../../src/metadata/ExclusionMetadata"; +import {join as joinPaths} from "../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../deps/mocha.ts"; +import "../../deps/chai.ts"; +import {Connection} from "../../../src/connection/Connection.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../utils/test-utils.ts"; +import {PromiseUtils} from "../../../src/index.ts"; +import {Teacher} from "./entity/Teacher.ts"; +import {Post} from "./entity/Post.ts"; +import {ExclusionMetadata} from "../../../src/metadata/ExclusionMetadata.ts"; describe("schema builder > change exclusion constraint", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => { connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], enabledDrivers: ["postgres"], // Only PostgreSQL supports exclusion constraints. schemaCreate: true, dropSchema: true, @@ -72,3 +75,5 @@ describe("schema builder > change exclusion constraint", () => { })); }); + +runIfMain(import.meta); diff --git a/test/functional/schema-builder/change-index.ts b/test/functional/schema-builder/change-index.ts index 47cb52a26..41f507ddd 100644 --- a/test/functional/schema-builder/change-index.ts +++ b/test/functional/schema-builder/change-index.ts @@ -1,20 +1,23 @@ -import "reflect-metadata"; -import {Connection} from "../../../src/connection/Connection"; -import {CockroachDriver} from "../../../src/driver/cockroachdb/CockroachDriver"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../utils/test-utils"; -import {PromiseUtils} from "../../../src"; -import {IndexMetadata} from "../../../src/metadata/IndexMetadata"; -import {Teacher} from "./entity/Teacher"; -import {Student} from "./entity/Student"; -import {TableIndex} from "../../../src/schema-builder/table/TableIndex"; -import {expect} from "chai"; +import {join as joinPaths} from "../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../deps/mocha.ts"; +import {expect} from "../../deps/chai.ts"; +import {Connection} from "../../../src/connection/Connection.ts"; +// TODO(uki00a) uncomment this when CockroachDriver is implemented. +// import {CockroachDriver} from "../../../src/driver/cockroachdb/CockroachDriver.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../utils/test-utils.ts"; +import {PromiseUtils} from "../../../src/index.ts"; +import {IndexMetadata} from "../../../src/metadata/IndexMetadata.ts"; +import {Teacher} from "./entity/Teacher.ts"; +import {Student} from "./entity/Student.ts"; +import {TableIndex} from "../../../src/schema-builder/table/TableIndex.ts"; describe("schema builder > change index", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => { connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], schemaCreate: true, dropSchema: true, }); @@ -72,7 +75,7 @@ describe("schema builder > change index", () => { const studentTable = await queryRunner.getTable("student"); await queryRunner.release(); // CockroachDB also stores indices for relation columns - if (connection.driver instanceof CockroachDriver) { + if (false/*connection.driver instanceof CockroachDriver*/) { // TODO(uki00a) uncomment this when CockroachDriver is implemented. studentTable!.indices.length.should.be.equal(2); } else { studentTable!.indices.length.should.be.equal(0); @@ -92,7 +95,7 @@ describe("schema builder > change index", () => { teacherTable = await queryRunner.getTable("teacher"); // CockroachDB stores unique indices as UNIQUE constraints - if (connection.driver instanceof CockroachDriver) { + if (false/*connection.driver instanceof CockroachDriver*/) { // TODO(uki00a) uncomment this when CockroachDriver is implemented. teacherTable!.indices.length.should.be.equal(0); teacherTable!.uniques.length.should.be.equal(1); teacherTable!.findColumnByName("name")!.isUnique.should.be.true; @@ -105,7 +108,7 @@ describe("schema builder > change index", () => { teacherTable = await queryRunner.getTable("teacher"); // CockroachDB stores unique indices as UNIQUE constraints - if (connection.driver instanceof CockroachDriver) { + if (false/*connection.driver instanceof CockroachDriver*/) { // TODO(uki00a) uncomment this when CockroachDriver is implemented. teacherTable!.indices.length.should.be.equal(0); teacherTable!.uniques.length.should.be.equal(0); teacherTable!.findColumnByName("name")!.isUnique.should.be.false; @@ -119,3 +122,5 @@ describe("schema builder > change index", () => { })); }); + +runIfMain(import.meta); diff --git a/test/functional/schema-builder/change-unique-constraint.ts b/test/functional/schema-builder/change-unique-constraint.ts index dc020b865..7d8fa4e34 100644 --- a/test/functional/schema-builder/change-unique-constraint.ts +++ b/test/functional/schema-builder/change-unique-constraint.ts @@ -1,21 +1,24 @@ -import "reflect-metadata"; -import {PromiseUtils} from "../../../src"; -import {Connection} from "../../../src"; -import {MysqlDriver} from "../../../src/driver/mysql/MysqlDriver"; -import {SapDriver} from "../../../src/driver/sap/SapDriver"; -import {AbstractSqliteDriver} from "../../../src/driver/sqlite-abstract/AbstractSqliteDriver"; -import {IndexMetadata} from "../../../src/metadata/IndexMetadata"; -import {UniqueMetadata} from "../../../src/metadata/UniqueMetadata"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../utils/test-utils"; -import {Post} from "./entity/Post"; -import {Teacher} from "./entity/Teacher"; +import {join as joinPaths} from "../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../deps/mocha.ts"; +import "../../deps/chai.ts"; +import {PromiseUtils} from "../../../src/index.ts"; +import {Connection} from "../../../src/index.ts"; +import {MysqlDriver} from "../../../src/driver/mysql/MysqlDriver.ts"; +import {SapDriver} from "../../../src/driver/sap/SapDriver.ts"; +import {AbstractSqliteDriver} from "../../../src/driver/sqlite-abstract/AbstractSqliteDriver.ts"; +import {IndexMetadata} from "../../../src/metadata/IndexMetadata.ts"; +import {UniqueMetadata} from "../../../src/metadata/UniqueMetadata.ts"; +import {closeTestingConnections, createTestingConnections, reloadTestingDatabases, getDirnameOfCurrentModule} from "../../utils/test-utils.ts"; +import {Post} from "./entity/Post.ts"; +import {Teacher} from "./entity/Teacher.ts"; describe("schema builder > change unique constraint", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => { connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], schemaCreate: true, dropSchema: true, }); @@ -146,3 +149,5 @@ describe("schema builder > change unique constraint", () => { })); }); + +runIfMain(import.meta); diff --git a/test/functional/schema-builder/create-foreign-key.ts b/test/functional/schema-builder/create-foreign-key.ts index a5b13b897..5336ba680 100644 --- a/test/functional/schema-builder/create-foreign-key.ts +++ b/test/functional/schema-builder/create-foreign-key.ts @@ -1,16 +1,20 @@ -import "reflect-metadata"; -import {Connection} from "../../../src/connection/Connection"; -import {CockroachDriver} from "../../../src/driver/cockroachdb/CockroachDriver"; -import {UniqueMetadata} from "../../../src/metadata/UniqueMetadata"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../utils/test-utils"; -import {ForeignKeyMetadata} from "../../../src/metadata/ForeignKeyMetadata"; +import {join as joinPaths} from "../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../deps/mocha.ts"; +import "../../deps/chai.ts"; +import {Connection} from "../../../src/connection/Connection.ts"; +// TODO(uki00a) uncomment this when CockroachDriver is implemented. +// import {CockroachDriver} from "../../../src/driver/cockroachdb/CockroachDriver.ts"; +import {UniqueMetadata} from "../../../src/metadata/UniqueMetadata.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../utils/test-utils.ts"; +import {ForeignKeyMetadata} from "../../../src/metadata/ForeignKeyMetadata.ts"; describe("schema builder > create foreign key", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => { connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], schemaCreate: true, dropSchema: true, }); @@ -34,7 +38,7 @@ describe("schema builder > create foreign key", () => { categoryMetadata.foreignKeys.push(fkMetadata); // CockroachDB requires unique constraint for foreign key referenced columns - if (connection.driver instanceof CockroachDriver) { + if (false/*connection.driver instanceof CockroachDriver*/) { // TODO(uki00a) uncomment this when CockroachDriver is implemented. const uniqueConstraint = new UniqueMetadata({ entityMetadata: categoryMetadata, columns: fkMetadata.columns, @@ -58,3 +62,5 @@ describe("schema builder > create foreign key", () => { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/schema-builder/create-table.ts b/test/functional/schema-builder/create-table.ts index 9f1c46ff5..868d94d88 100644 --- a/test/functional/schema-builder/create-table.ts +++ b/test/functional/schema-builder/create-table.ts @@ -1,17 +1,20 @@ -import {expect} from "chai"; -import "reflect-metadata"; -import {Connection} from "../../../src/connection/Connection"; -import {CockroachDriver} from "../../../src/driver/cockroachdb/CockroachDriver"; -import {MysqlDriver} from "../../../src/driver/mysql/MysqlDriver"; -import {SapDriver} from "../../../src/driver/sap/SapDriver"; -import {closeTestingConnections, createTestingConnections} from "../../utils/test-utils"; +import {join as joinPaths} from "../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../deps/mocha.ts"; +import {expect} from "../../deps/chai.ts"; +import {Connection} from "../../../src/connection/Connection.ts"; +// TODO(uki00a) uncomment this when CockroachDriver is implemented. +// import {CockroachDriver} from "../../../src/driver/cockroachdb/CockroachDriver.ts"; +import {MysqlDriver} from "../../../src/driver/mysql/MysqlDriver.ts"; +import {SapDriver} from "../../../src/driver/sap/SapDriver.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections} from "../../utils/test-utils.ts"; describe("schema builder > create table", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => { connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], dropSchema: true, }); }); @@ -55,7 +58,7 @@ describe("schema builder > create table", () => { studentTable!.should.exist; studentTable!.foreignKeys.length.should.be.equal(2); // CockroachDB also stores indices for relation columns - if (connection.driver instanceof CockroachDriver) { + if (false/*connection.driver instanceof CockroachDriver*/) { // TODO(uki00a) uncomment this when CockroachDriver is implemented. studentTable!.indices.length.should.be.equal(3); } else { studentTable!.indices.length.should.be.equal(1); @@ -68,3 +71,5 @@ describe("schema builder > create table", () => { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/schema-builder/custom-db-and-schema-sync.ts b/test/functional/schema-builder/custom-db-and-schema-sync.ts index d8d2a81b6..9851c8d04 100644 --- a/test/functional/schema-builder/custom-db-and-schema-sync.ts +++ b/test/functional/schema-builder/custom-db-and-schema-sync.ts @@ -1,18 +1,22 @@ -import "reflect-metadata"; -import {Connection} from "../../../src"; -import {MysqlDriver} from "../../../src/driver/mysql/MysqlDriver"; -import {PostgresDriver} from "../../../src/driver/postgres/PostgresDriver"; -import {SapDriver} from "../../../src/driver/sap/SapDriver"; -import {SqlServerDriver} from "../../../src/driver/sqlserver/SqlServerDriver"; -import {ForeignKeyMetadata} from "../../../src/metadata/ForeignKeyMetadata"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../utils/test-utils"; +import {join as joinPaths} from "../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../deps/mocha.ts"; +import "../../deps/chai.ts"; +import {Connection} from "../../../src/index.ts"; +import {MysqlDriver} from "../../../src/driver/mysql/MysqlDriver.ts"; +// TODO(uki00a) uncomment this when PostgresDriver is implemented. +// import {PostgresDriver} from "../../../src/driver/postgres/PostgresDriver.ts"; +import {SapDriver} from "../../../src/driver/sap/SapDriver.ts"; +import {SqlServerDriver} from "../../../src/driver/sqlserver/SqlServerDriver.ts"; +import {ForeignKeyMetadata} from "../../../src/metadata/ForeignKeyMetadata.ts"; +import {closeTestingConnections, createTestingConnections, reloadTestingDatabases, getDirnameOfCurrentModule} from "../../utils/test-utils.ts"; describe("schema builder > custom-db-and-schema-sync", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => { connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], enabledDrivers: ["mysql", "mssql", "postgres", "sap"], dropSchema: true, }); @@ -44,7 +48,7 @@ describe("schema builder > custom-db-and-schema-sync", () => { await queryRunner.createSchema(photoMetadata.schemaPath, true); await queryRunner.createSchema(albumMetadata.schemaPath, true); - } else if (connection.driver instanceof PostgresDriver || connection.driver instanceof SapDriver) { + } else if (/*connection.driver instanceof PostgresDriver || */connection.driver instanceof SapDriver) { // TODO(uki00a) uncomment this when PostgresDriver is implemented. photoMetadata.schema = "photo-schema"; photoMetadata.tablePath = "photo-schema.photo"; photoMetadata.schemaPath = "photo-schema"; @@ -105,3 +109,5 @@ describe("schema builder > custom-db-and-schema-sync", () => { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/schema-builder/drop-column.ts b/test/functional/schema-builder/drop-column.ts index b1d82f7d5..e7169e49a 100644 --- a/test/functional/schema-builder/drop-column.ts +++ b/test/functional/schema-builder/drop-column.ts @@ -1,15 +1,18 @@ -import "reflect-metadata"; -import {Connection} from "../../../src/connection/Connection"; -import {CockroachDriver} from "../../../src/driver/cockroachdb/CockroachDriver"; -import {closeTestingConnections, createTestingConnections} from "../../utils/test-utils"; -import {expect} from "chai"; +import {join as joinPaths} from "../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../deps/mocha.ts"; +import {expect} from "../../deps/chai.ts"; +import {Connection} from "../../../src/connection/Connection.ts"; +// TODO(uki00a) uncomment this when CockroachDriver is implemented. +// import {CockroachDriver} from "../../../src/driver/cockroachdb/CockroachDriver.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections} from "../../utils/test-utils.ts"; describe("schema builder > drop column", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => { connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], schemaCreate: true, dropSchema: true, }); @@ -44,7 +47,7 @@ describe("schema builder > drop column", () => { expect(studentTable!.findColumnByName("faculty")).to.be.undefined; // CockroachDB creates indices for foreign keys - if (connection.driver instanceof CockroachDriver) { + if (false/*connection.driver instanceof CockroachDriver*/) { // TODO(uki00a) uncomment this when CockroachDriver is implemented. studentTable!.indices.length.should.be.equal(1); } else { studentTable!.indices.length.should.be.equal(0); @@ -53,3 +56,5 @@ describe("schema builder > drop column", () => { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/schema-builder/entity/Album.ts b/test/functional/schema-builder/entity/Album.ts index 43687f077..eb435f32b 100644 --- a/test/functional/schema-builder/entity/Album.ts +++ b/test/functional/schema-builder/entity/Album.ts @@ -1,14 +1,14 @@ -import {Entity} from "../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../src/decorator/columns/Column"; -import {PrimaryColumn} from "../../../../src/decorator/columns/PrimaryColumn"; +import {Entity} from "../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../src/decorator/columns/Column.ts"; +import {PrimaryColumn} from "../../../../src/decorator/columns/PrimaryColumn.ts"; @Entity({ synchronize: false }) export class Album { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; - @Column() + @Column({ type: String }) name: string; -} \ No newline at end of file +} diff --git a/test/functional/schema-builder/entity/Category.ts b/test/functional/schema-builder/entity/Category.ts index f7fb85aee..668559b2d 100644 --- a/test/functional/schema-builder/entity/Category.ts +++ b/test/functional/schema-builder/entity/Category.ts @@ -1,20 +1,20 @@ -import {Entity} from "../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../src/decorator/columns/Column"; -import {PrimaryColumn} from "../../../../src/decorator/columns/PrimaryColumn"; +import {Entity} from "../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../src/decorator/columns/Column.ts"; +import {PrimaryColumn} from "../../../../src/decorator/columns/PrimaryColumn.ts"; @Entity() export class Category { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; - @Column() + @Column({ type: String }) name: string; - @Column() + @Column({ type: String }) postText: string; - @Column() + @Column({ type: String }) postTag: string; -} \ No newline at end of file +} diff --git a/test/functional/schema-builder/entity/Faculty.ts b/test/functional/schema-builder/entity/Faculty.ts index b2b4715b8..ca461b987 100644 --- a/test/functional/schema-builder/entity/Faculty.ts +++ b/test/functional/schema-builder/entity/Faculty.ts @@ -1,6 +1,6 @@ -import {Entity} from "../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../src/decorator/columns/Column"; -import {PrimaryGeneratedColumn} from "../../../../src/decorator/columns/PrimaryGeneratedColumn"; +import {Entity} from "../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../src/decorator/columns/Column.ts"; +import {PrimaryGeneratedColumn} from "../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; @Entity() export class Faculty { @@ -8,7 +8,7 @@ export class Faculty { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) name: string; -} \ No newline at end of file +} diff --git a/test/functional/schema-builder/entity/Photo.ts b/test/functional/schema-builder/entity/Photo.ts index 996f0f448..f54dbbf98 100644 --- a/test/functional/schema-builder/entity/Photo.ts +++ b/test/functional/schema-builder/entity/Photo.ts @@ -1,17 +1,17 @@ -import {Entity} from "../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../src/decorator/columns/Column"; -import {PrimaryColumn} from "../../../../src/decorator/columns/PrimaryColumn"; +import {Entity} from "../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../src/decorator/columns/Column.ts"; +import {PrimaryColumn} from "../../../../src/decorator/columns/PrimaryColumn.ts"; @Entity({ synchronize: false }) export class Photo { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; - @Column() + @Column({ type: String }) name: string; - @Column() + @Column({ type: Number }) albumId: number; -} \ No newline at end of file +} diff --git a/test/functional/schema-builder/entity/Post.ts b/test/functional/schema-builder/entity/Post.ts index e58bf4269..a536c8c4f 100644 --- a/test/functional/schema-builder/entity/Post.ts +++ b/test/functional/schema-builder/entity/Post.ts @@ -1,9 +1,9 @@ -import {Entity} from "../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../src/decorator/columns/Column"; -import {Unique} from "../../../../src/decorator/Unique"; -import {PrimaryColumn} from "../../../../src/decorator/columns/PrimaryColumn"; -import {Check} from "../../../../src/decorator/Check"; -import {Exclusion} from "../../../../src/decorator/Exclusion"; +import {Entity} from "../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../src/decorator/columns/Column.ts"; +import {Unique} from "../../../../src/decorator/Unique.ts"; +import {PrimaryColumn} from "../../../../src/decorator/columns/PrimaryColumn.ts"; +import {Check} from "../../../../src/decorator/Check.ts"; +import {Exclusion} from "../../../../src/decorator/Exclusion.ts"; @Entity() @Unique(["text", "tag"]) @@ -11,22 +11,22 @@ import {Exclusion} from "../../../../src/decorator/Exclusion"; @Check(`"likesCount" < 1000`) export class Post { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; - @Column({ unique: true }) + @Column({ unique: true, type: String }) version: string; - @Column({ default: "My post" }) + @Column({ default: "My post", type: String }) name: string; - @Column() + @Column({ type: String }) text: string; - @Column() + @Column({ type: String }) tag: string; - @Column() + @Column({ type: Number }) likesCount: number; } diff --git a/test/functional/schema-builder/entity/PostVersion.ts b/test/functional/schema-builder/entity/PostVersion.ts index e75de5eb6..7c42663d4 100644 --- a/test/functional/schema-builder/entity/PostVersion.ts +++ b/test/functional/schema-builder/entity/PostVersion.ts @@ -1,21 +1,21 @@ -import {Entity} from "../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../src/decorator/columns/Column"; -import {ManyToOne} from "../../../../src/decorator/relations/ManyToOne"; -import {JoinColumn} from "../../../../src"; -import {PrimaryColumn} from "../../../../src/decorator/columns/PrimaryColumn"; -import {Post} from "./Post"; +import {Entity} from "../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../src/decorator/columns/Column.ts"; +import {ManyToOne} from "../../../../src/decorator/relations/ManyToOne.ts"; +import {JoinColumn} from "../../../../src/index.ts"; +import {PrimaryColumn} from "../../../../src/decorator/columns/PrimaryColumn.ts"; +import {Post} from "./Post.ts"; @Entity() export class PostVersion { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; @ManyToOne(type => Post) @JoinColumn({ referencedColumnName: "version" }) post: Post; - @Column() + @Column({ type: String }) details: string; -} \ No newline at end of file +} diff --git a/test/functional/schema-builder/entity/Question.ts b/test/functional/schema-builder/entity/Question.ts index 745a28f8e..9ca01d1ee 100644 --- a/test/functional/schema-builder/entity/Question.ts +++ b/test/functional/schema-builder/entity/Question.ts @@ -1,6 +1,6 @@ -import {Entity} from "../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../src/decorator/columns/Column"; -import {PrimaryGeneratedColumn} from "../../../../src/decorator/columns/PrimaryGeneratedColumn"; +import {Entity} from "../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../src/decorator/columns/Column.ts"; +import {PrimaryGeneratedColumn} from "../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; @Entity() export class Question { @@ -8,7 +8,7 @@ export class Question { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) name: string; -} \ No newline at end of file +} diff --git a/test/functional/schema-builder/entity/Student.ts b/test/functional/schema-builder/entity/Student.ts index 4ad96493d..ee3cdd921 100644 --- a/test/functional/schema-builder/entity/Student.ts +++ b/test/functional/schema-builder/entity/Student.ts @@ -1,10 +1,10 @@ -import {Entity} from "../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../src/decorator/columns/Column"; -import {PrimaryGeneratedColumn} from "../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Faculty} from "./Faculty"; -import {ManyToOne} from "../../../../src/decorator/relations/ManyToOne"; -import {Teacher} from "./Teacher"; -import {Index} from "../../../../src/decorator/Index"; +import {Entity} from "../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../src/decorator/columns/Column.ts"; +import {PrimaryGeneratedColumn} from "../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Faculty} from "./Faculty.ts"; +import {ManyToOne} from "../../../../src/decorator/relations/ManyToOne.ts"; +import {Teacher} from "./Teacher.ts"; +import {Index} from "../../../../src/decorator/Index.ts"; @Entity() @Index("student_name_index", ["name"]) @@ -13,7 +13,7 @@ export class Student { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) name: string; @ManyToOne(type => Faculty) @@ -22,4 +22,4 @@ export class Student { @ManyToOne(type => Teacher) teacher: Teacher; -} \ No newline at end of file +} diff --git a/test/functional/schema-builder/entity/Teacher.ts b/test/functional/schema-builder/entity/Teacher.ts index 6a38a1956..9e8014abd 100644 --- a/test/functional/schema-builder/entity/Teacher.ts +++ b/test/functional/schema-builder/entity/Teacher.ts @@ -1,9 +1,9 @@ -import {Entity} from "../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../src/decorator/columns/Column"; -import {PrimaryGeneratedColumn} from "../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Student} from "./Student"; -import {OneToMany} from "../../../../src/decorator/relations/OneToMany"; -import {Index} from "../../../../src/decorator/Index"; +import {Entity} from "../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../src/decorator/columns/Column.ts"; +import {PrimaryGeneratedColumn} from "../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Student} from "./Student.ts"; +import {OneToMany} from "../../../../src/decorator/relations/OneToMany.ts"; +import {Index} from "../../../../src/decorator/Index.ts"; @Entity() @Index("ignored_index", { synchronize: false }) @@ -12,10 +12,10 @@ export class Teacher { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) name: string; @OneToMany(type => Student, student => student.teacher) students: Student[]; -} \ No newline at end of file +} diff --git a/test/functional/schema-builder/update-primary-keys.ts b/test/functional/schema-builder/update-primary-keys.ts index 5f472287a..97585791f 100644 --- a/test/functional/schema-builder/update-primary-keys.ts +++ b/test/functional/schema-builder/update-primary-keys.ts @@ -1,17 +1,21 @@ -import "reflect-metadata"; -import {Connection} from "../../../src/connection/Connection"; -import {CockroachDriver} from "../../../src/driver/cockroachdb/CockroachDriver"; -import {closeTestingConnections, createTestingConnections} from "../../utils/test-utils"; -import {Category} from "./entity/Category"; -import {Question} from "./entity/Question"; -import {AbstractSqliteDriver} from "../../../src/driver/sqlite-abstract/AbstractSqliteDriver"; +import {join as joinPaths} from "../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../deps/mocha.ts"; +import "../../deps/chai.ts"; +import {Connection} from "../../../src/connection/Connection.ts"; +// TODO(uki00a) uncomment this when CockroachDriver is implemented. +// import {CockroachDriver} from "../../../src/driver/cockroachdb/CockroachDriver.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections} from "../../utils/test-utils.ts"; +import {Category} from "./entity/Category.ts"; +import {Question} from "./entity/Question.ts"; +import {AbstractSqliteDriver} from "../../../src/driver/sqlite-abstract/AbstractSqliteDriver.ts"; describe("schema builder > update primary keys", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => { connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], schemaCreate: true, dropSchema: true, }); @@ -21,7 +25,7 @@ describe("schema builder > update primary keys", () => { it("should correctly update composite primary keys", () => Promise.all(connections.map(async connection => { // CockroachDB does not support changing primary key constraint - if (connection.driver instanceof CockroachDriver) + if (false/*connection.driver instanceof CockroachDriver*/) // TODO(uki00a) uncomment this when CockroachDriver is implemented. return; const metadata = connection.getMetadata(Category); @@ -44,7 +48,7 @@ describe("schema builder > update primary keys", () => { return; // CockroachDB does not support changing primary key constraint - if (connection.driver instanceof CockroachDriver) + if (false/*connection.driver instanceof CockroachDriver*/) // TODO(uki00a) uncomment this when CockroachDriver is implemented. return; const metadata = connection.getMetadata(Question); @@ -62,3 +66,5 @@ describe("schema builder > update primary keys", () => { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/spatial/postgres/entity/Post.ts b/test/functional/spatial/postgres/entity/Post.ts index c77c5c1eb..f77b48425 100644 --- a/test/functional/spatial/postgres/entity/Post.ts +++ b/test/functional/spatial/postgres/entity/Post.ts @@ -1,7 +1,7 @@ -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {Index} from "../../../../../src/decorator/Index"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {Index} from "../../../../../src/decorator/Index.ts"; @Entity() export class Post { diff --git a/test/functional/spatial/postgres/spatial-postgres.ts b/test/functional/spatial/postgres/spatial-postgres.ts index 30c6ef0ec..fdb292902 100644 --- a/test/functional/spatial/postgres/spatial-postgres.ts +++ b/test/functional/spatial/postgres/spatial-postgres.ts @@ -1,18 +1,21 @@ -import "reflect-metadata"; -import { expect } from "chai"; -import { Connection } from "../../../../src/connection/Connection"; +import { join as joinPaths } from "../../../../vendor/https/deno.land/std/path/mod.ts"; +import { runIfMain } from "../../../deps/mocha.ts"; +import { expect } from "../../../deps/chai.ts"; +import { Connection } from "../../../../src/connection/Connection.ts"; import { - closeTestingConnections, - createTestingConnections, - reloadTestingDatabases -} from "../../../utils/test-utils"; -import { Post } from "./entity/Post"; + getDirnameOfCurrentModule, + closeTestingConnections, + createTestingConnections, + reloadTestingDatabases +} from "../../../utils/test-utils.ts"; +import { Post } from "./entity/Post.ts"; describe("spatial-postgres", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => { connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], enabledDrivers: ["postgres"] }); }); @@ -227,3 +230,5 @@ describe("spatial-postgres", () => { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/sqljs/auto-save.ts b/test/functional/sqljs/auto-save.ts index cbdf75290..db43a9c07 100644 --- a/test/functional/sqljs/auto-save.ts +++ b/test/functional/sqljs/auto-save.ts @@ -1,10 +1,11 @@ -import "reflect-metadata"; -import {expect} from "chai"; -import {Post} from "./entity/Post"; -import {Connection} from "../../../src/connection/Connection"; -import {createTestingConnections} from "../../utils/test-utils"; - -describe("sqljs driver > autosave", () => { +import {runIfMain} from "../../deps/mocha.ts"; +import {expect} from "../../deps/chai.ts"; +import {Post} from "./entity/Post.ts"; +import {Connection} from "../../../src/connection/Connection.ts"; +import {createTestingConnections} from "../../utils/test-utils.ts"; + +// TODO(uki00a) Remove `.skip` when SqlijsDriver is implemented. +describe.skip("sqljs driver > autosave", () => { let connections: Connection[]; let saves = 0; const callback = (database: Uint8Array) => { @@ -34,7 +35,7 @@ describe("sqljs driver > autosave", () => { await connection.createQueryBuilder().insert().into(Post).values(posts).execute(); await connection.createQueryBuilder().update(Post).set({title: "Many posts"}).execute(); await connection.createQueryBuilder().delete().from(Post).where("title = ?", {title: "third post"}).execute(); - + const repository = connection.getRepository(Post); let post = new Post(); post.title = "A post"; @@ -93,4 +94,6 @@ describe("sqljs driver > autosave off", () => { expect(saves).to.be.equal(0); }))); -}); \ No newline at end of file +}); + +runIfMain(import.meta); diff --git a/test/functional/sqljs/entity/Post.ts b/test/functional/sqljs/entity/Post.ts index a4a7ec65b..440323cf6 100644 --- a/test/functional/sqljs/entity/Post.ts +++ b/test/functional/sqljs/entity/Post.ts @@ -1,13 +1,13 @@ -import {Entity} from "../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../src/decorator/columns/Column"; -import {PrimaryColumn} from "../../../../src/decorator/columns/PrimaryColumn"; +import {Entity} from "../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../src/decorator/columns/Column.ts"; +import {PrimaryColumn} from "../../../../src/decorator/columns/PrimaryColumn.ts"; @Entity() export class Post { - @PrimaryColumn() + @PrimaryColumn({ type: Number }) id: number; - @Column() + @Column({ type: String }) title: string; -} \ No newline at end of file +} diff --git a/test/functional/sqljs/load.ts b/test/functional/sqljs/load.ts index d3300fbb6..3c92e910f 100644 --- a/test/functional/sqljs/load.ts +++ b/test/functional/sqljs/load.ts @@ -1,12 +1,12 @@ -import "reflect-metadata"; -import * as fs from "fs"; -import {expect} from "chai"; -import {getSqljsManager} from "../../../src/index"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../utils/test-utils"; -import {Connection} from "../../../src/connection/Connection"; -import {Post} from "./entity/Post"; +import {runIfMain} from "../../deps/mocha.ts"; +import {expect} from "../../deps/chai.ts"; +import {getSqljsManager} from "../../../src/index.ts"; +import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../utils/test-utils.ts"; +import {Connection} from "../../../src/connection/Connection.ts"; +import {Post} from "./entity/Post.ts"; -describe("sqljs driver > load", () => { +// TODO(uki00a) Remove `.skip` when SqljsDriver is implemented. +describe.skip("sqljs driver > load", () => { let connections: Connection[]; before(async () => connections = await createTestingConnections({ @@ -32,7 +32,7 @@ describe("sqljs driver > load", () => { const exportedDatabase = manager.exportDatabase(); expect(exportedDatabase).not.to.be.undefined; - const originalFileContent = fs.readFileSync("test/functional/sqljs/sqlite/test.sqlite"); + const originalFileContent = Deno.readFileSync("test/functional/sqljs/sqlite/test.sqlite"); expect(exportedDatabase.length).to.equal(originalFileContent.length); }))); @@ -46,3 +46,5 @@ describe("sqljs driver > load", () => { } }))); }); + +runIfMain(import.meta); diff --git a/test/functional/sqljs/save.ts b/test/functional/sqljs/save.ts index 083aa27c7..8413d8ba5 100644 --- a/test/functional/sqljs/save.ts +++ b/test/functional/sqljs/save.ts @@ -1,14 +1,16 @@ -import "reflect-metadata"; -import * as fs from "fs"; -import * as path from "path"; -import {expect} from "chai"; -import {getSqljsManager} from "../../../src/index"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../utils/test-utils"; -import {Connection} from "../../../src/connection/Connection"; -import {Post} from "./entity/Post"; - -describe("sqljs driver > save", () => { - +import {runIfMain} from "../../deps/mocha.ts"; +import {expect} from "../../deps/chai.ts"; +import * as path from "../../../vendor/https/deno.land/std/path/mod.ts"; +import * as fs from "../../../vendor/https/deno.land/std/fs/mod.ts"; +import {getSqljsManager} from "../../../src/index.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../utils/test-utils.ts"; +import {Connection} from "../../../src/connection/Connection.ts"; +import {Post} from "./entity/Post.ts"; + +// TODO(uki00a) Remove `.skip` when SqljsDriver is implemented. +describe.skip("sqljs driver > save", () => { + + const __dirname = getDirnameOfCurrentModule(import.meta); const pathToSqlite = path.resolve(__dirname, "export.sqlite"); let connections: Connection[]; before(async () => connections = await createTestingConnections({ @@ -22,7 +24,7 @@ describe("sqljs driver > save", () => { it("should save to file", () => Promise.all(connections.map(async connection => { if (fs.existsSync(pathToSqlite)) { - fs.unlinkSync(pathToSqlite); + Deno.removeSync(pathToSqlite); } let post = new Post(); @@ -49,3 +51,5 @@ describe("sqljs driver > save", () => { } }))); }); + +runIfMain(import.meta); diff --git a/test/functional/sqljs/startup.ts b/test/functional/sqljs/startup.ts index 6e5ae7b0d..6db27e426 100644 --- a/test/functional/sqljs/startup.ts +++ b/test/functional/sqljs/startup.ts @@ -1,13 +1,15 @@ -import "reflect-metadata"; -import * as path from "path"; -import {expect} from "chai"; -import {Post} from "./entity/Post"; -import {Connection} from "../../../src/connection/Connection"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../utils/test-utils"; -import {PlatformTools} from "../../../src/platform/PlatformTools"; +import {runIfMain} from "../../deps/mocha.ts"; +import {expect} from "../../deps/chai.ts"; +import * as path from "../../../vendor/https/deno.land/std/path/mod.ts"; +import {Post} from "./entity/Post.ts"; +import {Connection} from "../../../src/connection/Connection.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../utils/test-utils.ts"; +import {PlatformTools} from "../../../src/platform/PlatformTools.ts"; -describe("sqljs driver > startup", () => { +// TODO(uki00a) Remove `.skip` when SqljsDriver is implemented. +describe.skip("sqljs driver > startup", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); const pathToSqlite = path.resolve(__dirname, "startup.sqlite"); before(async () => connections = await createTestingConnections({ @@ -38,3 +40,5 @@ describe("sqljs driver > startup", () => { expect(PlatformTools.fileExist(pathToSqlite)).to.be.true; }))); }); + +runIfMain(import.meta); diff --git a/test/functional/table-inheritance/extending/entity/Content.ts b/test/functional/table-inheritance/extending/entity/Content.ts index 9393d2c9d..acab99bbc 100644 --- a/test/functional/table-inheritance/extending/entity/Content.ts +++ b/test/functional/table-inheritance/extending/entity/Content.ts @@ -1,9 +1,9 @@ -import {Column} from "../../../../../src/decorator/columns/Column"; -import {Unit} from "./Unit"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {Unit} from "./Unit.ts"; export class Content extends Unit { - @Column() + @Column({ type: String }) name: string; -} \ No newline at end of file +} diff --git a/test/functional/table-inheritance/extending/entity/Post.ts b/test/functional/table-inheritance/extending/entity/Post.ts index 114e2e449..e23c28470 100644 --- a/test/functional/table-inheritance/extending/entity/Post.ts +++ b/test/functional/table-inheritance/extending/entity/Post.ts @@ -1,11 +1,11 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {Content} from "./Content"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {Content} from "./Content.ts"; @Entity() export class Post extends Content { - @Column() + @Column({ type: String }) text: string; -} \ No newline at end of file +} diff --git a/test/functional/table-inheritance/extending/entity/Unit.ts b/test/functional/table-inheritance/extending/entity/Unit.ts index 0a0afebb7..9d67938a1 100644 --- a/test/functional/table-inheritance/extending/entity/Unit.ts +++ b/test/functional/table-inheritance/extending/entity/Unit.ts @@ -1,8 +1,8 @@ -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; export class Unit { @PrimaryGeneratedColumn() id: number; -} \ No newline at end of file +} diff --git a/test/functional/table-inheritance/extending/extending-inheritance.ts b/test/functional/table-inheritance/extending/extending-inheritance.ts index 2e44a201f..ea70234af 100644 --- a/test/functional/table-inheritance/extending/extending-inheritance.ts +++ b/test/functional/table-inheritance/extending/extending-inheritance.ts @@ -1,14 +1,16 @@ -import "reflect-metadata"; -import {expect} from "chai"; -import {Connection} from "../../../../src/connection/Connection"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils"; -import {Post} from "./entity/Post"; +import {join as joinPaths} from "../../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../../deps/mocha.ts"; +import {expect} from "../../../deps/chai.ts"; +import {Connection} from "../../../../src/connection/Connection.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils.ts"; +import {Post} from "./entity/Post.ts"; describe("table inheritance > regular inheritance using extends keyword", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], })); beforeEach(() => reloadTestingDatabases(connections)); after(() => closeTestingConnections(connections)); @@ -35,3 +37,5 @@ describe("table inheritance > regular inheritance using extends keyword", () => }))); }); + +runIfMain(import.meta); diff --git a/test/functional/table-inheritance/single-table/basic-functionality/basic-functionality.ts b/test/functional/table-inheritance/single-table/basic-functionality/basic-functionality.ts index 5a76d5b0e..8522e8f39 100644 --- a/test/functional/table-inheritance/single-table/basic-functionality/basic-functionality.ts +++ b/test/functional/table-inheritance/single-table/basic-functionality/basic-functionality.ts @@ -1,18 +1,20 @@ -import "reflect-metadata"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils"; -import {Connection} from "../../../../../src/connection/Connection"; -import {Student} from "./entity/Student"; -import {Teacher} from "./entity/Teacher"; -import {Accountant} from "./entity/Accountant"; -import {Employee} from "./entity/Employee"; -import {Person} from "./entity/Person"; -import {expect} from "chai"; +import {join as joinPaths} from "../../../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../../../deps/mocha.ts"; +import {expect} from "../../../../deps/chai.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils.ts"; +import {Connection} from "../../../../../src/connection/Connection.ts"; +import {Student} from "./entity/Student.ts"; +import {Teacher} from "./entity/Teacher.ts"; +import {Accountant} from "./entity/Accountant.ts"; +import {Employee} from "./entity/Employee.ts"; +import {Person} from "./entity/Person.ts"; describe("table-inheritance > single-table > basic-functionality", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"] + entities: [joinPaths(__dirname, "/entity/*.ts")] })); beforeEach(() => reloadTestingDatabases(connections)); after(() => closeTestingConnections(connections)); @@ -341,3 +343,5 @@ describe("table-inheritance > single-table > basic-functionality", () => { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/table-inheritance/single-table/basic-functionality/entity/Accountant.ts b/test/functional/table-inheritance/single-table/basic-functionality/entity/Accountant.ts index 38a00c968..c8cb5c8a3 100644 --- a/test/functional/table-inheritance/single-table/basic-functionality/entity/Accountant.ts +++ b/test/functional/table-inheritance/single-table/basic-functionality/entity/Accountant.ts @@ -1,11 +1,11 @@ -import {Column} from "../../../../../../src/decorator/columns/Column"; -import {ChildEntity} from "../../../../../../src/decorator/entity/ChildEntity"; -import {Employee} from "./Employee"; +import {Column} from "../../../../../../src/decorator/columns/Column.ts"; +import {ChildEntity} from "../../../../../../src/decorator/entity/ChildEntity.ts"; +import {Employee} from "./Employee.ts"; @ChildEntity() export class Accountant extends Employee { - @Column() + @Column({ type: String }) department: string; } diff --git a/test/functional/table-inheritance/single-table/basic-functionality/entity/Employee.ts b/test/functional/table-inheritance/single-table/basic-functionality/entity/Employee.ts index 4502888cb..c940fa518 100644 --- a/test/functional/table-inheritance/single-table/basic-functionality/entity/Employee.ts +++ b/test/functional/table-inheritance/single-table/basic-functionality/entity/Employee.ts @@ -1,11 +1,11 @@ -import {Column} from "../../../../../../src/decorator/columns/Column"; -import {ChildEntity} from "../../../../../../src/decorator/entity/ChildEntity"; -import {Person} from "./Person"; +import {Column} from "../../../../../../src/decorator/columns/Column.ts"; +import {ChildEntity} from "../../../../../../src/decorator/entity/ChildEntity.ts"; +import {Person} from "./Person.ts"; @ChildEntity() export class Employee extends Person { - @Column() + @Column({ type: Number }) salary: number; } diff --git a/test/functional/table-inheritance/single-table/basic-functionality/entity/Person.ts b/test/functional/table-inheritance/single-table/basic-functionality/entity/Person.ts index abca8dc24..fe9267502 100644 --- a/test/functional/table-inheritance/single-table/basic-functionality/entity/Person.ts +++ b/test/functional/table-inheritance/single-table/basic-functionality/entity/Person.ts @@ -1,7 +1,7 @@ -import {Column} from "../../../../../../src/decorator/columns/Column"; -import {TableInheritance} from "../../../../../../src/decorator/entity/TableInheritance"; -import {Entity} from "../../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../../src/decorator/columns/PrimaryGeneratedColumn"; +import {Column} from "../../../../../../src/decorator/columns/Column.ts"; +import {TableInheritance} from "../../../../../../src/decorator/entity/TableInheritance.ts"; +import {Entity} from "../../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; @Entity() @TableInheritance({ column: { name: "type", type: "varchar" } }) @@ -10,7 +10,7 @@ export class Person { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) name: string; } diff --git a/test/functional/table-inheritance/single-table/basic-functionality/entity/Student.ts b/test/functional/table-inheritance/single-table/basic-functionality/entity/Student.ts index 33ed96145..c65fd4002 100644 --- a/test/functional/table-inheritance/single-table/basic-functionality/entity/Student.ts +++ b/test/functional/table-inheritance/single-table/basic-functionality/entity/Student.ts @@ -1,11 +1,11 @@ -import {Column} from "../../../../../../src/decorator/columns/Column"; -import {ChildEntity} from "../../../../../../src/decorator/entity/ChildEntity"; -import {Person} from "./Person"; +import {Column} from "../../../../../../src/decorator/columns/Column.ts"; +import {ChildEntity} from "../../../../../../src/decorator/entity/ChildEntity.ts"; +import {Person} from "./Person.ts"; @ChildEntity() export class Student extends Person { - @Column() + @Column({ type: String }) faculty: string; } diff --git a/test/functional/table-inheritance/single-table/basic-functionality/entity/Teacher.ts b/test/functional/table-inheritance/single-table/basic-functionality/entity/Teacher.ts index 33c83e283..4d867f1ab 100644 --- a/test/functional/table-inheritance/single-table/basic-functionality/entity/Teacher.ts +++ b/test/functional/table-inheritance/single-table/basic-functionality/entity/Teacher.ts @@ -1,11 +1,11 @@ -import {Column} from "../../../../../../src/decorator/columns/Column"; -import {ChildEntity} from "../../../../../../src/decorator/entity/ChildEntity"; -import {Employee} from "./Employee"; +import {Column} from "../../../../../../src/decorator/columns/Column.ts"; +import {ChildEntity} from "../../../../../../src/decorator/entity/ChildEntity.ts"; +import {Employee} from "./Employee.ts"; @ChildEntity() export class Teacher extends Employee { - @Column() + @Column({ type: String }) specialization: string; } diff --git a/test/functional/table-inheritance/single-table/database-option-inherited/database-option-inherited.ts b/test/functional/table-inheritance/single-table/database-option-inherited/database-option-inherited.ts index f08cf42c0..ebc5fad17 100644 --- a/test/functional/table-inheritance/single-table/database-option-inherited/database-option-inherited.ts +++ b/test/functional/table-inheritance/single-table/database-option-inherited/database-option-inherited.ts @@ -1,12 +1,15 @@ -import "reflect-metadata"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils"; -import {Connection} from "../../../../../src"; +import {join as joinPaths} from "../../../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../../../deps/mocha.ts"; +import "../../../../deps/chai.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils.ts"; +import {Connection} from "../../../../../src/index.ts"; describe("table-inheritance > single-table > database-option-inherited", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"] + entities: [joinPaths(__dirname, "/entity/*.ts")] })); beforeEach(() => reloadTestingDatabases(connections)); after(() => closeTestingConnections(connections)); @@ -19,3 +22,5 @@ describe("table-inheritance > single-table > database-option-inherited", () => { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/table-inheritance/single-table/database-option-inherited/entity/Employee.ts b/test/functional/table-inheritance/single-table/database-option-inherited/entity/Employee.ts index 20354d833..7c42ed68c 100644 --- a/test/functional/table-inheritance/single-table/database-option-inherited/entity/Employee.ts +++ b/test/functional/table-inheritance/single-table/database-option-inherited/entity/Employee.ts @@ -1,11 +1,11 @@ -import {ChildEntity, Column} from "../../../../../../src"; +import {ChildEntity, Column} from "../../../../../../src/index.ts"; -import {Person} from "./Person"; +import {Person} from "./Person.ts"; @ChildEntity() export class Employee extends Person { - @Column() + @Column({ type: Number }) salary: number; } diff --git a/test/functional/table-inheritance/single-table/database-option-inherited/entity/Person.ts b/test/functional/table-inheritance/single-table/database-option-inherited/entity/Person.ts index 35518ade0..5f3919f7d 100644 --- a/test/functional/table-inheritance/single-table/database-option-inherited/entity/Person.ts +++ b/test/functional/table-inheritance/single-table/database-option-inherited/entity/Person.ts @@ -1,4 +1,4 @@ -import {Column, Entity, PrimaryGeneratedColumn, TableInheritance} from "../../../../../../src"; +import {Column, Entity, PrimaryGeneratedColumn, TableInheritance} from "../../../../../../src/index.ts"; @Entity({database: "test"}) @TableInheritance({column: {name: "type", type: "varchar"}}) @@ -7,7 +7,7 @@ export class Person { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) name: string; } diff --git a/test/functional/table-inheritance/single-table/non-virtual-discriminator-column/entity/Employee.ts b/test/functional/table-inheritance/single-table/non-virtual-discriminator-column/entity/Employee.ts index 7861c9048..92e199158 100644 --- a/test/functional/table-inheritance/single-table/non-virtual-discriminator-column/entity/Employee.ts +++ b/test/functional/table-inheritance/single-table/non-virtual-discriminator-column/entity/Employee.ts @@ -1,11 +1,11 @@ -import {Column} from "../../../../../../src/decorator/columns/Column"; -import {ChildEntity} from "../../../../../../src/decorator/entity/ChildEntity"; -import {Person} from "./Person"; +import {Column} from "../../../../../../src/decorator/columns/Column.ts"; +import {ChildEntity} from "../../../../../../src/decorator/entity/ChildEntity.ts"; +import {Person} from "./Person.ts"; @ChildEntity("employee-type") export class Employee extends Person { - @Column() + @Column({ type: Number }) salary: number; } diff --git a/test/functional/table-inheritance/single-table/non-virtual-discriminator-column/entity/Person.ts b/test/functional/table-inheritance/single-table/non-virtual-discriminator-column/entity/Person.ts index f4dda7f4e..fe6dafd42 100644 --- a/test/functional/table-inheritance/single-table/non-virtual-discriminator-column/entity/Person.ts +++ b/test/functional/table-inheritance/single-table/non-virtual-discriminator-column/entity/Person.ts @@ -1,7 +1,7 @@ -import {Column} from "../../../../../../src/decorator/columns/Column"; -import {TableInheritance} from "../../../../../../src/decorator/entity/TableInheritance"; -import {Entity} from "../../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../../src/decorator/columns/PrimaryGeneratedColumn"; +import {Column} from "../../../../../../src/decorator/columns/Column.ts"; +import {TableInheritance} from "../../../../../../src/decorator/entity/TableInheritance.ts"; +import {Entity} from "../../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; @Entity() @TableInheritance({ column: { name: "type", type: "varchar" } }) @@ -10,10 +10,10 @@ export class Person { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) name: string; - @Column() + @Column({ type: String }) type: string; } diff --git a/test/functional/table-inheritance/single-table/non-virtual-discriminator-column/entity/Student.ts b/test/functional/table-inheritance/single-table/non-virtual-discriminator-column/entity/Student.ts index d30c684a2..dec3c6ae4 100644 --- a/test/functional/table-inheritance/single-table/non-virtual-discriminator-column/entity/Student.ts +++ b/test/functional/table-inheritance/single-table/non-virtual-discriminator-column/entity/Student.ts @@ -1,11 +1,11 @@ -import {Column} from "../../../../../../src/decorator/columns/Column"; -import {ChildEntity} from "../../../../../../src/decorator/entity/ChildEntity"; -import {Person} from "./Person"; +import {Column} from "../../../../../../src/decorator/columns/Column.ts"; +import {ChildEntity} from "../../../../../../src/decorator/entity/ChildEntity.ts"; +import {Person} from "./Person.ts"; @ChildEntity("student-type") export class Student extends Person { - @Column() + @Column({ type: String }) faculty: string; } diff --git a/test/functional/table-inheritance/single-table/non-virtual-discriminator-column/non-virtual-discriminator-column.ts b/test/functional/table-inheritance/single-table/non-virtual-discriminator-column/non-virtual-discriminator-column.ts index 700f9e616..3be034d82 100644 --- a/test/functional/table-inheritance/single-table/non-virtual-discriminator-column/non-virtual-discriminator-column.ts +++ b/test/functional/table-inheritance/single-table/non-virtual-discriminator-column/non-virtual-discriminator-column.ts @@ -1,15 +1,18 @@ -import "reflect-metadata"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils"; -import {Connection} from "../../../../../src/connection/Connection"; -import {Student} from "./entity/Student"; -import {Employee} from "./entity/Employee"; -import {Person} from "./entity/Person"; +import {join as joinPaths} from "../../../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../../../deps/mocha.ts"; +import "../../../../deps/chai.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../../utils/test-utils.ts"; +import {Connection} from "../../../../../src/connection/Connection.ts"; +import {Student} from "./entity/Student.ts"; +import {Employee} from "./entity/Employee.ts"; +import {Person} from "./entity/Person.ts"; describe("table-inheritance > single-table > non-virtual-discriminator-column", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"] + entities: [joinPaths(__dirname, "/entity/*.ts")] })); beforeEach(() => reloadTestingDatabases(connections)); after(() => closeTestingConnections(connections)); @@ -50,3 +53,5 @@ describe("table-inheritance > single-table > non-virtual-discriminator-column", }))); }); + +runIfMain(import.meta); diff --git a/test/functional/table-inheritance/single-table/relations/many-to-many/entity/Accountant.ts b/test/functional/table-inheritance/single-table/relations/many-to-many/entity/Accountant.ts index 1ef76aae5..347197573 100644 --- a/test/functional/table-inheritance/single-table/relations/many-to-many/entity/Accountant.ts +++ b/test/functional/table-inheritance/single-table/relations/many-to-many/entity/Accountant.ts @@ -1,8 +1,8 @@ -import {ChildEntity} from "../../../../../../../src/decorator/entity/ChildEntity"; -import {ManyToMany} from "../../../../../../../src/decorator/relations/ManyToMany"; -import {JoinTable} from "../../../../../../../src/decorator/relations/JoinTable"; -import {Employee} from "./Employee"; -import {Department} from "./Department"; +import {ChildEntity} from "../../../../../../../src/decorator/entity/ChildEntity.ts"; +import {ManyToMany} from "../../../../../../../src/decorator/relations/ManyToMany.ts"; +import {JoinTable} from "../../../../../../../src/decorator/relations/JoinTable.ts"; +import {Employee} from "./Employee.ts"; +import {Department} from "./Department.ts"; @ChildEntity() export class Accountant extends Employee { diff --git a/test/functional/table-inheritance/single-table/relations/many-to-many/entity/Department.ts b/test/functional/table-inheritance/single-table/relations/many-to-many/entity/Department.ts index 5261c738b..5b6975dff 100644 --- a/test/functional/table-inheritance/single-table/relations/many-to-many/entity/Department.ts +++ b/test/functional/table-inheritance/single-table/relations/many-to-many/entity/Department.ts @@ -1,8 +1,8 @@ -import {Column} from "../../../../../../../src/decorator/columns/Column"; -import {Entity} from "../../../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {ManyToMany} from "../../../../../../../src/decorator/relations/ManyToMany"; -import {Accountant} from "./Accountant"; +import {Column} from "../../../../../../../src/decorator/columns/Column.ts"; +import {Entity} from "../../../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {ManyToMany} from "../../../../../../../src/decorator/relations/ManyToMany.ts"; +import {Accountant} from "./Accountant.ts"; @Entity() export class Department { @@ -10,7 +10,7 @@ export class Department { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) name: string; @ManyToMany(type => Accountant, accountant => accountant.departments) diff --git a/test/functional/table-inheritance/single-table/relations/many-to-many/entity/Employee.ts b/test/functional/table-inheritance/single-table/relations/many-to-many/entity/Employee.ts index c02315cc3..045875df7 100644 --- a/test/functional/table-inheritance/single-table/relations/many-to-many/entity/Employee.ts +++ b/test/functional/table-inheritance/single-table/relations/many-to-many/entity/Employee.ts @@ -1,11 +1,11 @@ -import {Column} from "../../../../../../../src/decorator/columns/Column"; -import {ChildEntity} from "../../../../../../../src/decorator/entity/ChildEntity"; -import {Person} from "./Person"; +import {Column} from "../../../../../../../src/decorator/columns/Column.ts"; +import {ChildEntity} from "../../../../../../../src/decorator/entity/ChildEntity.ts"; +import {Person} from "./Person.ts"; @ChildEntity() export class Employee extends Person { - @Column() + @Column({ type: Number }) salary: number; } diff --git a/test/functional/table-inheritance/single-table/relations/many-to-many/entity/Faculty.ts b/test/functional/table-inheritance/single-table/relations/many-to-many/entity/Faculty.ts index 89f7ef94c..f556bb276 100644 --- a/test/functional/table-inheritance/single-table/relations/many-to-many/entity/Faculty.ts +++ b/test/functional/table-inheritance/single-table/relations/many-to-many/entity/Faculty.ts @@ -1,8 +1,8 @@ -import {Column} from "../../../../../../../src/decorator/columns/Column"; -import {Entity} from "../../../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {ManyToMany} from "../../../../../../../src/decorator/relations/ManyToMany"; -import {Student} from "./Student"; +import {Column} from "../../../../../../../src/decorator/columns/Column.ts"; +import {Entity} from "../../../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {ManyToMany} from "../../../../../../../src/decorator/relations/ManyToMany.ts"; +import {Student} from "./Student.ts"; @Entity() export class Faculty { @@ -10,7 +10,7 @@ export class Faculty { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) name: string; @ManyToMany(type => Student, student => student.faculties) diff --git a/test/functional/table-inheritance/single-table/relations/many-to-many/entity/Person.ts b/test/functional/table-inheritance/single-table/relations/many-to-many/entity/Person.ts index 64e01803e..ecade48eb 100644 --- a/test/functional/table-inheritance/single-table/relations/many-to-many/entity/Person.ts +++ b/test/functional/table-inheritance/single-table/relations/many-to-many/entity/Person.ts @@ -1,7 +1,7 @@ -import {Column} from "../../../../../../../src/decorator/columns/Column"; -import {TableInheritance} from "../../../../../../../src/decorator/entity/TableInheritance"; -import {Entity} from "../../../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../../../src/decorator/columns/PrimaryGeneratedColumn"; +import {Column} from "../../../../../../../src/decorator/columns/Column.ts"; +import {TableInheritance} from "../../../../../../../src/decorator/entity/TableInheritance.ts"; +import {Entity} from "../../../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; @Entity() @TableInheritance({ column: { name: "type", type: "varchar" } }) @@ -10,7 +10,7 @@ export class Person { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) name: string; } diff --git a/test/functional/table-inheritance/single-table/relations/many-to-many/entity/Specialization.ts b/test/functional/table-inheritance/single-table/relations/many-to-many/entity/Specialization.ts index e73a2846e..58086a00c 100644 --- a/test/functional/table-inheritance/single-table/relations/many-to-many/entity/Specialization.ts +++ b/test/functional/table-inheritance/single-table/relations/many-to-many/entity/Specialization.ts @@ -1,8 +1,8 @@ -import {Column} from "../../../../../../../src/decorator/columns/Column"; -import {Entity} from "../../../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {ManyToMany} from "../../../../../../../src/decorator/relations/ManyToMany"; -import {Teacher} from "./Teacher"; +import {Column} from "../../../../../../../src/decorator/columns/Column.ts"; +import {Entity} from "../../../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {ManyToMany} from "../../../../../../../src/decorator/relations/ManyToMany.ts"; +import {Teacher} from "./Teacher.ts"; @Entity() export class Specialization { @@ -10,7 +10,7 @@ export class Specialization { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) name: string; @ManyToMany(type => Teacher, teacher => teacher.specializations) diff --git a/test/functional/table-inheritance/single-table/relations/many-to-many/entity/Student.ts b/test/functional/table-inheritance/single-table/relations/many-to-many/entity/Student.ts index 0d685156f..a0180a49c 100644 --- a/test/functional/table-inheritance/single-table/relations/many-to-many/entity/Student.ts +++ b/test/functional/table-inheritance/single-table/relations/many-to-many/entity/Student.ts @@ -1,8 +1,8 @@ -import {ChildEntity} from "../../../../../../../src/decorator/entity/ChildEntity"; -import {ManyToMany} from "../../../../../../../src/decorator/relations/ManyToMany"; -import {Person} from "./Person"; -import {Faculty} from "./Faculty"; -import {JoinTable} from "../../../../../../../src/decorator/relations/JoinTable"; +import {ChildEntity} from "../../../../../../../src/decorator/entity/ChildEntity.ts"; +import {ManyToMany} from "../../../../../../../src/decorator/relations/ManyToMany.ts"; +import {Person} from "./Person.ts"; +import {Faculty} from "./Faculty.ts"; +import {JoinTable} from "../../../../../../../src/decorator/relations/JoinTable.ts"; @ChildEntity() export class Student extends Person { diff --git a/test/functional/table-inheritance/single-table/relations/many-to-many/entity/Teacher.ts b/test/functional/table-inheritance/single-table/relations/many-to-many/entity/Teacher.ts index a781fc223..be8867f97 100644 --- a/test/functional/table-inheritance/single-table/relations/many-to-many/entity/Teacher.ts +++ b/test/functional/table-inheritance/single-table/relations/many-to-many/entity/Teacher.ts @@ -1,8 +1,8 @@ -import {ChildEntity} from "../../../../../../../src/decorator/entity/ChildEntity"; -import {ManyToMany} from "../../../../../../../src/decorator/relations/ManyToMany"; -import {JoinTable} from "../../../../../../../src/decorator/relations/JoinTable"; -import {Employee} from "./Employee"; -import {Specialization} from "./Specialization"; +import {ChildEntity} from "../../../../../../../src/decorator/entity/ChildEntity.ts"; +import {ManyToMany} from "../../../../../../../src/decorator/relations/ManyToMany.ts"; +import {JoinTable} from "../../../../../../../src/decorator/relations/JoinTable.ts"; +import {Employee} from "./Employee.ts"; +import {Specialization} from "./Specialization.ts"; @ChildEntity() export class Teacher extends Employee { diff --git a/test/functional/table-inheritance/single-table/relations/many-to-many/many-to-many.ts b/test/functional/table-inheritance/single-table/relations/many-to-many/many-to-many.ts index 2fbc07ac7..b2af7d639 100644 --- a/test/functional/table-inheritance/single-table/relations/many-to-many/many-to-many.ts +++ b/test/functional/table-inheritance/single-table/relations/many-to-many/many-to-many.ts @@ -1,24 +1,28 @@ -import "reflect-metadata"; +import {join as joinPaths} from "../../../../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../../../../deps/mocha.ts"; +import "../../../../../deps/chai.ts"; import { + getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases -} from "../../../../../utils/test-utils"; -import {Connection} from "../../../../../../src/connection/Connection"; -import {Student} from "./entity/Student"; -import {Teacher} from "./entity/Teacher"; -import {Accountant} from "./entity/Accountant"; -import {Employee} from "./entity/Employee"; -import {Person} from "./entity/Person"; -import {Faculty} from "./entity/Faculty"; -import {Specialization} from "./entity/Specialization"; -import {Department} from "./entity/Department"; +} from "../../../../../utils/test-utils.ts"; +import {Connection} from "../../../../../../src/connection/Connection.ts"; +import {Student} from "./entity/Student.ts"; +import {Teacher} from "./entity/Teacher.ts"; +import {Accountant} from "./entity/Accountant.ts"; +import {Employee} from "./entity/Employee.ts"; +import {Person} from "./entity/Person.ts"; +import {Faculty} from "./entity/Faculty.ts"; +import {Specialization} from "./entity/Specialization.ts"; +import {Department} from "./entity/Department.ts"; describe("table-inheritance > single-table > relations > many-to-many", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], })); beforeEach(() => reloadTestingDatabases(connections)); after(() => closeTestingConnections(connections)); @@ -233,3 +237,5 @@ describe("table-inheritance > single-table > relations > many-to-many", () => { }); }); + +runIfMain(import.meta); diff --git a/test/functional/table-inheritance/single-table/relations/one-to-many/entity/Accountant.ts b/test/functional/table-inheritance/single-table/relations/one-to-many/entity/Accountant.ts index 5e7d99a23..9205f5f99 100644 --- a/test/functional/table-inheritance/single-table/relations/one-to-many/entity/Accountant.ts +++ b/test/functional/table-inheritance/single-table/relations/one-to-many/entity/Accountant.ts @@ -1,7 +1,7 @@ -import {ChildEntity} from "../../../../../../../src/decorator/entity/ChildEntity"; -import {OneToMany} from "../../../../../../../src/decorator/relations/OneToMany"; -import {Employee} from "./Employee"; -import {Department} from "./Department"; +import {ChildEntity} from "../../../../../../../src/decorator/entity/ChildEntity.ts"; +import {OneToMany} from "../../../../../../../src/decorator/relations/OneToMany.ts"; +import {Employee} from "./Employee.ts"; +import {Department} from "./Department.ts"; @ChildEntity() export class Accountant extends Employee { diff --git a/test/functional/table-inheritance/single-table/relations/one-to-many/entity/Department.ts b/test/functional/table-inheritance/single-table/relations/one-to-many/entity/Department.ts index c540747e5..f87f02b9d 100644 --- a/test/functional/table-inheritance/single-table/relations/one-to-many/entity/Department.ts +++ b/test/functional/table-inheritance/single-table/relations/one-to-many/entity/Department.ts @@ -1,8 +1,8 @@ -import {Column} from "../../../../../../../src/decorator/columns/Column"; -import {Entity} from "../../../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {ManyToOne} from "../../../../../../../src/decorator/relations/ManyToOne"; -import {Accountant} from "./Accountant"; +import {Column} from "../../../../../../../src/decorator/columns/Column.ts"; +import {Entity} from "../../../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {ManyToOne} from "../../../../../../../src/decorator/relations/ManyToOne.ts"; +import {Accountant} from "./Accountant.ts"; @Entity() export class Department { @@ -10,7 +10,7 @@ export class Department { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) name: string; @ManyToOne(type => Accountant, accountant => accountant.departments) diff --git a/test/functional/table-inheritance/single-table/relations/one-to-many/entity/Employee.ts b/test/functional/table-inheritance/single-table/relations/one-to-many/entity/Employee.ts index c02315cc3..045875df7 100644 --- a/test/functional/table-inheritance/single-table/relations/one-to-many/entity/Employee.ts +++ b/test/functional/table-inheritance/single-table/relations/one-to-many/entity/Employee.ts @@ -1,11 +1,11 @@ -import {Column} from "../../../../../../../src/decorator/columns/Column"; -import {ChildEntity} from "../../../../../../../src/decorator/entity/ChildEntity"; -import {Person} from "./Person"; +import {Column} from "../../../../../../../src/decorator/columns/Column.ts"; +import {ChildEntity} from "../../../../../../../src/decorator/entity/ChildEntity.ts"; +import {Person} from "./Person.ts"; @ChildEntity() export class Employee extends Person { - @Column() + @Column({ type: Number }) salary: number; } diff --git a/test/functional/table-inheritance/single-table/relations/one-to-many/entity/Faculty.ts b/test/functional/table-inheritance/single-table/relations/one-to-many/entity/Faculty.ts index bfdcf3696..964f4e713 100644 --- a/test/functional/table-inheritance/single-table/relations/one-to-many/entity/Faculty.ts +++ b/test/functional/table-inheritance/single-table/relations/one-to-many/entity/Faculty.ts @@ -1,8 +1,8 @@ -import {Column} from "../../../../../../../src/decorator/columns/Column"; -import {Entity} from "../../../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {ManyToOne} from "../../../../../../../src/decorator/relations/ManyToOne"; -import {Student} from "./Student"; +import {Column} from "../../../../../../../src/decorator/columns/Column.ts"; +import {Entity} from "../../../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {ManyToOne} from "../../../../../../../src/decorator/relations/ManyToOne.ts"; +import {Student} from "./Student.ts"; @Entity() export class Faculty { @@ -10,7 +10,7 @@ export class Faculty { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) name: string; @ManyToOne(type => Student, student => student.faculties) diff --git a/test/functional/table-inheritance/single-table/relations/one-to-many/entity/Person.ts b/test/functional/table-inheritance/single-table/relations/one-to-many/entity/Person.ts index 64e01803e..ecade48eb 100644 --- a/test/functional/table-inheritance/single-table/relations/one-to-many/entity/Person.ts +++ b/test/functional/table-inheritance/single-table/relations/one-to-many/entity/Person.ts @@ -1,7 +1,7 @@ -import {Column} from "../../../../../../../src/decorator/columns/Column"; -import {TableInheritance} from "../../../../../../../src/decorator/entity/TableInheritance"; -import {Entity} from "../../../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../../../src/decorator/columns/PrimaryGeneratedColumn"; +import {Column} from "../../../../../../../src/decorator/columns/Column.ts"; +import {TableInheritance} from "../../../../../../../src/decorator/entity/TableInheritance.ts"; +import {Entity} from "../../../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; @Entity() @TableInheritance({ column: { name: "type", type: "varchar" } }) @@ -10,7 +10,7 @@ export class Person { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) name: string; } diff --git a/test/functional/table-inheritance/single-table/relations/one-to-many/entity/Specialization.ts b/test/functional/table-inheritance/single-table/relations/one-to-many/entity/Specialization.ts index 63891c7ab..de97205f8 100644 --- a/test/functional/table-inheritance/single-table/relations/one-to-many/entity/Specialization.ts +++ b/test/functional/table-inheritance/single-table/relations/one-to-many/entity/Specialization.ts @@ -1,8 +1,8 @@ -import {Column} from "../../../../../../../src/decorator/columns/Column"; -import {Entity} from "../../../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {ManyToOne} from "../../../../../../../src/decorator/relations/ManyToOne"; -import {Teacher} from "./Teacher"; +import {Column} from "../../../../../../../src/decorator/columns/Column.ts"; +import {Entity} from "../../../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {ManyToOne} from "../../../../../../../src/decorator/relations/ManyToOne.ts"; +import {Teacher} from "./Teacher.ts"; @Entity() export class Specialization { @@ -10,7 +10,7 @@ export class Specialization { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) name: string; @ManyToOne(type => Teacher, teacher => teacher.specializations) diff --git a/test/functional/table-inheritance/single-table/relations/one-to-many/entity/Student.ts b/test/functional/table-inheritance/single-table/relations/one-to-many/entity/Student.ts index 0a78dbd62..17fe2d241 100644 --- a/test/functional/table-inheritance/single-table/relations/one-to-many/entity/Student.ts +++ b/test/functional/table-inheritance/single-table/relations/one-to-many/entity/Student.ts @@ -1,7 +1,7 @@ -import {ChildEntity} from "../../../../../../../src/decorator/entity/ChildEntity"; -import {OneToMany} from "../../../../../../../src/decorator/relations/OneToMany"; -import {Person} from "./Person"; -import {Faculty} from "./Faculty"; +import {ChildEntity} from "../../../../../../../src/decorator/entity/ChildEntity.ts"; +import {OneToMany} from "../../../../../../../src/decorator/relations/OneToMany.ts"; +import {Person} from "./Person.ts"; +import {Faculty} from "./Faculty.ts"; @ChildEntity() export class Student extends Person { diff --git a/test/functional/table-inheritance/single-table/relations/one-to-many/entity/Teacher.ts b/test/functional/table-inheritance/single-table/relations/one-to-many/entity/Teacher.ts index 8d9ae87d3..00d6339f2 100644 --- a/test/functional/table-inheritance/single-table/relations/one-to-many/entity/Teacher.ts +++ b/test/functional/table-inheritance/single-table/relations/one-to-many/entity/Teacher.ts @@ -1,7 +1,7 @@ -import {ChildEntity} from "../../../../../../../src/decorator/entity/ChildEntity"; -import {OneToMany} from "../../../../../../../src/decorator/relations/OneToMany"; -import {Employee} from "./Employee"; -import {Specialization} from "./Specialization"; +import {ChildEntity} from "../../../../../../../src/decorator/entity/ChildEntity.ts"; +import {OneToMany} from "../../../../../../../src/decorator/relations/OneToMany.ts"; +import {Employee} from "./Employee.ts"; +import {Specialization} from "./Specialization.ts"; @ChildEntity() export class Teacher extends Employee { diff --git a/test/functional/table-inheritance/single-table/relations/one-to-many/one-to-many.ts b/test/functional/table-inheritance/single-table/relations/one-to-many/one-to-many.ts index e68285e9b..43e4c6229 100644 --- a/test/functional/table-inheritance/single-table/relations/one-to-many/one-to-many.ts +++ b/test/functional/table-inheritance/single-table/relations/one-to-many/one-to-many.ts @@ -1,24 +1,28 @@ -import "reflect-metadata"; +import {join as joinPaths} from "../../../../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../../../../deps/mocha.ts"; +import "../../../../../deps/chai.ts"; import { + getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases -} from "../../../../../utils/test-utils"; -import {Connection} from "../../../../../../src/connection/Connection"; -import {Student} from "./entity/Student"; -import {Teacher} from "./entity/Teacher"; -import {Accountant} from "./entity/Accountant"; -import {Employee} from "./entity/Employee"; -import {Person} from "./entity/Person"; -import {Faculty} from "./entity/Faculty"; -import {Specialization} from "./entity/Specialization"; -import {Department} from "./entity/Department"; +} from "../../../../../utils/test-utils.ts"; +import {Connection} from "../../../../../../src/connection/Connection.ts"; +import {Student} from "./entity/Student.ts"; +import {Teacher} from "./entity/Teacher.ts"; +import {Accountant} from "./entity/Accountant.ts"; +import {Employee} from "./entity/Employee.ts"; +import {Person} from "./entity/Person.ts"; +import {Faculty} from "./entity/Faculty.ts"; +import {Specialization} from "./entity/Specialization.ts"; +import {Department} from "./entity/Department.ts"; describe("table-inheritance > single-table > relations > one-to-many", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"] + entities: [joinPaths(__dirname, "/entity/*.ts")] })); beforeEach(() => reloadTestingDatabases(connections)); after(() => closeTestingConnections(connections)); @@ -177,3 +181,5 @@ describe("table-inheritance > single-table > relations > one-to-many", () => { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/transaction/database-specific-isolation/entity/Category.ts b/test/functional/transaction/database-specific-isolation/entity/Category.ts index 0095127bd..fdbf6b325 100644 --- a/test/functional/transaction/database-specific-isolation/entity/Category.ts +++ b/test/functional/transaction/database-specific-isolation/entity/Category.ts @@ -1,6 +1,6 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../src/decorator/columns/Column"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; @Entity() export class Category { @@ -8,7 +8,7 @@ export class Category { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) name: string; -} \ No newline at end of file +} diff --git a/test/functional/transaction/database-specific-isolation/entity/Post.ts b/test/functional/transaction/database-specific-isolation/entity/Post.ts index b65476c52..f09d1969a 100644 --- a/test/functional/transaction/database-specific-isolation/entity/Post.ts +++ b/test/functional/transaction/database-specific-isolation/entity/Post.ts @@ -1,6 +1,6 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../src/decorator/columns/Column"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; @Entity() export class Post { @@ -8,7 +8,7 @@ export class Post { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) title: string; -} \ No newline at end of file +} diff --git a/test/functional/transaction/database-specific-isolation/full-isolation-support.ts b/test/functional/transaction/database-specific-isolation/full-isolation-support.ts index 0931806a9..6122dee20 100644 --- a/test/functional/transaction/database-specific-isolation/full-isolation-support.ts +++ b/test/functional/transaction/database-specific-isolation/full-isolation-support.ts @@ -1,16 +1,18 @@ -import "reflect-metadata"; -import {SapDriver} from "../../../../src/driver/sap/SapDriver"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils"; -import {Connection} from "../../../../src/connection/Connection"; -import {Post} from "./entity/Post"; -import {Category} from "./entity/Category"; -import {expect} from "chai"; +import {join as joinPaths} from "../../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../../deps/mocha.ts"; +import {expect} from "../../../deps/chai.ts"; +import {SapDriver} from "../../../../src/driver/sap/SapDriver.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils.ts"; +import {Connection} from "../../../../src/connection/Connection.ts"; +import {Post} from "./entity/Post.ts"; +import {Category} from "./entity/Category.ts"; describe("transaction > transaction with full isolation support", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], enabledDrivers: ["mysql", "mssql", "postgres", "sap"] // todo: for some reasons mariadb tests are not passing here })); beforeEach(() => reloadTestingDatabases(connections)); @@ -159,3 +161,5 @@ describe("transaction > transaction with full isolation support", () => { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/transaction/database-specific-isolation/oracle-isolation.ts b/test/functional/transaction/database-specific-isolation/oracle-isolation.ts index dd39b2220..a6ec1ed6a 100644 --- a/test/functional/transaction/database-specific-isolation/oracle-isolation.ts +++ b/test/functional/transaction/database-specific-isolation/oracle-isolation.ts @@ -1,15 +1,17 @@ -import "reflect-metadata"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils"; -import {Connection} from "../../../../src/connection/Connection"; -import {Post} from "./entity/Post"; -import {Category} from "./entity/Category"; -import {expect} from "chai"; +import {join as joinPaths} from "../../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../../deps/mocha.ts"; +import {expect} from "../../../deps/chai.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils.ts"; +import {Connection} from "../../../../src/connection/Connection.ts"; +import {Post} from "./entity/Post.ts"; +import {Category} from "./entity/Category.ts"; describe("transaction > transaction with oracle connection partial isolation support", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], enabledDrivers: ["oracle"] // todo: for some reasons mariadb tests are not passing here })); beforeEach(() => reloadTestingDatabases(connections)); @@ -85,3 +87,5 @@ describe("transaction > transaction with oracle connection partial isolation sup }))); }); + +runIfMain(import.meta); diff --git a/test/functional/transaction/database-specific-isolation/sqlite-isolation.ts b/test/functional/transaction/database-specific-isolation/sqlite-isolation.ts index 907cb0da2..9f96b441f 100644 --- a/test/functional/transaction/database-specific-isolation/sqlite-isolation.ts +++ b/test/functional/transaction/database-specific-isolation/sqlite-isolation.ts @@ -1,15 +1,17 @@ -import "reflect-metadata"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils"; -import {Connection} from "../../../../src/connection/Connection"; -import {Post} from "./entity/Post"; -import {Category} from "./entity/Category"; -import {expect} from "chai"; +import {join as joinPaths} from "../../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../../deps/mocha.ts"; +import {expect} from "../../../deps/chai.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils.ts"; +import {Connection} from "../../../../src/connection/Connection.ts"; +import {Post} from "./entity/Post.ts"; +import {Category} from "./entity/Category.ts"; describe("transaction > transaction with sqlite connection partial isolation support", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], enabledDrivers: ["sqlite"] // todo: for some reasons mariadb tests are not passing here })); beforeEach(() => reloadTestingDatabases(connections)); @@ -85,3 +87,5 @@ describe("transaction > transaction with sqlite connection partial isolation sup }))); }); + +runIfMain(import.meta); diff --git a/test/functional/transaction/return-data-from-transaction/entity/Category.ts b/test/functional/transaction/return-data-from-transaction/entity/Category.ts index a7bcef2c8..fdbf6b325 100644 --- a/test/functional/transaction/return-data-from-transaction/entity/Category.ts +++ b/test/functional/transaction/return-data-from-transaction/entity/Category.ts @@ -1,6 +1,6 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../src/decorator/columns/Column"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; @Entity() export class Category { @@ -8,7 +8,7 @@ export class Category { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) name: string; } diff --git a/test/functional/transaction/return-data-from-transaction/entity/Post.ts b/test/functional/transaction/return-data-from-transaction/entity/Post.ts index 440ff600d..f09d1969a 100644 --- a/test/functional/transaction/return-data-from-transaction/entity/Post.ts +++ b/test/functional/transaction/return-data-from-transaction/entity/Post.ts @@ -1,6 +1,6 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../src/decorator/columns/Column"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; @Entity() export class Post { @@ -8,7 +8,7 @@ export class Post { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) title: string; } diff --git a/test/functional/transaction/return-data-from-transaction/return-data-from-transaction.ts b/test/functional/transaction/return-data-from-transaction/return-data-from-transaction.ts index db10856a4..b78058581 100644 --- a/test/functional/transaction/return-data-from-transaction/return-data-from-transaction.ts +++ b/test/functional/transaction/return-data-from-transaction/return-data-from-transaction.ts @@ -1,15 +1,17 @@ -import "reflect-metadata"; -import {createTestingConnections, closeTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils"; -import {Connection} from "../../../../src/connection/Connection"; -import {Post} from "./entity/Post"; -import {Category} from "./entity/Category"; -import {expect} from "chai"; +import {join as joinPaths} from "../../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../../deps/mocha.ts"; +import {expect} from "../../../deps/chai.ts"; +import {getDirnameOfCurrentModule, createTestingConnections, closeTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils.ts"; +import {Connection} from "../../../../src/connection/Connection.ts"; +import {Post} from "./entity/Post.ts"; +import {Category} from "./entity/Category.ts"; describe("transaction > return data from transaction", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], enabledDrivers: ["mysql", "sqlite", "postgres"] // todo: for some reasons mariadb tests are not passing here })); beforeEach(() => reloadTestingDatabases(connections)); @@ -86,3 +88,5 @@ describe("transaction > return data from transaction", () => { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/transaction/single-query-runner/entity/Post.ts b/test/functional/transaction/single-query-runner/entity/Post.ts index 3373f10d9..f80ed88d2 100644 --- a/test/functional/transaction/single-query-runner/entity/Post.ts +++ b/test/functional/transaction/single-query-runner/entity/Post.ts @@ -1,6 +1,6 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../src/decorator/columns/Column"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; @Entity() export class Post { @@ -8,7 +8,7 @@ export class Post { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) title: string; constructor(id?: number, title?: string) { @@ -18,4 +18,4 @@ export class Post { this.title = title; } -} \ No newline at end of file +} diff --git a/test/functional/transaction/single-query-runner/repository/PostRepository.ts b/test/functional/transaction/single-query-runner/repository/PostRepository.ts index f8b9fe061..9c368086f 100644 --- a/test/functional/transaction/single-query-runner/repository/PostRepository.ts +++ b/test/functional/transaction/single-query-runner/repository/PostRepository.ts @@ -1,7 +1,7 @@ -import {AbstractRepository} from "../../../../../src/repository/AbstractRepository"; -import {Post} from "../entity/Post"; -import {EntityManager} from "../../../../../src/entity-manager/EntityManager"; -import {EntityRepository} from "../../../../../src/decorator/EntityRepository"; +import {AbstractRepository} from "../../../../../src/repository/AbstractRepository.ts"; +import {Post} from "../entity/Post.ts"; +import {EntityManager} from "../../../../../src/entity-manager/EntityManager.ts"; +import {EntityRepository} from "../../../../../src/decorator/EntityRepository.ts"; @EntityRepository() export class PostRepository extends AbstractRepository { @@ -14,4 +14,4 @@ export class PostRepository extends AbstractRepository { return this.manager; } -} \ No newline at end of file +} diff --git a/test/functional/transaction/single-query-runner/single-query-runner.ts b/test/functional/transaction/single-query-runner/single-query-runner.ts index 720f4e595..9b1f925dd 100644 --- a/test/functional/transaction/single-query-runner/single-query-runner.ts +++ b/test/functional/transaction/single-query-runner/single-query-runner.ts @@ -1,15 +1,17 @@ -import "reflect-metadata"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils"; -import {Connection} from "../../../../src/connection/Connection"; -import {Post} from "./entity/Post"; -import {expect} from "chai"; -import {PostRepository} from "./repository/PostRepository"; +import {join as joinPaths} from "../../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../../deps/mocha.ts"; +import {expect} from "../../../deps/chai.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils.ts"; +import {Connection} from "../../../../src/connection/Connection.ts"; +import {Post} from "./entity/Post.ts"; +import {PostRepository} from "./repository/PostRepository.ts"; describe("transaction > single query runner", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], })); beforeEach(() => reloadTestingDatabases(connections)); after(() => closeTestingConnections(connections)); @@ -59,3 +61,5 @@ describe("transaction > single query runner", () => { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/transaction/transaction-decorator/controller/PostController.ts b/test/functional/transaction/transaction-decorator/controller/PostController.ts index 385fccade..8a101e66d 100644 --- a/test/functional/transaction/transaction-decorator/controller/PostController.ts +++ b/test/functional/transaction/transaction-decorator/controller/PostController.ts @@ -1,12 +1,12 @@ -import {Repository} from "../../../../../src/repository/Repository"; -import {Transaction} from "../../../../../src/decorator/transaction/Transaction"; -import {TransactionManager} from "../../../../../src/decorator/transaction/TransactionManager"; -import {TransactionRepository} from "../../../../../src/decorator/transaction/TransactionRepository"; -import {EntityManager} from "../../../../../src/entity-manager/EntityManager"; +import {Repository} from "../../../../../src/repository/Repository.ts"; +import {Transaction} from "../../../../../src/decorator/transaction/Transaction.ts"; +import {TransactionManager} from "../../../../../src/decorator/transaction/TransactionManager.ts"; +// import {TransactionRepository} from "../../../../../src/decorator/transaction/TransactionRepository.ts"; +import {EntityManager} from "../../../../../src/entity-manager/EntityManager.ts"; -import {Post} from "../entity/Post"; -import {Category} from "../entity/Category"; -import {CategoryRepository} from "../repository/CategoryRepository"; +import {Post} from "../entity/Post.ts"; +import {Category} from "../entity/Category.ts"; +import {CategoryRepository} from "../repository/CategoryRepository.ts"; export class PostController { @@ -22,12 +22,13 @@ export class PostController { await entityManager.save(category); } + // TODO(uki00a) `@TransactionRepository` is not supported. @Transaction("mysql") // "mysql" is a connection name. you can not pass it if you are using default connection. async saveWithRepository( post: Post, category: Category, - @TransactionRepository(Post) postRepository: Repository, - @TransactionRepository() categoryRepository: CategoryRepository, + /*@TransactionRepository(Post)*/postRepository: Repository, + /*@TransactionRepository()*/categoryRepository: CategoryRepository, ) { await postRepository.save(post); await categoryRepository.save(category); @@ -41,4 +42,4 @@ export class PostController { await entityManager.save(category); } -} \ No newline at end of file +} diff --git a/test/functional/transaction/transaction-decorator/entity/Category.ts b/test/functional/transaction/transaction-decorator/entity/Category.ts index 0095127bd..fdbf6b325 100644 --- a/test/functional/transaction/transaction-decorator/entity/Category.ts +++ b/test/functional/transaction/transaction-decorator/entity/Category.ts @@ -1,6 +1,6 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../src/decorator/columns/Column"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; @Entity() export class Category { @@ -8,7 +8,7 @@ export class Category { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) name: string; -} \ No newline at end of file +} diff --git a/test/functional/transaction/transaction-decorator/entity/Post.ts b/test/functional/transaction/transaction-decorator/entity/Post.ts index b65476c52..f09d1969a 100644 --- a/test/functional/transaction/transaction-decorator/entity/Post.ts +++ b/test/functional/transaction/transaction-decorator/entity/Post.ts @@ -1,6 +1,6 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../src/decorator/columns/Column"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; @Entity() export class Post { @@ -8,7 +8,7 @@ export class Post { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) title: string; -} \ No newline at end of file +} diff --git a/test/functional/transaction/transaction-decorator/repository/CategoryRepository.ts b/test/functional/transaction/transaction-decorator/repository/CategoryRepository.ts index a49b586a8..a6d00dd4a 100644 --- a/test/functional/transaction/transaction-decorator/repository/CategoryRepository.ts +++ b/test/functional/transaction/transaction-decorator/repository/CategoryRepository.ts @@ -1,6 +1,6 @@ -import { Repository } from "../../../../../src/repository/Repository"; -import { EntityRepository } from "../../../../../src/decorator/EntityRepository"; -import {Category} from "../entity/Category"; +import { Repository } from "../../../../../src/repository/Repository.ts"; +import { EntityRepository } from "../../../../../src/decorator/EntityRepository.ts"; +import {Category} from "../entity/Category.ts"; @EntityRepository(Category) export class CategoryRepository extends Repository { @@ -9,4 +9,4 @@ export class CategoryRepository extends Repository { return this.findOne({ name }); } -} \ No newline at end of file +} diff --git a/test/functional/transaction/transaction-decorator/transaction-decorator.ts b/test/functional/transaction/transaction-decorator/transaction-decorator.ts index 651ce08fc..ebb02ccc3 100644 --- a/test/functional/transaction/transaction-decorator/transaction-decorator.ts +++ b/test/functional/transaction/transaction-decorator/transaction-decorator.ts @@ -1,16 +1,18 @@ -import "reflect-metadata"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils"; -import {Connection} from "../../../../src/connection/Connection"; -import {Post} from "./entity/Post"; -import {expect} from "chai"; -import {PostController} from "./controller/PostController"; -import {Category} from "./entity/Category"; +import {join as joinPaths} from "../../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../../deps/mocha.ts"; +import {expect} from "../../../deps/chai.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils.ts"; +import {Connection} from "../../../../src/connection/Connection.ts"; +import {Post} from "./entity/Post.ts"; +import {PostController} from "./controller/PostController.ts"; +import {Category} from "./entity/Category.ts"; describe("transaction > method wrapped into transaction decorator", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*{.js,.ts}")], enabledDrivers: ["mysql"] // since @Transaction accepts a specific connection name we can use only one connection and its name })); beforeEach(() => reloadTestingDatabases(connections)); @@ -116,7 +118,8 @@ describe("transaction > method wrapped into transaction decorator", () => { }))); - it("should inject repository and custom repository into method decorated with @Transaction", () => Promise.all(connections.map(async connection => { + // TODO(uki00a) Remove `.skip` when `@TransactionRepository` is supported. + it.skip("should inject repository and custom repository into method decorated with @Transaction", () => Promise.all(connections.map(async connection => { const post = new Post(); post.title = "successfully saved post"; @@ -125,7 +128,7 @@ describe("transaction > method wrapped into transaction decorator", () => { // call controller method const savedCategory = await controller.saveWithRepository.apply(controller, [post, category]); - + // controller should successfully call custom repository method and return the found entity expect(savedCategory).not.to.be.undefined; savedCategory!.should.be.eql(category); @@ -163,3 +166,5 @@ describe("transaction > method wrapped into transaction decorator", () => { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/transaction/transaction-in-entity-manager/entity/Category.ts b/test/functional/transaction/transaction-in-entity-manager/entity/Category.ts index 0095127bd..fdbf6b325 100644 --- a/test/functional/transaction/transaction-in-entity-manager/entity/Category.ts +++ b/test/functional/transaction/transaction-in-entity-manager/entity/Category.ts @@ -1,6 +1,6 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../src/decorator/columns/Column"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; @Entity() export class Category { @@ -8,7 +8,7 @@ export class Category { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) name: string; -} \ No newline at end of file +} diff --git a/test/functional/transaction/transaction-in-entity-manager/entity/Post.ts b/test/functional/transaction/transaction-in-entity-manager/entity/Post.ts index b65476c52..f09d1969a 100644 --- a/test/functional/transaction/transaction-in-entity-manager/entity/Post.ts +++ b/test/functional/transaction/transaction-in-entity-manager/entity/Post.ts @@ -1,6 +1,6 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../src/decorator/columns/Column"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; @Entity() export class Post { @@ -8,7 +8,7 @@ export class Post { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) title: string; -} \ No newline at end of file +} diff --git a/test/functional/transaction/transaction-in-entity-manager/transaction-in-entity-manager.ts b/test/functional/transaction/transaction-in-entity-manager/transaction-in-entity-manager.ts index 9b20840dc..c73938815 100644 --- a/test/functional/transaction/transaction-in-entity-manager/transaction-in-entity-manager.ts +++ b/test/functional/transaction/transaction-in-entity-manager/transaction-in-entity-manager.ts @@ -1,15 +1,17 @@ -import "reflect-metadata"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils"; -import {Connection} from "../../../../src/connection/Connection"; -import {Post} from "./entity/Post"; -import {Category} from "./entity/Category"; -import {expect} from "chai"; +import {join as joinPaths} from "../../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../../deps/mocha.ts"; +import {expect} from "../../../deps/chai.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils.ts"; +import {Connection} from "../../../../src/connection/Connection.ts"; +import {Post} from "./entity/Post.ts"; +import {Category} from "./entity/Category.ts"; describe("transaction > transaction with entity manager", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], enabledDrivers: ["mysql", "sqlite", "postgres"] // todo: for some reasons mariadb tests are not passing here })); beforeEach(() => reloadTestingDatabases(connections)); @@ -100,3 +102,5 @@ describe("transaction > transaction with entity manager", () => { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/tree-tables/closure-table/closure-table.ts b/test/functional/tree-tables/closure-table/closure-table.ts index 19cda4818..c49d2c14b 100644 --- a/test/functional/tree-tables/closure-table/closure-table.ts +++ b/test/functional/tree-tables/closure-table/closure-table.ts @@ -1,7 +1,8 @@ -import "reflect-metadata"; -import {Category} from "./entity/Category"; -import {Connection} from "../../../../src/connection/Connection"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils"; +import {runIfMain} from "../../../deps/mocha.ts"; +import "../../../deps/chai.ts"; +import {Category} from "./entity/Category.ts"; +import {Connection} from "../../../../src/connection/Connection.ts"; +import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils.ts"; describe("tree tables > closure-table", () => { @@ -189,3 +190,5 @@ describe("tree tables > closure-table", () => { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/tree-tables/closure-table/entity/Category.ts b/test/functional/tree-tables/closure-table/entity/Category.ts index 0a9db324d..2fd1e28b1 100644 --- a/test/functional/tree-tables/closure-table/entity/Category.ts +++ b/test/functional/tree-tables/closure-table/entity/Category.ts @@ -1,9 +1,9 @@ -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {TreeParent} from "../../../../../src/decorator/tree/TreeParent"; -import {TreeChildren} from "../../../../../src/decorator/tree/TreeChildren"; -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {Tree} from "../../../../../src/decorator/tree/Tree"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {TreeParent} from "../../../../../src/decorator/tree/TreeParent.ts"; +import {TreeChildren} from "../../../../../src/decorator/tree/TreeChildren.ts"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {Tree} from "../../../../../src/decorator/tree/Tree.ts"; @Entity() @Tree("closure-table") @@ -12,9 +12,9 @@ export class Category { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) name: string; - + @TreeParent() parentCategory: Category; @@ -24,4 +24,4 @@ export class Category { // @TreeLevelColumn() // level: number; -} \ No newline at end of file +} diff --git a/test/functional/tree-tables/materialized-path/entity/Category.ts b/test/functional/tree-tables/materialized-path/entity/Category.ts index d33e5887f..ae7d2353a 100644 --- a/test/functional/tree-tables/materialized-path/entity/Category.ts +++ b/test/functional/tree-tables/materialized-path/entity/Category.ts @@ -1,9 +1,9 @@ -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {TreeParent} from "../../../../../src/decorator/tree/TreeParent"; -import {TreeChildren} from "../../../../../src/decorator/tree/TreeChildren"; -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {Tree} from "../../../../../src/decorator/tree/Tree"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {TreeParent} from "../../../../../src/decorator/tree/TreeParent.ts"; +import {TreeChildren} from "../../../../../src/decorator/tree/TreeChildren.ts"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {Tree} from "../../../../../src/decorator/tree/Tree.ts"; @Entity() @Tree("materialized-path") @@ -12,7 +12,7 @@ export class Category { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) name: string; @TreeParent() @@ -24,4 +24,4 @@ export class Category { // @TreeLevelColumn() // level: number; -} \ No newline at end of file +} diff --git a/test/functional/tree-tables/materialized-path/materialized-path.ts b/test/functional/tree-tables/materialized-path/materialized-path.ts index 2986c445a..c9ea62862 100644 --- a/test/functional/tree-tables/materialized-path/materialized-path.ts +++ b/test/functional/tree-tables/materialized-path/materialized-path.ts @@ -1,7 +1,8 @@ -import "reflect-metadata"; -import {Category} from "./entity/Category"; -import {Connection} from "../../../../src/connection/Connection"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils"; +import {runIfMain} from "../../../deps/mocha.ts"; +import "../../../deps/chai.ts"; +import {Category} from "./entity/Category.ts"; +import {Connection} from "../../../../src/connection/Connection.ts"; +import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils.ts"; describe("tree tables > materialized-path", () => { @@ -165,3 +166,5 @@ describe("tree tables > materialized-path", () => { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/tree-tables/nested-set/entity/Category.ts b/test/functional/tree-tables/nested-set/entity/Category.ts index 316cb7865..ac4e47236 100644 --- a/test/functional/tree-tables/nested-set/entity/Category.ts +++ b/test/functional/tree-tables/nested-set/entity/Category.ts @@ -1,9 +1,9 @@ -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {TreeParent} from "../../../../../src/decorator/tree/TreeParent"; -import {TreeChildren} from "../../../../../src/decorator/tree/TreeChildren"; -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {Tree} from "../../../../../src/decorator/tree/Tree"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {TreeParent} from "../../../../../src/decorator/tree/TreeParent.ts"; +import {TreeChildren} from "../../../../../src/decorator/tree/TreeChildren.ts"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {Tree} from "../../../../../src/decorator/tree/Tree.ts"; @Entity() @Tree("nested-set") @@ -12,7 +12,7 @@ export class Category { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) name: string; @TreeParent() @@ -24,4 +24,4 @@ export class Category { // @TreeLevelColumn() // level: number; -} \ No newline at end of file +} diff --git a/test/functional/tree-tables/nested-set/nested-set.ts b/test/functional/tree-tables/nested-set/nested-set.ts index e4628e8e2..d9ee5cce6 100644 --- a/test/functional/tree-tables/nested-set/nested-set.ts +++ b/test/functional/tree-tables/nested-set/nested-set.ts @@ -1,7 +1,8 @@ -import "reflect-metadata"; -import {Category} from "./entity/Category"; -import {Connection} from "../../../../src/connection/Connection"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils"; +import {runIfMain} from "../../../deps/mocha.ts"; +import "../../../deps/chai.ts"; +import {Category} from "./entity/Category.ts"; +import {Connection} from "../../../../src/connection/Connection.ts"; +import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils.ts"; describe("tree tables > nested-set", () => { @@ -165,3 +166,5 @@ describe("tree tables > nested-set", () => { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/uuid/cockroach/entity/Post.ts b/test/functional/uuid/cockroach/entity/Post.ts index 19726dd62..b94419113 100644 --- a/test/functional/uuid/cockroach/entity/Post.ts +++ b/test/functional/uuid/cockroach/entity/Post.ts @@ -1,7 +1,7 @@ -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {Generated} from "../../../../../src/decorator/Generated"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {Generated} from "../../../../../src/decorator/Generated.ts"; @Entity() export class Post { @@ -9,7 +9,7 @@ export class Post { @PrimaryGeneratedColumn() id: string; - @Column() + @Column({ type: String }) @Generated("uuid") uuid: string; diff --git a/test/functional/uuid/cockroach/entity/Question.ts b/test/functional/uuid/cockroach/entity/Question.ts index 91e4c6a2a..876a35326 100644 --- a/test/functional/uuid/cockroach/entity/Question.ts +++ b/test/functional/uuid/cockroach/entity/Question.ts @@ -1,7 +1,7 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {Generated} from "../../../../../src/decorator/Generated"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {Generated} from "../../../../../src/decorator/Generated.ts"; @Entity() export class Question { @@ -9,7 +9,7 @@ export class Question { @PrimaryGeneratedColumn("uuid") id: string; - @Column() + @Column({ type: String }) @Generated("uuid") uuid: string; @@ -19,8 +19,8 @@ export class Question { @Column("uuid", { nullable: true }) uuid3: string|null; - @Column({ nullable: true }) + @Column({ nullable: true, type: String }) @Generated("uuid") uuid4: string|null; -} \ No newline at end of file +} diff --git a/test/functional/uuid/cockroach/entity/Record.ts b/test/functional/uuid/cockroach/entity/Record.ts index 4d40c2c89..be80c19d4 100644 --- a/test/functional/uuid/cockroach/entity/Record.ts +++ b/test/functional/uuid/cockroach/entity/Record.ts @@ -1,5 +1,5 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; @Entity() export class Record { @@ -7,4 +7,4 @@ export class Record { @PrimaryGeneratedColumn("uuid") id: string; -} \ No newline at end of file +} diff --git a/test/functional/uuid/cockroach/uuid-cockroach.ts b/test/functional/uuid/cockroach/uuid-cockroach.ts index 21888e233..32f84d950 100644 --- a/test/functional/uuid/cockroach/uuid-cockroach.ts +++ b/test/functional/uuid/cockroach/uuid-cockroach.ts @@ -1,17 +1,19 @@ -import "reflect-metadata"; -import {expect} from "chai"; -import {Record} from "./entity/Record"; -import {Connection} from "../../../../src/connection/Connection"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils"; -import {Post} from "./entity/Post"; -import {Question} from "./entity/Question"; +import {join as joinPaths} from "../../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../../deps/mocha.ts"; +import {expect} from "../../../deps/chai.ts"; +import {Record} from "./entity/Record.ts"; +import {Connection} from "../../../../src/connection/Connection.ts"; +import {closeTestingConnections, createTestingConnections, reloadTestingDatabases, getDirnameOfCurrentModule} from "../../../utils/test-utils.ts"; +import {Post} from "./entity/Post.ts"; +import {Question} from "./entity/Question.ts"; describe("uuid-cockroach", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => { connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], enabledDrivers: ["cockroachdb"], }); }); @@ -93,3 +95,5 @@ describe("uuid-cockroach", () => { expect(loadedQuestion2!.uuid4).to.be.null; }))); }); + +runIfMain(import.meta); diff --git a/test/functional/uuid/mssql/entity/Post.ts b/test/functional/uuid/mssql/entity/Post.ts index b3a4f110f..69df86d6c 100644 --- a/test/functional/uuid/mssql/entity/Post.ts +++ b/test/functional/uuid/mssql/entity/Post.ts @@ -1,7 +1,7 @@ -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {Generated} from "../../../../../src/decorator/Generated"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {Generated} from "../../../../../src/decorator/Generated.ts"; @Entity() export class Post { @@ -9,8 +9,8 @@ export class Post { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) @Generated("uuid") uuid: string; -} \ No newline at end of file +} diff --git a/test/functional/uuid/mssql/entity/Question.ts b/test/functional/uuid/mssql/entity/Question.ts index 61e8a731a..fb8ff4b7a 100644 --- a/test/functional/uuid/mssql/entity/Question.ts +++ b/test/functional/uuid/mssql/entity/Question.ts @@ -1,7 +1,7 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {Generated} from "../../../../../src/decorator/Generated"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {Generated} from "../../../../../src/decorator/Generated.ts"; @Entity() export class Question { @@ -9,7 +9,7 @@ export class Question { @PrimaryGeneratedColumn("uuid") id: string; - @Column() + @Column({ type: String }) @Generated("uuid") uuid: string; @@ -20,4 +20,4 @@ export class Question { @Generated("uuid") uuid3: string|null; -} \ No newline at end of file +} diff --git a/test/functional/uuid/mssql/uuid-mssql.ts b/test/functional/uuid/mssql/uuid-mssql.ts index 06c075d71..c03ab0430 100644 --- a/test/functional/uuid/mssql/uuid-mssql.ts +++ b/test/functional/uuid/mssql/uuid-mssql.ts @@ -1,16 +1,18 @@ -import "reflect-metadata"; -import {expect} from "chai"; -import {Connection} from "../../../../src/connection/Connection"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils"; -import {Question} from "./entity/Question"; -import {Post} from "./entity/Post"; +import {join as joinPaths} from "../../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../../deps/mocha.ts"; +import {expect} from "../../../deps/chai.ts"; +import {Connection} from "../../../../src/connection/Connection.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils.ts"; +import {Question} from "./entity/Question.ts"; +import {Post} from "./entity/Post.ts"; describe("uuid-mssql", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => { connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], enabledDrivers: ["mssql"], }); }); @@ -63,3 +65,5 @@ describe("uuid-mssql", () => { expect(loadedQuestion2!.uuid3).to.be.null; }))); }); + +runIfMain(import.meta); diff --git a/test/functional/uuid/mysql/entity/Post.ts b/test/functional/uuid/mysql/entity/Post.ts index b3a4f110f..69df86d6c 100644 --- a/test/functional/uuid/mysql/entity/Post.ts +++ b/test/functional/uuid/mysql/entity/Post.ts @@ -1,7 +1,7 @@ -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {Generated} from "../../../../../src/decorator/Generated"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {Generated} from "../../../../../src/decorator/Generated.ts"; @Entity() export class Post { @@ -9,8 +9,8 @@ export class Post { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) @Generated("uuid") uuid: string; -} \ No newline at end of file +} diff --git a/test/functional/uuid/mysql/entity/Question.ts b/test/functional/uuid/mysql/entity/Question.ts index f56408aac..4c3ab33a3 100644 --- a/test/functional/uuid/mysql/entity/Question.ts +++ b/test/functional/uuid/mysql/entity/Question.ts @@ -1,7 +1,7 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {Generated} from "../../../../../src/decorator/Generated"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {Generated} from "../../../../../src/decorator/Generated.ts"; @Entity() export class Question { @@ -9,11 +9,11 @@ export class Question { @PrimaryGeneratedColumn("uuid") id: string; - @Column() + @Column({ type: String }) @Generated("uuid") uuid: string; - @Column() + @Column({ type: String }) uuid2: string; @Column("varchar", { nullable: true }) @@ -23,4 +23,4 @@ export class Question { @Generated("uuid") uuid4: string|null; -} \ No newline at end of file +} diff --git a/test/functional/uuid/mysql/uuid-mysql.ts b/test/functional/uuid/mysql/uuid-mysql.ts index bc71cd4c5..5f9fd5145 100644 --- a/test/functional/uuid/mysql/uuid-mysql.ts +++ b/test/functional/uuid/mysql/uuid-mysql.ts @@ -1,16 +1,18 @@ -import "reflect-metadata"; -import {expect} from "chai"; -import {Connection} from "../../../../src/connection/Connection"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils"; -import {Post} from "./entity/Post"; -import {Question} from "./entity/Question"; +import {join as joinPaths} from "../../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../../deps/mocha.ts"; +import {expect} from "../../../deps/chai.ts"; +import {Connection} from "../../../../src/connection/Connection.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils.ts"; +import {Post} from "./entity/Post.ts"; +import {Question} from "./entity/Question.ts"; describe("uuid-mysql", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => { connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], enabledDrivers: ["mysql"], }); }); @@ -77,3 +79,5 @@ describe("uuid-mysql", () => { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/uuid/oracle/entity/Post.ts b/test/functional/uuid/oracle/entity/Post.ts index b3a4f110f..69df86d6c 100644 --- a/test/functional/uuid/oracle/entity/Post.ts +++ b/test/functional/uuid/oracle/entity/Post.ts @@ -1,7 +1,7 @@ -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {Generated} from "../../../../../src/decorator/Generated"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {Generated} from "../../../../../src/decorator/Generated.ts"; @Entity() export class Post { @@ -9,8 +9,8 @@ export class Post { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) @Generated("uuid") uuid: string; -} \ No newline at end of file +} diff --git a/test/functional/uuid/oracle/entity/Question.ts b/test/functional/uuid/oracle/entity/Question.ts index f56408aac..4c3ab33a3 100644 --- a/test/functional/uuid/oracle/entity/Question.ts +++ b/test/functional/uuid/oracle/entity/Question.ts @@ -1,7 +1,7 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {Generated} from "../../../../../src/decorator/Generated"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {Generated} from "../../../../../src/decorator/Generated.ts"; @Entity() export class Question { @@ -9,11 +9,11 @@ export class Question { @PrimaryGeneratedColumn("uuid") id: string; - @Column() + @Column({ type: String }) @Generated("uuid") uuid: string; - @Column() + @Column({ type: String }) uuid2: string; @Column("varchar", { nullable: true }) @@ -23,4 +23,4 @@ export class Question { @Generated("uuid") uuid4: string|null; -} \ No newline at end of file +} diff --git a/test/functional/uuid/oracle/uuid-oracle.ts b/test/functional/uuid/oracle/uuid-oracle.ts index 5be5fd24d..144c9235c 100644 --- a/test/functional/uuid/oracle/uuid-oracle.ts +++ b/test/functional/uuid/oracle/uuid-oracle.ts @@ -1,16 +1,18 @@ -import "reflect-metadata"; -import {expect} from "chai"; -import {Connection} from "../../../../src/connection/Connection"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils"; -import {Post} from "./entity/Post"; -import {Question} from "./entity/Question"; +import {join as joinPaths} from "../../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../../deps/mocha.ts"; +import {expect} from "../../../deps/chai.ts"; +import {Connection} from "../../../../src/connection/Connection.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils.ts"; +import {Post} from "./entity/Post.ts"; +import {Question} from "./entity/Question.ts"; describe("uuid-oracle", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => { connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], enabledDrivers: ["oracle"], }); }); @@ -67,3 +69,5 @@ describe("uuid-oracle", () => { expect(loadedQuestion2!.uuid4).to.be.null; }))); }); + +runIfMain(import.meta); diff --git a/test/functional/uuid/postgres/entity/Post.ts b/test/functional/uuid/postgres/entity/Post.ts index b3a4f110f..69df86d6c 100644 --- a/test/functional/uuid/postgres/entity/Post.ts +++ b/test/functional/uuid/postgres/entity/Post.ts @@ -1,7 +1,7 @@ -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {Generated} from "../../../../../src/decorator/Generated"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {Generated} from "../../../../../src/decorator/Generated.ts"; @Entity() export class Post { @@ -9,8 +9,8 @@ export class Post { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) @Generated("uuid") uuid: string; -} \ No newline at end of file +} diff --git a/test/functional/uuid/postgres/entity/Question.ts b/test/functional/uuid/postgres/entity/Question.ts index 91e4c6a2a..876a35326 100644 --- a/test/functional/uuid/postgres/entity/Question.ts +++ b/test/functional/uuid/postgres/entity/Question.ts @@ -1,7 +1,7 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {Generated} from "../../../../../src/decorator/Generated"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {Generated} from "../../../../../src/decorator/Generated.ts"; @Entity() export class Question { @@ -9,7 +9,7 @@ export class Question { @PrimaryGeneratedColumn("uuid") id: string; - @Column() + @Column({ type: String }) @Generated("uuid") uuid: string; @@ -19,8 +19,8 @@ export class Question { @Column("uuid", { nullable: true }) uuid3: string|null; - @Column({ nullable: true }) + @Column({ nullable: true, type: String }) @Generated("uuid") uuid4: string|null; -} \ No newline at end of file +} diff --git a/test/functional/uuid/postgres/entity/Record.ts b/test/functional/uuid/postgres/entity/Record.ts index 4d40c2c89..be80c19d4 100644 --- a/test/functional/uuid/postgres/entity/Record.ts +++ b/test/functional/uuid/postgres/entity/Record.ts @@ -1,5 +1,5 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; @Entity() export class Record { @@ -7,4 +7,4 @@ export class Record { @PrimaryGeneratedColumn("uuid") id: string; -} \ No newline at end of file +} diff --git a/test/functional/uuid/postgres/pgcrypto.ts b/test/functional/uuid/postgres/pgcrypto.ts index 49dc253b1..e8a0a9e22 100644 --- a/test/functional/uuid/postgres/pgcrypto.ts +++ b/test/functional/uuid/postgres/pgcrypto.ts @@ -1,17 +1,19 @@ -import "reflect-metadata"; -import {expect} from "chai"; -import {Record} from "./entity/Record"; -import {Connection} from "../../../../src/connection/Connection"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils"; -import {Post} from "./entity/Post"; -import {Question} from "./entity/Question"; +import {join as joinPaths} from "../../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../../deps/mocha.ts"; +import {expect} from "../../../deps/chai.ts"; +import {Record} from "./entity/Record.ts"; +import {Connection} from "../../../../src/connection/Connection.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils.ts"; +import {Post} from "./entity/Post.ts"; +import {Question} from "./entity/Question.ts"; describe("pgcrypto", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => { connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], enabledDrivers: ["postgres"], driverSpecific: { uuidExtension: "pgcrypto" @@ -96,3 +98,5 @@ describe("pgcrypto", () => { expect(loadedQuestion2!.uuid4).to.be.null; }))); }); + +runIfMain(import.meta); diff --git a/test/functional/uuid/postgres/uuid-ossp.ts b/test/functional/uuid/postgres/uuid-ossp.ts index 37083daa8..6d31b0056 100644 --- a/test/functional/uuid/postgres/uuid-ossp.ts +++ b/test/functional/uuid/postgres/uuid-ossp.ts @@ -1,17 +1,19 @@ -import "reflect-metadata"; -import {expect} from "chai"; -import {Record} from "./entity/Record"; -import {Connection} from "../../../../src/connection/Connection"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils"; -import {Post} from "./entity/Post"; -import {Question} from "./entity/Question"; +import {join as joinPaths} from "../../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../../deps/mocha.ts"; +import {expect} from "../../../deps/chai.ts"; +import {Record} from "./entity/Record.ts"; +import {Connection} from "../../../../src/connection/Connection.ts"; +import {closeTestingConnections, createTestingConnections, reloadTestingDatabases, getDirnameOfCurrentModule} from "../../../utils/test-utils.ts"; +import {Post} from "./entity/Post.ts"; +import {Question} from "./entity/Question.ts"; describe("uuid-ossp", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => { connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], enabledDrivers: ["postgres"], driverSpecific: { uuidExtension: "uuid-ossp" @@ -96,3 +98,5 @@ describe("uuid-ossp", () => { expect(loadedQuestion2!.uuid4).to.be.null; }))); }); + +runIfMain(import.meta); diff --git a/test/functional/uuid/sap/entity/Post.ts b/test/functional/uuid/sap/entity/Post.ts index b3a4f110f..69df86d6c 100644 --- a/test/functional/uuid/sap/entity/Post.ts +++ b/test/functional/uuid/sap/entity/Post.ts @@ -1,7 +1,7 @@ -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {Generated} from "../../../../../src/decorator/Generated"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {Generated} from "../../../../../src/decorator/Generated.ts"; @Entity() export class Post { @@ -9,8 +9,8 @@ export class Post { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) @Generated("uuid") uuid: string; -} \ No newline at end of file +} diff --git a/test/functional/uuid/sap/entity/Question.ts b/test/functional/uuid/sap/entity/Question.ts index ec73756c9..609bce158 100644 --- a/test/functional/uuid/sap/entity/Question.ts +++ b/test/functional/uuid/sap/entity/Question.ts @@ -1,7 +1,7 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {Generated} from "../../../../../src/decorator/Generated"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {Generated} from "../../../../../src/decorator/Generated.ts"; @Entity() export class Question { @@ -9,11 +9,11 @@ export class Question { @PrimaryGeneratedColumn("uuid") id: string; - @Column() + @Column({ type: String }) @Generated("uuid") uuid: string; - @Column() + @Column({ type: String }) uuid2: string; @Column("nvarchar", { nullable: true }) diff --git a/test/functional/uuid/sap/uuid-sap.ts b/test/functional/uuid/sap/uuid-sap.ts index 00ea67c3a..75083e742 100644 --- a/test/functional/uuid/sap/uuid-sap.ts +++ b/test/functional/uuid/sap/uuid-sap.ts @@ -1,16 +1,18 @@ -import {expect} from "chai"; -import "reflect-metadata"; -import {Connection} from "../../../../src"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils"; -import {Post} from "./entity/Post"; -import {Question} from "./entity/Question"; +import {join as joinPaths} from "../../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../../deps/mocha.ts"; +import {expect} from "../../../deps/chai.ts"; +import {Connection} from "../../../../src/index.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils.ts"; +import {Post} from "./entity/Post.ts"; +import {Question} from "./entity/Question.ts"; describe("uuid-mysql", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => { connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], enabledDrivers: ["sap"], }); }); @@ -77,3 +79,5 @@ describe("uuid-mysql", () => { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/uuid/sqlite/entity/Post.ts b/test/functional/uuid/sqlite/entity/Post.ts index b3a4f110f..69df86d6c 100644 --- a/test/functional/uuid/sqlite/entity/Post.ts +++ b/test/functional/uuid/sqlite/entity/Post.ts @@ -1,7 +1,7 @@ -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {Generated} from "../../../../../src/decorator/Generated"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {Generated} from "../../../../../src/decorator/Generated.ts"; @Entity() export class Post { @@ -9,8 +9,8 @@ export class Post { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) @Generated("uuid") uuid: string; -} \ No newline at end of file +} diff --git a/test/functional/uuid/sqlite/entity/Question.ts b/test/functional/uuid/sqlite/entity/Question.ts index f56408aac..4c3ab33a3 100644 --- a/test/functional/uuid/sqlite/entity/Question.ts +++ b/test/functional/uuid/sqlite/entity/Question.ts @@ -1,7 +1,7 @@ -import {Entity} from "../../../../../src/decorator/entity/Entity"; -import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn"; -import {Column} from "../../../../../src/decorator/columns/Column"; -import {Generated} from "../../../../../src/decorator/Generated"; +import {Entity} from "../../../../../src/decorator/entity/Entity.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/decorator/columns/PrimaryGeneratedColumn.ts"; +import {Column} from "../../../../../src/decorator/columns/Column.ts"; +import {Generated} from "../../../../../src/decorator/Generated.ts"; @Entity() export class Question { @@ -9,11 +9,11 @@ export class Question { @PrimaryGeneratedColumn("uuid") id: string; - @Column() + @Column({ type: String }) @Generated("uuid") uuid: string; - @Column() + @Column({ type: String }) uuid2: string; @Column("varchar", { nullable: true }) @@ -23,4 +23,4 @@ export class Question { @Generated("uuid") uuid4: string|null; -} \ No newline at end of file +} diff --git a/test/functional/uuid/sqlite/uuid-sqlite.ts b/test/functional/uuid/sqlite/uuid-sqlite.ts index f167faee6..216c7bf01 100644 --- a/test/functional/uuid/sqlite/uuid-sqlite.ts +++ b/test/functional/uuid/sqlite/uuid-sqlite.ts @@ -1,16 +1,18 @@ -import "reflect-metadata"; -import {expect} from "chai"; -import {Connection} from "../../../../src/connection/Connection"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils"; -import {Post} from "./entity/Post"; -import {Question} from "./entity/Question"; +import {join as joinPaths} from "../../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../../deps/mocha.ts"; +import {expect} from "../../../deps/chai.ts"; +import {Connection} from "../../../../src/connection/Connection.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils.ts"; +import {Post} from "./entity/Post.ts"; +import {Question} from "./entity/Question.ts"; describe("uuid-sqlite", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => { connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], enabledDrivers: ["sqlite"], }); }); @@ -67,3 +69,5 @@ describe("uuid-sqlite", () => { expect(loadedQuestion2!.uuid4).to.be.null; }))); }); + +runIfMain(import.meta); diff --git a/test/functional/view-entity/general/entity/Album.ts b/test/functional/view-entity/general/entity/Album.ts index 68315815a..bd6371c36 100644 --- a/test/functional/view-entity/general/entity/Album.ts +++ b/test/functional/view-entity/general/entity/Album.ts @@ -1,7 +1,7 @@ -import {Entity, JoinColumn, ManyToOne} from "../../../../../src"; -import {Column} from "../../../../../src"; -import {PrimaryGeneratedColumn} from "../../../../../src"; -import {Category} from "./Category"; +import {Entity, JoinColumn, ManyToOne} from "../../../../../src/index.ts"; +import {Column} from "../../../../../src/index.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/index.ts"; +import {Category} from "./Category.ts"; @Entity() export class Album { @@ -9,10 +9,10 @@ export class Album { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) name: string; - @Column() + @Column({ type: Number }) categoryId: number; @ManyToOne(() => Category) diff --git a/test/functional/view-entity/general/entity/Category.ts b/test/functional/view-entity/general/entity/Category.ts index b867f56ff..72f23e529 100644 --- a/test/functional/view-entity/general/entity/Category.ts +++ b/test/functional/view-entity/general/entity/Category.ts @@ -1,6 +1,6 @@ -import {Entity} from "../../../../../src"; -import {Column} from "../../../../../src"; -import {PrimaryGeneratedColumn} from "../../../../../src"; +import {Entity} from "../../../../../src/index.ts"; +import {Column} from "../../../../../src/index.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/index.ts"; @Entity() export class Category { @@ -8,7 +8,7 @@ export class Category { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) name: string; } diff --git a/test/functional/view-entity/general/entity/Photo.ts b/test/functional/view-entity/general/entity/Photo.ts index 05ce93386..d064ab649 100644 --- a/test/functional/view-entity/general/entity/Photo.ts +++ b/test/functional/view-entity/general/entity/Photo.ts @@ -1,9 +1,9 @@ -import {Entity} from "../../../../../src"; -import {Column} from "../../../../../src"; -import {PrimaryGeneratedColumn} from "../../../../../src"; -import {ManyToOne} from "../../../../../src"; -import {JoinColumn} from "../../../../../src"; -import {Album} from "./Album"; +import {Entity} from "../../../../../src/index.ts"; +import {Column} from "../../../../../src/index.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/index.ts"; +import {ManyToOne} from "../../../../../src/index.ts"; +import {JoinColumn} from "../../../../../src/index.ts"; +import {Album} from "./Album.ts"; @Entity() export class Photo { @@ -11,10 +11,10 @@ export class Photo { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) name: string; - @Column() + @Column({ type: String }) albumId: number; @ManyToOne(() => Album) diff --git a/test/functional/view-entity/general/entity/PhotoAlbumCategory.ts b/test/functional/view-entity/general/entity/PhotoAlbumCategory.ts index 1fea2be7e..c637ec760 100644 --- a/test/functional/view-entity/general/entity/PhotoAlbumCategory.ts +++ b/test/functional/view-entity/general/entity/PhotoAlbumCategory.ts @@ -1,9 +1,9 @@ -import {Connection} from "../../../../../src"; -import {ViewColumn} from "../../../../../src/decorator/columns/ViewColumn"; -import {ViewEntity} from "../../../../../src/decorator/entity-view/ViewEntity"; -import {Album} from "./Album"; -import {Category} from "./Category"; -import {Photo} from "./Photo"; +import {Connection} from "../../../../../src/index.ts"; +import {ViewColumn} from "../../../../../src/decorator/columns/ViewColumn.ts"; +import {ViewEntity} from "../../../../../src/decorator/entity-view/ViewEntity.ts"; +import {Album} from "./Album.ts"; +import {Category} from "./Category.ts"; +import {Photo} from "./Photo.ts"; @ViewEntity({ expression: (connection: Connection) => connection.createQueryBuilder() diff --git a/test/functional/view-entity/general/entity/Post.ts b/test/functional/view-entity/general/entity/Post.ts index 9da66f940..ee0efd4f4 100644 --- a/test/functional/view-entity/general/entity/Post.ts +++ b/test/functional/view-entity/general/entity/Post.ts @@ -1,9 +1,9 @@ -import {Entity} from "../../../../../src"; -import {Column} from "../../../../../src"; -import {PrimaryGeneratedColumn} from "../../../../../src"; -import {ManyToOne} from "../../../../../src"; -import {JoinColumn} from "../../../../../src"; -import {Category} from "./Category"; +import {Entity} from "../../../../../src/index.ts"; +import {Column} from "../../../../../src/index.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/index.ts"; +import {ManyToOne} from "../../../../../src/index.ts"; +import {JoinColumn} from "../../../../../src/index.ts"; +import {Category} from "./Category.ts"; @Entity() export class Post { @@ -11,10 +11,10 @@ export class Post { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) name: string; - @Column() + @Column({ type: Number }) categoryId: number; @ManyToOne(() => Category) diff --git a/test/functional/view-entity/general/entity/PostCategory.ts b/test/functional/view-entity/general/entity/PostCategory.ts index 740cd8985..819918496 100644 --- a/test/functional/view-entity/general/entity/PostCategory.ts +++ b/test/functional/view-entity/general/entity/PostCategory.ts @@ -1,8 +1,8 @@ -import {Connection} from "../../../../../src"; -import {ViewColumn} from "../../../../../src/decorator/columns/ViewColumn"; -import {ViewEntity} from "../../../../../src/decorator/entity-view/ViewEntity"; -import {Category} from "./Category"; -import {Post} from "./Post"; +import {Connection} from "../../../../../src/index.ts"; +import {ViewColumn} from "../../../../../src/decorator/columns/ViewColumn.ts"; +import {ViewEntity} from "../../../../../src/decorator/entity-view/ViewEntity.ts"; +import {Category} from "./Category.ts"; +import {Post} from "./Post.ts"; @ViewEntity({ expression: (connection: Connection) => connection.createQueryBuilder() diff --git a/test/functional/view-entity/general/view-entity-general.ts b/test/functional/view-entity/general/view-entity-general.ts index 1e456a2f6..634b2252d 100644 --- a/test/functional/view-entity/general/view-entity-general.ts +++ b/test/functional/view-entity/general/view-entity-general.ts @@ -1,20 +1,23 @@ -import {expect} from "chai"; -import "reflect-metadata"; -import {CockroachDriver} from "../../../../src/driver/cockroachdb/CockroachDriver"; -import {Album} from "./entity/Album"; -import {Category} from "./entity/Category"; -import {Connection} from "../../../../src"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils"; -import {Photo} from "./entity/Photo"; -import {PhotoAlbumCategory} from "./entity/PhotoAlbumCategory"; -import {Post} from "./entity/Post"; -import {PostCategory} from "./entity/PostCategory"; +import {join as joinPaths} from "../../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../../deps/mocha.ts"; +import {expect} from "../../../deps/chai.ts"; +// TODO(uki00a) uncomment this when CockroachDriver is implemented. +//import {CockroachDriver} from "../../../../src/driver/cockroachdb/CockroachDriver.ts"; +import {Album} from "./entity/Album.ts"; +import {Category} from "./entity/Category.ts"; +import {Connection} from "../../../../src/index.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils.ts"; +import {Photo} from "./entity/Photo.ts"; +import {PhotoAlbumCategory} from "./entity/PhotoAlbumCategory.ts"; +import {Post} from "./entity/Post.ts"; +import {PostCategory} from "./entity/PostCategory.ts"; describe("view entity > general", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"] + entities: [joinPaths(__dirname, "/entity/*.ts")] })); beforeEach(() => reloadTestingDatabases(connections)); after(() => closeTestingConnections(connections)); @@ -79,12 +82,12 @@ describe("view entity > general", () => { const postCategories = await connection.manager.find(PostCategory); postCategories.length.should.be.equal(2); - const postId1 = connection.driver instanceof CockroachDriver ? "1" : 1; + const postId1 = false/*connection.driver instanceof CockroachDriver*/ ? "1" : 1; // TODO(uki00a) uncomment this when CockroachDriver is implemented. postCategories[0].id.should.be.equal(postId1); postCategories[0].name.should.be.equal("About BMW"); postCategories[0].categoryName.should.be.equal("Cars"); - const postId2 = connection.driver instanceof CockroachDriver ? "2" : 2; + const postId2 = false/*connection.driver instanceof CockroachDriver*/ ? "2" : 2; // TODO(uki00a) uncomment this when CockroachDriver is implemented. postCategories[1].id.should.be.equal(postId2); postCategories[1].name.should.be.equal("About Boeing"); postCategories[1].categoryName.should.be.equal("Airplanes"); @@ -92,13 +95,13 @@ describe("view entity > general", () => { const photoAlbumCategories = await connection.manager.find(PhotoAlbumCategory); photoAlbumCategories.length.should.be.equal(2); - const photoId1 = connection.driver instanceof CockroachDriver ? "1" : 1; + const photoId1 = false/*connection.driver instanceof CockroachDriver*/ ? "1" : 1; // TODO(uki00a) uncomment this when CockroachDriver is implemented. photoAlbumCategories[0].id.should.be.equal(photoId1); photoAlbumCategories[0].name.should.be.equal("BMW E39"); photoAlbumCategories[0].albumName.should.be.equal("BMW photos"); photoAlbumCategories[0].categoryName.should.be.equal("Cars"); - const photoId2 = connection.driver instanceof CockroachDriver ? "2" : 2; + const photoId2 = false/*connection.driver instanceof CockroachDriver*/ ? "2" : 2; // TODO(uki00a) uncomment this when CockroachDriver is implemented. photoAlbumCategories[1].id.should.be.equal(photoId2); photoAlbumCategories[1].name.should.be.equal("BMW E60"); photoAlbumCategories[1].albumName.should.be.equal("BMW photos"); @@ -112,3 +115,5 @@ describe("view entity > general", () => { }))); }); + +runIfMain(import.meta); diff --git a/test/functional/view-entity/mssql/entity/Category.ts b/test/functional/view-entity/mssql/entity/Category.ts index b867f56ff..72f23e529 100644 --- a/test/functional/view-entity/mssql/entity/Category.ts +++ b/test/functional/view-entity/mssql/entity/Category.ts @@ -1,6 +1,6 @@ -import {Entity} from "../../../../../src"; -import {Column} from "../../../../../src"; -import {PrimaryGeneratedColumn} from "../../../../../src"; +import {Entity} from "../../../../../src/index.ts"; +import {Column} from "../../../../../src/index.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/index.ts"; @Entity() export class Category { @@ -8,7 +8,7 @@ export class Category { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) name: string; } diff --git a/test/functional/view-entity/mssql/entity/Post.ts b/test/functional/view-entity/mssql/entity/Post.ts index 9da66f940..ee0efd4f4 100644 --- a/test/functional/view-entity/mssql/entity/Post.ts +++ b/test/functional/view-entity/mssql/entity/Post.ts @@ -1,9 +1,9 @@ -import {Entity} from "../../../../../src"; -import {Column} from "../../../../../src"; -import {PrimaryGeneratedColumn} from "../../../../../src"; -import {ManyToOne} from "../../../../../src"; -import {JoinColumn} from "../../../../../src"; -import {Category} from "./Category"; +import {Entity} from "../../../../../src/index.ts"; +import {Column} from "../../../../../src/index.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/index.ts"; +import {ManyToOne} from "../../../../../src/index.ts"; +import {JoinColumn} from "../../../../../src/index.ts"; +import {Category} from "./Category.ts"; @Entity() export class Post { @@ -11,10 +11,10 @@ export class Post { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) name: string; - @Column() + @Column({ type: Number }) categoryId: number; @ManyToOne(() => Category) diff --git a/test/functional/view-entity/mssql/entity/PostCategory.ts b/test/functional/view-entity/mssql/entity/PostCategory.ts index d3540166e..7942761fa 100644 --- a/test/functional/view-entity/mssql/entity/PostCategory.ts +++ b/test/functional/view-entity/mssql/entity/PostCategory.ts @@ -1,5 +1,5 @@ -import {ViewColumn} from "../../../../../src/decorator/columns/ViewColumn"; -import {ViewEntity} from "../../../../../src/decorator/entity-view/ViewEntity"; +import {ViewColumn} from "../../../../../src/decorator/columns/ViewColumn.ts"; +import {ViewEntity} from "../../../../../src/decorator/entity-view/ViewEntity.ts"; @ViewEntity({ expression: ` SELECT "post"."id" "id", "post"."name" AS "name", "category"."name" AS "categoryName" diff --git a/test/functional/view-entity/mssql/view-entity-mssql.ts b/test/functional/view-entity/mssql/view-entity-mssql.ts index 4d0a41b5a..0ea01d343 100644 --- a/test/functional/view-entity/mssql/view-entity-mssql.ts +++ b/test/functional/view-entity/mssql/view-entity-mssql.ts @@ -1,17 +1,18 @@ -import {expect} from "chai"; -import "reflect-metadata"; -import {CockroachDriver} from "../../../../src/driver/cockroachdb/CockroachDriver"; -import {Category} from "./entity/Category"; -import {Connection} from "../../../../src"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils"; -import {Post} from "./entity/Post"; -import {PostCategory} from "./entity/PostCategory"; +import {join as joinPaths} from "../../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../../deps/mocha.ts"; +import {expect} from "../../../deps/chai.ts"; +import {Category} from "./entity/Category.ts"; +import {Connection} from "../../../../src/index.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils.ts"; +import {Post} from "./entity/Post.ts"; +import {PostCategory} from "./entity/PostCategory.ts"; describe("view entity > mssql", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], enabledDrivers: ["mssql"] })); beforeEach(() => reloadTestingDatabases(connections)); @@ -49,15 +50,17 @@ describe("view entity > mssql", () => { const postCategories = await connection.manager.find(PostCategory); postCategories.length.should.be.equal(2); - const postId1 = connection.driver instanceof CockroachDriver ? "1" : 1; + const postId1 = 1; postCategories[0].id.should.be.equal(postId1); postCategories[0].name.should.be.equal("About BMW"); postCategories[0].categoryName.should.be.equal("Cars"); - const postId2 = connection.driver instanceof CockroachDriver ? "2" : 2; + const postId2 = 2; postCategories[1].id.should.be.equal(postId2); postCategories[1].name.should.be.equal("About Boeing"); postCategories[1].categoryName.should.be.equal("Airplanes"); }))); }); + +runIfMain(import.meta); diff --git a/test/functional/view-entity/mysql/entity/Category.ts b/test/functional/view-entity/mysql/entity/Category.ts index b867f56ff..72f23e529 100644 --- a/test/functional/view-entity/mysql/entity/Category.ts +++ b/test/functional/view-entity/mysql/entity/Category.ts @@ -1,6 +1,6 @@ -import {Entity} from "../../../../../src"; -import {Column} from "../../../../../src"; -import {PrimaryGeneratedColumn} from "../../../../../src"; +import {Entity} from "../../../../../src/index.ts"; +import {Column} from "../../../../../src/index.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/index.ts"; @Entity() export class Category { @@ -8,7 +8,7 @@ export class Category { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) name: string; } diff --git a/test/functional/view-entity/mysql/entity/Post.ts b/test/functional/view-entity/mysql/entity/Post.ts index 9da66f940..ee0efd4f4 100644 --- a/test/functional/view-entity/mysql/entity/Post.ts +++ b/test/functional/view-entity/mysql/entity/Post.ts @@ -1,9 +1,9 @@ -import {Entity} from "../../../../../src"; -import {Column} from "../../../../../src"; -import {PrimaryGeneratedColumn} from "../../../../../src"; -import {ManyToOne} from "../../../../../src"; -import {JoinColumn} from "../../../../../src"; -import {Category} from "./Category"; +import {Entity} from "../../../../../src/index.ts"; +import {Column} from "../../../../../src/index.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/index.ts"; +import {ManyToOne} from "../../../../../src/index.ts"; +import {JoinColumn} from "../../../../../src/index.ts"; +import {Category} from "./Category.ts"; @Entity() export class Post { @@ -11,10 +11,10 @@ export class Post { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) name: string; - @Column() + @Column({ type: Number }) categoryId: number; @ManyToOne(() => Category) diff --git a/test/functional/view-entity/mysql/entity/PostCategory.ts b/test/functional/view-entity/mysql/entity/PostCategory.ts index 4b1df7d53..f2b4a7bc3 100644 --- a/test/functional/view-entity/mysql/entity/PostCategory.ts +++ b/test/functional/view-entity/mysql/entity/PostCategory.ts @@ -1,5 +1,5 @@ -import {ViewColumn} from "../../../../../src/decorator/columns/ViewColumn"; -import {ViewEntity} from "../../../../../src/decorator/entity-view/ViewEntity"; +import {ViewColumn} from "../../../../../src/decorator/columns/ViewColumn.ts"; +import {ViewEntity} from "../../../../../src/decorator/entity-view/ViewEntity.ts"; @ViewEntity({ expression: ` SELECT \`post\`.\`id\` \`id\`, \`post\`.\`name\` AS \`name\`, \`category\`.\`name\` AS \`categoryName\` diff --git a/test/functional/view-entity/mysql/view-entity-mysql.ts b/test/functional/view-entity/mysql/view-entity-mysql.ts index 17a55aef2..44ea18e37 100644 --- a/test/functional/view-entity/mysql/view-entity-mysql.ts +++ b/test/functional/view-entity/mysql/view-entity-mysql.ts @@ -1,17 +1,18 @@ -import {expect} from "chai"; -import "reflect-metadata"; -import {CockroachDriver} from "../../../../src/driver/cockroachdb/CockroachDriver"; -import {Category} from "./entity/Category"; -import {Connection} from "../../../../src"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils"; -import {Post} from "./entity/Post"; -import {PostCategory} from "./entity/PostCategory"; +import {join as joinPaths} from "../../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../../deps/mocha.ts"; +import {expect} from "../../../deps/chai.ts"; +import {Category} from "./entity/Category.ts"; +import {Connection} from "../../../../src/index.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils.ts"; +import {Post} from "./entity/Post.ts"; +import {PostCategory} from "./entity/PostCategory.ts"; describe("view entity > mysql", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], enabledDrivers: ["mysql", "mariadb"] })); beforeEach(() => reloadTestingDatabases(connections)); @@ -49,15 +50,17 @@ describe("view entity > mysql", () => { const postCategories = await connection.manager.find(PostCategory); postCategories.length.should.be.equal(2); - const postId1 = connection.driver instanceof CockroachDriver ? "1" : 1; + const postId1 = 1; postCategories[0].id.should.be.equal(postId1); postCategories[0].name.should.be.equal("About BMW"); postCategories[0].categoryName.should.be.equal("Cars"); - const postId2 = connection.driver instanceof CockroachDriver ? "2" : 2; + const postId2 = 2; postCategories[1].id.should.be.equal(postId2); postCategories[1].name.should.be.equal("About Boeing"); postCategories[1].categoryName.should.be.equal("Airplanes"); }))); }); + +runIfMain(import.meta); diff --git a/test/functional/view-entity/oracle/entity/Category.ts b/test/functional/view-entity/oracle/entity/Category.ts index b867f56ff..72f23e529 100644 --- a/test/functional/view-entity/oracle/entity/Category.ts +++ b/test/functional/view-entity/oracle/entity/Category.ts @@ -1,6 +1,6 @@ -import {Entity} from "../../../../../src"; -import {Column} from "../../../../../src"; -import {PrimaryGeneratedColumn} from "../../../../../src"; +import {Entity} from "../../../../../src/index.ts"; +import {Column} from "../../../../../src/index.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/index.ts"; @Entity() export class Category { @@ -8,7 +8,7 @@ export class Category { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) name: string; } diff --git a/test/functional/view-entity/oracle/entity/Post.ts b/test/functional/view-entity/oracle/entity/Post.ts index 9da66f940..ee0efd4f4 100644 --- a/test/functional/view-entity/oracle/entity/Post.ts +++ b/test/functional/view-entity/oracle/entity/Post.ts @@ -1,9 +1,9 @@ -import {Entity} from "../../../../../src"; -import {Column} from "../../../../../src"; -import {PrimaryGeneratedColumn} from "../../../../../src"; -import {ManyToOne} from "../../../../../src"; -import {JoinColumn} from "../../../../../src"; -import {Category} from "./Category"; +import {Entity} from "../../../../../src/index.ts"; +import {Column} from "../../../../../src/index.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/index.ts"; +import {ManyToOne} from "../../../../../src/index.ts"; +import {JoinColumn} from "../../../../../src/index.ts"; +import {Category} from "./Category.ts"; @Entity() export class Post { @@ -11,10 +11,10 @@ export class Post { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) name: string; - @Column() + @Column({ type: Number }) categoryId: number; @ManyToOne(() => Category) diff --git a/test/functional/view-entity/oracle/entity/PostCategory.ts b/test/functional/view-entity/oracle/entity/PostCategory.ts index d3540166e..7942761fa 100644 --- a/test/functional/view-entity/oracle/entity/PostCategory.ts +++ b/test/functional/view-entity/oracle/entity/PostCategory.ts @@ -1,5 +1,5 @@ -import {ViewColumn} from "../../../../../src/decorator/columns/ViewColumn"; -import {ViewEntity} from "../../../../../src/decorator/entity-view/ViewEntity"; +import {ViewColumn} from "../../../../../src/decorator/columns/ViewColumn.ts"; +import {ViewEntity} from "../../../../../src/decorator/entity-view/ViewEntity.ts"; @ViewEntity({ expression: ` SELECT "post"."id" "id", "post"."name" AS "name", "category"."name" AS "categoryName" diff --git a/test/functional/view-entity/oracle/view-entity-oracle.ts b/test/functional/view-entity/oracle/view-entity-oracle.ts index 570d2c3af..2532f5190 100644 --- a/test/functional/view-entity/oracle/view-entity-oracle.ts +++ b/test/functional/view-entity/oracle/view-entity-oracle.ts @@ -1,17 +1,18 @@ -import {expect} from "chai"; -import "reflect-metadata"; -import {CockroachDriver} from "../../../../src/driver/cockroachdb/CockroachDriver"; -import {Category} from "./entity/Category"; -import {Connection} from "../../../../src"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils"; -import {Post} from "./entity/Post"; -import {PostCategory} from "./entity/PostCategory"; +import {join as joinPaths} from "../../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../../deps/mocha.ts"; +import {expect} from "../../../deps/chai.ts"; +import {Category} from "./entity/Category.ts"; +import {Connection} from "../../../../src/index.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils.ts"; +import {Post} from "./entity/Post.ts"; +import {PostCategory} from "./entity/PostCategory.ts"; describe("view entity > oracle", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], enabledDrivers: ["oracle"] })); beforeEach(() => reloadTestingDatabases(connections)); @@ -49,15 +50,17 @@ describe("view entity > oracle", () => { const postCategories = await connection.manager.find(PostCategory); postCategories.length.should.be.equal(2); - const postId1 = connection.driver instanceof CockroachDriver ? "1" : 1; + const postId1 = 1; postCategories[0].id.should.be.equal(postId1); postCategories[0].name.should.be.equal("About BMW"); postCategories[0].categoryName.should.be.equal("Cars"); - const postId2 = connection.driver instanceof CockroachDriver ? "2" : 2; + const postId2 = 2; postCategories[1].id.should.be.equal(postId2); postCategories[1].name.should.be.equal("About Boeing"); postCategories[1].categoryName.should.be.equal("Airplanes"); }))); }); + +runIfMain(import.meta); diff --git a/test/functional/view-entity/postgres/entity/Category.ts b/test/functional/view-entity/postgres/entity/Category.ts index b867f56ff..72f23e529 100644 --- a/test/functional/view-entity/postgres/entity/Category.ts +++ b/test/functional/view-entity/postgres/entity/Category.ts @@ -1,6 +1,6 @@ -import {Entity} from "../../../../../src"; -import {Column} from "../../../../../src"; -import {PrimaryGeneratedColumn} from "../../../../../src"; +import {Entity} from "../../../../../src/index.ts"; +import {Column} from "../../../../../src/index.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/index.ts"; @Entity() export class Category { @@ -8,7 +8,7 @@ export class Category { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) name: string; } diff --git a/test/functional/view-entity/postgres/entity/Post.ts b/test/functional/view-entity/postgres/entity/Post.ts index 9da66f940..ee0efd4f4 100644 --- a/test/functional/view-entity/postgres/entity/Post.ts +++ b/test/functional/view-entity/postgres/entity/Post.ts @@ -1,9 +1,9 @@ -import {Entity} from "../../../../../src"; -import {Column} from "../../../../../src"; -import {PrimaryGeneratedColumn} from "../../../../../src"; -import {ManyToOne} from "../../../../../src"; -import {JoinColumn} from "../../../../../src"; -import {Category} from "./Category"; +import {Entity} from "../../../../../src/index.ts"; +import {Column} from "../../../../../src/index.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/index.ts"; +import {ManyToOne} from "../../../../../src/index.ts"; +import {JoinColumn} from "../../../../../src/index.ts"; +import {Category} from "./Category.ts"; @Entity() export class Post { @@ -11,10 +11,10 @@ export class Post { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) name: string; - @Column() + @Column({ type: Number }) categoryId: number; @ManyToOne(() => Category) diff --git a/test/functional/view-entity/postgres/entity/PostByCategory.ts b/test/functional/view-entity/postgres/entity/PostByCategory.ts index 70dd78a69..09f74c69b 100644 --- a/test/functional/view-entity/postgres/entity/PostByCategory.ts +++ b/test/functional/view-entity/postgres/entity/PostByCategory.ts @@ -1,8 +1,8 @@ -import {Connection} from "../../../../../src"; -import {ViewColumn} from "../../../../../src/decorator/columns/ViewColumn"; -import {ViewEntity} from "../../../../../src/decorator/entity-view/ViewEntity"; -import {Category} from "./Category"; -import {Post} from "./Post"; +import {Connection} from "../../../../../src/index.ts"; +import {ViewColumn} from "../../../../../src/decorator/columns/ViewColumn.ts"; +import {ViewEntity} from "../../../../../src/decorator/entity-view/ViewEntity.ts"; +import {Category} from "./Category.ts"; +import {Post} from "./Post.ts"; @ViewEntity({ materialized: true, diff --git a/test/functional/view-entity/postgres/entity/PostCategory.ts b/test/functional/view-entity/postgres/entity/PostCategory.ts index d3540166e..7942761fa 100644 --- a/test/functional/view-entity/postgres/entity/PostCategory.ts +++ b/test/functional/view-entity/postgres/entity/PostCategory.ts @@ -1,5 +1,5 @@ -import {ViewColumn} from "../../../../../src/decorator/columns/ViewColumn"; -import {ViewEntity} from "../../../../../src/decorator/entity-view/ViewEntity"; +import {ViewColumn} from "../../../../../src/decorator/columns/ViewColumn.ts"; +import {ViewEntity} from "../../../../../src/decorator/entity-view/ViewEntity.ts"; @ViewEntity({ expression: ` SELECT "post"."id" "id", "post"."name" AS "name", "category"."name" AS "categoryName" diff --git a/test/functional/view-entity/postgres/view-entity-postgres.ts b/test/functional/view-entity/postgres/view-entity-postgres.ts index 4e9763f4c..9e7f4b88c 100644 --- a/test/functional/view-entity/postgres/view-entity-postgres.ts +++ b/test/functional/view-entity/postgres/view-entity-postgres.ts @@ -1,18 +1,19 @@ -import {expect} from "chai"; -import "reflect-metadata"; -import {CockroachDriver} from "../../../../src/driver/cockroachdb/CockroachDriver"; -import {Category} from "./entity/Category"; -import {Connection} from "../../../../src"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils"; -import {Post} from "./entity/Post"; -import {PostCategory} from "./entity/PostCategory"; -import {PostByCategory} from "./entity/PostByCategory"; +import {join as joinPaths} from "../../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../../deps/mocha.ts"; +import {expect} from "../../../deps/chai.ts"; +import {Category} from "./entity/Category.ts"; +import {Connection} from "../../../../src/index.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils.ts"; +import {Post} from "./entity/Post.ts"; +import {PostCategory} from "./entity/PostCategory.ts"; +import {PostByCategory} from "./entity/PostByCategory.ts"; describe("view entity > postgres", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], enabledDrivers: ["postgres"] })); beforeEach(() => reloadTestingDatabases(connections)); @@ -75,15 +76,17 @@ describe("view entity > postgres", () => { const postCategories = await connection.manager.find(PostCategory); postCategories.length.should.be.equal(2); - const postId1 = connection.driver instanceof CockroachDriver ? "1" : 1; + const postId1 = 1; postCategories[0].id.should.be.equal(postId1); postCategories[0].name.should.be.equal("About BMW"); postCategories[0].categoryName.should.be.equal("Cars"); - const postId2 = connection.driver instanceof CockroachDriver ? "2" : 2; + const postId2 = 2; postCategories[1].id.should.be.equal(postId2); postCategories[1].name.should.be.equal("About Boeing"); postCategories[1].categoryName.should.be.equal("Airplanes"); }))); }); + +runIfMain(import.meta); diff --git a/test/functional/view-entity/sqlite/entity/Category.ts b/test/functional/view-entity/sqlite/entity/Category.ts index b867f56ff..72f23e529 100644 --- a/test/functional/view-entity/sqlite/entity/Category.ts +++ b/test/functional/view-entity/sqlite/entity/Category.ts @@ -1,6 +1,6 @@ -import {Entity} from "../../../../../src"; -import {Column} from "../../../../../src"; -import {PrimaryGeneratedColumn} from "../../../../../src"; +import {Entity} from "../../../../../src/index.ts"; +import {Column} from "../../../../../src/index.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/index.ts"; @Entity() export class Category { @@ -8,7 +8,7 @@ export class Category { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) name: string; } diff --git a/test/functional/view-entity/sqlite/entity/Post.ts b/test/functional/view-entity/sqlite/entity/Post.ts index 9da66f940..ee0efd4f4 100644 --- a/test/functional/view-entity/sqlite/entity/Post.ts +++ b/test/functional/view-entity/sqlite/entity/Post.ts @@ -1,9 +1,9 @@ -import {Entity} from "../../../../../src"; -import {Column} from "../../../../../src"; -import {PrimaryGeneratedColumn} from "../../../../../src"; -import {ManyToOne} from "../../../../../src"; -import {JoinColumn} from "../../../../../src"; -import {Category} from "./Category"; +import {Entity} from "../../../../../src/index.ts"; +import {Column} from "../../../../../src/index.ts"; +import {PrimaryGeneratedColumn} from "../../../../../src/index.ts"; +import {ManyToOne} from "../../../../../src/index.ts"; +import {JoinColumn} from "../../../../../src/index.ts"; +import {Category} from "./Category.ts"; @Entity() export class Post { @@ -11,10 +11,10 @@ export class Post { @PrimaryGeneratedColumn() id: number; - @Column() + @Column({ type: String }) name: string; - @Column() + @Column({ type: Number }) categoryId: number; @ManyToOne(() => Category) diff --git a/test/functional/view-entity/sqlite/entity/PostCategory.ts b/test/functional/view-entity/sqlite/entity/PostCategory.ts index d3540166e..7942761fa 100644 --- a/test/functional/view-entity/sqlite/entity/PostCategory.ts +++ b/test/functional/view-entity/sqlite/entity/PostCategory.ts @@ -1,5 +1,5 @@ -import {ViewColumn} from "../../../../../src/decorator/columns/ViewColumn"; -import {ViewEntity} from "../../../../../src/decorator/entity-view/ViewEntity"; +import {ViewColumn} from "../../../../../src/decorator/columns/ViewColumn.ts"; +import {ViewEntity} from "../../../../../src/decorator/entity-view/ViewEntity.ts"; @ViewEntity({ expression: ` SELECT "post"."id" "id", "post"."name" AS "name", "category"."name" AS "categoryName" diff --git a/test/functional/view-entity/sqlite/view-entity-sqlite.ts b/test/functional/view-entity/sqlite/view-entity-sqlite.ts index 31183cf3b..a40be2b08 100644 --- a/test/functional/view-entity/sqlite/view-entity-sqlite.ts +++ b/test/functional/view-entity/sqlite/view-entity-sqlite.ts @@ -1,17 +1,18 @@ -import {expect} from "chai"; -import "reflect-metadata"; -import {CockroachDriver} from "../../../../src/driver/cockroachdb/CockroachDriver"; -import {Category} from "./entity/Category"; -import {Connection} from "../../../../src"; -import {closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils"; -import {Post} from "./entity/Post"; -import {PostCategory} from "./entity/PostCategory"; +import {join as joinPaths} from "../../../../vendor/https/deno.land/std/path/mod.ts"; +import {runIfMain} from "../../../deps/mocha.ts"; +import {expect} from "../../../deps/chai.ts"; +import {Category} from "./entity/Category.ts"; +import {Connection} from "../../../../src/index.ts"; +import {getDirnameOfCurrentModule, closeTestingConnections, createTestingConnections, reloadTestingDatabases} from "../../../utils/test-utils.ts"; +import {Post} from "./entity/Post.ts"; +import {PostCategory} from "./entity/PostCategory.ts"; describe("view entity > sqlite", () => { let connections: Connection[]; + const __dirname = getDirnameOfCurrentModule(import.meta); before(async () => connections = await createTestingConnections({ - entities: [__dirname + "/entity/*{.js,.ts}"], + entities: [joinPaths(__dirname, "/entity/*.ts")], enabledDrivers: ["sqlite"] })); beforeEach(() => reloadTestingDatabases(connections)); @@ -49,15 +50,17 @@ describe("view entity > sqlite", () => { const postCategories = await connection.manager.find(PostCategory); postCategories.length.should.be.equal(2); - const postId1 = connection.driver instanceof CockroachDriver ? "1" : 1; + const postId1 = 1; postCategories[0].id.should.be.equal(postId1); postCategories[0].name.should.be.equal("About BMW"); postCategories[0].categoryName.should.be.equal("Cars"); - const postId2 = connection.driver instanceof CockroachDriver ? "2" : 2; + const postId2 = 2; postCategories[1].id.should.be.equal(postId2); postCategories[1].name.should.be.equal("About Boeing"); postCategories[1].categoryName.should.be.equal("Airplanes"); }))); }); + +runIfMain(import.meta); diff --git a/test/utils/test-utils.ts b/test/utils/test-utils.ts index 540593ca9..3fcfbe188 100644 --- a/test/utils/test-utils.ts +++ b/test/utils/test-utils.ts @@ -306,3 +306,7 @@ export function sleep(ms: number): Promise { setTimeout(ok, ms); }); } + +export function allSettled(values: any[]): Promise> { + return (Promise as any).allSettled(values); +}