nexial-core 4.4 (2022-12-04)
Release 4.4
2022-12-04
General
Fixes
- [FIXED] patched log4j zero-day vulnerability CVE-2021-44228.
- [FIXED] patched log4j vulnerability CVE-2021-45046
- [FIXED] patched log4j vulnerability CVE-2021-44832
- [FIXED] patched log4j vulnerability CVE-2022-23305, CVE-2022-23302, CVE-2022-23221, CVE-2021-42550, CVE-2021-4104, CVE-2019-17571
- [FIXED] typos in error messages.
- [FIXED] fixed erroneous library file found.
- [FIXED] Windows batch (.cmd) files to properly handleUSER_HOMEthat contains space.
- [FIXED] excel Report cell tainted value for the original value
- [FIXED] issue while opening Execution Report for WPS using nexial.openResult=true
- [FIXED] unwanted exceptions suppressed when evaluating Nexial Expression during the construction of execution output.
Improvements
- added Nexial version to initial banner at the start of a Nexial execution
- now recognize “executing under AzureDevOps” condition
- improved usage description of Nexial via commandline
- refactor batch files and shell scripts in $NEXIAL_HOME/binwith better naming convention and consistencies
- added keygen capability for nexial-specific SSL certificate (for upcoming features).
- better “temp” directory creation strategy to reduce collisions over time.
- code refactoring to reduce duplication.
- Execution Summary now enhanced with charts to aid in post-execution visualization.
    - added minor UI improvements.
- added drill down chart.
- added Skip Count
- improved visibility of test artifact links
- added screenshots generated for test steps during execution
- added errors with description for failed test steps
- improved the Web Filters functionality where user can search API results based on the methods or return codes
 
- Fixed step counting in dealing with skipped steps.
- support Java 18
- support newer version of gecko driver (firefox)
- update nexial-lib to 1.3
- enforce Java 17 as the minimum required Java version; helps to improve runtime stability and performance, and enable future enhancements.
- fix output message formatting on *NIX/MacOs shell scripts.
- updated nexialscripts to enforce and install (when needed) Java 17 or above runtime.
System Variables
- nexial.generateReport- Changed default to true, meaning the JSON-based report will be generated (by default) after each execution.
- nexial.web.toastDescription- Allow the description of the current test step to be exposed as a toast notification on the current browser window.
- nexial.web.toastDescriptionWaitMs- Allow the description of the current test step to be exposed as a toast notification on the current browser window.
- nexial.web.toastDescriptionDarkMode- Allow the description of the current test step to be exposed as a toast notification on the current browser window.
- nexial.targetDisplay: Support display pinning so that the browser used during automation will be opened to a display (monitor) of your choice. Expected 0-based value for display, or use- CURRENTfor currently active monitor. For example,- nexial.targetDisplay=CURRENT|0|1|...
- nexial.browser.windowSize: now supports specialized keyword (one of- maximized,- maximize,- fullscreen,- full) to maximize browser window when it initially opens.
- nexial.browser.lang: now supports changing browser language to aid the testing of language-aware websites.
Expression
- TEXT » json(text): now also sanitize data so that the resulting JSON is properly converted and OWASP-safe.
- CONFIG: now supports keys with spaces and tabs; as well as using both equal sign 
(=) and colon (:) as key-value separator.
Nexial Function
- $(random|number|from|to): code fix to extend the- tovalue as inclusive.
Nexial Interactive
- slightly improved console menu display
- default to “AutoRun”
- allow iteration to be specified either via iteration index (1-based, numeric) or via column letter (as found on corresponding datasheet).
JSONPath
- fix special character substitution when dealing with RegEx.
desktop commands
- saveLocatorCount(var,locator): Previously using a hardcoded 2.5 second, now this command uses- nexial.pollWaitMsas time out value when waiting for target- locatorto appear. This is now consistent with another similar command- saveElementCount(var,name)in terms of waiting.
json commands
- sanitize(var,json): sanitize data so that the resulting JSON is properly converted and OWASP-safe.
rdbms commands
- update Mongodb JDBC support to wisecoder’s mongojdbc4.1
web commands
- typeKeys(locator,value): add support for- {ESC}(same as- {ESCAPE}).
- better support for CORS security bypass via automated chrome browser options
- added additional configurations on chromedriver (for chrome browser) to ease security restriction for testing:
    - allow to run “insecure” (http) content locally
- allow access to local files
- allow for auth prompt when crossing site origin
- enable input event handling by the window manager
 
- restore chrome.embeddedsupport (unintended missed in previous build)
- disable nexial.browser.windowsSizeandnexial.browser.windowPositionfor embedded Chrome, Electron and mobile browser automation (since they don’t make sense in those scenario).
- disable automatic checking of webdriver updates for chrome.embedded, since embedded driver rarely updates.
- silenced “session exception” when terminating webdriver instance.
- fix webdriver auto-download logic; now with consideration with Apple M1 architecture
- saveTableAsCsv(locator,nextPageLocator,file): fixed error when target TABLE element becomes stale or invalid after paging.
- saveTableAsCsv(locator,nextPageLocator,file): fixed error when target “Next Page” element becomes stale or invalid after clicking.
- select(locator,text): support selecting by index (instead of text) via prefix- INDEX:. The specified index is 0-based. For example,- INDEX:1would select the second- OPTIONelement.
- INDEX:lastwould select the last- OPTIONelement.
 
- fix visibility assertion for radio and checkbox elements, which will have impact to the following commands:
- saveDivsAsCsv(headers,rows,cells,nextPage,file): added highlighting (if enabled) during data collection; added implicit wait during pagination to reduce flaky tests.
- open(url): added additional wait to further ensure page stability when- nexial.enforcePageSourceStabilityis set as- false. Similar impact to- openAndWait(url,waitMs)command as well.
- toast(message,duration,darkMode): NEW command to create a toast notification on the current browser window.
- suppress the display of toast notification on browser when no browser is yet in used during execution.
- suppress the certification selection dialog that pops up when accessing certain URL on Chrome (esp. when automation is performed on an enterprise-managed compute resource).
- prevent the changing of window position on headless browsers.
- switchBrowser(profile,config): fix issue with rendering multiple independent browsers.
webmail commands
- search(var,profile,searchCriteria,duration): supports the initialization of a “temporary-mail” inbox when- durationis set to- 0.
- improved email content parsing logic for Mailinator emails.
- avoid closing browser, and thus the underlying driver, after scanning for incoming emails.
- fixed the logic to harvest link and link labels for Mailinator mails.
ws commands
- upload(url,body,fileParams,var): enforces that multi-file upload request MUST be a multipart request.
- upload(url,body,fileParams,var): support setting- Content-Typefor the target file(s) other than the default- application/octet-stream. One should use the- header(name,value)command to specify the- Content-Typevalue PRIOR to invoking the target API.
- upload(url,body,fileParams,var): support variable substitution in uploaded file. Use- nexial.ws.requestPayloadAsRawto control this behavior (- falsemeans activate variable substitution).
- post(url,body,var): support- (IGNORE)content type while uploading files using multipart.