我喜欢用SuperTest像这样使用我的身份验证系统:
const request = require('./valid_access_token')(require('supertest'));
request(app)
.get('/v1/bots')
.valid_token()
.expect('Content-Type', /json/)
...
valid_token() 将插入一个有效的访问 token
module.exports = function (Request) {
const Token = require('../../../app/v1/models/loader')('token');
const UserFactory = require('../fixtures/user');
Request.prototype.valid_token = function()
{
return UserFactory.createAsync('user')
.then(function(user){
return new Token({username: user.username}).createWeeklyAsync()
.then(function(userToken){
this.set("access-token",userToken[0].token);
return this;
})
})
}
return Request;
}
但是,当我运行它时,出现了这个错误:
TypeError: request(...).get(...).valid_token is not a function
我尝试了各种不同的方法,但没有成功。
最佳答案
所有功劳归于https://github.com/acabreragnz
const request = require('supertest');
const Test = request.Test;
Test.prototype.authenticate = function(user) {
const {token, xsrfToken} = user.tokens;
return this
.set('Authorization', `Bearer ${token}`)
.set('X-XSRF-TOKEN', xsrfToken);
}
然后在你的测试中
return request(app)
.post('/user/settings')
.authenticate(user)
.send(...)
https://github.com/visionmedia/supertest/issues/381#issuecomment-282198972
关于javascript - 扩展 super 测试,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40683781/