🎯

ship-decisions

🎯Skill

from menkesu/awesome-pm-skills

VibeIndex|
What it does

Guides product decisions by evaluating whether to ship or iterate using frameworks that distinguish between reversible and irreversible choices, helping teams balance speed, learning, and risk.

πŸ“¦

Part of

menkesu/awesome-pm-skills(20 items)

ship-decisions

Installation

git cloneClone repository
git clone [your-repo-url]
πŸ“– Extracted from docs: menkesu/awesome-pm-skills
3Installs
-
AddedFeb 4, 2026

Skill Details

SKILL.md

Guides "ship or iterate?" decisions using Shreyas Doshi's frameworks, Marty Cagan's shipping philosophy, and Tobi Lutke's reversible decision-making. Use when deciding if feature is ready, preventing perfectionism paralysis, applying one-way vs two-way door thinking, or balancing technical debt vs shipping speed.

Overview

# The Shipping Decision Matrix

When This Skill Activates

Claude uses this skill when:

  • User asks "is this ready to ship?"
  • Deciding between shipping now vs iterating more
  • Evaluating if "good enough" is good enough
  • Balancing technical debt vs shipping speed
  • Preventing perfectionism paralysis

Core Frameworks

1. Reversible vs Irreversible Decisions (Source: Jeff Bezos, applied by Shreyas Doshi)

One-Way vs Two-Way Doors:

> "Some decisions are like one-way doors - hard to reverse. Most decisions are like two-way doors - easy to reverse. Don't treat all decisions the same."

The Framework:

πŸšͺ Two-Way Doors (Reversible)

  • Can be undone or changed easily
  • Low cost to reverse
  • Learning > being right
  • Decision speed: FAST (hours/days)
  • Process: Ship and iterate

πŸšͺ One-Way Doors (Irreversible)

  • Hard or impossible to reverse
  • High cost to undo
  • Need to get it right
  • Decision speed: SLOW (weeks/months)
  • Process: Research, debate, decide carefully

How to Apply:

```

Before shipping, ask:

  1. "Can we reverse this decision?"

- YES β†’ Two-way door β†’ Ship fast, iterate

- NO β†’ One-way door β†’ Go slow, get it right

  1. "What's the cost of being wrong?"

- LOW β†’ Ship and learn

- HIGH β†’ Research more

  1. "Can we learn more by shipping?"

- YES β†’ Ship to learn

- NO β†’ Prototype/test first

```

Examples:

```

TWO-WAY DOORS (Ship Fast):

βœ… Button color

βœ… Copy/messaging

βœ… UI layout

βœ… Feature flag experiments

βœ… Pricing (for small customers)

ONE-WAY DOORS (Go Slow):

⚠️ Database schema (migrations expensive)

⚠️ API contracts (breaking changes hurt users)

⚠️ Brand decisions (hard to rebrand)

⚠️ Pricing (for enterprise customers)

⚠️ Architecture (refactoring expensive)

```

---

2. The Shipping Scorecard (Source: Shreyas Doshi)

Is It Ready?

> "Don't ship broken products. But also don't wait for perfect. Ship when it's good enough for real users to get value."

The 5-Check System:

βœ… 1. Core Functionality Works

  • Happy path functions end-to-end
  • User can complete main job
  • No critical bugs

βœ… 2. Edge Cases Acceptable

  • Not perfect, but handled gracefully
  • Errors don't break experience
  • User can recover

βœ… 3. Reversible Decision

  • Can we undo or iterate?
  • Is this a two-way door?
  • What's the rollback plan?

βœ… 4. Learning Value > Polish Value

  • Will shipping teach us more than building more?
  • Do we need real user feedback to improve?
  • Is hypothetical polish valuable without data?

βœ… 5. Risk Mitigated

  • Critical failure modes addressed
  • Monitoring in place
  • Gradual rollout plan

Scoring:

```

5/5 checks β†’ SHIP NOW

4/5 checks β†’ SHIP TO SMALL GROUP

3/5 checks β†’ ITERATE ONE MORE CYCLE

<3/5 checks β†’ NOT READY

```

