Curated library of 28 public AI agent skills for Ruby on Rails development. Organized by category: testing, code-quality, engines, infrastructure, api, and context. 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. Repository agents remain documented in GitHub but are intentionally excluded from the Tessl tile.
93
95%
Does it follow best practices?
Impact
93%
1.78xAverage score across 28 eval scenarios
Passed
No known issues
Reference for complex schema operations beyond add-column and add-index.
Never change a column type in a single migration on a busy table. Use the add-copy-migrate-drop approach:
# Step 1: add new column with new type
add_column :orders, :amount_cents, :bigint
# Step 2: backfill (separate deploy, in batches)
# Order.in_batches.update_all('amount_cents = CAST(amount * 100 AS BIGINT)')
# Step 3: migrate code references to new column, then drop old column
remove_column :orders, :amountAdding a unique index on data that may have duplicates will fail at the database level:
SELECT col, COUNT(*) FROM table GROUP BY col HAVING COUNT(*) > 1disable_ddl_transaction!
add_index :users, :email, unique: true, algorithm: :concurrentAdding a foreign key validates all existing rows by default, which can lock the table:
# Step 1: add without validation (fast, no lock)
add_foreign_key :orders, :users, validate: false
# Step 2 (separate migration): validate after cleaning orphans
validate_foreign_key :orders, :usersRails caches column information. Removing a column without first telling Active Record to ignore it causes ActiveModel::MissingAttributeError during the deploy window.
# Step 1: add to ignored_columns in the model (deploy this first)
class Order < ApplicationRecord
self.ignored_columns += %w[legacy_field]
end
# Step 2 (next deploy): drop the column
remove_column :orders, :legacy_fieldWhen running migrations against a non-primary database, use connects_to in the migration class:
class AddIndexToAnalyticsEvents < ActiveRecord::Migration[7.2]
def connection
AnalyticsEvent.connection
end
def change
disable_ddl_transaction!
add_index :analytics_events, :occurred_at, algorithm: :concurrent
end
endagents
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
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
testing
plan-tests
test-service
write-tests