chore: standardize on *_internal_test.go for white-box tests (#25601)

My agent added `//nolint:testpackage` to a test file on one of my PRs.
Again. This PR cleans it up across the entire repo and updates the
in-repo conventions so future agents stop doing it.

The repo already has a precedent for white-box tests that need to touch
unexported symbols: `*_internal_test.go` (145+ existing files). The
`testpackage` linter's default `skip-regexp` exempts that filename
suffix, so the `//nolint:testpackage` directive is unnecessary in every
case where someone reached for it. This PR renames 51 such files to
`*_internal_test.go` via `git mv` so blame and history follow, and
strips the dead directive from 2 files that were already correctly named
(`coderd/oauth2provider/authorize_internal_test.go`,
`coderd/x/chatd/advisor_internal_test.go`).

`.claude/docs/TESTING.md` now documents the rule explicitly under *Test
Package Naming*, which is imported into the root `AGENTS.md` via
`@.claude/docs/TESTING.md`. The rule: prefer `package foo_test`; if you
need internal access, rename the file to `*_internal_test.go` rather
than adding a nolint directive.
This commit is contained in:
Ethan
2026-05-22 20:24:38 +10:00
committed by GitHub
parent 705421bc5d
commit c650aabbef
52 changed files with 70 additions and 64 deletions
@@ -1,4 +1,3 @@
//nolint:testpackage // Tests private env helpers directly.
package reconnectingpty
import (
@@ -1,4 +1,4 @@
package agent //nolint:testpackage // Exercises internal agent secrets handling.
package agent
import (
"testing"