|  | Commit message (Collapse) | Author | Age | Files | Lines | 
|---|
| ... |  | 
| | 
| 
| 
| 
| 
| 
| 
| | This reverts changes made to integration tests in PR #23807.
The issue happens when using capybara with a driver that needs to start a
server in a separate thread like (poltergeist, selenium, etc).
Both threads the capybara server one and the test thread end running
syncronize over the interlock. | 
| | 
| 
| 
| 
| 
| | These should allow external code to run blocks of user code to do
"work", at a similar unit size to a web request, without needing to get
intimate with ActionDipatch. | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Yesterday, when improving how `parsed_body` extracted a parser I wrote
77bbf1e. Then I thought that was too many changes in one commit
and broke it up locally... or so I thought.
When pushed the extra commits removed the changes! Wups!
In shame, lob those changes together here:
  * 3b94c38 which meant to fix the CHANGELOG syntax error.
  * 5007df5 which meant to mention `parsed_body` in the docs.
  * 036a7a0 which meant to memoize the `parsed_body`. | 
| | 
| 
| 
| 
| 
| 
| 
| | It's common to use several assertions on the parsed response. The response
bodies aren't meant to be mutated. People should make new test requests
instead.
Thus, it should be safe to memoize the parsing. | 
| | 
| 
| 
| | Little easier to understand when you know the method that's used. | 
| | 
| 
| 
| 
| 
| 
| | We're not guaranteed to have a `RequestEncoder` to assign on `get` requests
because we aren't extracting the parser from the response content type.
Until now. | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | When testing:
```ruby
post articles_path, params: { article: { title: 'Ahoy!' } }, as: :json
```
It's common to want to make assertions on the response body. Perhaps the
server responded with JSON, so you write `JSON.parse(response.body)`.
But that gets tedious real quick.
Instead add `parsed_body` which will automatically parse the reponse
body as what the last request was encoded `as`. | 
| |\  
| | 
| | | Add `as` to encode a request as a specific mime type. | 
| | | 
| | 
| | 
| | 
| | 
| | 
| | 
| | 
| | 
| | 
| | 
| | 
| | 
| | 
| | | Turns
```
post articles_path(format: :json), params: { article: { name: 'Ahoy!' } }.to_json,
  headers: { 'Content-Type' => 'application/json' }
```
into
```
post articles_path, params: { article: { name: 'Ahoy!' } }, as: :json
``` | 
| | | 
| | 
| | 
| | 
| | | Prototype, you have served us well. But you are no longer how we make an
XMLHttpRequest. RIP | 
| | | |  | 
| | | 
| | 
| | 
| | | `with_indifferent_access` had been used in `assigns` method, but has been removed in ca83436. | 
| |/  
|   
|   
|   
| | Also, refactor logic to convert between symbol and response code,
via the AssertionResponse class | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | In Rails 5.1 `ActionController::TestCase` will be moved out of Rails
into it's own gem.
Please use `ActionDispatch::IntegrationTest` going foward.
Because this will be moved to a gem I used `# :stopdoc:` instead of
deleting the documentation. This will remove it from the Rails
documentation but still leave the method documented for when we move it
to a gem.
Guides have been updated to use the routing structure used in Integration
and all test examples have been updated to inherit from
`ActionDispatch::IntegrationTest` instead of `ActionController::TestCase.
Fixes #22496 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Follow-up to PR #19977, which helpfully added the redirection path to the error message of assert_response if response is a redirection, but which removed the response code, obscuring the type of redirect.
This PR:
- brings back the response code in the error message,
- updates the tests so the new messages can be tested,
- and adds test cases for the change. | 
| |\  
| | 
| | 
| | 
| | | prathamesh-sonpatki/use-assert-over-assert-predicate
Use assert over assert_predicate in assert_response | 
| | | 
| | 
| | 
| | 
| | 
| | 
| | 
| | 
| | 
| | 
| | 
| | 
| | 
| | 
| | 
| | 
| | 
| | 
| | | - `assert_predicate` appends its own error message at the end of message
  generated by `assert_response` and because of that the error message
  displays the whole `response` object.
- For eg.
  Expected response to be a <success>, but was a redirect to <http://test.host/posts>.
  Expected #<ActionDispatch::TestResponse:0x007fb1cc1cf6f8....(lambda)>}>> to be successful?.
- Complete message can be found here -
  https://gist.github.com/prathamesh-sonpatki/055afb74b66108e71ded#file-gistfile1-txt-L19.
- After this change the message from `assert_predicate` won't be
  displayed and only message generated by `assert_response` will be shown
  as follows:
  Expected response to be a <success>, but was a redirect to <http://test.host/posts> | 
| |/  
|   
|   
|   
|   
|   
|   
|   
|   
|   
|   
| | We want to get rid of the `Live::Response` so we are consolidating methods
from `Live::Response` and `Response` by merging them together.
This adds an `#empty` method to the request so we don't need to
hard-code the empty array each time we call an empty
`ActionDispatch::Request`.
The work here is a continuation on combining controller and integration
test code bases into one. | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | :redirect
- If the assert_response is checking for any non-redirect response like
  :success and actual response is :redirect then, the error message displayed
  was -
     Expected response to be a <success>, but was <302>
