2017-01-10 18:02:20 -05:00
|
|
|
/* eslint-disable space-before-function-paren, new-parens, quotes, no-var, one-var, one-var-declaration-per-line, comma-dangle, max-len */
|
2016-12-14 00:26:26 -05:00
|
|
|
/* global MockU2FDevice */
|
|
|
|
/* global U2FRegister */
|
2016-07-24 16:45:11 -04:00
|
|
|
|
2017-05-16 17:01:51 -04:00
|
|
|
import '~/u2f/register';
|
|
|
|
import '~/u2f/util';
|
|
|
|
import '~/u2f/error';
|
|
|
|
import 'vendor/u2f';
|
|
|
|
import './mock_u2f_device';
|
2016-07-24 16:45:11 -04:00
|
|
|
|
|
|
|
(function() {
|
|
|
|
describe('U2FRegister', function() {
|
2016-12-30 19:14:33 -05:00
|
|
|
preloadFixtures('u2f/register.html.raw');
|
2017-01-03 15:48:37 -05:00
|
|
|
|
2016-07-24 16:45:11 -04:00
|
|
|
beforeEach(function() {
|
2016-12-30 19:14:33 -05:00
|
|
|
loadFixtures('u2f/register.html.raw');
|
2016-07-24 16:45:11 -04:00
|
|
|
this.u2fDevice = new MockU2FDevice;
|
|
|
|
this.container = $("#js-register-u2f");
|
|
|
|
this.component = new U2FRegister(this.container, $("#js-register-u2f-templates"), {}, "token");
|
|
|
|
return this.component.start();
|
|
|
|
});
|
|
|
|
it('allows registering a U2F device', function() {
|
|
|
|
var deviceResponse, inProgressMessage, registeredMessage, setupButton;
|
|
|
|
setupButton = this.container.find("#js-setup-u2f-device");
|
2017-04-04 14:06:32 -04:00
|
|
|
expect(setupButton.text()).toBe('Setup new U2F device');
|
2016-07-24 16:45:11 -04:00
|
|
|
setupButton.trigger('click');
|
|
|
|
inProgressMessage = this.container.children("p");
|
|
|
|
expect(inProgressMessage.text()).toContain("Trying to communicate with your device");
|
|
|
|
this.u2fDevice.respondToRegisterRequest({
|
|
|
|
deviceData: "this is data from the device"
|
|
|
|
});
|
|
|
|
registeredMessage = this.container.find('p');
|
|
|
|
deviceResponse = this.container.find('#js-device-response');
|
|
|
|
expect(registeredMessage.text()).toContain("Your device was successfully set up!");
|
|
|
|
return expect(deviceResponse.val()).toBe('{"deviceData":"this is data from the device"}');
|
|
|
|
});
|
|
|
|
return describe("errors", function() {
|
|
|
|
it("doesn't allow the same device to be registered twice (for the same user", function() {
|
|
|
|
var errorMessage, setupButton;
|
|
|
|
setupButton = this.container.find("#js-setup-u2f-device");
|
|
|
|
setupButton.trigger('click');
|
|
|
|
this.u2fDevice.respondToRegisterRequest({
|
|
|
|
errorCode: 4
|
|
|
|
});
|
|
|
|
errorMessage = this.container.find("p");
|
|
|
|
return expect(errorMessage.text()).toContain("already been registered with us");
|
|
|
|
});
|
|
|
|
it("displays an error message for other errors", function() {
|
|
|
|
var errorMessage, setupButton;
|
|
|
|
setupButton = this.container.find("#js-setup-u2f-device");
|
|
|
|
setupButton.trigger('click');
|
|
|
|
this.u2fDevice.respondToRegisterRequest({
|
|
|
|
errorCode: "error!"
|
|
|
|
});
|
|
|
|
errorMessage = this.container.find("p");
|
|
|
|
return expect(errorMessage.text()).toContain("There was a problem communicating with your device");
|
|
|
|
});
|
|
|
|
return it("allows retrying registration after an error", function() {
|
|
|
|
var registeredMessage, retryButton, setupButton;
|
|
|
|
setupButton = this.container.find("#js-setup-u2f-device");
|
|
|
|
setupButton.trigger('click');
|
|
|
|
this.u2fDevice.respondToRegisterRequest({
|
|
|
|
errorCode: "error!"
|
|
|
|
});
|
|
|
|
retryButton = this.container.find("#U2FTryAgain");
|
|
|
|
retryButton.trigger('click');
|
|
|
|
setupButton = this.container.find("#js-setup-u2f-device");
|
|
|
|
setupButton.trigger('click');
|
|
|
|
this.u2fDevice.respondToRegisterRequest({
|
|
|
|
deviceData: "this is data from the device"
|
|
|
|
});
|
|
|
|
registeredMessage = this.container.find("p");
|
|
|
|
return expect(registeredMessage.text()).toContain("Your device was successfully set up!");
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
2017-02-10 02:29:41 -05:00
|
|
|
}).call(window);
|