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
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
endUse this table when stating lock/rewrite risk for each migration step.
| Operation | PG Lock | Blocks | Duration | Notes |
|---|---|---|---|---|
add_column (nullable, no default) | ACCESS EXCLUSIVE | All | ~ms | Fast metadata-only change |
add_column (with default, PG 11+) | ACCESS EXCLUSIVE | All | ~ms | No rewrite since PG 11 |
add_column (with default, PG < 11) | ACCESS EXCLUSIVE | All | Full table rewrite | Avoid on large tables |
add_index (standard) | SHARE | Writes | Duration of index build | Blocks INSERT/UPDATE/DELETE |
add_index (concurrent) | SHARE UPDATE EXCLUSIVE | DDL only | Duration of index build | Does not block writes |
add_foreign_key (validate: true, default) | SHARE ROW EXCLUSIVE | Writes | Full row scan | Validates all existing rows |
add_foreign_key (validate: false) | ACCESS EXCLUSIVE | All | ~ms | Metadata-only, no row scan |
validate_foreign_key | SHARE UPDATE EXCLUSIVE | DDL only | Full row scan | Does not block writes |
change_column_null (to NOT NULL) | ACCESS EXCLUSIVE | All | Full row scan | Scans every row to verify no NULLs |
change_column (type change) | ACCESS EXCLUSIVE | All | Full table rewrite | Always rewrite unless cast is binary-coercible |
remove_column | ACCESS EXCLUSIVE | All | ~ms | Fast metadata-only change |
rename_column | ACCESS EXCLUSIVE | All | ~ms | Fast but breaks running app code |
.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