@camperaid/watest 2.3.8 → 2.3.9
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +13 -0
- package/core/base.js +2 -1
- package/package.json +2 -2
- package/tests/e2e/samples/wd_mixed/node_modules/.package-lock.json +3550 -0
- package/tests/e2e/samples/wd_mixed/package-lock.json +5806 -0
- package/tests/e2e/samples/wd_single/node_modules/.package-lock.json +3550 -0
- package/tests/e2e/samples/wd_single/package-lock.json +5806 -0
- package/tests/series/build/t_loader_mixed.js +1 -1
- package/webdriver/driver_base.js +34 -7
package/webdriver/driver_base.js
CHANGED
|
@@ -65,6 +65,26 @@ function warn_if_stale(e, msg) {
|
|
|
65
65
|
|
|
66
66
|
class TestExecutionError extends Error {}
|
|
67
67
|
|
|
68
|
+
class CriteriaTimeoutError extends Error {
|
|
69
|
+
constructor() {
|
|
70
|
+
super(`timeout while waiting to meet criteria`);
|
|
71
|
+
}
|
|
72
|
+
}
|
|
73
|
+
|
|
74
|
+
class NoElementsError extends Error {
|
|
75
|
+
constructor(selector) {
|
|
76
|
+
super(`no elements matching '${selector}' selector`);
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
|
|
80
|
+
class UnexpectedElementCountError extends Error {
|
|
81
|
+
constructor(selector, gotCount, expectedCount) {
|
|
82
|
+
super(
|
|
83
|
+
`ambigious '${selector}' selector, got ${gotCount} elements, expected ${expectedCount}`
|
|
84
|
+
);
|
|
85
|
+
}
|
|
86
|
+
}
|
|
87
|
+
|
|
68
88
|
/**
|
|
69
89
|
* A chainable wrapper around selenium web driver, provides barebone methods
|
|
70
90
|
* to build webdrivers upon.
|
|
@@ -424,15 +444,17 @@ class DriverBase {
|
|
|
424
444
|
'Waiting for at least one element to be located'
|
|
425
445
|
)
|
|
426
446
|
) {
|
|
427
|
-
throw new
|
|
447
|
+
throw new NoElementsError(selector);
|
|
428
448
|
}
|
|
429
449
|
}
|
|
430
450
|
throw e;
|
|
431
451
|
})
|
|
432
452
|
.then(els => {
|
|
433
453
|
if (els.length > count) {
|
|
434
|
-
throw new
|
|
435
|
-
|
|
454
|
+
throw new UnexpectedElementCountError(
|
|
455
|
+
selector,
|
|
456
|
+
els.length,
|
|
457
|
+
count
|
|
436
458
|
);
|
|
437
459
|
}
|
|
438
460
|
return els;
|
|
@@ -665,7 +687,7 @@ class DriverBase {
|
|
|
665
687
|
) {
|
|
666
688
|
this.checkBreadcrumbs(get_breadcrumbs);
|
|
667
689
|
if (e.message.startsWith(`Waiting until meet criteria`)) {
|
|
668
|
-
throw new
|
|
690
|
+
throw new CriteriaTimeoutError();
|
|
669
691
|
}
|
|
670
692
|
}
|
|
671
693
|
throw e;
|
|
@@ -803,9 +825,7 @@ class DriverBase {
|
|
|
803
825
|
|
|
804
826
|
return this.chain(() =>
|
|
805
827
|
Promise.resolve()
|
|
806
|
-
.then(() =>
|
|
807
|
-
log(`Test: ${msg}${(details && `. ${details}`) || ''}`)
|
|
808
|
-
)
|
|
828
|
+
.then(() => log(`Test: ${msg}${(details && `. ${details}`) || ''}`))
|
|
809
829
|
.then(() => chain())
|
|
810
830
|
.then(v => this.browserLogs().then(() => v))
|
|
811
831
|
.then(v => {
|
|
@@ -830,6 +850,13 @@ class DriverBase {
|
|
|
830
850
|
}`;
|
|
831
851
|
}
|
|
832
852
|
report(`${msg}${fdetails}`);
|
|
853
|
+
if (
|
|
854
|
+
!(e instanceof CriteriaTimeoutError) &&
|
|
855
|
+
!(e instanceof NoElementsError) &&
|
|
856
|
+
!(e instanceof UnexpectedElementCountError)
|
|
857
|
+
) {
|
|
858
|
+
log_error(e);
|
|
859
|
+
}
|
|
833
860
|
})
|
|
834
861
|
.then(() => this.captureScreenshot())
|
|
835
862
|
.catch(e => {
|