Skip to main content
ESLint Interlace
Plugin: reliability

Overview

ESLint rules for code reliability and error prevention

Live from GitHub

This content is fetched directly from README.md on GitHub and cached for 1 hour.

Reliable Code

Prevent runtime errors and ensure code reliability with defensive programming patterns.


Live README from GitHubfrom eslint-plugin-reliability/README.md, cached for 1 hour.Edit on GitHub
ESLint Interlace Logo

Reliability rules for defensive programming, error handling, and async correctness.

NPM VersionNPM DownloadsPackage LicenseCodecovSince Dec 2025

โญ If this plugin caught a real bug for you, star the repo โ€” it's the signal that keeps these rules maintained.

Description

This plugin provides Reliability rules for defensive programming, error handling, and async correctness.

Philosophy

Interlace fosters strength through integration. Instead of stacking isolated rules, we interlace security directly into your workflow to create a resilient fabric of code. We believe tools should guide rather than gatekeep, providing educational feedback that strengthens the developer with every interaction.

Getting Started

npm install eslint-plugin-reliability --save-dev

โš™๏ธ Configuration Presets

PresetDescription
recommendedBalanced reliability checks for most projects

๐Ÿข Usage Example

// eslint.config.js
import reliability from 'eslint-plugin-reliability';

export default [reliability.configs.recommended];

Why These Rules?

no-silent-errors

Empty catch blocks hide errors, making debugging impossible.

// โŒ Bad: Silent error swallowing
try {
  await processPayment(order);
} catch (e) {
  // Error is silently ignored!
}

// โœ… Good: Handle or log the error
try {
  await processPayment(order);
} catch (e) {
  logger.error('Payment processing failed', { orderId: order.id, error: e });
  throw new PaymentError('Payment failed', { cause: e });
}

no-missing-null-checks

Catches potential null or undefined dereferences.

// โŒ Bad: Potential runtime error
function greet(user: User | null) {
  return `Hello, ${user.name}`; // TypeError if user is null!
}

// โœ… Good: Null-safe access
function greet(user: User | null) {
  return user ? `Hello, ${user.name}` : 'Hello, guest';
}

require-network-timeout

Network requests without timeouts can hang indefinitely.

// โŒ Bad: No timeout, can hang forever
const response = await fetch('/api/data');

// โœ… Good: Request with timeout
const controller = new AbortController();
const timeoutId = setTimeout(() => controller.abort(), 5000);

const response = await fetch('/api/data', {
  signal: controller.signal,
});
clearTimeout(timeoutId);

no-await-in-loop

Sequential awaits in loops cause N+1 performance issues.

// โŒ Bad: Sequential requests (slow)
for (const id of userIds) {
  const user = await fetchUser(id); // N sequential requests
  results.push(user);
}

// โœ… Good: Parallel requests (fast)
const results = await Promise.all(userIds.map((id) => fetchUser(id)));

๐Ÿ“ฆ Compatibility

PackageVersion
ESLint^8.0.0 || ^9.0.0 || ^10.0.0
Node.js>=18.0.0

See the ESLint Version Support Policy โ€” current ecosystem share data, the 20% gate, and the forward-looking exception that covers v10.

Rules

Legend

IconDescription
๐Ÿ’ผRecommended: Included in the recommended preset.
โš ๏ธWarns: Set to warn in recommended preset.
๐Ÿ”งAuto-fixable: Automatically fixable by the --fix CLI option.
๐Ÿ’กSuggestions: Providing code suggestions in IDE.
๐ŸšซDeprecated: This rule is deprecated.
๐ŸŸขType-unaware: AST-only, runs in oxlint JS-plugin tier.
๐ŸŸกType-aware (refining): pure-AST primary path; types refine precision.
๐ŸŸ Type-aware (graceful): requires TS program; silent without it.
RuleCWEOWASPCVSSDescription๐Ÿง ๐Ÿ’ผโš ๏ธ๐Ÿ”ง๐Ÿ’ก๐Ÿšซ
error-messageEnforce providing a message when creating built-in Error objects for better debugging. This rule is part ofโ€ฆ๐ŸŸข๐Ÿ’ก
no-await-in-loopDisallow await inside loops without considering concurrency implications๐ŸŸข๐Ÿ’ก
no-jsdoc-terminator-in-exampleDetect */ sequences inside JSDoc @example blocks that prematurely close the JSDoc comment.๐ŸŸข๐Ÿ’ก
no-missing-error-contextESLint Rule: no-missing-error-context with LLM-optimized suggestions and auto-fix capabilities.๐ŸŸข๐Ÿ’ก
no-missing-null-checksCWE-476ESLint Rule: no-missing-null-checks with LLM-optimized suggestions and auto-fix capabilities.๐ŸŸขโš ๏ธ๐Ÿ’ก
no-silent-errorsESLint Rule: no-silent-errors with LLM-optimized suggestions and auto-fix capabilities.๐ŸŸขโš ๏ธ๐Ÿ’ก
no-unhandled-promiseCWE-1024Disallow unhandled Promise rejections with LLM-optimized suggestions for proper async error handling. Thisโ€ฆ๐ŸŸข๐Ÿ’ก
no-unsafe-type-narrowingESLint Rule: no-unsafe-type-narrowing with LLM-optimized suggestions and auto-fix capabilities.๐ŸŸข๐Ÿ’ก
require-network-timeoutRequire timeout configuration for network requests. This rule is part of eslint-plugin-reliability and provโ€ฆ๐ŸŸข๐Ÿ’ผ๐Ÿ’ก

Part of the Interlace ESLint Ecosystem โ€” AI-native security plugins with LLM-optimized error messages:

PluginDownloadsDescription
eslint-plugin-secure-codingdownloadsGeneral security rules & OWASP guidelines.
eslint-plugin-pgdownloadsPostgreSQL security & best practices.
eslint-plugin-node-securitydownloadsNode.js core-module security (fs, child_process, vm, crypto, Buffer).
eslint-plugin-jwtdownloadsJWT security & best practices.
eslint-plugin-browser-securitydownloadsBrowser-specific security & XSS prevention.
eslint-plugin-express-securitydownloadsExpress.js security hardening rules.
eslint-plugin-lambda-securitydownloadsAWS Lambda security best practices.
eslint-plugin-nestjs-securitydownloadsNestJS security rules & patterns.
eslint-plugin-mongodb-securitydownloadsMongoDB security best practices.
eslint-plugin-vercel-ai-securitydownloadsVercel AI SDK security hardening.
eslint-plugin-import-nextdownloadsNext-gen import sorting & architecture.

โญ Support & follow

If this plugin caught a real bug for you, star the repo โ€” stars are the signal that keeps the Interlace ESLint ecosystem maintained โ€” and follow the writeups on Dev.to for the benchmarks and security research behind these rules.

GitHub stars

๐Ÿ“„ License

MIT ยฉ Ofri Peretz

ESLint Interlace Plugin

View README.md on GitHub โ†’

On this page

No Headings