Curated library of 39 AI agent skills for Ruby on Rails development. Organized by category: planning, testing, code-quality, ddd, engines, infrastructure, api, patterns, context, orchestration, and workflows. Includes 5 callable workflow skills (rails-tdd-loop, rails-review-flow, rails-setup-flow, rails-quality-flow, rails-engines-flow) for complete development cycles. Covers code review, architecture, security, testing (RSpec), engines, service objects, DDD patterns, and TDD automation.
95
98%
Does it follow best practices?
Impact
95%
1.20xAverage score across 35 eval scenarios
Passed
No known issues
Implement versioning strategies for Rails APIs.
Files: SKILL.md · EXAMPLES.md · references/workflow.md · references/strategies.md
ALWAYS maintain backward compatibility for at least one major version
NEVER remove endpoints without deprecation period
ALWAYS version in URL path (/api/v1/) or Accept header, never in body| Concern | File |
|---|---|
| Route namespaces | config/routes.rb |
| Header versioning | app/controllers/concerns/api_versioning.rb |
| Deprecation headers | app/controllers/concerns/deprecatable.rb |
| Compatibility specs | spec/requests/api/backward_compatibility_spec.rb |
/api/v1/) for public APIs; Accept header for internal/private APIs.namespace :v2 block in config/routes.rb.Deprecatable in old-version controllers to emit sunset headers.rspec spec/requests/api/backward_compatibility_spec.rb to confirm no regressions.See references/workflow.md for the complete annotated workflow.
namespace :v1 do
resources :users
end
namespace :v2 do
resources :users
endOverride only actions that change between versions:
module V2
class UsersController < V1::UsersController
def index
render json: User.all, only: [:id, :name, :email, :phone]
end
end
endSee references/strategies.md for a full URL path vs. Accept header comparison.
Define the Deprecatable concern to emit Sunset and Deprecation response headers. The inline implementation below is the canonical reference; a copy also lives in app/controllers/concerns/deprecatable.rb.
# app/controllers/concerns/deprecatable.rb
module Deprecatable
extend ActiveSupport::Concern
included do
before_action :set_deprecation_headers
end
private
def set_deprecation_headers
sunset_date = self.class.sunset_date
response.set_header("Deprecation", "true")
response.set_header("Sunset", sunset_date.httpdate) if sunset_date
Rails.logger.warn "[DEPRECATED] #{controller_path}##{action_name} called — sunset: #{sunset_date}"
end
class_methods do
def sunset_date
nil # Override per controller, e.g.: -> { Date.new(2025, 6, 1) }
end
end
endInclude it in any controller version due for retirement:
module V1
class UsersController < ApplicationController
include Deprecatable
# ...
end
endAfter adding a new version, always run the backward compatibility suite before merging:
bundle exec rspec spec/requests/api/backward_compatibility_spec.rbAll existing v1 contract tests must remain green; a new version should never silently break prior consumers.
See EXAMPLES.md for complete code including:
See references/strategies.md for URL path vs header versioning comparison.
docs
evals
scenario-1
scenario-2
scenario-3
scenario-4
scenario-5
scenario-6
scenario-7
scenario-8
scenario-9
scenario-10
scenario-11
scenario-12
scenario-13
scenario-14
scenario-15
scenario-16
scenario-17
scenario-18
scenario-19
scenario-20
scenario-21
scenario-22
scenario-23
scenario-24
scenario-25
scenario-26
scenario-27
scenario-28
scenario-29
scenario-30
scenario-31
scenario-32
scenario-33
scenario-34
scenario-35
mcp_server
skills
api
api-rest-collection
rails-graphql-best-practices
code-quality
rails-architecture-review
rails-code-conventions
rails-code-review
rails-review-response
rails-security-review
rails-stack-conventions
assets
snippets
refactor-safely
context
rails-context-engineering
rails-project-onboarding
ddd
ddd-boundaries-review
ddd-rails-modeling
ddd-ubiquitous-language
engines
rails-engine-compatibility
rails-engine-docs
rails-engine-extraction
rails-engine-installers
rails-engine-release
rails-engine-reviewer
rails-engine-testing
infrastructure
rails-api-versioning
rails-background-jobs
rails-database-seeding
rails-frontend-hotwire
rails-migration-safety
rails-performance-optimization
orchestration
rails-skills-orchestrator
patterns
ruby-service-objects
strategy-factory-null-calculator
yard-documentation
planning
create-prd
generate-tasks
ticket-planning
testing
rails-bug-triage
rails-tdd-slices
rspec-best-practices
rspec-service-testing