Si vous avez seulement besoin d'un utilisateur authentifié, simplement attribuer à l'utilisateur à la propriété credentials
dans les tests:
var user = { ... };
server.inject({ method: 'GET', url: '/', credentials: user }, function (res) {
console.log(res.result);
});
Voici un exemple qui le démontre:
var Bcrypt = require('bcrypt');
var Hapi = require('hapi');
var HapiAuthCookie = require('hapi-auth-cookie');
var server = new Hapi.Server();
server.connection({ port: 3000 });
var users = {
john: {
username: 'john',
password: '$2a$10$iqJSHD.BGr0E2IxQwYgJmeP3NvhPrXAeLSaGCj6IR/XU5QtjVu5Tm',
name: 'John Doe',
id: '2133d32a'
}
};
var validate = function (request, username, password, callback) {
var user = users[username];
if (!user) {
return callback(null, false);
}
Bcrypt.compare(password, user.password, function (err, isValid) {
callback(err, isValid, { id: user.id, name: user.name });
});
};
server.register(HapiAuthCookie, function (err) {
server.auth.strategy('session', 'cookie', {
password: 'secret',
validateFunc: validate
});
server.route({
method: 'GET',
path: '/',
config: {
auth: 'session',
handler: function (request, reply) {
reply('hello, ' + request.auth.credentials.name);
}
}
});
server.inject({ method: 'GET', url: '/', credentials: users.john }, function (res) {
console.log(res.result);
});
});
grande partie de la exemple a été prise à partir du Authentication Tutorial.
Vous pouvez suivre l'exemple @Gergo Erdosi mais ce https://medium.com/the-spumko-suite/testing-hapi-services-with-lab-96ac463c490a vaut également le détour. – Whisher
Aussi cela peut aider http://codereview.stackexchange.com/questions/97975/hapi-lab-e2e-test-workflow – Whisher