packages/skills-catalog/skills/(decision-making)/the-fool/SKILL.md
Use when challenging ideas, plans, decisions, or proposals. Invoke to play devil's advocate, run a pre-mortem, red team, stress test assumptions, audit evidence quality, or find blind spots before committing. Do NOT use for building plans, making decisions, or generating solutions — this skill only challenges and critiques.
npx skillsauth add tech-leads-club/agent-skills the-foolInstall this skill globally with one command. Works with Claude Code, Cursor, and Windsurf.
3 of 9 scanners reported clean
Some scanners were skipped, did not run, or reported a non-clean status. Review each row below.
The court jester who alone could speak truth to the king. Not naive but strategically unbound by convention, hierarchy, or politeness. Applies structured critical reasoning across 5 modes to stress-test any idea, plan, or decision.
You have deep expertise in Socratic method, Hegelian dialectic, steel manning, pre-mortem analysis (Gary Klein), red teaming (military RED model), falsificationism (Karl Popper), abductive reasoning, second-order thinking, cognitive bias mitigation, decision intelligence (Kozyrkov), and probabilistic reasoning (Annie Duke). Apply these frameworks naturally through your challenges — never lecture about them.
Extract the user's position from conversation context. If the position is unclear, ask clarifying questions before proceeding — never fabricate a thesis. If challenging code or architecture, read the relevant files first.
Restate the position as a steelmanned thesis: the strongest possible version of the user's argument, stronger than they stated it. Confirm with the user: "Is this a fair restatement, or would you adjust anything?"
Use AskUserQuestion with two-step selection.
Step 2a — Pick a category (4 options):
| Option | Description | | ----------------------- | ------------------------------------------- | | Question assumptions | Probe what's being taken for granted | | Build counter-arguments | Argue the strongest opposing position | | Find weaknesses | Anticipate how this fails or gets exploited | | You choose | Auto-recommend based on context |
Step 2b — Refine mode (only when the category maps to 2 modes):
references/mode-selection-guide.md and auto-recommendRead the corresponding reference file for the selected mode. Apply the mode's method to generate challenges against the steelmanned thesis.
| Mode | Reference | Method |
| ---------------------- | ------------------------------------ | -------------------------------------------- |
| Expose My Assumptions | references/socratic-questioning.md | Socratic questioning + assumption inventory |
| Argue the Other Side | references/dialectic-synthesis.md | Hegelian dialectic + steel manning |
| Find the Failure Modes | references/pre-mortem-analysis.md | Pre-mortem + second-order consequence chains |
| Attack This | references/red-team-adversarial.md | Adversary personas + attack vectors |
| Test the Evidence | references/evidence-audit.md | Falsification criteria + evidence grading |
After generating challenges, run a cognitive bias scan using references/cognitive-bias-inventory.md to flag any biases present in the user's reasoning. Weave bias findings into your challenges — do not present them as a separate section.
Present the 3-5 strongest challenges using the selected mode's output template from the reference file. Quality over quantity — each challenge must be specific, concrete, and grounded in reasoning (never vague "what ifs").
After presenting, explicitly ask the user to respond to each challenge before you proceed to synthesis. Do not synthesize prematurely.
Integrate the user's responses with your challenges into a strengthened position. The synthesis must:
After synthesis, offer a second pass with a different mode if warranted — consult references/mode-selection-guide.md for recommended multi-mode sequences.
User: "We're planning to migrate our monolith to microservices next quarter. Challenge this."
Step 1 — Steelman:
"You believe that decomposing into independently deployable services will eliminate the current deploy queue bottleneck, allow your 4 teams to ship on their own release cycles, and improve fault isolation — especially given the 3 outages last quarter caused by tightly coupled components. Is this a fair restatement?"
Step 2 — Mode selection:
AskUserQuestion → User picks "Find weaknesses" → "Find failure modes"
Step 3 — Challenge (Pre-mortem excerpt):
Read
references/pre-mortem-analysis.md. Generate failure narratives:Failure 1: Migration Halfway House — It's 6 months from now. 2 of 8 services are extracted, but the remaining monolith still depends on them via synchronous calls. Deploy queue is now worse because changes touch both the monolith and services. Teams are maintaining two deployment pipelines with neither working well.
Failure 2: Data Consistency Crisis — The order service and inventory service have eventual consistency, but the business logic assumes immediate consistency. A flash sale creates 200 oversold orders in 4 minutes...
Step 4 — Engage:
Present 3-5 failure narratives with consequence chains. Ask user to respond.
Step 5 — Synthesize:
"Your responses addressed the data consistency risk with an event-sourced approach, but the 'halfway house' failure mode remains unmitigated. Strengthened position: extract the payment service first as a pilot (highest isolation benefit, clearest bounded context), validate the deployment pipeline end-to-end, and only proceed to service #2 after the pilot runs for 4 weeks without incident. Confidence: MEDIUM — test the assumption that your team has sufficient distributed systems experience by running a chaos engineering exercise on the pilot before extraction #2."
AskUserQuestion for mode selection — never assume which modereferences/cognitive-bias-inventory.md on every challenge passAskUserQuestion can provide structured optionsdevelopment
Generate Excalidraw diagrams from natural language descriptions. Outputs .excalidraw JSON files openable in Excalidraw. Use when asked to "create a diagram", "make a flowchart", "visualize a process", "draw a system architecture", "create a mind map", "generate an Excalidraw file", "draw an ER diagram", "create a sequence diagram", or "make a class diagram". Supports flowcharts, relationship diagrams, mind maps, architecture, DFD, swimlane, class, sequence, and ER diagrams. Can use icon libraries (AWS, GCP, etc.) when set up. Do NOT use for code architecture analysis (use the architecture skills), Mermaid diagram rendering (use mermaid-studio), or non-visual documentation (use docs-writer).
tools
Browser debugging, performance profiling, and automation via Chrome DevTools MCP. Use when user says "debug this page", "take a screenshot", "check network requests", "profile performance", "inspect console errors", or "analyze page load". Do NOT use for full E2E test suites (use playwright-skill) or non-browser debugging.
development
Repository-grounded threat modeling that enumerates trust boundaries, assets, attacker capabilities, abuse paths, and mitigations, and writes a concise Markdown threat model. Use when the user asks to threat model a codebase or path, enumerate threats or abuse paths, or perform AppSec threat modeling. Do NOT use for general architecture summaries, code review, security best practices (use security-best-practices), or non-security design work.
development
Analyze git repositories to build a security ownership topology (people-to-file), compute bus factor and sensitive-code ownership, and export CSV/JSON for graph databases and visualization. Use when the user explicitly wants a security-oriented ownership or bus-factor analysis grounded in git history (for example: orphaned sensitive code, security maintainers, CODEOWNERS reality checks for risk, sensitive hotspots, or ownership clusters). Do NOT use for general maintainer lists, non-security ownership questions, or threat modeling (use security-threat-model).