- This commit adds the redirect path to the error message of
  assert_response if the response is :redirect.
  So above message is changed to -
     Expected response to be a <success>, but was a redirect to <http://test.host/posts/lol> | 
| | |  | 
| |\ |  | 
| | | 
| | 
| | 
| | 
| | | ‘Asserts’ at all places [ci skip]
Following commit https://github.com/rails/docrails/commit/495722a95687e25114ae75608dd3107ac5d6611b | 
| | | |  | 
| | | 
| | 
| | 
| | | `skip_filter`, `skip_action_callback` may both are deprecated in Rails 5.1 so waring msg should be specific. | 
| | | 
| | 
| | 
| | 
| | 
| | | This commit follows up of ea9bc06c9a47b839d5e2db94ba6bf7e29c8f0ae9.
To check `@response.content_type.to_s` is ended with `"xml"`,
to use `\z` is sufficient. | 
| | | 
| | 
| | 
| | | parse RSS/ATOM responses as XML, not HTML | 
| |/  
|   
|   
|   
|   
|   
|   
|   
|   
|   
|   
|   
|   
|   
|   
|   
| | Rails 4.x and earlier didn't support `Mime::Type[:FOO]`, so libraries
that support multiple Rails versions would've had to feature-detect
whether to use `Mime::Type[:FOO]` or `Mime::FOO`.
`Mime[:foo]` has been around for ages to look up registered MIME types
by symbol / extension, though, so libraries and plugins can safely
switch to that without breaking backward- or forward-compatibility.
Note: `Mime::ALL` isn't a real MIME type and isn't registered for lookup
by type or extension, so it's not available as `Mime[:all]`. We use it
internally as a wildcard for `respond_to` negotiation. If you use this
internal constant, continue to reference it with `Mime::ALL`.
Ref. efc6dd550ee49e7e443f9d72785caa0f240def53 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | I'm making this change so that I can construct response objects that
*don't* have the default headers applied.  For example, I would like to
construct a response object from the return value of a controller.
If you need to construct a response object with the default headers,
then please use the alternate constructor:
`ActionDispatch::Response.create` | 
| | 
| 
| 
| 
| | We should be asking the mime type method for the mime objects rather
than via const lookup | 
| | |  | 
| | 
| 
| 
| 
| 
| | `extra_keys` is a confusing variable name because it's not clear what is
"extra". This renames it to `query_string_keys` so it's clear that the
"extra" is just the query string. | 
| | 
| 
| 
| 
| 
| 
| | Actions are processed through `dispatch`, so they should have the
request set on them before any user land code can be executed.  Lets
stop setting _env on the controller, and give access to it through the
`env` method. | 
| | 
| 
| 
| 
| | - webservers do not do it
 - it makes redirect urls ugly when request.host is used for redirection | 
| | 
| 
| 
| 
| | eventually we will make the cookie jar derive these values from the
request object rather than save a reference to the values | 
| | 
| 
| 
| 
| 
| | Accessing a request object has nice advantages over accessing a hash.
If you use a missing method name, you'll get an exception rather than a
`nil` (is one nice feature) | 
| | |  | 
| | |  | 
| | |  | 
| | 
| 
| 
| | Rack [already implements `redirect?` on the response object](https://github.com/rack/rack/blob/1569a985e17d9caaf94d0e97d95ef642c4ab14ba/lib/rack/response.rb#L141) so we don't need to implement our own. | 
| | 
| 
| 
| 
| 
| 
| 
| | We shouldn't depend on specific methods imlemented in the TestResponse
subclass because the response could actually be a real response object.
In the future, we should either push the aliased predicate methods in
TestResponse up to the real response object, or remove them | 
| | 
| 
| 
| | this prevents mutations from being available globally | 
| | |  | 
| | |  | 
| | |  | 
| | 
| 
| 
| 
| | We should leverage the request / response objects that the superclass
has already allocated for us. | 
| | |  | 
| | 
| 
| 
| 
| | we should be pushing the cookies in via headers rather than maintaining
some object and "recycling" it. | 
| | |  | 
| |\  
| | 
| | | Deprecate `assert_template` and `assigns()`. | 
| | | |  |