我遇到了这种奇怪的情况,我的 Cron 作业成功执行了一个返回承诺的函数,但是,当它尝试.find()
在模型上执行 a 时,它实际上从未执行过。我在我的应用程序的其他地方使用了相同的函数,并且通过 API 调用调用并且没有返回问题。有什么我想念的吗?
这是我的 cron 脚本:
var CronJob = require('node-cron');
var TradeService = require('../services/TradeService');
// Setup the cron job to fire every second
CronJob.schedule('* * * * * *', function() {
console.log('You will see this message every second');
TradeService.executePendingTrades();
}, null, true, 'America/Los_Angeles');
以下是被调用的相关函数:
exports.executePendingTrades = () => {
// Get all pending trades
exports.getPendingTrades().then(results => {
console.log('results', results); // This never fires
})
}
exports.getPendingTrades = () => {
return new Promise((resolve, reject) => {
Trades.find({})
.where('is_canceled').equals('false')
.where('is_completed').equals('false')
.sort('-created_at')
.exec( (err, payload) => {
if (err) {
return reject(err); // This never fires
}
return resolve(payload); // This never fires
})
});
}