This document is the single canonical source of truth for all DevRail development standards applied to the devrail.dev documentation site.
These eight rules are non-negotiable. Every developer and every AI agent must follow them without exception.
-
Run
make checkbefore completing any story or task. Never mark work done without passing checks. This is the single gate for all linting, formatting, security, and test validation. -
Use conventional commits. Every commit message follows the
type(scope): descriptionformat. No exceptions. See the Conventional Commits section for types and scopes. -
Never install tools outside the container. All linters, formatters, scanners, and test runners live inside
ghcr.io/devrail-dev/dev-toolchain:v1. The Makefile delegates to Docker. Do not install tools on the host. -
Respect
.editorconfig. Never override formatting rules (indent style, line endings, trailing whitespace) without explicit instruction. The.editorconfigfile in each repo is authoritative. -
Write idempotent scripts. Every script must be safe to re-run. Check before acting:
command -v tool || install_tool,mkdir -p, guard file writes with existence checks. -
Use the shared logging library. No raw
echofor status messages. Uselog_info,log_warn,log_error,log_debug, anddiefromlib/log.sh. -
Never suppress failing checks. When a lint, format, security, or test check fails, fix the underlying issue. Never comment out code, add suppression annotations (
# noqa,# nosec,#tfsec:ignore,// nolint), disable rules, or mark CI jobs as allowed-to-fail to bypass a failing check. If a finding is a confirmed false positive, document the justification inline alongside the tool's designated suppression mechanism. -
Update documentation when changing behavior. When a change affects public interfaces, configuration, CLI usage, or setup steps, update the relevant documentation (README, DEVELOPMENT.md, inline docs) in the same commit or PR. Do not leave documentation out of sync with code.
The Makefile is the universal execution interface. Developers, CI pipelines, and AI agents all interact with the project through make targets.
This is a documentation site, so it includes Hugo-specific targets alongside the standard DevRail contract:
| Target | Purpose |
|---|---|
make help |
List all targets with descriptions (default target) |
make build |
Build the Hugo site with hugo --minify |
make serve |
Start local development server with hugo server |
make check |
Run all DevRail checks |
make install-hooks |
Install pre-commit hooks |
All commits follow the Conventional Commits specification.
type(scope): description
| Type | When to Use |
|---|---|
feat |
A new feature or capability |
fix |
A bug fix |
docs |
Documentation-only changes |
chore |
Maintenance tasks (dependencies, config) |
ci |
CI/CD pipeline changes |
refactor |
Code restructuring without behavior change |
test |
Adding or updating tests |
| Scope | Applies To |
|---|---|
docs |
Documentation content changes |
ci |
CI/CD pipeline configuration |
hugo |
Hugo configuration changes |
General software engineering standards that apply across all languages. For the full reference, see standards/coding-practices.md.
- DRY, KISS, YAGNI -- don't repeat yourself, keep it simple, build only what is needed now
- Single responsibility -- each function, class, or module does one thing
- Fail fast -- validate inputs at boundaries, return or raise immediately on invalid state
- No swallowed exceptions -- every error branch handles the error meaningfully or propagates it
- Test behavior, not implementation -- assert on outputs and side effects, follow the test pyramid (unit > integration > e2e)
- New code must include tests -- PRs that add logic without tests are incomplete
- ~50 line function guideline -- split long functions into focused helpers
- Pin dependency versions -- commit lock files, update regularly, respond to security advisories promptly
Git discipline and collaboration standards. For the full reference, see standards/git-workflow.md.
- Never push directly to
main-- all changes reach the default branch through a pull/merge request - Branch naming --
type/short-description(e.g.,feat/add-auth,fix/login-error) - Minimum 1 approval required before merging, no self-merge
- Atomic commits -- one logical change per commit, conventional commit format
- No
--force-pushto shared branches -- only force push your own feature branches - Squash-merge feature branches for clean, linear history on
main - No secrets in commits -- enforced by gitleaks pre-commit hook and
make scan - Branch protection on
main-- require PR, approvals, and CI pass
Release management and versioning discipline. For the full reference, see standards/release-versioning.md.
- Semantic versioning --
MAJOR.MINOR.PATCHwith strict adherence afterv1.0.0 - Annotated tags only --
vX.Y.Zformat, tagged frommain, never moved or deleted after push - Release process -- review changelog, tag, push, create platform release with artifacts
- Hotfixes -- branch from tag, fix, merge to
main, tag new patch release - Pre-release versions --
v1.0.0-rc.1,v1.0.0-beta.1conventions for unstable releases - Libraries vs services -- libraries follow semver strictly; services may use date-based versioning
- Changelog -- auto-generated from conventional commits, Keep a Changelog format
Continuous integration and deployment standards. For the full reference, see standards/ci-cd-pipelines.md.
- Standard stages --
lint → format → test → security → scan → build → deploy(in order) - Stage contract -- each CI stage calls a
maketarget; identical behavior locally and in CI - Required jobs -- lint, format, test, security, scan must pass before merge
- Deployment gates -- auto-deploy to staging on merge to
main; manual approval for production - Pipeline types -- library (test+publish), service (test+build+deploy), infrastructure (plan+apply)
- Artifact management -- release tags are immutable, pin toolchain versions, commit lock files
- Performance -- cache dependencies, parallelize independent stages, target < 10 min for PR checks
Container image build and runtime standards. For the full reference, see standards/container-standards.md.
- Pin base images -- use specific tags or digests, never
latest - Multi-stage builds -- separate build dependencies from the runtime image
- Layer ordering -- least-changing layers first to maximize cache reuse
- Non-root user -- never run containers as root in production
- No secrets in images -- inject at runtime via env vars or mounted volumes
- Image tagging --
vX.Y.Zfor releases,sha-<short>for CI builds, never overwrite release tags - Health checks -- every service container exposes
/healthzand/readyzendpoints .dockerignorerequired -- exclude.git, tests, docs, and build artifacts from the context
Standards for handling secrets and sensitive configuration. For the full reference, see standards/secrets-management.md.
- Classify correctly -- secrets vs sensitive config vs environment config vs application config
- Never in source control -- no API keys, passwords, or tokens in committed files (enforced by gitleaks)
- Platform secrets -- use GitHub/GitLab secrets or a dedicated manager (Vault, AWS SM, GCP SM)
.envgitignored,.env.examplecommitted -- document required variables with placeholdersUPPER_SNAKE_CASEnaming -- prefix by service or context to avoid collisions- Rotate on schedule -- 90-day minimum for keys and credentials; immediately on exposure
- Least privilege -- no shared credentials, service accounts over personal, audit access
Standards for designing APIs and CLIs. For the full reference, see standards/api-cli-design.md.
- Version APIs from day one -- URL path (
/v1/) preferred; never break clients without a version bump - JSON by default -- consistent envelope, ISO 8601 timestamps, request IDs in every response
- Structured errors -- machine-readable
code, human-readablemessage, detailedfields; correct HTTP status codes - CLI conventions --
--helpon every command, exit codes 0/1/2, JSON output for machines - Backward compatibility -- additive changes are safe; removals require deprecation + version bump
- OpenAPI for APIs -- spec is the source of truth, kept in sync with code
- Pagination and rate limiting -- standard patterns for collection endpoints
Runtime monitoring and observability standards. For the full reference, see standards/monitoring-observability.md.
- Health endpoints --
/healthz(liveness) and/readyz(readiness) for every service - Structured logging -- JSON format, correlation IDs, log levels (
debug,info,warn,error) - RED metrics -- Rate, Errors, Duration for every service; Prometheus-style exposition
- Alerting -- alert on symptoms not causes, every alert links to a runbook, minimize noise
- Dashboards -- one per service minimum, golden signals visible at a glance
- Never log PII -- no secrets, tokens, emails, or government IDs in logs; redact if unavoidable
Incident detection, response, and learning standards. For the full reference, see standards/incident-response.md.
- Severity levels -- SEV1 (15 min response) through SEV4 (1 business day)
- Incident workflow -- detect → triage → mitigate → resolve → post-mortem
- Communication -- status page updates, stakeholder notification cadence per severity
- Post-mortems -- required for SEV1-SEV2, blameless, concrete action items with owners and due dates
- Runbooks -- required for every production service, stored alongside code, reviewed quarterly
- On-call -- defined rotation, clean handoffs, escalation path documented
Data classification, privacy, and compliance standards. For the full reference, see standards/data-handling.md.
- Data classification -- public, internal, confidential, restricted; classify at collection time
- PII handling -- identify, minimize collection, encrypt at rest and in transit, document what is collected
- Retention -- define periods per data type, automate deletion, support right-to-deletion requests
- Backups -- regular, tested restores, encrypted, offsite copy, automated
- Encryption -- TLS 1.2+ in transit, AES-256 at rest, keys managed via secrets manager
- Compliance awareness -- GDPR, CCPA, HIPAA, PCI DSS as applicable; breach notification process documented
- Never log PII -- redact or mask if logging is unavoidable; route to restricted log stream
This site is built with Hugo using the Docsy theme. Content is written in Markdown and rendered to static HTML.
content/
├── _index.md -- Landing page
├── docs/
│ ├── _index.md -- Documentation overview
│ ├── getting-started/ -- Quick start guides
│ ├── standards/ -- Per-language standards reference
│ ├── container/ -- Dev-toolchain container docs
│ ├── templates/ -- Project template docs
│ └── contributing/ -- Contribution guidelines
└── blog/ -- Blog posts (future)
- Hugo extended (for building the site)
- Go >= 1.21 (for Hugo modules)
- Docker (for
make check) - pre-commit (for git hooks)