let Sequelize = require('sequelize'); let db = syzoj.db; let User = syzoj.model('user'); let Problem = syzoj.model('problem'); let model = db.define('custom_test', { id: { type: Sequelize.INTEGER, primaryKey: true, autoIncrement: true }, input_filepath: { type: Sequelize.TEXT }, code: { type: Sequelize.TEXT('medium') }, language: { type: Sequelize.STRING(20) }, status: { type: Sequelize.STRING(50) }, time: { type: Sequelize.INTEGER }, pending: { type: Sequelize.BOOLEAN }, memory: { type: Sequelize.INTEGER }, result: { type: Sequelize.JSON }, user_id: { type: Sequelize.INTEGER }, problem_id: { type: Sequelize.INTEGER }, submit_time: { type: Sequelize.INTEGER } }, { timestamps: false, tableName: 'custom_test', indexes: [ { fields: ['status'], }, { fields: ['user_id'], }, { fields: ['problem_id'], } ] }); let Model = require('./common'); class CustomTest extends Model { static async create(val) { return CustomTest.fromRecord(CustomTest.model.build(Object.assign({ input_filepath: '', code: '', language: '', user_id: 0, problem_id: 0, submit_time: parseInt((new Date()).getTime() / 1000), pending: true, time: 0, memory: 0, result: {}, status: 'Waiting', }, val))); } async loadRelationships() { this.user = await User.fromID(this.user_id); this.problem = await Problem.fromID(this.problem_id); } async updateResult(result) { this.pending = result.pending; this.status = result.status; this.time = result.time_used; this.memory = result.memory_used; this.result = result; } getModel() { return model; } } CustomTest.model = model; module.exports = CustomTest;