Is it possible to create function inside `conf.js`?
Is it possible to create function which is used for every spec to test, for example login function inside the conf.js
file or directly sendKeys
from conf.js
as from spec.js
javascript testing protractor automated-tests
add a comment |
Is it possible to create function which is used for every spec to test, for example login function inside the conf.js
file or directly sendKeys
from conf.js
as from spec.js
javascript testing protractor automated-tests
add a comment |
Is it possible to create function which is used for every spec to test, for example login function inside the conf.js
file or directly sendKeys
from conf.js
as from spec.js
javascript testing protractor automated-tests
Is it possible to create function which is used for every spec to test, for example login function inside the conf.js
file or directly sendKeys
from conf.js
as from spec.js
javascript testing protractor automated-tests
javascript testing protractor automated-tests
edited Nov 22 '18 at 11:13
Munawir
2,81782238
2,81782238
asked Nov 22 '18 at 7:00
RaoRao
6611
6611
add a comment |
add a comment |
1 Answer
1
active
oldest
votes
From nodejs syntax, it supports to do that as following:
// conf.js
exports.config = {
// put config at here as usual
};
exports.login = function(username, password) {
browser.get('');
element.sendKeys('');
};
// spec.js
var login = require('./conf.js').login;
// actually, you can move the login function to another .js file to keep
// conf.js more dedicated on configuration purpose.
describe("A spec (with setup and tear-down)", function() {
it('', function(){
login('username', 'password')
});
});
But that is not a good practice. Because main test framework supports to do something before each test case. For jasmine it supplys beforeEach
:
describe("A spec (with setup and tear-down)", function() {
var foo;
beforeEach(function() {
foo = 0;
foo += 1;
});
afterEach(function() {
foo = 0;
});
it("is just a function, so it can contain any code", function() {
expect(foo).toEqual(1);
});
it("can have more than one expectation", function() {
expect(foo).toEqual(1);
expect(true).toEqual(true);
});
});
At last, I can't see the benefit/advantage to do as you required.
just a silly question tho isbeforeEach
function will get call once only or before each function
– Rao
Nov 23 '18 at 4:54
thanks i implemented above mentioned solution and it worked
– Rao
Nov 23 '18 at 5:07
beforeEach()
will be called before eachit()
function be executed.
– yong
Nov 23 '18 at 6:47
then if i want to login thenbefoeEach
won't work
– Rao
Nov 23 '18 at 6:55
1
If you login inbeforeEach()
, you can do logout inafterEach()
. Or you can only usebeforeEach()
with following process: 1) do logout no matter is login or not, 2) do login
– yong
Nov 23 '18 at 6:59
|
show 2 more comments
Your Answer
StackExchange.ifUsing("editor", function () {
StackExchange.using("externalEditor", function () {
StackExchange.using("snippets", function () {
StackExchange.snippets.init();
});
});
}, "code-snippets");
StackExchange.ready(function() {
var channelOptions = {
tags: "".split(" "),
id: "1"
};
initTagRenderer("".split(" "), "".split(" "), channelOptions);
StackExchange.using("externalEditor", function() {
// Have to fire editor after snippets, if snippets enabled
if (StackExchange.settings.snippets.snippetsEnabled) {
StackExchange.using("snippets", function() {
createEditor();
});
}
else {
createEditor();
}
});
function createEditor() {
StackExchange.prepareEditor({
heartbeatType: 'answer',
autoActivateHeartbeat: false,
convertImagesToLinks: true,
noModals: true,
showLowRepImageUploadWarning: true,
reputationToPostImages: 10,
bindNavPrevention: true,
postfix: "",
imageUploader: {
brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
allowUrls: true
},
onDemand: true,
discardSelector: ".discard-answer"
,immediatelyShowMarkdownHelp:true
});
}
});
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53425440%2fis-it-possible-to-create-function-inside-conf-js%23new-answer', 'question_page');
}
);
Post as a guest
Required, but never shown
1 Answer
1
active
oldest
votes
1 Answer
1
active
oldest
votes
active
oldest
votes
active
oldest
votes
From nodejs syntax, it supports to do that as following:
// conf.js
exports.config = {
// put config at here as usual
};
exports.login = function(username, password) {
browser.get('');
element.sendKeys('');
};
// spec.js
var login = require('./conf.js').login;
// actually, you can move the login function to another .js file to keep
// conf.js more dedicated on configuration purpose.
describe("A spec (with setup and tear-down)", function() {
it('', function(){
login('username', 'password')
});
});
But that is not a good practice. Because main test framework supports to do something before each test case. For jasmine it supplys beforeEach
:
describe("A spec (with setup and tear-down)", function() {
var foo;
beforeEach(function() {
foo = 0;
foo += 1;
});
afterEach(function() {
foo = 0;
});
it("is just a function, so it can contain any code", function() {
expect(foo).toEqual(1);
});
it("can have more than one expectation", function() {
expect(foo).toEqual(1);
expect(true).toEqual(true);
});
});
At last, I can't see the benefit/advantage to do as you required.
just a silly question tho isbeforeEach
function will get call once only or before each function
– Rao
Nov 23 '18 at 4:54
thanks i implemented above mentioned solution and it worked
– Rao
Nov 23 '18 at 5:07
beforeEach()
will be called before eachit()
function be executed.
– yong
Nov 23 '18 at 6:47
then if i want to login thenbefoeEach
won't work
– Rao
Nov 23 '18 at 6:55
1
If you login inbeforeEach()
, you can do logout inafterEach()
. Or you can only usebeforeEach()
with following process: 1) do logout no matter is login or not, 2) do login
– yong
Nov 23 '18 at 6:59
|
show 2 more comments
From nodejs syntax, it supports to do that as following:
// conf.js
exports.config = {
// put config at here as usual
};
exports.login = function(username, password) {
browser.get('');
element.sendKeys('');
};
// spec.js
var login = require('./conf.js').login;
// actually, you can move the login function to another .js file to keep
// conf.js more dedicated on configuration purpose.
describe("A spec (with setup and tear-down)", function() {
it('', function(){
login('username', 'password')
});
});
But that is not a good practice. Because main test framework supports to do something before each test case. For jasmine it supplys beforeEach
:
describe("A spec (with setup and tear-down)", function() {
var foo;
beforeEach(function() {
foo = 0;
foo += 1;
});
afterEach(function() {
foo = 0;
});
it("is just a function, so it can contain any code", function() {
expect(foo).toEqual(1);
});
it("can have more than one expectation", function() {
expect(foo).toEqual(1);
expect(true).toEqual(true);
});
});
At last, I can't see the benefit/advantage to do as you required.
just a silly question tho isbeforeEach
function will get call once only or before each function
– Rao
Nov 23 '18 at 4:54
thanks i implemented above mentioned solution and it worked
– Rao
Nov 23 '18 at 5:07
beforeEach()
will be called before eachit()
function be executed.
– yong
Nov 23 '18 at 6:47
then if i want to login thenbefoeEach
won't work
– Rao
Nov 23 '18 at 6:55
1
If you login inbeforeEach()
, you can do logout inafterEach()
. Or you can only usebeforeEach()
with following process: 1) do logout no matter is login or not, 2) do login
– yong
Nov 23 '18 at 6:59
|
show 2 more comments
From nodejs syntax, it supports to do that as following:
// conf.js
exports.config = {
// put config at here as usual
};
exports.login = function(username, password) {
browser.get('');
element.sendKeys('');
};
// spec.js
var login = require('./conf.js').login;
// actually, you can move the login function to another .js file to keep
// conf.js more dedicated on configuration purpose.
describe("A spec (with setup and tear-down)", function() {
it('', function(){
login('username', 'password')
});
});
But that is not a good practice. Because main test framework supports to do something before each test case. For jasmine it supplys beforeEach
:
describe("A spec (with setup and tear-down)", function() {
var foo;
beforeEach(function() {
foo = 0;
foo += 1;
});
afterEach(function() {
foo = 0;
});
it("is just a function, so it can contain any code", function() {
expect(foo).toEqual(1);
});
it("can have more than one expectation", function() {
expect(foo).toEqual(1);
expect(true).toEqual(true);
});
});
At last, I can't see the benefit/advantage to do as you required.
From nodejs syntax, it supports to do that as following:
// conf.js
exports.config = {
// put config at here as usual
};
exports.login = function(username, password) {
browser.get('');
element.sendKeys('');
};
// spec.js
var login = require('./conf.js').login;
// actually, you can move the login function to another .js file to keep
// conf.js more dedicated on configuration purpose.
describe("A spec (with setup and tear-down)", function() {
it('', function(){
login('username', 'password')
});
});
But that is not a good practice. Because main test framework supports to do something before each test case. For jasmine it supplys beforeEach
:
describe("A spec (with setup and tear-down)", function() {
var foo;
beforeEach(function() {
foo = 0;
foo += 1;
});
afterEach(function() {
foo = 0;
});
it("is just a function, so it can contain any code", function() {
expect(foo).toEqual(1);
});
it("can have more than one expectation", function() {
expect(foo).toEqual(1);
expect(true).toEqual(true);
});
});
At last, I can't see the benefit/advantage to do as you required.
answered Nov 23 '18 at 2:04
yongyong
6,2661411
6,2661411
just a silly question tho isbeforeEach
function will get call once only or before each function
– Rao
Nov 23 '18 at 4:54
thanks i implemented above mentioned solution and it worked
– Rao
Nov 23 '18 at 5:07
beforeEach()
will be called before eachit()
function be executed.
– yong
Nov 23 '18 at 6:47
then if i want to login thenbefoeEach
won't work
– Rao
Nov 23 '18 at 6:55
1
If you login inbeforeEach()
, you can do logout inafterEach()
. Or you can only usebeforeEach()
with following process: 1) do logout no matter is login or not, 2) do login
– yong
Nov 23 '18 at 6:59
|
show 2 more comments
just a silly question tho isbeforeEach
function will get call once only or before each function
– Rao
Nov 23 '18 at 4:54
thanks i implemented above mentioned solution and it worked
– Rao
Nov 23 '18 at 5:07
beforeEach()
will be called before eachit()
function be executed.
– yong
Nov 23 '18 at 6:47
then if i want to login thenbefoeEach
won't work
– Rao
Nov 23 '18 at 6:55
1
If you login inbeforeEach()
, you can do logout inafterEach()
. Or you can only usebeforeEach()
with following process: 1) do logout no matter is login or not, 2) do login
– yong
Nov 23 '18 at 6:59
just a silly question tho is
beforeEach
function will get call once only or before each function– Rao
Nov 23 '18 at 4:54
just a silly question tho is
beforeEach
function will get call once only or before each function– Rao
Nov 23 '18 at 4:54
thanks i implemented above mentioned solution and it worked
– Rao
Nov 23 '18 at 5:07
thanks i implemented above mentioned solution and it worked
– Rao
Nov 23 '18 at 5:07
beforeEach()
will be called before each it()
function be executed.– yong
Nov 23 '18 at 6:47
beforeEach()
will be called before each it()
function be executed.– yong
Nov 23 '18 at 6:47
then if i want to login then
befoeEach
won't work– Rao
Nov 23 '18 at 6:55
then if i want to login then
befoeEach
won't work– Rao
Nov 23 '18 at 6:55
1
1
If you login in
beforeEach()
, you can do logout in afterEach()
. Or you can only use beforeEach()
with following process: 1) do logout no matter is login or not, 2) do login– yong
Nov 23 '18 at 6:59
If you login in
beforeEach()
, you can do logout in afterEach()
. Or you can only use beforeEach()
with following process: 1) do logout no matter is login or not, 2) do login– yong
Nov 23 '18 at 6:59
|
show 2 more comments
Thanks for contributing an answer to Stack Overflow!
- Please be sure to answer the question. Provide details and share your research!
But avoid …
- Asking for help, clarification, or responding to other answers.
- Making statements based on opinion; back them up with references or personal experience.
To learn more, see our tips on writing great answers.
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53425440%2fis-it-possible-to-create-function-inside-conf-js%23new-answer', 'question_page');
}
);
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown