Example of Java test code on OpenFin Runtime with Chrome Driver.
HelloOpenFinTest.java has sample code for testing HTML5 components and OpenFin javascript adapter in Hello OpenFin demo application.
Since all HTML5 applications in the OpenFin environment need to be started with OpenFin API, chromeDriver.get(URL) is not supported.
ChromeDriver, by default, starts Chrome browser with various Chrome arguments, including remote debugging port, before running tests. ChromeOptions.setBinary needs to be called so ChromeDriver can start OpenFin Runtime properly. RunOpenFin.bat is an example batch file that can be set as 'binary'.
Given there can be multiple applications/windows active in OpenFin Runtime, tests must begin by selecting the targeted window. Each test script has a function that selects the window by matching it's title.
Since the OpenFin Runtime is started by OpenFinRVM, Chromedriver does not have direct control of the OpenFin Runtime. Chromedriver must be started before any test runs. Once a test is complete, it needs to shut down OpenFin Runtime by running javascript code "fin.desktop.System.exit();". driver.quit() does not shut down OpenFin Runtime since it does not have access. Moving forward, we will improve how Chromedriver controls OpenFin Runtime in the future release.
In Summary
- Tests must target specific windows
- ChromeDriver must be started before tests are run
- OpenFin RunTime must be shut down after a test is completed
- Version 10.66.x.x of Runtime is required
All binaries required to run HelloOpenFinTest are in release directory:
- Install Hello OpenFin App
- start chromedriver.exe
- run testHelloOpenFin.bat
To build one jar that includes all dependencies, use the command mvn assembly:assembly -DdescriptorId=jar-with-dependencies
Two example scripts are included in this project to demonstrate use of Selenium Server on localhost.
- seleniumHub.bat/sh for launching Selenium Grid hub.
- seleniumNode.bat for launching Selenium Grid node.
- set RemoteDriverURL=http://localhost:8818/wd/hub
- This is a starter example and intended to demonstrate to app providers a sample of how to approach an implementation. There are potentially other ways to approach it and alternatives could be considered.
- This is an open source project and all are encouraged to contribute.
- Its possible that the repo is not actively maintained.
MIT
The code in this repository is covered by the included license.
However, if you run this code, it may call on the OpenFin RVM or OpenFin Runtime, which are covered by OpenFin’s Developer, Community, and Enterprise licenses. You can learn more about OpenFin licensing at the links listed below or just email us at [email protected] with questions.
https://openfin.co/developer-agreement/
https://openfin.co/licensing/
Please enter an issue in the repo for any questions or problems.
Alternatively, please contact us at [email protected]