All files / src/Projection/migrations 1682519108363-pool-metadata-table.ts

23.07% Statements 3/13
100% Branches 0/0
0% Functions 0/2
23.07% Lines 3/13

Press n or j to go to the next uncovered block, b, p or k for the previous block.

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29  40x   40x 40x                                                
import { MigrationInterface, QueryRunner } from 'typeorm';
import { PoolMetadataEntity } from '@cardano-sdk/projection-typeorm';
 
export class PoolMetadataTableMigration1682519108363 implements MigrationInterface {
  static entity = PoolMetadataEntity;
 
  async up(queryRunner: QueryRunner): Promise<void> {
    await queryRunner.query(
      'CREATE TABLE "pool_metadata" ("id" SERIAL NOT NULL, "ticker" character varying NOT NULL, "name" character varying NOT NULL, "description" character varying NOT NULL, "homepage" character varying NOT NULL, "hash" character varying NOT NULL, "ext" jsonb, "stake_pool_id" character(56), "pool_update_id" bigint NOT NULL, CONSTRAINT "REL_pool_metadata_pool_update_id" UNIQUE ("pool_update_id"), CONSTRAINT "PK_pool_metadata_id" PRIMARY KEY ("id"))'
    );
    await queryRunner.query('CREATE INDEX "IDX_pool_metadata_ticker" ON "pool_metadata" ("ticker") ');
    await queryRunner.query('CREATE INDEX "IDX_pool_metadata_name" ON "pool_metadata" ("name") ');
    await queryRunner.query(
      'ALTER TABLE "pool_metadata" ADD CONSTRAINT "FK_pool_metadata_stake_pool_id" FOREIGN KEY ("stake_pool_id") REFERENCES "stake_pool"("id") ON DELETE NO ACTION ON UPDATE NO ACTION'
    );
    await queryRunner.query(
      'ALTER TABLE "pool_metadata" ADD CONSTRAINT "FK_pool_metadata_pool_update_id" FOREIGN KEY ("pool_update_id") REFERENCES "pool_registration"("id") ON DELETE CASCADE ON UPDATE NO ACTION'
    );
  }
 
  async down(queryRunner: QueryRunner): Promise<void> {
    await queryRunner.query('ALTER TABLE "pool_metadata" DROP CONSTRAINT "FK_pool_metadata_pool_update_id"');
    await queryRunner.query('ALTER TABLE "pool_metadata" DROP CONSTRAINT "FK_pool_metadata_stake_pool_id"');
    await queryRunner.query('DROP INDEX "public"."IDX_pool_metadata_name"');
    await queryRunner.query('DROP INDEX "public"."IDX_pool_metadata_ticker"');
    await queryRunner.query('DROP TABLE "pool_metadata"');
  }
}