У меня есть код, который использует обещания, но он не запускается при запуске через Mocha. Я упростил его к основам:Обещает не работать с Mocha, в nodejs
process.env.NODE_ENV = 'test';
const Promise = require('bluebird');
console.log('zzzz IN');
Promise.resolve('xxx').then(function(val) {
console.log('[normal]', val);
}).catch(function(error) {
console.log('[error]', error);
})
console.log('zzzz OUT');
при запуске через node test/index.js
я получаю:
zzzz IN
zzzz OUT
[normal] xxx
но через мокко:
> [email protected] test /Users/ajmas/Development/mocha-and-promise
> eslint lib && mocha --timeout 10000
zzzz IN
zzzz OUT
0 passing (0ms)
Является ли это проблема в мокко или в пути Я настроил что-то?
Package.json:
{
"name": "my-server",
"version": "0.0.1",
"description": "Mocha and Promises test case",
"main": "lib/main.js",
"scripts": {
"start-dev": "NODE_ENV=dev node test/index.js",
"start-dev-debug": "DEBUG=express:* npm run start-dev",
"start": "node lib/main.js",
"test": "eslint lib && mocha --timeout 10000"
},
"engines": {
"node": ">=6.7.0"
},
"dependencies": {
"bluebird": "^3.4.6"
},
"devDependencies": {
"chai": "^3.5.0",
"chai-http": "^3.0.0",
"eslint": "^3.8.1",
"eslint-config-standard": "^6.2.1",
"eslint-plugin-promise": "^3.3.0",
"eslint-plugin-standard": "^2.0.1",
"mocha": "^3.2.0"
}
}
Запуск с узлом 6.7.0 на MacOS X 10.12.2. Также попробовали с 'bluebird', 'promise' и родной Promise, но такое же поведение с каждым.
BTW этот код предназначен для приложения. Я интеграционное тестирование, но поскольку никакие обещания не завершаются, я не могу запустить сервер изнутри Mocha.
Вам не нужно 'done', вы можете просто вернуть обещание. См. Https://mochajs.org/#working-with-promises –