-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy pathexampleFluentDslWithTypeScript.spec.ts
93 lines (78 loc) · 4.24 KB
/
exampleFluentDslWithTypeScript.spec.ts
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
/**
* Example for using the new Scenarioo Fluent DSL with TypeScript Typings of ScenariooJS.
*
* For TypeScript typings we only support Fluent DSL as our newest and most comfortable API
* that is recommended to be used.
*
* Precondition for running this example using labels in Fluent DSL:
* All labels used in Scenarioo Fluent DSL have to be defined before usage.
* Usually we do this once on starting up the test suite.
* The example `./exampleFluentDslLabelDefinitions.js` demonstrates the declaration of all labels
* used in this examples.
*/
import {browser, by, element} from 'protractor';
// use 'scenarioo-js' instead of '../../lib' in real project
import {scenario, ScreenAnnotationClickAction, ScreenAnnotationStyle, step, useCase} from '../../lib';
// label definitions: usually only declared once on setup (no need to import in every test):
import './exampleFluentDslLabelDefinitions';
/**
* The use case description
*/
useCase('Example Use Case with Fluent DSL in TypeScript')
.description('An optional but recommended description for the use case')
.labels(['example-custom-label'])
.describe(() => {
/**
* A scenario description
*/
scenario('Example Scenario with Fluent DSL')
.description('An optional but recommended description for the scenario')
.labels(['happy', 'example-label'])
.it(async () => {
await browser.get('/index.html');
// use the step method to document interaction steps inside the scenario (with screenshot, etc.)
await step('browse to start page');
// you could also hook such saveStep method calls into your page objects or even the e2e test toolkit
// (e.g. by overwriting protractor functions, like click on element)
// to automatically document a step on each important interaction and not clutter your tests with such calls
// (actually that is what we recommend for real projects and can be done easily).
// A step could also have additional propoerties, like e.g. labels
await step('a step with labels', {labels: ['step-label-example']});
// Or a step can have screen annotations
await step('a step with a screen annotation', {
screenAnnotations: [
{
clickAction: ScreenAnnotationClickAction.TO_NEXT_STEP,
region: {x: 20, y: 20, width: 500, height: 30},
style: ScreenAnnotationStyle.CLICK
},
],
});
// more steps of this scenario would of course come here ...
});
scenario('Example Failing Scenario with several expectation failures')
.description('This scenario should demonstrate that also for each failed expectation a screenshot is taken')
.it(async function exampleScenarioWithMultipleExpectationsFailingAndNoLabels() {
await browser.get('/index.html');
await expect(await element.all(by.css('.element-not-existing')).count()).toBe(78); // will fail --> expectation failed step
await element(by.css('li#item_one')).click();
await step('item one clicked');
await expect(await element.all(by.css('.another-element-not-existing')).count()).toEqual(13); // will fail --> expectation failed step
await element(by.css('li#item_is_not_present')).click(); // will fail the scenario --> scenario failed step
await expect(await element.all(by.css('.another-element-not-existing-after-scenario-failed')).count()).toEqual(6); // will not be executed (no step)
});
scenario('Example Failing Scenario that throws an Error')
.description('This scenario just tests that thwoing an Error in a scenario is reported nicely')
.it(function exampleScenarioWhichThrowsError() {
throw Error('Something went wrong in a test (this is expected test failure, just for demonstration purposes!)');
});
/**
* Another scenario ...
* This one is set to pending, which means it is a currently not yet working test (=work in progress)
*/
scenario('Example Pending Scenario')
.description('An optional description for the scenario')
.pending('Put a comment here, why this scenario is currently put to be pending (is recommended to be used in favour of xit!)')
.it(function examplePendingScenario() {
});
});