Javascript node.js中的Mocha测试挂起或丢失
目前,我正在处理一个项目,我应该在node.js中使用express.js编写路由 测试和项目的其他部分不是我写的,因此我假设它们没有错误 我遇到的问题是:在程序的当前阶段,当我运行“npm测试”时,我会挂起测试,而控制不会返回到命令行。我注意到,当我注释掉server.js、api.js和employees.js中的所有行时,测试运行顺利 另外,有时只执行一部分测试,比如1/3的测试 你知道为什么测试会挂起,以及如何修复它们吗 下面是package.json文件以及到目前为止项目的主要文件 提前谢谢 package.jsonJavascript node.js中的Mocha测试挂起或丢失,javascript,node.js,mocha.js,Javascript,Node.js,Mocha.js,目前,我正在处理一个项目,我应该在node.js中使用express.js编写路由 测试和项目的其他部分不是我写的,因此我假设它们没有错误 我遇到的问题是:在程序的当前阶段,当我运行“npm测试”时,我会挂起测试,而控制不会返回到命令行。我注意到,当我注释掉server.js、api.js和employees.js中的所有行时,测试运行顺利 另外,有时只执行一部分测试,比如1/3的测试 你知道为什么测试会挂起,以及如何修复它们吗 下面是package.json文件以及到目前为止项目的主要文件 提
{
"name": "expresso",
"version": "1.0.0",
"description": "",
"main": "server.js",
"scripts": {
"test": "mocha"
},
"author": "",
"license": "ISC",
"dependencies": {
"body-parser": "^1.19.0",
"chai": "^4.1.2",
"cors": "^2.8.5",
"errorhandler": "^1.5.1",
"express": "^4.17.1",
"mocha": "^6.1.4",
"react": "^15.6.1",
"react-dom": "^15.6.1",
"react-router-dom": "^4.2.2",
"sqlite3": "^4.0.6",
"supertest": "^3.0.0",
"whatwg-fetch": "^2.0.3"
},
"devDependencies": {
"babel": "^6.23.0",
"babel-core": "^6.26.0",
"babel-loader": "^7.1.2",
"babel-preset-es2015": "^6.24.1",
"babel-preset-react": "^6.24.1",
"babel-preset-stage-2": "^6.24.1",
"webpack": "^3.5.5"
}
}
server.js
const bodyParser = require('body-parser');
const cors = require('cors');
const errorHandler = require('errorhandler');
const express = require('express');
const apiRouter = require('./api/api');
const app = express();
const PORT = process.env.PORT || 4000;
app.use(bodyParser.json());
app.use(cors());
app.use('/api', apiRouter);
app.use(errorHandler());
app.listen(PORT, () => {
console.log(`Listening on port ${PORT}`);
});
module.exports = app;
const express = require('express');
const apiRouter = express.Router();
const employeesRouter = require('./employees');
// <<< api/employees >>>
apiRouter.use('/employees', employeesRouter);
module.exports = apiRouter;
const express = require('express');
const employeesRouter = express.Router();
const sqlite = require('sqlite3');
const db = new sqlite.Database('./database.sqlite');
// <<< api/employees >>>
employeesRouter.get('/', (req, res, next) => {
const sql = 'SELECT * FROM Employee WHERE is_current_employee = 1';
db.all(sql, (error, employees) => {
if (error) {
next(error);
} else {
res.status(200).json({ employees: employees });
}
});
});
module.exports = employeesRouter;
api.js
const bodyParser = require('body-parser');
const cors = require('cors');
const errorHandler = require('errorhandler');
const express = require('express');
const apiRouter = require('./api/api');
const app = express();
const PORT = process.env.PORT || 4000;
app.use(bodyParser.json());
app.use(cors());
app.use('/api', apiRouter);
app.use(errorHandler());
app.listen(PORT, () => {
console.log(`Listening on port ${PORT}`);
});
module.exports = app;
const express = require('express');
const apiRouter = express.Router();
const employeesRouter = require('./employees');
// <<< api/employees >>>
apiRouter.use('/employees', employeesRouter);
module.exports = apiRouter;
const express = require('express');
const employeesRouter = express.Router();
const sqlite = require('sqlite3');
const db = new sqlite.Database('./database.sqlite');
// <<< api/employees >>>
employeesRouter.get('/', (req, res, next) => {
const sql = 'SELECT * FROM Employee WHERE is_current_employee = 1';
db.all(sql, (error, employees) => {
if (error) {
next(error);
} else {
res.status(200).json({ employees: employees });
}
});
});
module.exports = employeesRouter;
const express=require('express');
const apiRouter=express.Router();
const employeesRouter=要求('./员工');
// >
apiRouter.use('/employees',employeesRouter);
module.exports=apiRouter;
employees.js
const bodyParser = require('body-parser');
const cors = require('cors');
const errorHandler = require('errorhandler');
const express = require('express');
const apiRouter = require('./api/api');
const app = express();
const PORT = process.env.PORT || 4000;
app.use(bodyParser.json());
app.use(cors());
app.use('/api', apiRouter);
app.use(errorHandler());
app.listen(PORT, () => {
console.log(`Listening on port ${PORT}`);
});
module.exports = app;
const express = require('express');
const apiRouter = express.Router();
const employeesRouter = require('./employees');
// <<< api/employees >>>
apiRouter.use('/employees', employeesRouter);
module.exports = apiRouter;
const express = require('express');
const employeesRouter = express.Router();
const sqlite = require('sqlite3');
const db = new sqlite.Database('./database.sqlite');
// <<< api/employees >>>
employeesRouter.get('/', (req, res, next) => {
const sql = 'SELECT * FROM Employee WHERE is_current_employee = 1';
db.all(sql, (error, employees) => {
if (error) {
next(error);
} else {
res.status(200).json({ employees: employees });
}
});
});
module.exports = employeesRouter;
const express=require('express');
const employeesRouter=express.Router();
const sqlite=require('sqlite3');
const db=new sqlite.Database('./Database.sqlite');
// >
employeesRouter.get(“/”,(req,res,next)=>{
const sql='SELECT*FROM Employee,其中是_current_Employee=1';
db.all(sql,(错误,员工)=>{
如果(错误){
下一步(错误);
}否则{
res.status(200).json({employees:employees});
}
});
});
module.exports=员工外部;
您必须将脚本->测试中的标签-exit
添加到包.json
中
结果应该是:
“脚本”:{
“测试”:“摩卡咖啡——退出”
}
据
--退出:测试完成后强制摩卡退出
之后,当测试完成时,命令行再次可用。多亏了!这允许测试运行并将控制返回控制台!然而,不幸的是,在项目的当前阶段,总共80多个测试中只有30个被执行。你知道如何解决这个问题吗?我认为这个问题可能是测试实现的问题。当测试失败时,控制台是否输出消息?我想我遇到了一些异常错误。下面是详细的结果->。这是测试实现的一个问题。断言在大多数情况下都是不正确的。可能测试写得不好,或者应用程序出现故障,测试正常。你必须和写测试的人谈谈。但我认为这是另一个问题。