---

3. Technical Debt vs Shipping Speed (Source: Marty Cagan, Tobi Lutke)

The Tradeoff:

> "Technical debt isn't inherently bad. It's bad when it slows you down. Ship fast, pay down debt strategically."

When to Ship with Tech Debt:

  • Learning debt: Need user feedback to validate approach
  • Temporary: Planning to refactor soon anyway
  • Isolated: Debt doesn't affect other systems
  • Value >> Debt cost: User value gained > refactor cost

When to Pay Down Debt First:

  • Compounding debt: Will make future changes harder
  • Security/Privacy: User trust at risk
  • Platform/API: Breaking changes expensive
  • Team velocity: Slowing everyone down

Framework:

```

Assess Tech Debt:

  1. What's the carrying cost?

- Slows future features?

- Blocks other teams?

- Creates bugs?

  1. What's the payoff of fixing?

- Unblocks work?

- Reduces bugs?

- Improves velocity?

  1. What's the user value of shipping now?

- Solves immediate problem?

- Competitive advantage?

- Revenue impact?

Decision:

IF (user value > debt cost) β†’ SHIP

IF (debt blocks future) β†’ REFACTOR

IF (uncertain) β†’ SHIP TO SMALL GROUP

```

---

4. Gradual Rollout Strategy (Source: Modern tech best practices)

Don't Ship to Everyone at Once:

> "The safest way to ship is gradually. Start small, monitor, expand."

The Rollout Ladder:

Stage 1: Internal (1-10 users)

  • Team uses it daily
  • Find obvious bugs
  • Duration: 1-3 days

Stage 2: Early Adopters (1-5% users)

  • Select forgiving users
  • Eager for new features
  • Provide feedback actively
  • Duration: 3-7 days

Stage 3: Broader Beta (10-25%)

  • Larger sample size
  • Monitor metrics closely
  • Duration: 1-2 weeks

Stage 4: General Availability (100%)

  • All users
  • Stable metrics
  • Duration: Ongoing

Rollback Plan:

```javascript

// Feature flag implementation

if (isFeatureEnabled(user, 'new-feature')) {

return newExperience();

} else {

return oldExperience();

}

// Quick rollback = change flag, no deploy

```

---

Decision Tree: Ship or Wait?

```

FEATURE: Ready to evaluate

β”‚

β”œβ”€ Core functionality works? ───────NO──→ FIX CRITICAL BUGS

β”‚ YES ↓

β”‚

β”œβ”€ Is this reversible decision? ────────┐

β”‚ YES (two-way door) ───────────────────

β”‚ NO (one-way door) β†’ RESEARCH MORE β”‚

β”‚ ↓

β”œβ”€ Edge cases acceptable? ───────────────

β”‚ YES ──────────────────────────────────

β”‚ NO β†’ FIX OR GRACEFUL DEGRADATION β”‚

β”‚ ↓

β”œβ”€ Can we learn from shipping? ──────────

β”‚ YES ──────────────────────────────────

β”‚ NO β†’ TEST/PROTOTYPE MORE β”‚

β”‚ ↓

β”œβ”€ Risk mitigated? ──────────────────────

β”‚ YES β†’ SHIP GRADUALLY β”‚

β”‚ NO β†’ ADD MONITORING/ROLLBACK β”‚

β”‚ ↓

└─ SHIP β†β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜

Start: Internal β†’ 5% β†’ 25% β†’ 100%

```

Action Templates

Template 1: Shipping Readiness Assessment

