我正在使用koa-jwt
,而依次使用jsonwebtoken
。这是我的路由器实现:
index.ts
const jwt = require('koa-jwt');
...
// some other code
...
export const publicEndpoints = ['/', '/openapi.json', '/healthcheck'];
export default new Router<ApplicationState, ApplicationContext>()
.use(configure)
.use((ctx,next) => {
console.log("REACH 02 opts",ctx,next);
console.log("REACH 02 jwt", jwt);
})
.use(
jwt({
secret: customSecretLoader,
audience: (jwksConfig.audience as unknown) as string,
algorithms: ['RS256'],
}).unless({ path: publicEndpoints })
)
// Public endpoints
.use('/openapi.json', swagger)
.use('/', helloworld)
.use('/healthcheck', healthcheck)
// Secure endpoints
.get('/secure', helloworld)
.middleware();
调用/secure
应该通过调用jwt
并传递令牌的中间件
我想测试每条安全路由,以确保它不会传递没有正确令牌的任何请求,而传递那些没有正确令牌的请求。
先验很简单,我只需要拨打一条安全路线:
index.test.ts
it('Unauthenticated secure request returns 401', async () => {
const response = await request(server).get('/secure');
expect(response.status).toEqual(401);
});
但是,后者要使其正常工作,我需要模拟jwt()
函数调用,并使其返回200
,但是问题是,无论我写什么内容我的测试中,我仍然称呼koa-jwt
的原始实现。
*要了解一些背景,这是我正在尝试模拟https://github.com/koajs/jwt/blob/master/lib/index.js的koa-js
库。它返回middleware()
,后者调用verify
,而后者依次使用jsonwebtoken
模拟整个导出的功能
index.test.ts
`var jwt = require('koa-jwt');`
...
// some code
...
it('Authenticated secure request returns 200', async () => {
jwt = jest.fn(() => {
Promise.resolve({
status: 200,
success: 'Token is valid'
});
});
console.log("REACH 01 jwt", jwt);
const response = await request(server).get('/secure');
console.log("REACH RESPONSE",response);
expect(response.status).toEqual(200);
});
从控制台日志中得到的输出是:
REACH 01 jwt function mockConstructor() {
return fn.apply(this, arguments);
}
这是我的期望,但是当在jwt()
中击中index.ts
时,我得到的输出是:
REACH 02 jwt (opts = {}) => {
const { debug, getToken, isRevoked, key = 'user', passthrough, tokenKey } = opts;
const tokenResolvers = [resolveCookies, resolveAuthHeader];
if (getToken && typeof getToken === 'function') {
tokenResolvers.unshift(getToken);
}
const middleware = async function jwt(ctx, next) {
let token;
tokenResolvers.find(resolver => token = resolver(ctx, opts));
.....
我希望嘲笑koa-jwt
可以在两个控制台日志中看到相同的输出。
我尝试了一些不同的事情,这些事情给了我相同的结果:
-在koa-js
中导出的默认函数中模拟中间件函数
-模拟koa-js
的依赖项jsonwebtoken
我想念什么?
答案 0 :(得分:0)
该解决方案正在模拟测试的整个模块外部:
import....
// some other code
jest.mock('koa-jwt', () => {
const fn = jest.fn((opts) => // 1st level i.e. jwt()
{
const middlewareMock = jest.fn(async (ctx, next) => { // 2nd level i.e. middleware()
// Unreachable
});
// @ts-ignore
middlewareMock.unless = jest.fn(() => jest.fn((ctx, next) => {
next();
})); // 4th level i.e. middleware().unless()
return middlewareMock;
});
return fn;
});
...
describe('routes: index', () => {
// Testing each secure endpoint with authentication
it('Authenticated requests to secure endpoints return 200', async () => {
secureEndpoints.forEach(async (endpoint) => {
const response = await request(server).get(endpoint);
expect(response.status).toEqual(200);
});
});
});