- Change default value of
--server-url
option tohttp://localhost:4444
(i.e. remove/wd/hub
from the URL). - Update to Bootstrap 5 in results.xml and generated timeline.
- Show test result in timeline tooltip.
- Show spinner in results.xml when tests are still in progress.
- Fix displaying text executors in generated timeline (executors are now read and stored also for tests run on Selenium 4).
- Invalid class annotation could cause fatal error when parsing tests.
--parallel-limit
(-l
) option ofrun
command to allow limiting maximum number of tests being run simultaneously.- Show test duration in timeline tooltips.
- PHP 8 support.
- Require PHP 7.3+ and Symfony 5 components.
- Update to namespaced PHPUnit. Set minimal required version to PHPUnit 8.5.
- Use php-webdriver 1.8+ with W3C WebDriver support.
- Methods now uses strict type-hints and return type-hints. Inherited classes and interfaces (eg.
CustomCapabilitiesResolverInterface
,OptimizeOrderInterface
etc.) may require to be changed in accordance with this. - Simplified and improved test output.
RunTestsProcessEvent
(dispatched fromrun
command when initializing PHPUnit processes) now contains array of environment variables instead of ProcessBuilder. UsesetEnvironmentVars()
method to change the variables passed to the process.- Default browser size is now defined using class constants instead of class variables. To override the default, instead of
public static $browserWidth = ...;
usepublic const BROWSER_WIDTH = ...;
. - When test class constants defining default browser width (
BROWSER_WIDTH
) or height (BROWSER_HEIGHT
) is set tonull
, no default browser window size will be set on test startup. - Don't hardcode timezone to
Europe/Prague
. Timezone is now used based on your PHP settings (date.timezone). - Server URL now must be provided including URL prefix (if it has one, like
/wd/hub
) - eg.http://foo.bar:4444/wd/hub
. This means the/wd/hub
part is now never auto-amended. - Package
symfony/polyfill-mbstring
now provides mbstring functions even if PHP mbstring extension is not installed. - Read annotations (like
@group
,@noBrowser
etc.) using different and more-robust underlying libraries. - When filling file input element, do not dump whole file contents to the output to not pollute it with useless data.
- Download Selenium server releases from GitHub (see announcement).
- Remote server running in W3C-protocol mode (eg. Selenium v3.5.3+) was erroneously detected as BrowserStack cloud service.
--xdebug
option did not have any effect unless passed as the last option.- Properly auto-detect port 443 (not 80) when https server URL is used as
--server-url
. - Do not start browser for test skipped because it was depending on some already failed test (using
@depends
annotation). - Parsing the latest Selenium server version in
install
command. - Do not print
Error closing the session, browser may died.
after Firefox closes the error. - Properly detect Xdebug 3.
TestUtils
class which was already deprecated in 2.1.- Instead of
TestUtils::setSelect2Value()
use directly the newSelect2
component andselectByVisiblePartialText()
method. - Instead of
TestUtils::getFixturePath()
useFacebook\WebDriver\Remote\FileDetector
instead. - Instead of
TestUtils::sleep()
useAbstractTestCase::sleep()
method instead.
- Instead of
getConfig()
method of ConfigProvider. Call the property instead directly on an instance of the ConfigProvider.--fixtures-dir
option of therun
command,fixtures_dir
option of configuration file andConfigProvider->fixturesDir
variable. They were deprecated in version 2.1.0 and no longer used since.UniqueValue
component. (You may use Faker or some other library for similar use-case.)AbstractTestCaseBase
class. It should probably not affect anything, as it was only used internally.- Workarounds for legacy Firefox (version 47 and older) which are no longer needed.
- PhantomJS support.
resolveRequiredCapabilities()
method fromCustomCapabilitiesResolverInterface
, as this feature is not fully used in php-webdriver anyway.
- Replace facebook/webdriver with its successor php-webdriver/webdriver.
- Backport visibility fix of
setUp()
andtearDown()
methods of AbstractTestCase (to eg. allow use of lmc/coding-standard in projects using Steward).
- Selenium server releases were incorrectly parsed, meaning
steward install
command will detect version 3.9.1 as the latest one (even though there are already released newer versions of Selenium server).
- Increase minimal required version of PHPUnit and nette/reflections to maintain PHP 7.2 compatibility even with lowest possible versions of dependencies.
- HTML timeline generated using
generate-timeline
command was not working properly in Safari.
- If url endpoint (
/wd/hub
) is passed as part of server URL, it is automatically trimmed, as it is not necessary and will cause connection error.
- Base directory (which affects default paths to tests, logs etc.) is now properly detected even when Steward is not installed in
/vendor
directory. - Don't rely on default path to PHPUnit binary (
vendor/bin/phpunit
) to allow custombin-dir
andvendor-dir
Composer settings.
- Minor Windows compatibility issues (dir paths passed to run command now respect system directory separator etc.).
- Compatibility with Symfony/Console 3.3 (
--xdebug
option behavior was incorrect with symfony/console 3.3.0).
- Configuration file support 🎉. Useful for global Steward configuration which doesn't change for different runs. Place
steward.yml
orsteward.yml.dist
to base directory or use-c
/--configuration
option to define custom path to configuration file. Supported options are currently:capabilities_resolver
(given class must implement newCustomCapabilitiesResolverInterface
)tests_dir
logs_dir
fixtures_dir
- Event
command.pre_initialize
, triggered before initialization of any command is started. - Capabilities passed using
--capability
CLI option could now be forced to be specified as an string (by encapsulating the value into additional quotes). - Print total execution time at the end; in
-vv
and-vvv
modes print also execution after each testcase is finished. - Show total execution of each testcase when viewing
result.xml
file via browser (currently only execution time of each test was shown). Also show full test name (including testcase name) when hovering over its name.
- Capabilities are now resolved using
CapabilitiesResolver
class. - Require PHPUnit ^5.7.
- Remove dependency on unmaintained Configula library (and internally reimplement configuration options retrieval).
- Improve
install
command output (eg. to always include path to downloaded file). - Use custom method
Strings::toFilename
to convert class name to file name (and remove direct Composer dependency onnette/utils
).
- Attempting to download not existing Selenium server version (with
install
command) will not create empty jar file but only show an error. - Do not throw misleading exception "Test case must be descendant of Lmc\Steward\Test\AbstractTestCase" when invalid data provider is used.
- Debug messages about destroying WebDriver instance on the end of each test were printed to the output before output of the actual tests.
- Logs dir was not passed to PHPUnit processes, causing JUnit log files to be always written to
logs/
directory.
- Command
generate-timeline
to generate timeline-based visualization of test run into HTML file. - When test is started, url of the executing node is stored in the
results.xml
file. (Applies only for Selenium standalone server.) Select2
component for jQuery based Select2, which mimics behavior of nativeWebDriverSelect
(it actually uses the same interface; though not all methods are implemented).waitForTitleRegexp()
syntax sugar method to wait until current page title matches given regular expression (shortcut for newWebDriverExpectedCondition::titleMatches()
method).
- Deprecate
TestUtils
. The class will be removed in next major release. This includes:- Deprecate default instantiation of TestUtils in TestCase -
$this->utils
property of TestCase. - Deprecate
TestUtils::setSelect2Value()
method. Use directly the newSelect2
component andselectByVisiblePartialText()
method. - Deprecate
TestUtils::getFixturePath()
method. UseFacebook\WebDriver\Remote\FileDetector
instead. - Deprecate
TestUtils::sleep()
method. UseAbstractTestCase::sleep()
method instead.
- Deprecate default instantiation of TestUtils in TestCase -
- Upgrade php-webdriver to version 1.3.0.
- Values passed using
--capability
option may not work as expected for different data types than strings.
- Support for PHP 5.5, minimal required version of PHP is now 5.6. Also the 5.5 version is no longer supported by the upstream since July. (#87)
- BC: Aliases for old non-namespaced php-webdriver which were deprecated in Steward 1.2. (#66)
- BC:
run-tests
alias ofrun
command. (#71) - BC: Option
--publish-results
of run command. The default publishers and custom publishers defined in phpunit.xml will be always registered. (#85)
- Command
results
to show test results summary from the command line (CLI equivalent to viewingresults.xml
in a browser). (#65) - Command
clean
to remove old content of logs directory (previous png screenshots, HTML snapshots and JUnit xmls). (#68) - Option
--capability
torun
command which allows to simply pass any custom DesiredCapabilities to the WebDriver server. (#78) - Support for cloud services like Sauce Labs, BrowserStack or TestingBot - simply pass remote server URL (including credentials) using
--server-url
. (#78, #82) - If Sauce Labs or TestingBot is used as a remote cloud platform, test results are automatically published to their API. (#78, #82)
- Microsoft Edge could be selected as a browser to run the tests. (#95)
- Content of directory with logs is cleaned before
run
command starts by default. This could be suppressed using--no-clean
option of therun
command. (#63) - Directory for logs is automatically created if it does not exist. (#67)
- Process output printed to console (when using
-vv
or-vvv
) is now prefixed with class name. (#62, #73) - BC: Pass instance of current PHPUnit test as third parameter of
publishResult()
method ofAbstractPublisher
descendants. (#78) - Throw an exception if there are multiple testcase classes defined in one file. (#79)
- Status of tests is checked every 100 ms instead of 1 second to speed up the execution loop. (#93)
- Parsing of latest Selenium server version in
install
command so that even Selenium 3 beta releases are installed (#76) - Testcases that have zero delay defined (
@delayMinutes
) weren't properly added to the dependency graph, what causes multiple bugs:- Testcases were not marked as failed even though the test they were depending on has failed.
- It was not checked that the tests dependencies build a tree, ie. you could select (using
--group
etc.) subset of tests which will lead to an infinite wait in the execution loop. (#39)
- Output from test processes may miss is last lines if debug verbosity (
-vvv
) was enabled. (#93)
- Parsing of latest Selenium server version in
install
command (due to Selenium 3.0.0-beta1 release). Selenium server version 2.x will be downloaded by default.
- Shortcut
-i
to invoke--ignore-delays
option ofrun
command. (#69)
- Prepare removal of deprecated features - show deprecation warning when
run-tests
alias is being used. Note this alias and also non-namespaced WebDriver (deprecated in 1.2.0) will be removed in future Steward versions! (#60)
- Process status and result was not properly published to results.xml file. (#59)
- Option
--ignore-delays
ofrun
command to ignore delays defined between tests with@delayAfter
annotation. Usable when writing or debugging dependent tests. (#27, #52)
- Throw explanatory exception when attempting to load test file without any test class defined (instead of confusing
ReflectionException
). (#53) - Throw explanatory exception when test class cannot be instantiated (if class name/namespace doesn't match file path). (#53)
- Testcases depending on failed testcase are instantly marked as failed and skipped. (#47, #55)
- Allow Symfony/Process 3.0.4+ to be installed. (#57)
- Upgrade nette/reflection to not throw confusing exception if testcase does not have any use statement nor annotation. (#51, #58)
- Provide information about results of finished processes in output of the
run
command. (#44)
- Adjust output verbosity for different verbosity levels to improve clarity of the output mainly when running the tests locally. (#45, #46)
- Use default level if you care only about test results count.
- Use verbose mode (
-v
) to see name of failed tests during execution. - Use very verbose mode (
-vv
) to see detailed progress information during execution and also output of failed tests. - Debug level (
-vvv
) should be used when you want to know all available information about the run or when you run the tests on CI server. The tests output is printed incrementally.
- Set status of timeouted tests as done and their result as failed (#46)
- Output of tests was missing from the console when using Symfony/Process component 3.0.2. (#48)
- Property annotation added to
SyntaxSugarTrait
to know$wd
property meaning in IDE. (#36)
- php-webdriver upgraded to version 1.1, which moves all WebDriver classes from root namespace to
Facebook\WebDriver
namespace. Aliases for the old classes are provided in Steward 1.x, but will be removed in future, so you should update your tests to use the namespaced version. (#31) - Sort testcases alphabetically so that the order is same regardless the filesystem. (#38)
run-tests
command renamed to justrun
, keeping the original name as alias to maintain backward compatibility. (#40)- Upgrade to Symfony 3.0. (#41)
- PHPUnit 5.x could now be installed so that Steward fully supports PHP 7. (#43)
- When exception from WebDriver occurs (ie. browser dies or times out), prevent throwing another exception when attempting to closes the session (which leads to PHPUnit not generating any report). (#7)
- Require PHPUnit 4.8.6 to fix incorrect test status being reported (see phpunit#1835). (#34)
- Tests having @dataProvider and named data-sets were not properly logged with XmlPublisher and exceptions were thrown. (#28, #29)
- Start and end dates of tests were sometimes not properly displayed when viewing results.xml file in Firefox. (#33)
- Check if browser given to
run-tests
command is supported (this helps avoiding typos, interchange of browser and environment etc.). (#9, #15) - Option
--filter
which allows filtering tests/testcases by name (#20). - @ziizii
- The
logs/results.xml
could now be also accessed locally (the XSLT is now embedded right into the file, so we don't encounter same-origin policy problems). (25d73a4) - Use tagged version 0.6.0 of php-webdriver. (#11)
- Upgrade to Symfony 2.7 (causing eg. the
--help
format to change a bit - according to docopt standard) (#18) - If any test fails, the
run-tests
command now exits with code1
. This behavior could be altered using new--no-exit
option, which forces the command to exit0
even if some test fails. (#13, #16) - Steward executable was renamed from
steward.php
to juststeward
, which should work on both Unix and Windows (#21, #25) - @mhujer
- Properly trigger PHPUnit colored (ANSI) mode when Steward itself is in ANSI mode. (#10)
- Stop counting test's running time (shown in
results.xml
), if the test ended with fatal error. (#6, #17)
- Possibility to specify zero as
@delayMinutes
(eg. if you want to force test order, but don't need to actually wait) or to use floating point number as delay. - SyntaxSugarTrait with shortcuts for element locating and waiting (
$this->findBy...()
,$this->findMultipleBy...()
and$this->waitFor...()
) usable in TestCases and Components.
- BC: Global configuration constants replaced with Config object accessed through ConfigProvider. Thus all the global constants (BROWSER_NAME, ENV, SERVER_URL, PUBLISH_RESULTS, FIXTURES_DIR, LOGS_DIR, DEBUG) are no longer available, use the Config object instead.
- BC:
lib/
andlib-tests/
directories renamed tosrc/
andsrc-tests/
respectively. - BC: Changed namespaces of eg.
ConfigProvider
andProcessSet
.
- Workaround for Firefox locking port collisions (consequence of Selenium issue #5172) - if FF cannot be started, try it again up to five times
- New
debug()
method that output to log only in debug mode. Could be used in both TestCases and Components. - ext-curl requirement into composer.json (as CURL is needed by HttpCommandExecutor).
- Test-cases order is optimized before running tests, so that test-cases with the longest delay of theirs dependencies are run as first.
- Improved error messages when Selenium server is not accessible or when any of required directory does not exist.
- Error is thrown if not-existing method is called on AbstractComponent descendants.
- Properly handle PHPUnit_Framework_Warning when eg. data provider is invalid.
- Fix Xdebug being initialized even if the
--xdebug
option ofrun-tests
command was not passed at all.
@noBrowser
annotation on either test case class or test method could be used if you don't need to create new WebDriver (= browser window) instance.- Legacy component (imported from separate repository). It allows you to share data between test-cases.
- Verbose output of executed WebDriver commands is provided in debug mode of
run-tests
command (debug mode could be enabled using-vvv
). - Added
--xdebug
option torun-tests
command to allow simple remote debugging of tests using Xdebug.
- Test cases running longer than 1 hour are killed and their result is set as "Fatal" in
results.xml
.
- CHANGELOG.md file.
- Global
DEBUG
constant (is true if -vvv passed to run-tests), that could be used in tests to print some more verbose output. - The
install
command now checks for the latest version of Selenium server and interactively asks for confirmation. - Possibility to add custom test Publishers (enabled by
--publish-results
). Pass it as argument of TestStatusListener inphpunit.xml
. - During the
run-tests
execution, current test results are generated intologs/results.xml
. This is useful eg. on long-lasting Jenkins jobs or if you want to know more precise status of the current (or last) test run. - Shortcut to WebDriver in components - it's now possible to write
$this->wd
instead of$this->tc->wd
. - Possibility to set
--fixtures-dir
inrun-tests
command. This is handy eg. when tests are run on remote terminal and fixtures are located on network directory. - Possibility to set
--logs-dir
inrun-tests
command. Useful when Steward core is installed as dependency and is run from vendor/bin/. - Possibility to easily overload any browser-specific capability, using custom (overloaded) WebdriverListener.
- Specified group(s) could be excluded from the
run-tests
, using--exclude-group
option.
- The last argument of
run-tests
command (browser name) is now always required (as well as the environment name). - The
--publish-results
parameter is now used without a value (as a switch to enable publishing test results). - Unified testcases and test status and results naming:
- Testcases (= process) statuses: done, prepared, queued
- Testcases (= process) results (for "done" status): passed, failed, fatal
- Test statuses: started, done
- Test results (for "done" status): passed, failed, broken, skipped, incomplete
- The
install
command now outputs only full path to jar file in-no-interactive
mode (except-vv
or-vvv
is passed) and nothing else. - Path to tests in
run-tests
command is now defined using--tests-dir
. - Browser resolution is by default 1280x1024 and could easily be set eg. in AbstractTestCase using
$browserWidth
and$browserHeight
properties. - The
--group
option could now be specified multiple times to select multiple values forrun-tests
. - Both
run-tests
andinstall
commands now uses the project base directory as root path (for logs, test files, fixtures and as jar file installation) even if installed as dependency into vendor/ dir, so that it is not necessary to define the paths manually. - Commands are now triggering Events (see CommandEvents), which could be used to extend commands with custom features.