|  | Commit message (Collapse) | Author | Age | Files | Lines | 
|---|
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | In ca324a0 the flash middleware was effectively removed by its
constructor returning the app it was passed and the `commit_flash`
call was moved to the `ActionController::Metal#dispatch` method.
This broke any redirect routes that modified the flash because the
redirect happens before `dispatch` gets called.
To fix it, this commit adds a `commit_flash` call in the `serve`
method of `ActionDispatch::Routing::Redirect`.
Fixes #27992. | 
| | 
| 
| 
| 
| 
| 
| 
| | A gzip file has a checksum and length for the decompressed data in its
footer which isn't checked by just calling Zlib::GzipReader#read.
Calling Zlib::GzipReader#close must be called after reading to the end
of the file causes this check to be done, which is done by
Zlib::GzipReader.wrap after its block is called. | 
| | 
| 
| 
| 
| 
| | Previously, `driven_by` would change the Capybara configuration when
the test case is loaded, and having multiple test classes with different
`driven_by` configs would fail as the last loaded would be effective. | 
| | |  | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | Since a `direct` url helper block is evaluated using `instance_exec`
then methods that are available in the instance context can be
accessed, e.g. the params object in a controller action or view.
This wasn't clear from the example so expand on that point and add
a test case for this situation. | 
| | 
| 
| 
| | Further missing requires for Timeout exposed due to Bundler 1.14.5 | 
| | 
| 
| 
| 
| | Use a separate method called `resolve` for the custom polymorphic
mapping to clarify the API. | 
| | |  | 
| | |  | 
| | |  | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Allow the use of `direct` to specify custom mappings for polymorphic_url, e.g:
  resource :basket
  direct(class: "Basket") { [:basket] }
This will then generate the following:
  >> link_to "Basket", @basket
  => <a href="/basket">Basket</a>
