-
Notifications
You must be signed in to change notification settings - Fork 0
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
#9 #12
#9 #12
Changes from 10 commits
28c4711
74782fc
c2a9295
08a5e67
01f181f
e4dafdf
1a345b1
5698ae1
6b10bca
8564fa4
9f3ffc4
4f7eb0a
e3e9b5b
227def1
43e59cc
27deb8b
bf72ef1
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,9 @@ | ||
#!/usr/bin/env bash | ||
|
||
#Run server in background | ||
node_modules/http-server/bin/http-server ./test/demo-app -p 9000 > /dev/null & | ||
server=$! | ||
#Run tests | ||
./node_modules/.bin/wdio test/wdio.conf.js | ||
#Kill server after run | ||
kill -9 ${server} |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,13 +1,13 @@ | ||
'use strict' | ||
|
||
const fs = require('fs'); | ||
const files = fs.readdirSync('./src/steps'); | ||
const fs = require('fs') | ||
const files = fs.readdirSync('./src/steps') | ||
|
||
files.forEach((f) => { | ||
const path = `./src/steps/${f}` | ||
const fileSteps = require(path); | ||
const fileSteps = require(path) | ||
|
||
if (typeof fileSteps === 'function') { | ||
fileSteps.apply(this); | ||
fileSteps.apply(this) | ||
} | ||
}); | ||
}) |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,23 @@ | ||
/* eslint no-undef: 0 */ | ||
|
||
'use strict' | ||
|
||
const { defineSupportCode } = require('cucumber') | ||
const { pageObject, getPageObject } = require('../helpers/objects.processor') | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more.
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Lets try to use no semicolons. |
||
const { _r } = require('../helpers/utils') | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more.
|
||
|
||
module.exports = function () { | ||
defineSupportCode(({ Then }) => { | ||
|
||
Then(_r(`^${pageObject} should be present$`), (object) => { | ||
/** | ||
* The element should be present | ||
* @type {PageObject} | ||
*/ | ||
const locator = getPageObject(object) | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more.
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Lets try to use no semicolons. |
||
|
||
browser.$(locator).waitForExist() | ||
}) | ||
|
||
}) | ||
} | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more.
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Lets try to use no semicolons. |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,11 @@ | ||
<!DOCTYPE html> | ||
<html lang="en"> | ||
<head> | ||
<title>DEMO APP FOR THE WDIO-STEPS</title> | ||
<link rel="stylesheet" href="styles/styles.css"> | ||
<script src="inc/script.js"></script> | ||
</head> | ||
<body> | ||
<div id="header">Header</div> | ||
</body> | ||
</html> |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,6 @@ | ||
'use strict' | ||
let e = {} | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more.
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Lets try to use no semicolons. |
||
|
||
e.txtHeader = '//*[@id="header"]' | ||
|
||
module.exports = e | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more.
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Lets try to use no semicolons. |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,4 +1,4 @@ | ||
'use strict'; | ||
'use strict' | ||
|
||
const { expect } = require('chai') | ||
|
||
|
@@ -14,18 +14,21 @@ const { _r } = require('../../src/helpers/utils') | |
|
||
const realId = 12345 | ||
|
||
const World = { | ||
id: realId, | ||
pages: { | ||
page: { | ||
object: `//div[@id='${dynamicId}']` | ||
}, | ||
dictionary: { | ||
object: `dictionaryObject${dynamicId}` | ||
} | ||
global.pages = { | ||
main: { | ||
object: `//div[@id='${dynamicId}']` | ||
}, | ||
book: { | ||
word: `dictionaryObject${dynamicId}` | ||
} | ||
} | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more.
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Lets try to use no semicolons. |
||
|
||
global.id = { | ||
getId: () => realId | ||
} | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more.
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Lets try to use no semicolons. |
||
|
||
global.objectsProcessor = { } | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more.
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Lets try to use no semicolons. |
||
|
||
describe('injectInto', () => { | ||
const data = [ | ||
{ locator: '//a', injection: '@class="b"]', result: '//a[@class="b"]' }, | ||
|
@@ -36,18 +39,18 @@ describe('injectInto', () => { | |
|
||
data.forEach((d) => { | ||
it(`should get "${d.result}" string from "${d.locator}" and "${d.injection}" injection`, () => { | ||
expect(injectInto(d.locator, d.injection)).to.be.equals(d.result); | ||
}); | ||
}); | ||
}); | ||
expect(injectInto(d.locator, d.injection)).to.be.equals(d.result) | ||
}) | ||
}) | ||
}) | ||
|
||
describe('getPageObject', () => { | ||
const data = [ | ||
{ | ||
step: 'When I click "page"."object"', | ||
step: 'When I click object from main page', | ||
regExp: _r(`When I click ${pageObject}`), | ||
result: `//div[@id='${realId}' and not(ancestor-or-self::*[contains(@style,"visibility: hidden;") ` + | ||
'or contains(@style,"display: none;") or contains(@class,"x-hide-offsets")])]' | ||
result: `//div[@id='${realId}' and not(ancestor-or-self::*[contains(@style,"visibility: hidden") ` + | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Let's not remove semicolons from CSS |
||
'or contains(@style,"display: none") or contains(@class,"x-hide-offsets")])]' | ||
} | ||
] | ||
|
||
|
@@ -59,18 +62,18 @@ describe('getPageObject', () => { | |
|
||
expect(match).to.be.an('array') | ||
const strPageObject = match[1] | ||
const pageObjectVal = getPageObject.call(World, strPageObject) | ||
const pageObjectVal = getPageObject(strPageObject) | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more.
|
||
|
||
expect(pageObjectVal).to.be.equals(result) | ||
next() | ||
}); | ||
}); | ||
}); | ||
}) | ||
}) | ||
}) | ||
|
||
describe('getDictionaryObject', () => { | ||
const data = [ | ||
{ | ||
step: 'When I write "dictionary"."object"', | ||
step: 'When I write word from book dictionary', | ||
regExp: _r(`When I write ${dictionaryObject}`), | ||
result: `dictionaryObject${realId}` | ||
}, | ||
|
@@ -89,10 +92,10 @@ describe('getDictionaryObject', () => { | |
|
||
expect(match).to.be.an('array') | ||
const strDictionaryObject = match[1] | ||
const dictionaryObjectVal = getDictionaryObject.call(World, strDictionaryObject) | ||
const dictionaryObjectVal = getDictionaryObject(strDictionaryObject) | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more.
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Lets try to use no semicolons. |
||
|
||
expect(dictionaryObjectVal).to.be.equals(result) | ||
next() | ||
}); | ||
}); | ||
}); | ||
}) | ||
}) | ||
}) |
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -188,6 +188,19 @@ exports.config = { | |
global.expect = chai.expect; | ||
global.assert = chai.assert; | ||
global.should = chai.should(); | ||
|
||
global.pages = { | ||
main: require('./features/page_objects/main') | ||
} | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more.
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Lets try to use no semicolons. |
||
|
||
global.id = { | ||
value: '', | ||
regenerate: () => this.value === (new Date()).getTime(), | ||
getId: () => this.value | ||
} | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more.
|
||
|
||
global.objectsProcessor = { } | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more.
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Lets try to use no semicolons. |
||
|
||
}, | ||
/** | ||
* Runs before a WebdriverIO command gets executed. | ||
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Let's not remove semicolons from CSS
"visibility: hidden;"