如何为具有子域的多租户应用编写集成测试。
我正在开发一个多租户应用程序。我正在尝试为子域编写集成测试,但似乎无法使其正常工作。
这是我所做的:
测试文件
import supertest from 'supertest';
import http from 'http';
import app from '../../../app';
const baseUrl = 'censio.lvh.me:7000';
describe('Censio tests', () => {
let server;
let request;
beforeAll((done) => {
server = http.createServer(app);
server.listen(7000, done);
request = supertest(server);
});
afterAll((done) => {
server.close(done);
});
describe('Signin', () => {
it('should respond with missing fields ...', async () => {
const response = await request
.post(`${baseUrl}/signin`)
.send({})
.set('Accept', 'application/json');
expect(response.status).toBe(400);
});
});
});
应用.js
import '@babel/polyfill';
import bodyParser from 'body-parser';
import cookieParser from 'cookie-parser';
import express from 'express';
import subdomain from 'express-subdomain';
import censioRouter from './tenants/censio';
const app = express();
app.use(bodyParser.urlencoded({ extended: true }));
app.use(bodyParser.json());
app.use(cookieParser());
// Subdomain definitions
app.use(subdomain('censio', censioRouter));
app.get('*', (req, res) => res.status(200).json({ message: 'Project started' }));
export default app;
当我检查响应时,我看到 <!DOCTYPE html>
<html lang="en">
<head>
<meta charset="utf-8">
<title>Error</title>
</head>
<body>
<pre>Cannot POST /:7000censio.lvh.me/signin</pre>
</body>
</html>
它把柱子放在前面。当我摆脱端口时,我收到此错误:connect ECONNREFUSED 127.0.0.1:80
我该怎么办?
我终于让它工作了。我正在为将来可能需要此解决方案的任何人发布此解决方案。
-
首先,我完全了解如何使用自定义域在本地测试我的应用程序。我不得不修改我的
/etc/hosts
文件。这篇文章帮助了我。 -
我修改了我的测试(如上面的问题所示)。我没有将
app
传递给supertest,而是传递了我想要的基本URL,即包含我的子域(censio.mydomain.com:myport)的URL。这就是现在的样子。import supertest from 'supertest'; import http from 'http'; import app from '../../../app'; describe('Censio tests', () => { describe('Signin', () => { let server; let request; beforeAll((done) => { server = http.createServer(app); server.listen(7000, done); request = supertest('http://censio.mydomain.com:7000'); }); afterAll((done) => { server.close(done); }); it('should respond with missing fields ...', async () => { const response = await request .post('/signin') .send({}) .set('Accept', 'application/json'); expect(response.status).toBe(400); }); }); });
请注意,我更改了调用前后钩子的位置。
我希望这对你有帮助,因为它帮助了我。