audiobookshelf/test/server/migrations/v0.0.1-migration_example.js

44 lines
1.6 KiB
JavaScript
Raw Normal View History

const { DataTypes } = require('sequelize')
/**
* This is an example of an upward migration script.
*
* @param {import { QueryInterface } from "sequelize";} options.context.queryInterface - a suquelize QueryInterface object.
2024-09-07 21:24:19 +02:00
* @param {import { Logger } from "../../../server/Logger";} options.context.logger - a Logger object.
* @returns {Promise<void>} - A promise that resolves when the migration is complete.
*/
2024-09-07 21:24:19 +02:00
async function up({ context: { queryInterface, logger } }) {
logger.info('Running migration_example up...')
logger.info('Creating example_table...')
await queryInterface.createTable('example_table', {
id: {
type: DataTypes.INTEGER,
primaryKey: true,
autoIncrement: true
},
name: {
type: DataTypes.STRING,
allowNull: false
}
})
2024-09-07 21:24:19 +02:00
logger.info('example_table created.')
logger.info('migration_example up complete.')
}
/**
* This is an example of a downward migration script.
*
* @param {import { QueryInterface } from "sequelize";} options.context.queryInterface - a suquelize QueryInterface object.
2024-09-07 21:24:19 +02:00
* @param {import { Logger } from "../../../server/Logger";} options.context.logger - a Logger object.
* @returns {Promise<void>} - A promise that resolves when the migration is complete.
*/
2024-09-07 21:24:19 +02:00
async function down({ context: { queryInterface, logger } }) {
logger.info('Running migration_example down...')
logger.info('Dropping example_table...')
await queryInterface.dropTable('example_table')
2024-09-07 21:24:19 +02:00
logger.info('example_table dropped.')
logger.info('migration_example down complete.')
}
module.exports = { up, down }