- For navigating/exploring the workspace, invoke the
nx-workspaceskill first - it has patterns for querying projects, targets, and dependencies - For upgrading the Nx workspace version, invoke the
nx-migrate-workspaceskill -nx migrateone major at a time; after migrations finish, update backwards-compat CI, basic-test/e2e Node matrices,.nvmrc, root@types/node(major aligned with.nvmrc), andmainrequired status checks for.nvmrcNode from the version inpackage.json - When running tasks (for example build, lint, test, e2e, etc.), always prefer running the task through
nx(i.e.nx run,nx run-many,nx affected) instead of using the underlying tooling directly - Prefix nx commands with the workspace's package manager (e.g.,
pnpm nx build,npm exec nx test) - avoids using globally installed CLI - You have access to the Nx MCP server and its tools, use them to help the user
- For Nx plugin best practices, check
node_modules/@nx/<plugin>/PLUGIN.md. Not all plugins have this file - proceed without it if unavailable. - NEVER guess CLI flags - always check nx_docs or
--helpfirst when unsure
- For scaffolding tasks (creating apps, libs, project structure, setup), ALWAYS invoke the
nx-generateskill FIRST before exploring or calling MCP tools
- USE for: advanced config options, unfamiliar flags, migration guides, plugin configuration, edge cases
- DON'T USE for: basic generator syntax (
nx g @nx/react:app), standard commands, things you already know - The
nx-generateskill handles generator discovery internally - don't call nx_docs just to look up generator syntax
When creating or editing *.spec.ts / *.smoke.spec.ts files, follow .cursor/rules/tests-sifers.mdc:
- Every test starts with one
setup()call; setup returns all mocks/spies. - Never
jest.spyOn/ mock wiring insideit()ortest()blocks. - Never
beforeEach+ outerletfor per-test state. - Copy patterns from
engine.spec.ts,generator.spec.ts, orwrite-dist-folder-path-on-deploy-target-options.spec.ts.