diff options
author | eileencodes <eileencodes@gmail.com> | 2017-03-06 12:33:34 -0500 |
---|---|---|
committer | eileencodes <eileencodes@gmail.com> | 2017-03-09 10:52:05 -0500 |
commit | 7c9af60e5c26941dc9ec6a263f5fc5fe10050cba (patch) | |
tree | 649265a1a13d65419fa9db104ed1e1cd71e84f4e /ci/travis.rb | |
parent | 4dbebe487df54e8684183f3b3154639a77d8deaa (diff) | |
download | rails-7c9af60e5c26941dc9ec6a263f5fc5fe10050cba.tar.gz rails-7c9af60e5c26941dc9ec6a263f5fc5fe10050cba.tar.bz2 rails-7c9af60e5c26941dc9ec6a263f5fc5fe10050cba.zip |
Call system test driver per-instance rather than globally
Previously the system test subclasses would call `driven_by` when the
app booted and not again when the test was initialized which resulted in
the driver from whichever class was called last to be used in tests.
In rails/rails#28144 the `driven_by` method was changed to run `use` on
setup and `reset` on teardown. While this was a viable fix this really
pointed to the problem that system test `driven_by` was a global
setting, rather than a per-class setting.
To alieviate this problem calling the driver should be done on an
instance level, rather than on the global level. I added an `initialize`
method to `SystemTestCase` which will call `use` on the superclass
driver. Running the server has been moved to `start_application` so that
it only needs to be called once on boot and no options from `driven_by`
were being passed to it.
This required a largish rewrite of the tests. Each test needs to utilize
the subclass so that it can properly test the drivers.
`ActionDispatch::SystemTestCase` shouldn't be called directly anymore.
Diffstat (limited to 'ci/travis.rb')
0 files changed, 0 insertions, 0 deletions