我在 typescript 中使用 express 制作了我的第一台服务器,它运行良好
import app from './Server'
const server = app.listen(8080, '0.0.0.0', () => {
console.log("Server is listening on standard port 80...");
});
export default server;
现在我尝试测试存储在应用程序中的路线:
import express from 'express';
import * as bodyParser from "body-parser";
const app = express();
app.use(bodyParser.json());
app.get("/", (req: express.Request, res: express.Response) => {
res.status(200).send("SUCCESS");
});
export default app;
使用此测试:
import * as chai from 'chai';
import chaiHttp = require('chai-http');
chai.use(chaiHttp);
import server from '../src';
describe("LogAPI", () => {
describe('Base express tests', () => {
it("Should return 'SUCCESS' if GET /", async () => {
return chai.request(server).get("/").then(res => {
chai.expect(res.body).to.equal("SUCCESS");
})
});
it("Should return status-code 200 by calling GET /", async () => {
return chai.request(server).get("/").then(res => {
chai.expect(res.status).to.equal(200);
})
});
});
});
但即使在运行服务器本身工作时,用
mocha --require ts-node/register ./../test/**/*.ts
向我抛出此错误:
/Users/.../NotificationService/src/Server/index.js:5 var app = express_1.default(); ^ TypeError: express_1.default 不是 Object 的函数。(/Users/.../NotificationService/src/Server/inde> x.js:5:28)
我正在使用 es6 目标和 commonjs 模块。如何正确测试我的服务器?
更新 1
我现在摆弄了一下,结果发现default()
从编译的代码中删除该方法解决了一些问题。
现在,我明白了
/Users/.../NotificationService/test/node_modules/@types/chai-http/index.d.ts:13 import * as request from 'superagent'; SyntaxError:意外的令牌导入
更新 2 我的 ts-config.json:
{
"compilerOptions": {
"target": "es6",
"module": "commonjs",
"outDir": "./../out“,
"strict": true,
"esModuleInterop": true
}
}