effect-ts-anti-patterns

Use when reviewing Effect-TS code, debugging unexpected crashes, or optimizing concurrent operations.

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 "effect-ts-anti-patterns" with this command: npx skills add mrevanzak/effect-ts-skills/mrevanzak-effect-ts-skills-effect-ts-anti-patterns

Effect-TS Anti-Patterns

Overview

Effect-TS provides a powerful functional framework, but common imperative habits can bypass its safety guarantees. This skill identifies and fixes patterns that lead to resource leaks, process crashes, and unhandled errors.

When to Use

  • During code reviews of Effect-TS implementations.
  • When debugging "unhandled promise rejections" or process crashes in Effect code.
  • When optimizing performance of parallel operations.

When NOT to use:

  • For simple, non-Effect TypeScript code.
  • When using other functional libraries (fp-ts, etc.).

Anti-Patterns Reference

Anti-PatternBad CodeGood CodeWhy
Run Outside Boundaryawait Effect.runPromise(fx) mid-functionyield* fx (compose)Bypasses error channel & tracing.
Missing yield*const user = yield fetchUser()const user = yield* fetchUser()Yields the Effect object, not the result.
Throwing Errorsif (!ok) throw new Error()yield* Effect.fail(new Error())throw creates a "Defect" (crash), not a typed error.
Unbounded ParallelismEffect.all(tasks) (default)Effect.all(tasks, { concurrency: 10 })Prevents OOM and rate limit exhaustion.
Ignoring ErrorsEffect.runPromise(fx) (no catch)fx.pipe(Effect.catchAll(...))Leads to unhandled rejections.
Manual Cleanuptry { ... } finally { cleanup() }Effect.acquireRelease(...)finally doesn't guarantee cleanup on interruption.

Common Mistakes

1. The yield vs yield* Trap

// ❌ BAD: Missing *, yields the Effect object itself
const bad = Effect.gen(function* () {
  const user = yield fetchUser(id); // Returns Effect, not User!
});

// ✅ GOOD: yield* executes the Effect
const good = Effect.gen(function* () {
  const user = yield* fetchUser(id); // Returns User
});

2. Unbounded Parallelism

// ❌ BAD: 10,000 concurrent requests (OOM risk)
const bad = Effect.all(urls.map(fetch));

// ✅ GOOD: Bounded to 10 concurrent
const good = Effect.all(urls.map(fetch), { concurrency: 10 });

3. Running Effects Mid-Code

// ❌ BAD: Effect.runPromise scattered throughout
const bad = async () => {
  const user = await Effect.runPromise(getUser(id));
  const posts = await Effect.runPromise(getPosts(user.id));
};

// ✅ GOOD: Compose effects, run ONCE at boundary
const good = Effect.gen(function* () {
  const user = yield* getUser(id);
  const posts = yield* getPosts(user.id);
  return { user, posts };
});

Rationalization Table

ExcuseReality
"I'll use concurrency: 'unbounded' to make it fast"Fast = Crash. Always bound parallelism for external resources.
"I'll just throw for now"throw bypasses the error channel and makes code untestable.
"It's easier to run it here"Running mid-code loses the context, tracing, and interruption safety.

Red Flags

  • Effect.runPromise or Effect.runSync inside a loop or helper function.
  • Effect.all without a concurrency option on large lists.
  • throw keyword inside an Effect.gen block.
  • yield without * when calling an Effect.

Cross-References

  • REQUIRED BACKGROUND: effect-ts-fundamentals
  • REQUIRED SUB-SKILL: effect-ts-concurrency
  • REFERENCE: effect-ts-resources

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

effect-ts-concurrency

No summary provided by upstream source.

Repository SourceNeeds Review
General

effect-ts-resources

No summary provided by upstream source.

Repository SourceNeeds Review
General

effect-ts-fundamentals

No summary provided by upstream source.

Repository SourceNeeds Review
General

effect-ts-errors

No summary provided by upstream source.

Repository SourceNeeds Review