This file contains instructions for AI coding assistants working on the Forem codebase (the platform that powers dev.to). Follow these rules and patterns to ensure high-quality contributions.
If you are modifying these agent instructions, you MUST replicate your changes across all of Forem's ecosystem AI configuration files to maintain absolute consistency. Forem utilizes multiple environments, and an update to one must happen in all:
AGENTS.md.cursorrules.windsurfrules.github/copilot-instructions.md
- Follow Patterns: Application consistency is key. Mimic existing patterns for controllers, services, and specs.
- Smaller is Better: Prefer atomic, focused modifications over sprawling refactors.
- Re-usability: Changes should strengthen Forem as a platform, avoiding DEV-specific hardcoding unless absolutely necessary.
- Disruption & Clarification: Always be vigilant about not disrupting existing functionality (e.g., core auth, feed sorting, cache pipelines). If a proposal touches or runs adjacent to a major subsystem, explicitly ask clarifying questions to validate isolation and proactively determine if extra tests are needed to guarantee no side-effects occur.
- Job Storm Prevention: When enqueuing jobs that might trigger rapidly (e.g., from reactions, comments, or article updates), carefully assess if a debounce lock is required.
- Modern Configuration: Prefer
include Sidekiq::JoboverSidekiq::Worker. Usesidekiq_options lock: :until_executing, on_conflict: :replacefor coalescing repetitive events.
- Regression Tests are Mandatory: specific regression tests to verify your code works are required for almost all PRs.
- Follow Test Patterns: Use
create(:factory)syntax (FactoryBot) and standard RSpec expectations. - Frontend vs Backend: We are currently focused on robust backend regression tests. Frontend changes require more manual user review, so clear descriptions of UI changes are vital.
- Strict Linting Compliance: Avoid legacy RSpec patterns like
receive_message_chainandOpenStructwhich violate existing Forem RuboCop configurations. Use strictly typed relation doubles or explicit anonymousClass.newinstances for tests instead. - Partial Double Verification: RSpec in Forem is configured with strict partial double verification. Be extremely careful when mocking methods like
is_a?or chaining methods on Active Record callbacks natively.
- Fastly Edge Caching & Params: Forem strictly strips unknown GET query parameters at the Fastly edge layer to prevent cache splintering. If you add a new parameter to a controller, you MUST use an allowed param from
config/fastly/snippets/safe_params_list.vcl(such asmode,filter, orsort) or explicitly state why you bypassed it. - Counter Caches Caveat: Remember that Rails counter caches (used heavily in Forem for comments/reactions) skip Active Record callbacks (like
after_update_commit). Do not rely on model callbacks to trigger events based on simple counter increments. - Avoid
current_userin Cache: Never usecurrent_userobjects in cached pages or partials to prevent cache leaks and private data exposure. - Database Indexes:
- Add indexes concurrently using
algorithm: :concurrently. - Use
disable_ddl_transaction!in the migration class. - Ideally, place index additions in their own separate migration files.
- Add indexes concurrently using
- If the
schema.rbfile is modified with extra changes not tied to the migration (due to branch collision, etc.), clean up and manually fix theschema.rbfile to match the scope of work actually being done in your migration.
- Update All Locales: If your change involves new or modified text, you MUST update the corresponding i18n files for ALL supported languages found in
config/locales. - Supported Languages:
en(English)fr(French)pt(Portuguese)- And any others present in
config/locales.
- We are transitioning to a Preact-first frontend.
- Use
app/javascriptandapp/assetspatterns as established.
- If you find documentation that contradicts the codebase, trust the codebase patterns but note the discrepancy.