skills/review-tooling/SKILL.md
Detect what dev tooling infrastructure a project has and flag gaps across linters, formatters, pre-commit hooks, test runners, and CI/CD pipelines. Returns structured findings without applying changes. Use when the user asks to "review tooling", "check project tooling", "what tooling is missing", "review dev infrastructure", or "tooling audit".
npx skillsauth add tobihagemann/turbo review-toolingInstall this skill globally with one command. Works with Claude Code, Cursor, and Windsurf.
3 of 9 scanners reported clean
Some scanners were skipped, did not run, or reported a non-clean status. Review each row below.
Detect dev tooling infrastructure and flag gaps. Analysis only. Does not install or configure tools.
Tooling review always operates at the project level since config files live at the project root. Scope parameters (diff commands, file lists) are accepted but ignored.
When called standalone, use the git repository root as the project root (fall back to the current working directory if not in a git repo).
Search for config files in the project root and subdirectories (exclude vendored directories like node_modules/, vendor/, .build/). Classify findings into five categories:
| Config file pattern | Tool |
|---|---|
| .eslintrc*, eslint.config.* | ESLint |
| biome.json, biome.jsonc | Biome (linter + formatter) |
| deno.json, deno.jsonc with lint config | Deno lint |
| .swiftlint.yml | SwiftLint |
| ruff.toml, [tool.ruff] in pyproject.toml | Ruff |
| .pylintrc, pylintrc | Pylint |
| .flake8, [flake8] in setup.cfg | Flake8 |
| .rubocop.yml | RuboCop |
| .golangci.yml, .golangci.yaml | golangci-lint |
| clippy.toml, .clippy.toml | Clippy |
| ktlint*, .editorconfig with ktlint | ktlint |
| Config file pattern | Tool |
|---|---|
| .prettierrc*, prettier.config.* | Prettier |
| biome.json, biome.jsonc | Biome (linter + formatter) |
| deno.json, deno.jsonc with fmt config | Deno fmt |
| .swift-format, .swiftformat | swift-format / SwiftFormat |
| [tool.black] in pyproject.toml, pyproject.toml with [tool.ruff.format] | Black / Ruff formatter |
| rustfmt.toml, .rustfmt.toml | rustfmt |
| gofmt / goimports (check CI config or Makefile for usage) | gofmt |
| .clang-format | ClangFormat |
| Config file pattern | Tool |
|---|---|
| .husky/ directory | Husky |
| .lintstagedrc*, lint-staged key in package.json | lint-staged |
| .pre-commit-config.yaml | pre-commit framework |
| .git/hooks/pre-commit (non-sample) | Custom git hook |
| .lefthook.yml, lefthook.yml | Lefthook |
| Config file pattern | Tool |
|---|---|
| jest.config.*, jest key in package.json | Jest |
| vitest.config.* | Vitest |
| pytest.ini, [tool.pytest] in pyproject.toml, conftest.py | pytest |
| Package.swift with test targets, *Tests/ directories | Swift Testing / XCTest |
| _test.go files | Go testing |
| Cargo.toml with [dev-dependencies], tests/ directory | Rust tests |
| .rspec, spec/ directory | RSpec |
| phpunit.xml* | PHPUnit |
| Config file pattern | Tool |
|---|---|
| .github/workflows/*.yml | GitHub Actions |
| .gitlab-ci.yml | GitLab CI |
| Jenkinsfile | Jenkins |
| .circleci/config.yml | CircleCI |
| bitbucket-pipelines.yml | Bitbucket Pipelines |
| .travis.yml | Travis CI |
| azure-pipelines.yml | Azure Pipelines |
These tables are not exhaustive. If the project uses a tool not listed here, detect it by recognizing its config files.
Determine the primary language(s) and ecosystem from config files and source code. This informs which tooling gaps are relevant. A Go project without Prettier is not a gap. A Node.js project without a linter is.
| Signal | Ecosystem |
|---|---|
| package.json | Node.js / JavaScript / TypeScript |
| Package.swift, *.xcodeproj | Swift / Apple |
| pyproject.toml, setup.py, requirements.txt | Python |
| go.mod | Go |
| Cargo.toml | Rust |
| Gemfile | Ruby |
| pom.xml, build.gradle* | Java / Kotlin |
| deno.json, deno.jsonc | Deno |
For each category, assess whether the project has adequate tooling for its ecosystem:
When assessing pre-commit hooks, also check whether detected linters and formatters are wired into the hooks. A project with ESLint and Prettier but no pre-commit hook means formatting issues can slip into commits.
When assessing CI/CD, check whether the pipeline runs tests and linters. A CI config that only builds but never tests is a gap.
Return findings as a numbered list. For each finding:
### [P<N>] <title (imperative, <=80 chars)>
**Category:** <Linters | Formatters | Pre-commit Hooks | Test Runners | CI/CD>
<one paragraph: what is missing or misconfigured and why it matters for this project>
After all findings, add:
## Tooling Summary
| Category | Status | Tool(s) |
|---|---|---|
| Linters | <Present/Partial/Missing> | <detected tools or "—"> |
| Formatters | <Present/Partial/Missing> | <detected tools or "—"> |
| Pre-commit Hooks | <Present/Partial/Missing> | <detected tools or "—"> |
| Test Runners | <Present/Partial/Missing> | <detected tools or "—"> |
| CI/CD | <Present/Partial/Missing> | <detected tools or "—"> |
## Overall Verdict
**Tooling:** <well-equipped | gaps found>
<1-3 sentence summary>
If all categories are adequately covered, report that and highlight what the project does well.
tools
Run autonomous task execution using the codex CLI. Use when the user asks to "codex exec", "run codex exec", "execute a task with codex", or "delegate to codex".
development
Run the post-implementation quality assurance workflow including tests, code polishing, review, and commit. Use when the user asks to "finalize implementation", "finalize changes", "wrap up implementation", "finish up", "ready to commit", or "run QA workflow".
development
Run the post-implementation quality assurance workflow including tests, code polishing, review, and commit. Use when the user asks to "finalize implementation", "finalize changes", "wrap up implementation", "finish up", "ready to commit", or "run QA workflow".
tools
Teach the user to deeply understand a change through interactive tutoring: restating understanding, drilling into why/what/how, and quizzing until mastery. The active counterpart to a one-shot explanation. Use when the user asks to "understand this change", "teach me this change", "help me understand what changed", "walk me through this change", "make sure I understand this", "quiz me on this", or "teach me what we did".