- Address concurrency issue with task consumers. #33
- Handle unexpected alerts. #36
- Address Java 9 (and above) related issues in core. #63 #64
- Don't rely on thread's interrupted state to stop. #68
- Clear input text fields before setting the value. #73
- Fix the regular expression of choosing candidate elements. #76
- Update log related dependencies #22
- Update Java version of web module to 8. #25
- Start browsers in headless mode by default. #34
- Add workaround for hidden elements and Firefox. #43
- Remove empty style attributes (Firefox workaround). #67
- Update Selenium library to 3.141.59. #113
3.7 - 2017-08-09
First release after forking.
- Fix WebDriver process leak. #20
- Allow to specify a crawl scope. #5
- Change group ID to be under
org.zaproxy
. #1 - Update Selenium to version 3.4.0. #4
- Use
StringBuilder
whenever possible. #8 - Improve support for HtmlUnit browser. #11 #15
- Updated Selenium to 2.41.0
- Fixed stripped DOM method
- Updated dependencies
- Deprecated the malfunctioning DomChangeNotifierPlugin. Introuced StateVertexFactoryl. #347
- Better PhantomJS support. Tests run on PhantomJS by default.
- Switched from URL's to URI's for better performance. #322
- Added Web UI project.
- Crawljax doesn't accidentally go to other URLs anymore during a Crawl. #339
StateVertexImpl.getUsedEventables()
Always returned an empty list #350- Fixed some Findbugs errors (thanks to @keheliya)
- PhantomJSDriver support is added. You can now use PhantomJS as a driver in Crawljax. For details see #327
- External URLs are not opened by default #328
- Updated selenium.
- Crawl configuration now has an option to set the output folder. #316
- A crawl now also reports some statistics. These are also extendible. Checkout the example for details. #314
Browser.getDom()
is deprecated. You can now choose betweengetStrippedDom
andgetUnstrippedDom()
#305.- Proxy plugin has been removed. It didn't work in 3.1 and 3.0 and is now replaced by the
PreCrawlPlugin
. #286
- Added the possibility to stop Crawljax from using the runner or by calling stop from any plugin. #270
- Fixes bug positioning of elements in the crawloverview #237
- Fixed HashCode/Equals bug in Conditions #276
- Fixes bug where edges would disappear from the StateFlowGraph #272
- Updated to the new version of Selenium
- New Overview plugin
- Crawljax is now configured using a builder
- Crawljax can now crawl hidden
href
elements as well. - Children of a certain elements can be excluded using a nice syntax.
- The project has been split up in three versions: core, cli and examples.
- Major performance and stability improvements
- View closed issues
- View the full diff
- Support for concurrent multi-browser crawling. The number of browsers can be configured using the ThreadConfiguration API.
- Support added for the HTMLUnit driver. Note: this driver is very fast, but it is not a real browser.
- Added CrawlPathToException class to wrap a crawl path into a stack trace like exception giving developers / testers better insight to on which page an invariant or plugin reported an error.
- Added a Filter option to Helper.getDifferences, so a list of differences can be generated without being bothered with the changes in style attributes for example.
- Upgraded the dependencies on Selenium (version 2.0a7). Issue: 9.
- The initial browser was null, this was caused by the fact that the currentBrowser was not correctly set. The browser pool did not register the currentBrowser for a given thread as the browser got requested directly, as what happened with the initial browser. Issue: 26.
- When running a (large) CrawlSpec and set a MaxRuntime constraint for it, the Crawler is not terminated directly when the MaxRuntime is reached. Basically what happened was that the current Crawler was terminated. Afterwards all waiting Crawlers got executed and start back-tracking and when in the previous state the check constraints terminates the Crawler. It was changed to, when the MaxRuntime is reached the current Crawler was terminated and that Crawler made a call the all other Crawlers running to shutdown and it tells the queue to empty and shutdown. Issue: 27.
- Ignore iFrames specified by full identifier or using wild-cards. Issue: 29.
- When using one wait condition during crawling and the first waitcondition takes a long time (> timeout) but in the end it is successful a IndexOutOfBounceException is thrown. The index is increased after an successful execution of a waitcondition and later the log event uses the increased index number to retrieve the WaitCondition that took to long to get successful. Issue: 30.
- When supplying wrong or malformed urllocator causes an exception. Changed the behaviour not to suspect an urllocator starts with 7 characters. Issue: 31.
- The exactEventPath got updated when OnNewState plugins where finished executing. This resulted in the wrong data being exposed to the CrawlSession. The initial fix was made to prevent this behaviour, late the CrawlPath and the ExactEventPath where merged because both lists are doing exactly the same. Issue: 32.
- Refactored most of the Exception handling within Crawljax, when a browser crashed (for whatever reason) the Exception thrown by WebDriver was catched and ignored. Resulting in all calls to WebDriver to fail and by that flushing all the work from the queue by Crawlers using that Browser. The new implementation handles the exception at the right location and makes sure the crashed browser will be removed from the pool and won’��t be used any further. The crawler where the browser crashed will be removed from the queue, limiting the number of missed states by the number that would have been found by that crawler. Issue: 33/34.
- Fixed a lot of the FindBugs warnings, remove some legacy code (clone() support)
- Updated the WebDriver version, this was needed to support screenshots for RemoteWebDrivers. It also enables screenshotting of WebDriver instances wrapping an other WebDriver by implementing the WrapsDriver class. This enabled screenshotting in EventFiringWebDriver classes.
- Changed Crawljax Core so a CrossBrowser tool could be developed; therefore added an call to block the CrawljaxController (waitForTermination).
- When having allot elements to examine prevent getXPathExpression get called over and over again. This was solved by caching the build of the XPath�s in the current DOM. Every node in the DOM contains the full xPath leading to it self, so preventing to calculate for example the /HMTL/BODY part over and over again. Only calculate the part which has not yet been calculated.
- Rename BrowserFactory to BrowserPool which is a more correct name.
- Support for iframe crawling. Works great in Firefox if iframes have unique IDs or NAME attributes.
- Added support for Google Chrome 4.0. Works with versions lower than 5 currently (due to WebDriver issues).
- OnFireEventFailed Plugins; enable an extension point when a fireEvent failed.
- Fix a bug where underXPath would only work for XPaths that result in one element. Issue: 16.
- Fix a bug where hashes, dots and spaces were not allowed in attribute values of clickables. Issue: 7.
- Fix bug where wrong currentState was stored in in CrawlSession when OnInvariantViolation was called.
- Make Crawljax work with Firefox 2.0. You also need a patched webdriver. (http://code.google.com/p/selenium/issues/detail?id=387)
- Handle popups such as alert by always “clicking” OK. This is a workaround and doesn’t always work. Issue: 2.
- Fix bug where Crawljax would write to / if the output directory was not set.
- Changed CrawljaxConfiguration to CrawljaxConfigurationReader in CrawlSession Issue: 5.
- runOnFireEventFailedPlugins failed in some cases, prevented from happening Issue: 8.
- Various improvements and polishments.
- Extended Crawljax Exceptions with more information about the system used. This is helpful to debug problems. Issue: 9.
- Upgrade WebDriver dependency to Selenium 2.0a2.
- Rename oracle comparators. The names are more logical now.
- Hibernate (database) has been removed.
- Properties file is no longer supported. Issue: 5.