Javascript node.js中的Mocha测试挂起或丢失

Javascript 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文件以及到目前为止项目的主要文件 提

目前,我正在处理一个项目,我应该在node.js中使用express.js编写路由

测试和项目的其他部分不是我写的,因此我假设它们没有错误

我遇到的问题是:在程序的当前阶段,当我运行“npm测试”时,我会挂起测试,而控制不会返回到命令行。我注意到,当我注释掉server.js、api.js和employees.js中的所有行时,测试运行顺利

另外,有时只执行一部分测试,比如1/3的测试

你知道为什么测试会挂起,以及如何修复它们吗

下面是package.json文件以及到目前为止项目的主要文件

提前谢谢

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个被执行。你知道如何解决这个问题吗?我认为这个问题可能是测试实现的问题。当测试失败时,控制台是否输出消息?我想我遇到了一些异常错误。下面是详细的结果->。这是测试实现的一个问题。断言在大多数情况下都是不正确的。可能测试写得不好,或者应用程序出现故障,测试正常。你必须和写测试的人谈谈。但我认为这是另一个问题。