phx:challenge

Challenge Mode Reviews

Safety Notice

This listing is imported from skills.sh public index metadata. Review upstream SKILL.md and repository scripts before running.

Copy this and send it to your AI assistant to learn

Install skill "phx:challenge" with this command: npx skills add oliver-kriska/claude-elixir-phoenix/oliver-kriska-claude-elixir-phoenix-phx-challenge

Challenge Mode Reviews

Rigorous, critical review patterns inspired by Boris Cherny's "Grill me" approach. Push beyond first solutions to ensure quality.

Iron Laws - Never Violate These

  • No approval without verification - Don't approve until all concerns addressed

  • Assume bugs exist - Look for edge cases, race conditions, missing handlers

  • Question everything - Even "obvious" code can hide issues

  • Demand proof - Ask for tests, show state transitions, verify behavior

Adversarial Lenses (Apply to ALL Modes)

Before diving into mode-specific checks, apply these three lenses:

  • "What Would Break This?" — Describe realistic scenarios where this code fails catastrophically. Not edge cases — production failure modes under load, during deploys, with unexpected data.

  • "Assumption Stress Test" — List every assumption this code relies on. Which are most fragile? (e.g., "assumes user always has an email", "assumes this query returns < 1000 rows")

  • "Contradictions Finder" — Find contradictions between tests and implementation, docs and behavior, or between different parts of the changeset.

Challenge Modes

Ecto Challenge (/phx:challenge ecto )

Grill the developer on database changes:

Migration Safety

  • Will this migration lock the table in production?

  • What happens to existing records without the new field?

  • Is the migration reversible?

  • Are there any unsafe operations (column removal, type change)?

Query Performance

  • Have you introduced any N+1 queries?

  • Are there missing indexes for new WHERE clauses?

  • Will this query scale with data growth?

Schema Integrity

  • Are all constraints enforced at database level?

  • What happens during rolling deployment (old code, new schema)?

  • Are foreign key cascades correct?

Backward Compatibility

  • Will old code work during deployment?

  • Are there any breaking changes to the context API?

LiveView Challenge (/phx:challenge liveview )

Prove the LiveView handles all cases:

Event Coverage

  • List every handle_event clause and expected socket state

  • What happens if socket assigns are missing when event fires?

  • Are there race conditions between user events and server pushes?

PubSub Handling

  • List every handle_info clause and when it's triggered

  • Do all PubSub subscriptions have corresponding handlers?

  • What happens if a message arrives before mount completes?

State Transitions

  • Show the event → handler → state transition table

  • Are all error states handled gracefully?

  • What's the recovery path from each error state?

Memory & Performance

  • Are large lists using streams?

  • Is transient data using temporary_assigns?

  • What's the memory footprint per connected user?

PR Challenge (/phx:challenge pr )

Senior engineer review checklist:

Must Pass

  • No direct Repo calls in controllers/LiveViews

  • All Ecto queries use explicit preloads

  • Changesets validate all user input

  • No atoms created from params

  • Error cases handled (not just happy path)

  • Tests cover new functionality

Performance

  • No queries in Enum.map loops

  • LiveView streams for lists > 100 items

  • Indexes exist for WHERE clause columns

OTP

  • GenServers have supervision

  • Timeouts set for GenServer.call

  • No unbounded process spawning

Security

  • No SQL injection via raw queries

  • No path traversal in file handling

  • Authorization checks present

Prior Findings Deduplication

Before running a challenge, check for prior review output:

  • Search for existing reviews in .claude/plans/*/reviews/ and .claude/reviews/

  • If prior findings exist, read them first

  • In your challenge output, classify each finding as:

  • NEW — Not found in any prior review

  • PERSISTENT — Found before AND still present (not fixed)

  • REGRESSION — Was fixed but reintroduced

  • Do NOT re-flag fixed issues — If prior review flagged something and the code now addresses it, skip it

  • Focus on NEW issues — Spend most effort on findings not in prior reviews

When presenting results, show NEW findings first, then PERSISTENT (with note "flagged previously"), then REGRESSION. This prevents the "3 challenges to clear" problem where the same issues get re-discovered.

Usage

Run /phx:challenge [mode] to initiate a rigorous review. The reviewer will not approve until all concerns are addressed with evidence.

Example workflow:

  • Run /phx:challenge ecto after migration changes

  • Answer each question with code references or test results

  • Address all concerns before proceeding to PR

Source Transparency

This detail page is rendered from real SKILL.md content. Trust labels are metadata-based hints, not a safety guarantee.

Related Skills

Related by shared tags or category signals.

General

oban

No summary provided by upstream source.

Repository SourceNeeds Review
General

ecto-patterns

No summary provided by upstream source.

Repository SourceNeeds Review
General

phx:full

No summary provided by upstream source.

Repository SourceNeeds Review
General

tidewave-integration

No summary provided by upstream source.

Repository SourceNeeds Review