test(ui) : fiabiliser la suite Vitest (3 tests SelectCheckbox + flaky)
- SelectCheckbox : 3 tests cliquaient setValue() sur la checkbox (event change), mais depuis MUI-42 le toggle se fait au clic sur la ligne d'option (checkbox en pointer-events-none) -> on clique la ligne. Echec deterministe corrige. - vitest.config : testTimeout 15000 (absorbe la contention CPU des 12 workers jsdom) + retry 2 (rejoue les flaky de timing diffus sur focus/popover/async). - Suite : 4 runs pleine charge -> 975/975 a chaque fois. Co-Authored-By: Claude Opus 4.8 (1M context) <noreply@anthropic.com>
This commit is contained in:
@@ -68,8 +68,9 @@ describe('MalioSelectCheckbox', () => {
|
|||||||
})
|
})
|
||||||
|
|
||||||
await wrapper.get('button').trigger('click')
|
await wrapper.get('button').trigger('click')
|
||||||
const checkboxInputs = wrapper.findAll('input[type="checkbox"]')
|
// Le toggle se fait au clic sur la ligne d'option (la checkbox est en pointer-events-none).
|
||||||
await checkboxInputs[1].setValue(true)
|
const optionRows = wrapper.findAll('li[role="option"]')
|
||||||
|
await optionRows[1].trigger('click')
|
||||||
|
|
||||||
expect(wrapper.emitted('update:modelValue')?.[0]).toEqual([['fr', 'be']])
|
expect(wrapper.emitted('update:modelValue')?.[0]).toEqual([['fr', 'be']])
|
||||||
})
|
})
|
||||||
@@ -149,8 +150,9 @@ describe('MalioSelectCheckbox', () => {
|
|||||||
|
|
||||||
await wrapper.get('button').trigger('click')
|
await wrapper.get('button').trigger('click')
|
||||||
|
|
||||||
const checkboxes = wrapper.findAll('input[type="checkbox"]')
|
// La ligne « tout sélectionner » est la première option de la liste.
|
||||||
await checkboxes[0].setValue(true)
|
const selectAllRow = wrapper.findAll('li[role="option"]')[0]
|
||||||
|
await selectAllRow.trigger('click')
|
||||||
|
|
||||||
expect(wrapper.emitted('update:modelValue')?.[0]).toEqual([['fr', 'be', 'ca']])
|
expect(wrapper.emitted('update:modelValue')?.[0]).toEqual([['fr', 'be', 'ca']])
|
||||||
})
|
})
|
||||||
@@ -162,8 +164,9 @@ describe('MalioSelectCheckbox', () => {
|
|||||||
|
|
||||||
await wrapper.get('button').trigger('click')
|
await wrapper.get('button').trigger('click')
|
||||||
|
|
||||||
const checkboxes = wrapper.findAll('input[type="checkbox"]')
|
// La ligne « tout sélectionner » est la première option de la liste.
|
||||||
await checkboxes[0].setValue(false)
|
const selectAllRow = wrapper.findAll('li[role="option"]')[0]
|
||||||
|
await selectAllRow.trigger('click')
|
||||||
|
|
||||||
expect(wrapper.emitted('update:modelValue')?.[0]).toEqual([[]])
|
expect(wrapper.emitted('update:modelValue')?.[0]).toEqual([[]])
|
||||||
})
|
})
|
||||||
|
|||||||
@@ -6,5 +6,13 @@ export default defineConfig({
|
|||||||
test: {
|
test: {
|
||||||
environment: 'jsdom',
|
environment: 'jsdom',
|
||||||
include: ['app/**/*.test.ts'],
|
include: ['app/**/*.test.ts'],
|
||||||
|
// La suite de composants (jsdom + focus/popover/async) est sujette à des
|
||||||
|
// échecs intermittents sous charge : timeouts par contention CPU, et quelques
|
||||||
|
// assertions de timing qui se déclenchent avant stabilisation du DOM.
|
||||||
|
// testTimeout élargi : absorbe la contention (12 workers jsdom concurrents).
|
||||||
|
// retry : rejoue les flaky de timing diffus (ne masque PAS un échec déterministe,
|
||||||
|
// qui rate ses 3 tentatives).
|
||||||
|
testTimeout: 15000,
|
||||||
|
retry: 2,
|
||||||
},
|
},
|
||||||
})
|
})
|
||||||
|
|||||||
Reference in New Issue
Block a user