```markdown

# Feature: [Name]

Shipping Scorecard

1. Core Functionality Works

  • [ ] Happy path works end-to-end
  • [ ] User can complete main job
  • [ ] No critical bugs blocking core use

Status: [Ready / Needs work]

2. Edge Cases Acceptable

  • [ ] Error states handled gracefully
  • [ ] User can recover from failures
  • [ ] Edge cases don't break experience

Status: [Acceptable / Needs improvement]

3. Reversible Decision

  • Is this reversible? [Yes / No]
  • Rollback plan: [describe]
  • Two-way door? [Yes / No]

Status: [Safe to ship / Risky]

4. Learning Value

  • Will shipping teach us more? [Yes / No]
  • Do we need real user feedback? [Yes / No]
  • Is polish speculative without data? [Yes / No]

Status: [Ship to learn / Build more first]

5. Risk Mitigated

  • [ ] Monitoring in place
  • [ ] Gradual rollout plan
  • [ ] Critical failure modes addressed

Status: [Risks managed / Needs work]

Score: [X / 5]

Decision:

  • 5/5 β†’ Ship to 5% immediately
  • 4/5 β†’ Ship to internal first
  • 3/5 β†’ One more iteration
  • <3 β†’ Not ready

Rollout Plan

  • [ ] Internal (team): [date]
  • [ ] Early adopters (5%): [date]
  • [ ] Broader beta (25%): [date]
  • [ ] General availability (100%): [date]

```

Template 2: Tech Debt Decision

```markdown

# Feature: [Name]

Technical Debt Assessment

Current Debt

[Describe shortcuts taken, code quality issues]

Carrying Cost

  • Slows future features? [Yes / No / How much]
  • Blocks other teams? [Yes / No]
  • Creates bugs? [Yes / No / Frequency]
  • Security/privacy risk? [Yes / No]

Debt Impact: [High / Medium / Low]

Payoff of Fixing Now

  • Time to refactor: [X days]
  • Would unblock: [list]
  • Would improve: [list]

Refactor Value: [High / Medium / Low]

User Value of Shipping Now

  • User problem solved: [describe]
  • Revenue/metric impact: [estimate]
  • Competitive advantage: [Yes / No]
  • User waiting for this: [Yes / No]

Shipping Value: [High / Medium / Low]

Decision

IF Shipping Value > Debt Impact:

β†’ SHIP NOW, refactor later

Plan: [when to address debt]

IF Debt Impact > Shipping Value:

β†’ REFACTOR FIRST, then ship

Plan: [how to refactor]

IF Uncertain:

β†’ SHIP TO SMALL GROUP (5%)

Monitor: [specific metrics]

```

Template 3: One-Way vs Two-Way Door

```markdown

# Decision: [Description]

Reversibility Analysis

Can we reverse this decision?

[Yes / No / Partially]

Cost to reverse

  • Time: [X days/weeks]
  • Money: [$X]
  • User impact: [High / Medium / Low]
  • Team impact: [High / Medium / Low]

Why hard to reverse?

[Technical, contractual, brand, user expectations, etc.]

Door Type

Two-Way Door (Reversible):

β†’ Decide in: Hours/days

β†’ Process: Ship fast, iterate

β†’ Research: Minimal

One-Way Door (Irreversible):

β†’ Decide in: Weeks/months

β†’ Process: Research, debate, consensus

β†’ Research: Extensive

Decision

Door type: [Two-way / One-way]

Decision timeline: [X time]

Process: [describe]

```

Quick Reference Card

🚒 Shipping Decision Checklist

Before Evaluating:

  • [ ] Core functionality tested
  • [ ] Edge cases identified
  • [ ] Rollback plan ready

The 5 Questions:

  1. Works? Core functionality end-to-end βœ“
  2. Acceptable? Edge cases handled gracefully βœ“
  3. Reversible? Can we undo or iterate? βœ“
  4. Learn? Shipping teaches us more than building? βœ“
  5. Safe? Risks mitigated, monitoring ready βœ“

Decision Rules:

  • 5/5 β†’ Ship to small group now
  • 4/5 β†’ Ship internal first
  • 3/5 β†’ One more iteration
  • <3/5 β†’ Not ready yet

Rollout Ladder:

  1. Internal (team)
  2. Early adopters (5%)
  3. Broader beta (25%)
  4. General availability (100%)

---

Real-World Examples

Example 1: Facebook's "Move Fast" Philosophy

Approach: Ship fast, break things (early days)

  • Two-way doors: Ship immediately
  • Feature flags: Easy rollback
  • Gradual rollouts: 1% β†’ 5% β†’ 25% β†’ 100%

