mirror of
https://github.com/affaan-m/everything-claude-code.git
synced 2026-06-16 16:36:53 +08:00
* feat(rules): add vue and nuxt rule sets Add rules/vue/ and rules/nuxt/, each with the standard 5-file layout (coding-style, hooks, patterns, security, testing) that extends common/, following the Adding a New Language convention in rules/README.md. Vue rules reference the frontend-patterns and vite-patterns skills. Nuxt rules reference the nuxt4-patterns and vite-patterns skills. Content is concise (1.5 to 4 KB per file) since rules load as always-on context. * fix(rules): address PR review on vue and nuxt rule sets - nuxt/coding-style: generalize the srcDir-override note (drop project-specific 'this repo' phrasing so it is correct for any Nuxt project). - vue/hooks: add **/*.ts and **/*.tsx to paths so the lint/typecheck guidance loads when editing composables and stores. - nuxt/hooks: add **/*.vue to paths (covers pages/layouts/components) and wrap nuxi typecheck in a timeout, mirroring web/hooks.md. - nuxt/security: tighten the /security-review auto-trigger scope to external fetch, credential handling, and sensitive mutations, with examples. - nuxt/testing: correct 'Vitest-only' to note built-in Playwright E2E, and drop the @nuxt/test-utils version pin. - README: register vue and nuxt in the structure tree and install examples. Skipped: 'X specific' -> 'X-specific' hyphenation (all existing rule sets use the unhyphenated form, changing only vue/nuxt would be inconsistent); repeating the 80%/TDD mandate in nuxt/testing (already inherited from common/testing.md).
2.0 KiB
2.0 KiB
paths
| paths | |
|---|---|
|
Vue Testing
This file extends common/testing.md with Vue specific content.
Stack
- Vitest (Vite-native runner) plus
@vue/test-utils.create-vuescaffolds@vitejs/plugin-vue. - DOM environment via
happy-domorjsdom, set invite.config.tsundertest.environment.
Rendering and Async
mountfor a full render.shallowMountto stub all child components.triggerandsetValuereturn promises,awaitthem.flushPromisesflushes resolved promise handlers.nextTicksettles the DOM after a state change.
What to Test
- Test the public interface only: props, emitted events, slots, rendered output.
- Do not assert private state or internal methods, and do not rely solely on snapshots.
Composables
- Composables that use only reactivity APIs unit-test directly: call the function, assert on the returned refs.
- Composables that use lifecycle hooks or
injectmust be tested through a host component.
Pinia
- In components:
createTestingPinia()from@pinia/testing, passed viaglobal.plugins. Actions are stubbed by default, setstubActions: falseto run them.createSpy: vi.fnis required under Vitest (no Jest globals). - In isolation:
beforeEach(() => setActivePinia(createPinia()))gives a fresh store per test and prevents state leakage.
Mount Config
global.plugins,global.stubs(stubsTransition/TransitionGroupby default),global.mocks(e.g.$router),global.provide(forinject, Symbol keys supported).RouterLinkStubstubsrouter-linkwithout mounting a full router.
const wrapper = mount(AuctionCard, {
props: { id: 1 },
global: { plugins: [createTestingPinia({ createSpy: vi.fn })] },
})
await wrapper.find('button').trigger('click')
expect(wrapper.emitted('bid')).toBeTruthy()
Reference
- ECC skills:
frontend-patterns,vite-patterns. - Docs: https://test-utils.vuejs.org/api/ · https://pinia.vuejs.org/cookbook/testing.html · https://vitest.dev/