I'm trying to test with nightwatch that when a user logs in while already being logged in in a different browser, it automatically logs you out from the first session.
But I have no idea how to create a new browser instance.
That's how my code looks like:
// For authoring Nightwatch tests, see // http://ift.tt/1L3kzGK
module.exports = {
'Landing Page': function (browser) {
// automatically uses dev Server port from /config.index.js
// default: http://localhost:8080
// see nightwatch.conf.js
const devServer = browser.globals.devServerURL;
browser
.url(devServer)
.waitForElementVisible('#app', 5000)
.assert.urlContains('login')
.assert.title('Customer Relation Manager')
.assert.elementPresent('.login')
.assert.containsText('.login-header', 'Log into CRM')
},
'A User not logged in will be redirected to login page': function (browser) {
browser
.url('http://localhost:8080/cust')
.pause(1000)
.assert.urlContains('login')
},
'A User can login': function (browser) {
browser
.setValue('input[type=text]', '********')
.setValue('input[type=password]', '*******')
.click('#submit')
.pause(1000)
.assert.urlContains('dashboard')
.assert.containsText(".header-logo", "CRM V3")
},
'A User who is logged in cannot access the Login page again': function (browser) {
browser
.url('http://localhost:8080/login')
.pause(1000)
.assert.urlContains('dashboard')
// .end();
},
'A user can refresh the page and redirect to the same page': function (browser) {
browser
.refresh()
.pause(1000)
.assert.urlContains('dashboard')
},
'A User can logout': function (browser) {
browser
.click('.header-user-info')
.pause(1000)
.assert.urlContains('login')
.assert.containsText('.login-header', 'Log into CRM')
.end();
}
}
Aucun commentaire:
Enregistrer un commentaire