Curated library of 28 atomic skills and 9 personas for Ruby on Rails development. Organized by category: testing, code-quality, engines, infrastructure, api, context, and personas. Covers code review, architecture, security, testing (RSpec), engines, Hotwire, and TDD automation. Shared Ruby skills (YARD docs, DDD, service objects) have moved to ruby-core-skills.
93
95%
Does it follow best practices?
Impact
93%
1.16xAverage score across 28 eval scenarios
Advisory
Suggest reviewing before use
DO NOT propose code, specs, PRDs, or task lists until the Context Summary is posted.
DO NOT silently resolve ambiguity — if requirements conflict or specs and code disagree, post a Confusion Block first.
DO NOT load the entire repo — use targeted reads (schema, routes, one neighbor of each kind).
ALWAYS cite the files you read (path:line where possible) so the user can verify.
ALWAYS re-check context when the user's request changes scope mid-conversation.Load minimum context before any code, spec, or PRD in an existing Rails codebase. A fifteen-second read of db/schema.rb, config/routes.rb, and one neighbor saves a full retry.
If rails-ai-bridge is running, call the get_project_context tool to retrieve unified project context (structure, routes, models, schema, dependencies). When this succeeds, skip manual steps 2 and 3 below and proceed directly to finding neighbor patterns and posting the Context Summary.
db/schema.rb — tables and columns involved (grep by table name)config/routes.rb — routes that border the changeGemfile.lock — confirm Rails version + domain gems (sidekiq, pundit, rspec, rails-i18n, graphql, etc.)
Do not read other files (like config/application.rb) as baseline context unless explicitly requested by the task.grep -r commands using the pattern: grep -r "class.*<LayerName>" <directory>.
Specifically:
grep -r "class.*Controller" app/controllersgrep -r "class.*Service" app/servicesgrep -r "class.*Model" app/modelsgrep -r "class.*Job" app/jobs
Do not use glob patterns or find commands to search for classes. Include the exact grep command in the Context Summary.### Confusion Block
- Conflict: <what conflicts — e.g., spec asserts X but code does Y>
- Options: <list the options with their tradeoffs>
- Recommendation: <state which option and why, or ask user to choose>Do not pick silently.
7. Hand off: With context loaded, proceed to the next skill (plan-tests, apply-stack-conventions, etc.). The Context Summary travels with the task.
When asked to load project context (or write a plan/recommendation involving context), your output answer.md MUST follow the template below exactly. You MUST replicate the template block in its entirety, including the Resources section and all three reference links at the end. To avoid ceremony and keep the output concise, weave the motivating principle directly into the introduction rather than using a separate header:
To ensure a rapid setup and avoid retries, we follow the fifteen-second read principle of schema, routes, and one neighbor before proposing any changes.
### Context Summary
**Rails layer:** <controller | model | service | job | engine | view/Turbo | migration | API | GraphQL>
**Files read:**
- <path>:<line-range> — <one-line finding>
- <path>:<line-range> — <one-line finding>
- (repeat for each file)
**Neighbor patterns found:**
- <layer>: <file path> — <key convention or pattern observed> (found using grep: <exact grep command used>)
- (repeat per layer)
**Gemfile notes:** Rails <version>; relevant gems: <list>
**Drift detected:** <none | description of spec-vs-code mismatch>
**Ambiguities:** <none | list any unresolved conflicts — triggers a Confusion Block>
**Next step:** <plan-tests | apply-stack-conventions | write migration | etc.>
**Resources:**
Load these files only when their specific content is needed:
- [EXAMPLES.md](EXAMPLES.md) — Use when you need worked examples showing Context Summary and Confusion Block templates
- [references/confusion-management.md](references/confusion-management.md) — Use when you encounter ambiguity or conflicting signals between code layers
- [references/context-sources.md](references/context-sources.md) — Use when you need the comprehensive list of context sources by Rails layer beyond the Quick Reference table| Pitfall | Mitigation |
|---|---|
| Over-grepping | Narrow by directory or class-name prefix. Never read more than one neighbor per layer. |
| Absent schema.rb | Look for db/structure.sql. Parse the relevant CREATE TABLE block instead. |
| Multiple engines | Scope reads to the specific engine directory; document the boundary in summary. |
| Missing spec | Write "no spec coverage" in summary; treat code as the source of truth. |
| Self-neighbor | Do not use the file being changed; select the nearest independent sibling. |
| Scope changes mid-run | Re-run discovery (steps 1-4) and post an updated Context Summary. |
Load these files only when their specific content is needed:
.tessl-plugin
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
skills
api
generate-api-collection
implement-graphql
code-quality
apply-code-conventions
apply-stack-conventions
assets
snippets
code-review
refactor-code
review-architecture
security-check
context
load-context
setup-environment
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
personas
testing
plan-tests
test-service