Evolution: "Move fast with stable infrastructure"

  • One-way doors: Go slow (API, platform)
  • Two-way doors: Still fast (UI, features)

---

Example 2: Stripe's API Versioning

Challenge: Changing API breaks customers

Decision: ONE-WAY DOOR

  • Treat API as contract
  • Never break backwards compatibility
  • Version all changes
  • Support old versions forever

Result: Trust through stability

---

Example 3: Tech Debt at Airbnb

Challenge: Ship new features vs refactor

Decision Framework:

  • Debt blocking growth β†’ Refactor first
  • Debt isolated β†’ Ship, refactor later
  • Uncertain β†’ Ship to 5%, measure velocity

Result: Strategic debt paydown, maintained velocity

---

Common Pitfalls

❌ Mistake 1: Treating All Decisions Like One-Way Doors

Problem: Slow decision-making, perfectionism

Fix: Identify two-way doors, ship fast on those

❌ Mistake 2: Shipping Broken Core Functionality

Problem: "Move fast and break things" gone wrong

Fix: Core must work, edge cases can be rough

❌ Mistake 3: No Rollback Plan

Problem: Ship breaks, no way to undo

Fix: Feature flags, gradual rollout

❌ Mistake 4: Ignoring Compounding Tech Debt

Problem: Short-term speed, long-term slowdown

Fix: Strategic debt paydown

---

Related Skills

  • strategic-build - For LNO framework (is this Leverage work?)
  • quality-speed - For craft quality vs shipping speed
  • zero-to-launch - For MVP scoping decisions
  • exp-driven-dev - For A/B testing risky changes

---

Key Quotes

Jeff Bezos (Amazon):

> "Some decisions are consequential and irreversible - one-way doors. Make those slowly. Most decisions are reversible - two-way doors. Make those fast."

Shreyas Doshi:

> "The best PMs know when 'good enough' is good enough. Ship to learn, not to be perfect."

Marty Cagan:

> "Technical debt isn't the enemy. The enemy is debt that compounds and slows you down."

Tobi Lutke (Shopify):

> "Trust is built on shipping what you promise. Ship early, ship often, ship small."

---

Further Learning

  • references/reversible-decisions.md - One-way vs two-way doors guide
  • references/shipping-checklist.md - Comprehensive readiness assessment
  • references/gradual-rollout-guide.md - Feature flag implementation
  • references/tech-debt-paydown.md - Strategic refactoring frameworks

More from this repository10

🎯
strategy-frameworks🎯Skill

Generates strategic product roadmaps using frameworks like Playing to Win and Crossing the Chasm, helping teams define market strategy and competitive positioning.

🎯
zero-to-launch🎯Skill

Rapidly guides users from product concept to working prototype by applying AI-first thinking, simplicity frameworks, and experience design principles.

🎯
workplace-navigation🎯Skill

Helps professionals navigate workplace conflicts by understanding root causes, finding common ground, and resolving tensions with strategic communication.

🎯
ai-startup-building🎯Skill

Builds AI-native products using modern startup frameworks, optimizing for speed, cost, and user experience with 2025+ best practices.

🎯
growth-embedded🎯Skill

Embeds viral growth mechanics and retention strategies into product development, using proven frameworks to optimize user acquisition, activation, and network effects.

🎯
jtbd-building🎯Skill

Designs product features by uncovering customer's deeper motivations, functional needs, and emotional progress using Jobs-to-be-Done theory.

🎯
strategic-build🎯Skill

Strategically prioritizes and builds high-impact, compounding work using the LNO framework to maximize development efficiency and prevent low-value efforts.

🎯
exec-comms🎯Skill

Drafts precise executive communications using Amazon's 6-pager, Stripe's memo format, and SCQA framework for strategic documents.

🎯
influence-craft🎯Skill

Strategically maps organizational power dynamics and builds influence by leveraging relationships, expertise, and strategic stakeholder engagement.

🎯
user-feedback-system🎯Skill

Systematically collects and analyzes user feedback using PMF surveys, NPS tracking, interviews, and feature request mechanisms to drive product improvement.