froth-webdriverio-framework 4.0.31 → 4.0.33

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.
@@ -16,18 +16,21 @@ async function assertText(elementSelector, expectedText) {
16
16
  } catch (error) {
17
17
  console.log(`Assertion failed. Expected text: ${expectedText}.`);
18
18
  let annotationMessage = `Assertion failed. Expected text: ${expectedText}.`;
19
- assert.fail(annotationMessage, "error: ", error.message);
20
- browser.testError = annotationMessage
21
19
  await amendToBrowserstack(annotationMessage, "error");
20
+ if (!browser.testErrors) browser.testErrors = [];
21
+ browser.testErrors.push(`Assertion failed.: ${error.message}`);
22
+
23
+ // assert.fail(`Text assertion failed: ${error.message}`);
22
24
  }
23
25
 
24
26
 
25
27
  } catch (error) {
26
28
  console.error('Error occurred while verifying text:', error);
27
29
  let annotationMessage = `Error occurred while verifying text: ${error.message}.`;
28
- browser.testError = annotationMessage
29
- assert.fail(annotationMessage, "error: ", error.message);
30
30
  await amendToBrowserstack(annotationMessage, "error");
31
+ if (!browser.testErrors) browser.testErrors = [];
32
+ browser.testErrors.push(`Assertion failed.: ${error.message}`);
33
+ // assert.fail(`Text assertion failed: ${error.message}`);
31
34
  // throw error;
32
35
  }
33
36
 
@@ -50,16 +53,19 @@ async function assertAttributeValue(elementSelector, attributeName, expectedText
50
53
  } catch (error) {
51
54
  console.warn("Assertion failed:", error.message);
52
55
  let annotationMessage = `Assertion failed. Expected text: ${expectedText}. ,${error.message}`;
53
- browser.testError = annotationMessage
54
- assert.fail(annotationMessage, "error: ", error.message);
55
56
  await amendToBrowserstack(annotationMessage, "error");
57
+ console.log("Assertion failed. Expected text: ", expectedText);
58
+ if (!browser.testErrors) browser.testErrors = [];
59
+ browser.testErrors.push(`Assertion failed.: ${error.message}`);
60
+ // assert.fail(`Text assertion failed: ${error.message}`);
56
61
  }
57
62
  } catch (error) {
58
63
  console.error('Error occurred while verifying text:', error);
59
64
  let annotationMessage = `Error occurred while asserting Attribute: ${error.message}.`;
60
- browser.testError = annotationMessage
61
- assert.fail(annotationMessage, "error: ", error.message);
62
65
  await amendToBrowserstack(annotationMessage, "error");
66
+ if (!browser.testErrors) browser.testErrors = [];
67
+ browser.testErrors.push(`Assertion failed.: ${error.message}`);
68
+ // assert.fail(`Text assertion failed: ${error.message}`);
63
69
  }
64
70
 
65
71
 
@@ -142,7 +142,7 @@ const commonconfig = {
142
142
 
143
143
  console.log('==== BEFORE TEST HOOK ====');
144
144
  console.log(`====> Test Started '${test.title}'`);
145
-
145
+ browser.testErrors = [];
146
146
  // console.log("File Name:", test.file);
147
147
 
148
148
  },
@@ -169,31 +169,32 @@ const commonconfig = {
169
169
  console.log(`====> Status of test: ${passed}`);
170
170
 
171
171
  let scriptresult = "NOT RUN";
172
- let localError = null;
173
-
174
- // if (browser.testError) {
175
- // console.error("Test Error:", browser.testError);
176
- // localError = browser.testError;
177
- // resultdetails.comments.push(`${test.title} - failed: ${localError}`);
178
- // browser.testError = null; // clear it
179
- // scriptresult = "FAILED"
180
- // passed = false; // Mark test as failed
181
- // result = 1; // Update the result status
182
-
183
- // // throw err; // causes test to fail after execution
184
- // }
185
- if (passed) {
172
+ // Default assumption: test passed (unless soft assertion failed)
173
+ let finalPassed = passed;
174
+ // Check soft assertion failures
175
+ const softErrors = browser.testErrors || [];
176
+ if (softErrors.length > 0) {
177
+ finalPassed = false; // Override status
178
+ const softErrorMessage = `Soft assertion errors: ${softErrors.join('<br>')}`;
179
+ console.log('====> Soft Assertion Failures Detected:\n' + softErrorMessage);
180
+
181
+ // Log in resultdetails
182
+ resultdetails.comments.push(`${test.title} - failed: ${softErrorMessage}`);
183
+
184
+ // Overwrite the error param so your logic can pick it up
185
+ error = new Error(softErrorMessage);
186
+ }
187
+ if (finalPassed) {
186
188
  scriptresult = "PASSED"
187
189
  resultdetails.comments.push(`${test.title} - passed`);
188
190
  }
189
- else if (!passed || error) {
191
+ else if (!finalPassed || error) {
190
192
  scriptresult = "FAILED"
191
193
  // if (!resultdetails.comments.some(comment => typeof comment === 'string' && comment.includes(test.title)))
192
194
  console.log(`====> Failed or error while executing the test: ${error ? error.message : "Test failed"}`);
193
195
  resultdetails.comments.push(`${test.title} - failed: ${error ? error.message : "Test failed"}`);
194
196
 
195
197
  }
196
-
197
198
 
198
199
  let scriptDetails = BUFFER.getItem("FROTHE_SUITE_DETAILS");
199
200
  if (typeof scriptDetails === "string") {
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "froth-webdriverio-framework",
3
- "version": "4.0.31",
3
+ "version": "4.0.33",
4
4
  "readme": "WebdriverIO Integration",
5
5
  "description": "WebdriverIO and BrowserStack App Automate",
6
6
  "license": "MIT",