2016-01-29 11:24:01 +01:00
|
|
|
'use strict';
|
|
|
|
|
|
|
|
const gemini = require('gemini');
|
2016-02-01 18:03:20 +01:00
|
|
|
const environment = require('../../environment');
|
2016-02-04 11:59:25 +01:00
|
|
|
const MAIN_USER = environment.MAIN_USER;
|
|
|
|
const TIMEOUTS = environment.TIMEOUTS;
|
2016-01-29 11:24:01 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Basic suite of tests against whitelabel routes that do not require authentication.
|
|
|
|
*/
|
|
|
|
gemini.suite('Whitelabel basic', (suite) => {
|
|
|
|
suite
|
|
|
|
.setCaptureElements('.ascribe-wallet-app > .container')
|
|
|
|
.before((actions, find) => {
|
|
|
|
// This will be called before every nested suite begins unless that suite
|
|
|
|
// also defines a `.before()`
|
|
|
|
// FIXME: use a more generic class for this, like just '.ascribe-app'
|
2016-02-04 11:59:25 +01:00
|
|
|
actions.waitForElementToShow('.ascribe-wallet-app', TIMEOUTS.NORMAL);
|
2016-01-29 11:24:01 +01:00
|
|
|
|
|
|
|
// Use a dumb wait in case we're still waiting for other assets, like fonts, to load
|
|
|
|
actions.wait(1000);
|
|
|
|
});
|
|
|
|
|
|
|
|
gemini.suite('Login', (loginSuite) => {
|
|
|
|
loginSuite
|
|
|
|
.setUrl('/login')
|
|
|
|
// See Ikono
|
|
|
|
.skip(/Ikono/)
|
|
|
|
.capture('login', (actions, find) => {
|
2016-02-04 11:59:25 +01:00
|
|
|
actions.waitForElementToShow('.ascribe-form', TIMEOUTS.NORMAL);
|
2016-01-29 11:24:01 +01:00
|
|
|
// For some reason, the screenshots seem to keep catching the whitelabel login form
|
|
|
|
// on a refresh and without fonts loaded (maybe because they're the first tests run
|
|
|
|
// and the cache isn't hot yet?).
|
|
|
|
// Let's wait a bit and hope they load.
|
2016-02-04 11:59:25 +01:00
|
|
|
actions.wait(TIMEOUTS.SHORT);
|
2016-01-29 11:24:01 +01:00
|
|
|
})
|
|
|
|
.capture('hover on login submit', (actions, find) => {
|
|
|
|
actions.mouseMove(find('.ascribe-form button[type=submit]'));
|
|
|
|
})
|
|
|
|
.capture('hover on sign up link', (actions, find) => {
|
|
|
|
actions.mouseMove(find('.ascribe-login-text a[href="/signup"]'));
|
|
|
|
})
|
|
|
|
.capture('login form filled with focus', (actions, find) => {
|
|
|
|
const emailInput = find('.ascribe-form input[name=email]');
|
|
|
|
|
|
|
|
// Remove hover from sign up link
|
|
|
|
actions.click(emailInput);
|
|
|
|
|
2016-02-04 11:59:25 +01:00
|
|
|
actions.sendKeys(emailInput, MAIN_USER.email);
|
|
|
|
actions.sendKeys(find('.ascribe-form input[name=password]'), MAIN_USER.password);
|
2016-01-29 11:24:01 +01:00
|
|
|
})
|
|
|
|
.capture('login form filled', (actions, find) => {
|
|
|
|
actions.click(find('.ascribe-form-header'));
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
gemini.suite('Sign up', (signUpSuite) => {
|
|
|
|
signUpSuite
|
|
|
|
.setUrl('/signup')
|
|
|
|
// See Ikono
|
|
|
|
.skip(/Ikono/)
|
|
|
|
.capture('sign up', (actions, find) => {
|
2016-02-04 11:59:25 +01:00
|
|
|
actions.waitForElementToShow('.ascribe-form', TIMEOUTS.NORMAL);
|
2016-01-29 11:24:01 +01:00
|
|
|
// Wait in case the form reloads due to other assets loading
|
|
|
|
actions.wait(500);
|
|
|
|
})
|
|
|
|
.capture('sign up form filled with focus', (actions, find) => {
|
2016-02-04 11:59:25 +01:00
|
|
|
actions.sendKeys(find('.ascribe-form input[name=email]'), MAIN_USER.email);
|
|
|
|
actions.sendKeys(find('.ascribe-form input[name=password]'), MAIN_USER.password);
|
|
|
|
actions.sendKeys(find('.ascribe-form input[name=password_confirm]'), MAIN_USER.password);
|
2016-01-29 11:24:01 +01:00
|
|
|
})
|
|
|
|
.capture('sign up form filled with check', (actions, find) => {
|
|
|
|
actions.click(find('.ascribe-form input[type="checkbox"] ~ .checkbox'));
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
gemini.suite('Password reset', (passwordResetSuite) => {
|
|
|
|
passwordResetSuite
|
|
|
|
.setUrl('/password_reset')
|
|
|
|
.capture('password reset', (actions, find) => {
|
2016-02-04 11:59:25 +01:00
|
|
|
actions.waitForElementToShow('.ascribe-form', TIMEOUTS.NORMAL);
|
2016-01-29 11:24:01 +01:00
|
|
|
// Wait in case the form reloads due to other assets loading
|
|
|
|
actions.wait(500);
|
|
|
|
})
|
|
|
|
.capture('password reset form filled with focus', (actions, find) => {
|
2016-02-04 11:59:25 +01:00
|
|
|
actions.sendKeys(find('.ascribe-form input[name="email"]'), MAIN_USER.email);
|
2016-01-29 11:24:01 +01:00
|
|
|
})
|
|
|
|
.capture('password reset form filled', (actions, find) => {
|
|
|
|
actions.click(find('.ascribe-form-header'));
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
gemini.suite('Coa verify', (coaVerifySuite) => {
|
|
|
|
coaVerifySuite
|
|
|
|
.setUrl('/coa_verify')
|
|
|
|
.capture('coa verify', (actions, find) => {
|
2016-02-04 11:59:25 +01:00
|
|
|
actions.waitForElementToShow('.ascribe-form', TIMEOUTS.NORMAL);
|
2016-01-29 11:24:01 +01:00
|
|
|
// Wait in case the form reloads due to other assets loading
|
|
|
|
actions.wait(500);
|
|
|
|
})
|
|
|
|
.capture('coa verify form filled with focus', (actions, find) => {
|
|
|
|
actions.sendKeys(find('.ascribe-form input[name="message"]'), 'sample text');
|
|
|
|
actions.sendKeys(find('.ascribe-form .ascribe-property-wrapper:nth-of-type(2) textarea'), 'sample signature');
|
|
|
|
})
|
|
|
|
.capture('coa verify form filled', (actions, find) => {
|
|
|
|
actions.click(find('.ascribe-login-header'));
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
gemini.suite('Not found', (notFoundSuite) => {
|
|
|
|
notFoundSuite
|
|
|
|
.setUrl('/not_found_page')
|
|
|
|
.capture('not found page');
|
|
|
|
});
|
|
|
|
});
|