Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/gdwrd/had
🗃 Gem for generating documentation by specs for hanami
https://github.com/gdwrd/had
Last synced: 2 months ago
JSON representation
🗃 Gem for generating documentation by specs for hanami
- Host: GitHub
- URL: https://github.com/gdwrd/had
- Owner: gdwrd
- License: mit
- Created: 2017-07-12T14:22:06.000Z (over 7 years ago)
- Default Branch: master
- Last Pushed: 2018-04-16T10:01:17.000Z (almost 7 years ago)
- Last Synced: 2024-05-18T21:40:35.294Z (8 months ago)
- Language: Ruby
- Homepage: https://nsheremet.pw/had
- Size: 168 KB
- Stars: 7
- Watchers: 2
- Forks: 0
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.txt
- License: LICENSE.txt
Awesome Lists containing this project
- awesome-hanami - had - Hanami API Documentation (Hanami Gem List / API Documentation)
README
# Had
Had is Hanami Api Documentation. Gem generates API documentation from your integration tests written with `rspec` for [Hanami](https://hanamirb.org).
This is fork of [`reqres_rspec`](https://github.com/reqres-api/reqres_rspec) gem and worked implemantation for Hanami.
## Installation
### 1) Gem
Just add this gem to `Gemfile` of your API Application
gem 'had', group: :test
And then execute:
$ bundle install
If necessary, add `require "had"` to your `spec/spec_helper.rb` file
## Usage
Before start you need to setup environment.
`export APP_ROOT=/path/to/your/application`By default `had` is not active (this may be configured!). To activate it, run `rspec` with
`HAD_RUN=1 bundle exec rspec --order=defined`
Documentation will be put into your application's `/doc` folder
### Sample controller action
```ruby
params do
required(:book).schema do
required(:author).filled(:str?) # This is params description
required(:title).filled(:str?) # Can be empty
end
end# @description creates Category from given parameters
# description text may be multiline
# @param book[author] required String | You can use this params
# @param book[title] in which order | if you did't using dry-validation
# param text may also be multiline
def call(params)
# action code
end
```### Sample rspec test
```ruby
it 'validates params', :skip_had do
...
endcontext 'With valid params' do
it 'bakes pie' do
...
end
endcontext 'With invalid params', :skip_had do
it 'returns errors' do
...
end
end
```By default all examples will be added to docs. A context of examples (`context` and `describe` blocks) or any particular examples may be excluded from docs with option `:skip_had`
Doc will use full example description, as a title for each separate spec
If you want to group examples in another way, you can do something like:
```ruby
describe 'Something', had_section: 'Foo' do
context 'valid params', had_title: 'Bakes Pie' do
it 'works' do
...
endit 'tires baker', had_title: 'Tires baker' do
...
end
end
end
```## Configuration
```ruby
Had.configure do |c|
c.templates_path = './spec/support/reqres/templates' # Path to custom templates
c.output_path = 'some path' # by default it will use doc/reqres
c.formatters = %w(MyCustomFormatter) # List of custom formatters, these can be inherited from Had::Formatters::HTML
c.title = 'My API Documentation' # Title for your documentation
end
```## Custom Formatter example
```ruby
class CustomAPIDoc < Had::Formatters::HTML
private
def write
# Copy assets
%w(styles images components scripts).each do |folder|
FileUtils.cp_r(path(folder), output_path)
end# Generate general pages
@pages = {
'index.html' => 'Introduction',
'authentication.html' => 'Authentication',
'filtering.html' => 'Filtering, Sorting and Pagination',
'locations.html' => 'Locations',
'files.html' => 'Files',
'external-ids.html' => 'External IDs',
}@pages.each do |filename, _|
@current_page = filename
save filename, render("pages/#{filename}")
end# Generate API pages
@records.each do |record|
@record = record
@current_page = @record[:filename]
save "#{record[:filename]}.html", render('spec.html.erb')
end
end
end
```1. Fork it
2. Create your feature branch (`git checkout -b my_new_feature`)
3. Commit your changes (`git commit -am 'Add some feature'`)
4. Push to the branch (`git push origin my_new_feature`)
5. Create new Pull Request