DuckRails is a development tool.
Its main purpose is to allow developers to quickly mock API endpoints that for many possible reasons can't reach at a specific time.
If it looks like a duck, walks like a duck and quacks like a duck, then it's a duck
The application allows to create new routes dynamically to which developers can assign static or dynamic responses:
- body
- headers
- content type
- status code
or even cause delays, timeouts etc.
You can find DuckRails' guides here.
Mocks index page
Changing mocks order
Setting general mock properties
Defining the response body
Setting response headers
Setting some advanced configuration (delays, dynamic headers, content type & status)
Upon save the route is becoming available to the application and you can use the endpoint:
You can define static or dynamic responses for a mock.
Currently supported dynamic types are:
- Embedded ruby
- Javascript
When specifying dynamic content of embedded ruby (more options to be added), you can read as local variables:
@parameters
: The parameters of the request@request
: The request@response
: The response
When specifying dynamic content of javascript type, you can read as local variables:
parameters
: The parameters of the requestheaders
: The request headers
The script should always return a string (for JSON use JSON.stringify(your_variable)
)
You can specify routes and access their parts in the @parameters variable, for example:
/authors/:author_id/posts/:post_id
give you access to the parameters with:
@parameters[:author_id]
@parameters[:post_id]
- Clone the repository.
- Execute
bundle install
to install the required gems. - Execute
rake db:setup
to setup the database. - Execute
rails server
to start the application on the default port.
- Clone the repository.
- Execute
bundle install
to install the required gems. - Export an env variable for your secret key base:
export SECRET_KEY_BASE="your_secret_key_base_here"
- Execute
RAILS_ENV=production rake db:setup
to setup the database. - Execute
RAILS_ENV=production rake assets:precompile
to generate the assets. - Execute
bundle exec rails s -e production
to start the application on the default port.
The application is by default configured to use MySQL. If you want to use another configuration, update the config/database.yml
accordingly to match your setup.
- Fork it ( https://github.com/iridakos/duckrails/fork )
- Create your feature branch (
git checkout -b my-new-feature
) - Commit your changes (
git commit -am 'Add some feature'
) - Push to the branch (
git push origin my-new-feature
) - Create a new Pull Request
This application is open source under the MIT License terms.