Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/rack/rack-test
Rack::Test is a small, simple testing API for Rack apps.
https://github.com/rack/rack-test
ruby testing
Last synced: 7 days ago
JSON representation
Rack::Test is a small, simple testing API for Rack apps.
- Host: GitHub
- URL: https://github.com/rack/rack-test
- Owner: rack
- License: mit
- Created: 2009-02-24T02:13:47.000Z (almost 16 years ago)
- Default Branch: main
- Last Pushed: 2025-01-07T16:59:52.000Z (17 days ago)
- Last Synced: 2025-01-11T23:02:59.789Z (12 days ago)
- Topics: ruby, testing
- Language: Ruby
- Homepage:
- Size: 611 KB
- Stars: 920
- Watchers: 30
- Forks: 250
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- Changelog: History.md
- License: MIT-LICENSE.txt
Awesome Lists containing this project
README
# Rack::Test
[![Gem Version](https://badge.fury.io/rb/rack-test.svg)](https://badge.fury.io/rb/rack-test)Code: https://github.com/rack/rack-test
## Description
Rack::Test is a small, simple testing API for Rack apps. It can be used on its
own or as a reusable starting point for Web frameworks and testing libraries
to build on.## Features
* Allows for submitting requests and testing responses
* Maintains a cookie jar across requests
* Supports request headers used for subsequent requests
* Follow redirects when requested## Examples
These examples use `test/unit` but it's equally possible to use `rack-test` with
other testing frameworks such as `minitest` or `rspec`.```ruby
require "test/unit"
require "rack/test"
require "json"class HomepageTest < Test::Unit::TestCase
include Rack::Test::Methodsdef app
lambda { |env| [200, {'content-type' => 'text/plain'}, ['All responses are OK']] }
enddef test_response_is_ok
# Optionally set headers used for all requests in this spec:
#header 'accept-charset', 'utf-8'# First argument is treated as the path
get '/'assert last_response.ok?
assert_equal 'All responses are OK', last_response.body
enddef delete_with_url_params_and_body
# First argument can have a query string
#
# Second argument is used as the parameters for the request, which will be
# included in the request body for non-GET requests.
delete '/?foo=bar', JSON.generate('baz' => 'zot')
enddef post_with_json
# Third argument is the rack environment to use for the request. The following
# entries in the submitted rack environment are treated specially (in addition
# to options supported by `Rack::MockRequest#env_for`:
#
# :cookie : Set a cookie for the current session before submitting the request.
#
# :query_params : Set parameters for the query string (as opposed to the body).
# Value should be a hash of parameters.
#
# :xhr : Set HTTP_X_REQUESTED_WITH env key to XMLHttpRequest.
post(uri, JSON.generate('baz' => 'zot'), 'CONTENT_TYPE' => 'application/json')
end
end
````rack-test` will test the app returned by the `app` method. If you are loading middleware
in a `config.ru` file, and want to test that, you should load the Rack app created from
the `config.ru` file:```ruby
OUTER_APP = Rack::Builder.parse_file("config.ru").firstclass TestApp < Test::Unit::TestCase
include Rack::Test::Methodsdef app
OUTER_APP
enddef test_root
get "/"
assert last_response.ok?
end
end
```## Install
To install the latest release as a gem:
```
gem install rack-test
```Or add to your `Gemfile`:
```
gem 'rack-test'
```## Contribution
Contributions are welcome. Please make sure to:
* Use a regular forking workflow
* Write tests for the new or changed behaviour
* Provide an explanation/motivation in your commit message / PR message
* Ensure `History.md` is updated## Authors
- Contributions from Bryan Helmkamp, Jeremy Evans, Simon Rozet, and others
- Much of the original code was extracted from Merb 1.0's request helper## License
`rack-test` is released under the [MIT License](MIT-LICENSE.txt).
## Supported platforms
* Ruby 2.0+
* JRuby 9.1+## Releasing
* Bump VERSION in lib/rack/test/version.rb
* Ensure `History.md` is up-to-date, including correct version and date
* `git commit . -m 'Release $VERSION'`
* `git push`
* `git tag -a -m 'Tag the $VERSION release' $VERSION`
* `git push --tags`
* `gem build rack-test.gemspec`
* `gem push rack-test-$VERSION.gem`
* Add a discussion post for the release