More importantly it will generate the correct url when used with `form_for`.
Fixes #1769. | 
| | |  | 
| | |  | 
| | |  | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Allow the definition of custom url helpers that will be available
automatically wherever standard url helpers are available. The
current solution is to create helper methods in ApplicationHelper
or some other helper module and this isn't a great solution since
the url helper module can be called directly or included in another
class which doesn't include the normal helper modules.
Reference #22512. | 
| |\  
| | 
| | | Use `response#location` instead of `#location` in redirect. | 
| | | 
| | 
| | 
| | | Closes #28033 | 
| | | 
| | 
| | 
| | 
| | 
| | 
| | 
| | 
| | 
| | 
| | 
| | 
| | 
| | 
| | 
| | 
| | 
| | 
| | 
| | 
| | 
| | 
| | 
| | 
| | 
| | 
| | | * Override integration test default host
Integration tests automatically set the default host to
'http://example.com'. This works fine for integration tests because they
are not real browser sessions, but doesn't work fine for system tests
because they are real browser sessions.
We can override this by setting the `host!` in `before_setup. The
`Capybara.always_include_port` will allow the test to look at
`127.0.0.1:port capybara picks` and properly redirect the test.
Any application can override this by setting the `host!` in
their system test helper. Generally though, applications are going to be
using localhost.
In this commit I also moved the setup and teardown into their own module
for tidiness.
* Move teardown settings into system test case
These configuration options can be put into the system test case file
instead of the generated system tests helper file. This is an
implementation detail and therefore shouldn't be generated with the
template. | 
| | | 
| | 
| | 
| | 
| | | We only want the file name to include the word `failures` if it failed,
not any time the user wants to take a screenshot during a test run. | 
| | | 
| | 
| | 
| | 
| | 
| | 
| | 
| | 
| | 
| | | * Move system tests back into Action Pack
* Rename `ActionSystemTest` to `ActionDispatch::SystemTestCase`
* Remove private base module and only make file for public
`SystemTestCase` class, name private module `SystemTesting`
* Rename `ActionSystemTestCase` to `ApplicationSystemTestCase`
* Update corresponding documentation and guides
* Delete old `ActionSystemTest` files | 
| | | 
| | 
| | 
| | 
| | 
| | 
| | 
| | 
| | 
| | | Renames `Rails::SystemTestCase` to `ActionSystemTest` and moves it to a
gem under the Rails name.
We need to name the class `ActionSystemTestCase` because the gem expects
a module but tests themselves expect a class.
Adds MIT-LICENSE, CHANGELOG, and README for the future. | 
| | | 
| | 
| | 
| | | Rubocop / code climate don't like single quotes and prefer doubles. | 
| | | 
| | 
| | 
| | 
| | 
| | 
| | 
| | 
| | | Puma is the default webserver of Rails. Because of this it doesn't make
sense to run tests in Webkit if the default server is Puma.
Here I've refactored the webserver to be it's own standalone module so
it can be shared between Rails' selenium default driver and Capybara's
defaut drivers. | 
| | | 
| | 
| | 
| | 
| | 
| | 
| | 
| | 
| | | This change adds support, tests, and documentation for the screenshot
helper.
If taking screenshots is supported by the driver (for example Rack Test
doesn't support screenshots) then a screenshot will be taken if the test
fails. | 
| | | 
| | 
| | 
| | 
| | 
| | 
| | 
| | 
| | 
| | 
| | 
| | 
| | 
| | | This removes the useless Rack Test Driver that Rails was providing and
moves to a shim like approach for default adapters.
If someone wants to use one of the default Capybara Drivers then we will
initialize a new `CapybaraDriver` that simply sets the default driver.
Rails though is much more opinionated than Capybara and to make system
testing a "works out of the box" framework in Rails we have the
`RailsSeleniumDriver`. This driver sets defaults that Rails deems
important for selenium testing. The purpose of this is to simply add a
test and it just works. | 
| |/  
|   
|   
|   
|   
|   
|   
|   
|   
| | * Adds test case test
* Adds driver adapter test
* Adds tests for capybara seleium driver (testing the settings not
actually opening the browser to test capybara w/ selenium because that
would so so so slow)
* Adds tests for rack test driver
* Adds tests for generators | 
| | |  | 
| | 
| 
| 
| | empty lines | 
| | 
| 
| 
| 
| 
| 
| | ```
go get -u github.com/client9/misspell/cmd/misspell
misspell  -w -error -source=text .
``` | 
| | 
| 
| 
| | since the test names become Regexp filters, non-escaped test names cause RegexpError on isolated test via bin/test | 
| | |  | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | Prevents PATH_INFO from being used to infer the request format in later
test requests when no explicit format is given.
As the request PATH_INFO may be set before a request, it can't be
deleted during pre-request scrubbing.
Fixes #27774 | 
| | 
| 
| 
| 
| 
| 
| 
| | Mixing Rack::Test::Methods into ActionDispatch::IntegrationTest seems
to trigger Ruby bug 13107[1]. By using our methods instead of rack-test
we shouldn't trigger the bug in Forwardable.
[1]: https://bugs.ruby-lang.org/issues/13107 | 
| | |  | 
| | 
| 
| 
| 
| 
| | These are followups for 307065f959f2b34bdad16487bae906eb3bfeaf28,
but TBH I'm personally not very much confortable with this style.
Maybe we could override assert_equal in our test_helper not to warn? | 
| | |  | 
| | 
| 
| 
| | we call them only in the tests | 
| |\  
| | 
| | | make `render` work with AC::Params | 
| | | 
| | 
| | 
| | 
| | 
| | 
| | 
| | | In 4.2, since AC::Params inherited `Hash`, processing in the case of
`Hash` was done. But in 5.x, since AC::Params does not inherit `Hash`,
need to add care for AC::Params.
Related to 00285e7cf75c96553719072a27c27e4ab7d25b40 | 
| | | 
| | 
| | 
| | | the speed-up from 26dd9b26ab7317f94fd285245879e888344143b2 (cc: @fxn) | 
| |/  
|   
|   
| | [26dd9b26ab7317f94fd285245879e888344143b2] as it broke Parameters#to_h on at least fields_for-style nested params. | 
| | 
| 
| | existing_acrnoyms -> existing_acronyms | 
| | 
| 
| 
| | because Struct.new returns a Class, we just can give it a name and use it directly without inheriting from it | 
| | 
| 
| 
| | (I personally prefer writing one string in one line no matter how long it is, though) | 
| |\  
| | 
| | | Fix inconsistent parsing of Durations with both months and years | 
| | | 
| | 
| | 
| | 
| | 
| | 
| | 
| | 
| | 
| | 
| | 
| | 
| | 
| | 
| | 
| | 
| | 
| | 
| | 
| | 
| | 
| | 
| | 
| | 
| | | durations from code
    ActiveSupport::Duration.parse('P3Y') == 3.years # It should be true
Duration parsing made independent from any moment of time:
Fixed length in seconds is assigned to each duration part during parsing.
Changed duration of months and years in seconds to more accurate and logical:
 1. The value of 365.2425 days in Gregorian year is more accurate
    as it accounts for every 400th non-leap year.
 2. Month's length is bound to year's duration, which makes
    sensible comparisons like `12.months == 1.year` to be `true`
    and nonsensical ones like `30.days == 1.month` to be `false`.
Calculations on times and dates with durations shouldn't be affected as
duration's numeric value isn't used in calculations, only parts are used.
Methods on `Numeric` like `2.days` now use these predefined durations
to avoid duplicating of duration constants through the codebase and
eliminate creation of intermediate durations. | 
| | | 
| | 
| | 
| | 
| | 
| | 
| | | This reverts commit 5eff7a9ca7bb2ee7f16db1ab4d11cebe28757ba5, reversing
changes made to 5f03172f54a58a57a48a3121562beb2cef866cbe.
Reason: It caused a regression. The test case is on the PR. | 
| |/ |  | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | Regression introduced by ae29142142324545a328948e059e8b8118fd7a33 / 8363b879fe759f0645179f4521cc64795efbee6e.
Previously, cookies were only updated on `GET` requests. Now we will
update the helper for all requests, as part of `process`. Added
regression tests for all available HTTP method helpers in
`ActionController::TestCase`. | 
| | 
| 
| 
| | Actually, private methods cannot be called with `self.`, so it's not just redundant, it's a bad habit in Ruby |