Curated library of 42 public AI agent skills for Ruby on Rails development, plus 5 callable workflow skills. Organized by category: planning, testing, code-quality, ddd, engines, infrastructure, api, patterns, context, orchestration, and workflows. Covers code review, architecture, security, testing (RSpec), engines, service objects, DDD patterns, and TDD automation.
96
96%
Does it follow best practices?
Impact
—
No eval scenarios have been run
Risky
Do not use without reviewing
Identify and fix performance bottlenecks in Rails applications.
Files: SKILL.md · EXAMPLES.md · references/tools.md
NEVER optimize without a baseline measurement
ALWAYS write a regression spec before optimizing (query count assertion)
ALWAYS verify with EXPLAIN ANALYZE for database changes
REPORT ORDER MUST MATCH WORK ORDER:
1. Baseline measurement
2. Bottleneck identification (Bullet / rack-mini-profiler / EXPLAIN)
3. Regression spec written + run + FAILS at the unoptimized count
4. Fix applied
5. Regression spec rerun + PASSES at the optimized count
6. EXPLAIN ANALYZE confirms plan change
NEVER write the report as "I applied includes(:author), then wrote a spec
to lock it in." The spec MUST be written and shown failing BEFORE the fix
appears in your output. Reordering for narrative flow fails the audit even
when the underlying work was correct.| Tool | Use |
|---|---|
bullet | N+1 detection in development |
rack-mini-profiler | Endpoint timing breakdown |
EXPLAIN ANALYZE | Query plan analysis |
See references/tools.md for detailed configuration.
# Bad
Post.all.each { |p| p.author.name }
# Good
Post.includes(:author).each { |p| p.author.name }Write this spec before applying any optimization to lock in the expected query count:
RSpec.describe "Post index performance" do
it "loads posts with authors in a fixed number of queries" do
create_list(:post, 10, :with_author)
expect do
Post.includes(:author).to_a
end.to make_database_queries(count: 2) # posts + authors
end
endUse the db-query-matchers gem or a custom make_database_queries matcher. The spec must pass after the fix and fail if a future change reintroduces the N+1.
Run directly in rails dbconsole (PostgreSQL) after applying an index or query change:
EXPLAIN ANALYZE
SELECT posts.*, users.name
FROM posts
INNER JOIN users ON users.id = posts.author_id
WHERE posts.published = true;Key things to check in the output:
Seq Scan on large tables → should become Index Scan after adding an indexactual time rows — confirm the new value is lower than the baselinerows estimate accuracy — large discrepancies indicate stale statistics (ANALYZE table_name)See EXAMPLES.md for complete examples including:
includes, preload, joinspluck and find_eachReport sections, in the HARD-GATE order:
bullet, rack-mini-profiler, or EXPLAIN ANALYZE — at least one named).make_database_queries(count: <unoptimized>), shown failing.Seq Scan → Index Scan or actual time delta.queries: N → M, p95: X ms → Y ms. Numbers, not adjectives.build
docs
mcp_server
skills
api
generate-api-collection
implement-graphql
code-quality
apply-code-conventions
apply-stack-conventions
assets
snippets
code-review
refactor-code
respond-to-review
review-architecture
security-check
context
load-context
setup-environment
ddd
define-domain-language
model-domain
review-domain-boundaries
engines
create-engine
create-engine-installer
document-engine
extract-engine
release-engine
review-engine
test-engine
upgrade-engine
infrastructure
implement-background-job
implement-hotwire
optimize-performance
review-migration
seed-database
version-api
orchestration
skill-router
patterns
create-service-object
implement-calculator-pattern
write-yard-docs
planning
create-prd
generate-tasks
plan-tickets
testing
plan-tests
test-service
triage-bug
write-tests
workflows