agentic-qe 1.4.4 → 1.5.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.claude/agents/qe-api-contract-validator.md +133 -27
- package/.claude/agents/qe-api-contract-validator.md.backup +1148 -0
- package/.claude/agents/qe-api-contract-validator.md.backup-20251107-134747 +1148 -0
- package/.claude/agents/qe-api-contract-validator.md.backup-phase2-20251107-140039 +1123 -0
- package/.claude/agents/qe-chaos-engineer.md +142 -23
- package/.claude/agents/qe-chaos-engineer.md.backup +808 -0
- package/.claude/agents/qe-chaos-engineer.md.backup-20251107-134747 +808 -0
- package/.claude/agents/qe-chaos-engineer.md.backup-phase2-20251107-140039 +787 -0
- package/.claude/agents/qe-code-complexity.md +111 -23
- package/.claude/agents/qe-code-complexity.md.backup +291 -0
- package/.claude/agents/qe-code-complexity.md.backup-20251107-134747 +291 -0
- package/.claude/agents/qe-code-complexity.md.backup-phase2-20251107-140039 +286 -0
- package/.claude/agents/qe-coverage-analyzer.md +306 -30
- package/.claude/agents/qe-coverage-analyzer.md.backup +467 -0
- package/.claude/agents/qe-coverage-analyzer.md.backup-20251107-134747 +467 -0
- package/.claude/agents/qe-coverage-analyzer.md.backup-phase2-20251107-140039 +438 -0
- package/.claude/agents/qe-deployment-readiness.md +84 -28
- package/.claude/agents/qe-deployment-readiness.md.backup +1166 -0
- package/.claude/agents/qe-deployment-readiness.md.backup-20251107-134747 +1166 -0
- package/.claude/agents/qe-deployment-readiness.md.backup-phase2-20251107-140039 +1140 -0
- package/.claude/agents/qe-flaky-test-hunter.md +277 -35
- package/.claude/agents/qe-flaky-test-hunter.md.backup +1195 -0
- package/.claude/agents/qe-flaky-test-hunter.md.backup-20251107-134747 +1195 -0
- package/.claude/agents/qe-flaky-test-hunter.md.backup-phase2-20251107-140039 +1162 -0
- package/.claude/agents/qe-fleet-commander.md +126 -23
- package/.claude/agents/qe-fleet-commander.md.backup +718 -0
- package/.claude/agents/qe-fleet-commander.md.backup-20251107-134747 +718 -0
- package/.claude/agents/qe-fleet-commander.md.backup-phase2-20251107-140039 +697 -0
- package/.claude/agents/qe-performance-tester.md +314 -57
- package/.claude/agents/qe-performance-tester.md.backup +428 -0
- package/.claude/agents/qe-performance-tester.md.backup-20251107-134747 +428 -0
- package/.claude/agents/qe-performance-tester.md.backup-phase2-20251107-140039 +372 -0
- package/.claude/agents/qe-production-intelligence.md +126 -27
- package/.claude/agents/qe-production-intelligence.md.backup +1219 -0
- package/.claude/agents/qe-production-intelligence.md.backup-20251107-134747 +1219 -0
- package/.claude/agents/qe-production-intelligence.md.backup-phase2-20251107-140039 +1194 -0
- package/.claude/agents/qe-quality-analyzer.md +127 -32
- package/.claude/agents/qe-quality-analyzer.md.backup +425 -0
- package/.claude/agents/qe-quality-analyzer.md.backup-20251107-134747 +425 -0
- package/.claude/agents/qe-quality-analyzer.md.backup-phase2-20251107-140039 +394 -0
- package/.claude/agents/qe-quality-gate.md +148 -33
- package/.claude/agents/qe-quality-gate.md.backup +446 -0
- package/.claude/agents/qe-quality-gate.md.backup-20251107-134747 +446 -0
- package/.claude/agents/qe-quality-gate.md.backup-phase2-20251107-140039 +415 -0
- package/.claude/agents/qe-regression-risk-analyzer.md +78 -27
- package/.claude/agents/qe-regression-risk-analyzer.md.backup +1009 -0
- package/.claude/agents/qe-regression-risk-analyzer.md.backup-20251107-134747 +1009 -0
- package/.claude/agents/qe-regression-risk-analyzer.md.backup-phase2-20251107-140039 +984 -0
- package/.claude/agents/qe-requirements-validator.md +131 -27
- package/.claude/agents/qe-requirements-validator.md.backup +748 -0
- package/.claude/agents/qe-requirements-validator.md.backup-20251107-134747 +748 -0
- package/.claude/agents/qe-requirements-validator.md.backup-phase2-20251107-140039 +723 -0
- package/.claude/agents/qe-security-scanner.md +137 -62
- package/.claude/agents/qe-security-scanner.md.backup +634 -0
- package/.claude/agents/qe-security-scanner.md.backup-20251107-134747 +634 -0
- package/.claude/agents/qe-security-scanner.md.backup-phase2-20251107-140039 +573 -0
- package/.claude/agents/qe-test-data-architect.md +129 -26
- package/.claude/agents/qe-test-data-architect.md.backup +1064 -0
- package/.claude/agents/qe-test-data-architect.md.backup-20251107-134747 +1064 -0
- package/.claude/agents/qe-test-data-architect.md.backup-phase2-20251107-140039 +1040 -0
- package/.claude/agents/qe-test-executor.md +165 -21
- package/.claude/agents/qe-test-executor.md.backup +389 -0
- package/.claude/agents/qe-test-executor.md.backup-20251107-134747 +389 -0
- package/.claude/agents/qe-test-executor.md.backup-phase2-20251107-140039 +369 -0
- package/.claude/agents/qe-test-generator.md +379 -34
- package/.claude/agents/qe-test-generator.md.backup +997 -0
- package/.claude/agents/qe-test-generator.md.backup-20251107-134747 +997 -0
- package/.claude/agents/qe-visual-tester.md +236 -23
- package/.claude/agents/qe-visual-tester.md.backup +777 -0
- package/.claude/agents/qe-visual-tester.md.backup-20251107-134747 +777 -0
- package/.claude/agents/qe-visual-tester.md.backup-phase2-20251107-140039 +756 -0
- package/.claude/agents/subagents/qe-code-reviewer.md +59 -0
- package/.claude/agents/subagents/qe-data-generator.md +60 -0
- package/.claude/agents/subagents/qe-integration-tester.md +77 -0
- package/.claude/agents/subagents/qe-performance-validator.md +55 -0
- package/.claude/agents/subagents/qe-security-auditor.md +51 -0
- package/.claude/agents/subagents/qe-test-implementer.md +371 -0
- package/.claude/agents/subagents/qe-test-refactorer.md +510 -0
- package/.claude/agents/subagents/qe-test-writer.md +603 -0
- package/.claude/skills/accessibility-testing/SKILL.md +764 -777
- package/.claude/skills/agentic-quality-engineering/SKILL.md +0 -6
- package/.claude/skills/api-testing-patterns/SKILL.md +0 -12
- package/.claude/skills/bug-reporting-excellence/SKILL.md +0 -6
- package/.claude/skills/chaos-engineering-resilience/SKILL.md +0 -6
- package/.claude/skills/code-review-quality/SKILL.md +0 -6
- package/.claude/skills/compatibility-testing/SKILL.md +0 -6
- package/.claude/skills/compliance-testing/SKILL.md +0 -6
- package/.claude/skills/consultancy-practices/SKILL.md +0 -6
- package/.claude/skills/context-driven-testing/SKILL.md +0 -6
- package/.claude/skills/contract-testing/SKILL.md +0 -6
- package/.claude/skills/database-testing/SKILL.md +0 -6
- package/.claude/skills/exploratory-testing-advanced/SKILL.md +0 -6
- package/.claude/skills/holistic-testing-pact/SKILL.md +0 -6
- package/.claude/skills/localization-testing/SKILL.md +0 -6
- package/.claude/skills/mobile-testing/SKILL.md +535 -548
- package/.claude/skills/mutation-testing/SKILL.md +0 -6
- package/.claude/skills/performance-testing/SKILL.md +0 -6
- package/.claude/skills/quality-metrics/SKILL.md +0 -12
- package/.claude/skills/refactoring-patterns/SKILL.md +0 -6
- package/.claude/skills/regression-testing/SKILL.md +1033 -1045
- package/.claude/skills/risk-based-testing/SKILL.md +0 -12
- package/.claude/skills/security-testing/SKILL.md +0 -6
- package/.claude/skills/shift-left-testing/SKILL.md +529 -535
- package/.claude/skills/shift-right-testing/SKILL.md +585 -591
- package/.claude/skills/tdd-london-chicago/SKILL.md +0 -6
- package/.claude/skills/technical-writing/SKILL.md +0 -6
- package/.claude/skills/test-automation-strategy/SKILL.md +0 -6
- package/.claude/skills/test-data-management/SKILL.md +1054 -1067
- package/.claude/skills/test-design-techniques/SKILL.md +0 -6
- package/.claude/skills/test-environment-management/SKILL.md +0 -6
- package/.claude/skills/test-reporting-analytics/SKILL.md +0 -6
- package/.claude/skills/visual-testing-advanced/SKILL.md +0 -6
- package/.claude/skills/xp-practices/SKILL.md +0 -6
- package/CHANGELOG.md +426 -5
- package/README.md +24 -19
- package/dist/cli/commands/init.d.ts +4 -0
- package/dist/cli/commands/init.d.ts.map +1 -1
- package/dist/cli/commands/init.js +97 -44
- package/dist/cli/commands/init.js.map +1 -1
- package/dist/mcp/handlers/coordination/index.d.ts +14 -14
- package/dist/mcp/handlers/coordination/index.d.ts.map +1 -1
- package/dist/mcp/handlers/coordination/index.js +14 -14
- package/dist/mcp/handlers/coordination/index.js.map +1 -1
- package/dist/mcp/handlers/phase2/Phase2Tools.d.ts.map +1 -1
- package/dist/mcp/handlers/phase2/Phase2Tools.js +39 -10
- package/dist/mcp/handlers/phase2/Phase2Tools.js.map +1 -1
- package/dist/mcp/handlers/phase3/Phase3DomainTools.d.ts +63 -0
- package/dist/mcp/handlers/phase3/Phase3DomainTools.d.ts.map +1 -0
- package/dist/mcp/handlers/phase3/Phase3DomainTools.js +885 -0
- package/dist/mcp/handlers/phase3/Phase3DomainTools.js.map +1 -0
- package/dist/mcp/handlers/phase3/index.d.ts +6 -0
- package/dist/mcp/handlers/phase3/index.d.ts.map +1 -0
- package/dist/mcp/handlers/phase3/index.js +10 -0
- package/dist/mcp/handlers/phase3/index.js.map +1 -0
- package/dist/mcp/handlers/prediction/index.d.ts +10 -10
- package/dist/mcp/handlers/prediction/index.d.ts.map +1 -1
- package/dist/mcp/handlers/prediction/index.js +10 -10
- package/dist/mcp/handlers/prediction/index.js.map +1 -1
- package/dist/mcp/handlers/security/check-authz.d.ts +152 -0
- package/dist/mcp/handlers/security/check-authz.d.ts.map +1 -0
- package/dist/mcp/handlers/security/check-authz.js +434 -0
- package/dist/mcp/handlers/security/check-authz.js.map +1 -0
- package/dist/mcp/handlers/security/generate-report.d.ts +156 -0
- package/dist/mcp/handlers/security/generate-report.d.ts.map +1 -0
- package/dist/mcp/handlers/security/generate-report.js +469 -0
- package/dist/mcp/handlers/security/generate-report.js.map +1 -0
- package/dist/mcp/handlers/security/index.d.ts +80 -0
- package/dist/mcp/handlers/security/index.d.ts.map +1 -0
- package/dist/mcp/handlers/security/index.js +91 -0
- package/dist/mcp/handlers/security/index.js.map +1 -0
- package/dist/mcp/handlers/security/scan-comprehensive.d.ts +66 -0
- package/dist/mcp/handlers/security/scan-comprehensive.d.ts.map +1 -0
- package/dist/mcp/handlers/security/scan-comprehensive.js +296 -0
- package/dist/mcp/handlers/security/scan-comprehensive.js.map +1 -0
- package/dist/mcp/handlers/security/scan-dependencies.d.ts +148 -0
- package/dist/mcp/handlers/security/scan-dependencies.d.ts.map +1 -0
- package/dist/mcp/handlers/security/scan-dependencies.js +354 -0
- package/dist/mcp/handlers/security/scan-dependencies.js.map +1 -0
- package/dist/mcp/handlers/security/validate-auth.d.ts +128 -0
- package/dist/mcp/handlers/security/validate-auth.d.ts.map +1 -0
- package/dist/mcp/handlers/security/validate-auth.js +294 -0
- package/dist/mcp/handlers/security/validate-auth.js.map +1 -0
- package/dist/mcp/handlers/test/generate-integration-tests.d.ts +95 -0
- package/dist/mcp/handlers/test/generate-integration-tests.d.ts.map +1 -0
- package/dist/mcp/handlers/test/generate-integration-tests.js +286 -0
- package/dist/mcp/handlers/test/generate-integration-tests.js.map +1 -0
- package/dist/mcp/handlers/test/generate-unit-tests.d.ts +89 -0
- package/dist/mcp/handlers/test/generate-unit-tests.d.ts.map +1 -0
- package/dist/mcp/handlers/test/generate-unit-tests.js +273 -0
- package/dist/mcp/handlers/test/generate-unit-tests.js.map +1 -0
- package/dist/mcp/handlers/test/optimize-test-suite.d.ts +97 -0
- package/dist/mcp/handlers/test/optimize-test-suite.d.ts.map +1 -0
- package/dist/mcp/handlers/test/optimize-test-suite.js +282 -0
- package/dist/mcp/handlers/test/optimize-test-suite.js.map +1 -0
- package/dist/mcp/server.d.ts.map +1 -1
- package/dist/mcp/server.js +211 -0
- package/dist/mcp/server.js.map +1 -1
- package/dist/mcp/tools/deprecated.d.ts +1390 -0
- package/dist/mcp/tools/deprecated.d.ts.map +1 -0
- package/dist/mcp/tools/deprecated.js +859 -0
- package/dist/mcp/tools/deprecated.js.map +1 -0
- package/dist/mcp/tools/qe/api-contract/index.d.ts +138 -0
- package/dist/mcp/tools/qe/api-contract/index.d.ts.map +1 -0
- package/dist/mcp/tools/qe/api-contract/index.js +572 -0
- package/dist/mcp/tools/qe/api-contract/index.js.map +1 -0
- package/dist/mcp/tools/qe/code-quality/analyze-complexity.d.ts +110 -0
- package/dist/mcp/tools/qe/code-quality/analyze-complexity.d.ts.map +1 -0
- package/dist/mcp/tools/qe/code-quality/analyze-complexity.js +381 -0
- package/dist/mcp/tools/qe/code-quality/analyze-complexity.js.map +1 -0
- package/dist/mcp/tools/qe/code-quality/calculate-quality-metrics.d.ts +115 -0
- package/dist/mcp/tools/qe/code-quality/calculate-quality-metrics.d.ts.map +1 -0
- package/dist/mcp/tools/qe/code-quality/calculate-quality-metrics.js +461 -0
- package/dist/mcp/tools/qe/code-quality/calculate-quality-metrics.js.map +1 -0
- package/dist/mcp/tools/qe/code-quality/index.d.ts +12 -0
- package/dist/mcp/tools/qe/code-quality/index.d.ts.map +1 -0
- package/dist/mcp/tools/qe/code-quality/index.js +30 -0
- package/dist/mcp/tools/qe/code-quality/index.js.map +1 -0
- package/dist/mcp/tools/qe/coverage/analyze-with-risk-scoring.d.ts +58 -0
- package/dist/mcp/tools/qe/coverage/analyze-with-risk-scoring.d.ts.map +1 -0
- package/dist/mcp/tools/qe/coverage/analyze-with-risk-scoring.js +172 -0
- package/dist/mcp/tools/qe/coverage/analyze-with-risk-scoring.js.map +1 -0
- package/dist/mcp/tools/qe/coverage/calculate-trends.d.ts +73 -0
- package/dist/mcp/tools/qe/coverage/calculate-trends.d.ts.map +1 -0
- package/dist/mcp/tools/qe/coverage/calculate-trends.js +240 -0
- package/dist/mcp/tools/qe/coverage/calculate-trends.js.map +1 -0
- package/dist/mcp/tools/qe/coverage/detect-gaps-ml.d.ts +38 -0
- package/dist/mcp/tools/qe/coverage/detect-gaps-ml.d.ts.map +1 -0
- package/dist/mcp/tools/qe/coverage/detect-gaps-ml.js +204 -0
- package/dist/mcp/tools/qe/coverage/detect-gaps-ml.js.map +1 -0
- package/dist/mcp/tools/qe/coverage/index.d.ts +12 -0
- package/dist/mcp/tools/qe/coverage/index.d.ts.map +1 -0
- package/dist/mcp/tools/qe/coverage/index.js +23 -0
- package/dist/mcp/tools/qe/coverage/index.js.map +1 -0
- package/dist/mcp/tools/qe/coverage/recommend-tests.d.ts +46 -0
- package/dist/mcp/tools/qe/coverage/recommend-tests.d.ts.map +1 -0
- package/dist/mcp/tools/qe/coverage/recommend-tests.js +248 -0
- package/dist/mcp/tools/qe/coverage/recommend-tests.js.map +1 -0
- package/dist/mcp/tools/qe/flaky-detection/analyze-patterns.d.ts +179 -0
- package/dist/mcp/tools/qe/flaky-detection/analyze-patterns.d.ts.map +1 -0
- package/dist/mcp/tools/qe/flaky-detection/analyze-patterns.js +554 -0
- package/dist/mcp/tools/qe/flaky-detection/analyze-patterns.js.map +1 -0
- package/dist/mcp/tools/qe/flaky-detection/detect-statistical.d.ts +172 -0
- package/dist/mcp/tools/qe/flaky-detection/detect-statistical.d.ts.map +1 -0
- package/dist/mcp/tools/qe/flaky-detection/detect-statistical.js +498 -0
- package/dist/mcp/tools/qe/flaky-detection/detect-statistical.js.map +1 -0
- package/dist/mcp/tools/qe/flaky-detection/index.d.ts +35 -0
- package/dist/mcp/tools/qe/flaky-detection/index.d.ts.map +1 -0
- package/dist/mcp/tools/qe/flaky-detection/index.js +66 -0
- package/dist/mcp/tools/qe/flaky-detection/index.js.map +1 -0
- package/dist/mcp/tools/qe/flaky-detection/stabilize-auto.d.ts +159 -0
- package/dist/mcp/tools/qe/flaky-detection/stabilize-auto.d.ts.map +1 -0
- package/dist/mcp/tools/qe/flaky-detection/stabilize-auto.js +462 -0
- package/dist/mcp/tools/qe/flaky-detection/stabilize-auto.js.map +1 -0
- package/dist/mcp/tools/qe/fleet/index.d.ts +422 -0
- package/dist/mcp/tools/qe/fleet/index.d.ts.map +1 -0
- package/dist/mcp/tools/qe/fleet/index.js +652 -0
- package/dist/mcp/tools/qe/fleet/index.js.map +1 -0
- package/dist/mcp/tools/qe/performance/analyze-bottlenecks.d.ts +180 -0
- package/dist/mcp/tools/qe/performance/analyze-bottlenecks.d.ts.map +1 -0
- package/dist/mcp/tools/qe/performance/analyze-bottlenecks.js +347 -0
- package/dist/mcp/tools/qe/performance/analyze-bottlenecks.js.map +1 -0
- package/dist/mcp/tools/qe/performance/generate-report.d.ts +146 -0
- package/dist/mcp/tools/qe/performance/generate-report.d.ts.map +1 -0
- package/dist/mcp/tools/qe/performance/generate-report.js +354 -0
- package/dist/mcp/tools/qe/performance/generate-report.js.map +1 -0
- package/dist/mcp/tools/qe/performance/index.d.ts +13 -0
- package/dist/mcp/tools/qe/performance/index.d.ts.map +1 -0
- package/dist/mcp/tools/qe/performance/index.js +24 -0
- package/dist/mcp/tools/qe/performance/index.js.map +1 -0
- package/dist/mcp/tools/qe/performance/monitor-realtime.d.ts +120 -0
- package/dist/mcp/tools/qe/performance/monitor-realtime.d.ts.map +1 -0
- package/dist/mcp/tools/qe/performance/monitor-realtime.js +215 -0
- package/dist/mcp/tools/qe/performance/monitor-realtime.js.map +1 -0
- package/dist/mcp/tools/qe/performance/run-benchmark.d.ts +68 -0
- package/dist/mcp/tools/qe/performance/run-benchmark.d.ts.map +1 -0
- package/dist/mcp/tools/qe/performance/run-benchmark.js +120 -0
- package/dist/mcp/tools/qe/performance/run-benchmark.js.map +1 -0
- package/dist/mcp/tools/qe/quality-gates/assess-deployment-risk.d.ts +239 -0
- package/dist/mcp/tools/qe/quality-gates/assess-deployment-risk.d.ts.map +1 -0
- package/dist/mcp/tools/qe/quality-gates/assess-deployment-risk.js +671 -0
- package/dist/mcp/tools/qe/quality-gates/assess-deployment-risk.js.map +1 -0
- package/dist/mcp/tools/qe/quality-gates/evaluate-quality-gate.d.ts +219 -0
- package/dist/mcp/tools/qe/quality-gates/evaluate-quality-gate.d.ts.map +1 -0
- package/dist/mcp/tools/qe/quality-gates/evaluate-quality-gate.js +732 -0
- package/dist/mcp/tools/qe/quality-gates/evaluate-quality-gate.js.map +1 -0
- package/dist/mcp/tools/qe/quality-gates/generate-quality-report.d.ts +447 -0
- package/dist/mcp/tools/qe/quality-gates/generate-quality-report.d.ts.map +1 -0
- package/dist/mcp/tools/qe/quality-gates/generate-quality-report.js +551 -0
- package/dist/mcp/tools/qe/quality-gates/generate-quality-report.js.map +1 -0
- package/dist/mcp/tools/qe/quality-gates/index.d.ts +40 -0
- package/dist/mcp/tools/qe/quality-gates/index.d.ts.map +1 -0
- package/dist/mcp/tools/qe/quality-gates/index.js +56 -0
- package/dist/mcp/tools/qe/quality-gates/index.js.map +1 -0
- package/dist/mcp/tools/qe/quality-gates/validate-quality-metrics.d.ts +226 -0
- package/dist/mcp/tools/qe/quality-gates/validate-quality-metrics.d.ts.map +1 -0
- package/dist/mcp/tools/qe/quality-gates/validate-quality-metrics.js +603 -0
- package/dist/mcp/tools/qe/quality-gates/validate-quality-metrics.js.map +1 -0
- package/dist/mcp/tools/qe/regression/analyze-risk.d.ts +212 -0
- package/dist/mcp/tools/qe/regression/analyze-risk.d.ts.map +1 -0
- package/dist/mcp/tools/qe/regression/analyze-risk.js +617 -0
- package/dist/mcp/tools/qe/regression/analyze-risk.js.map +1 -0
- package/dist/mcp/tools/qe/regression/index.d.ts +36 -0
- package/dist/mcp/tools/qe/regression/index.d.ts.map +1 -0
- package/dist/mcp/tools/qe/regression/index.js +63 -0
- package/dist/mcp/tools/qe/regression/index.js.map +1 -0
- package/dist/mcp/tools/qe/regression/select-tests.d.ts +241 -0
- package/dist/mcp/tools/qe/regression/select-tests.d.ts.map +1 -0
- package/dist/mcp/tools/qe/regression/select-tests.js +601 -0
- package/dist/mcp/tools/qe/regression/select-tests.js.map +1 -0
- package/dist/mcp/tools/qe/requirements/generate-bdd-scenarios.d.ts +134 -0
- package/dist/mcp/tools/qe/requirements/generate-bdd-scenarios.d.ts.map +1 -0
- package/dist/mcp/tools/qe/requirements/generate-bdd-scenarios.js +737 -0
- package/dist/mcp/tools/qe/requirements/generate-bdd-scenarios.js.map +1 -0
- package/dist/mcp/tools/qe/requirements/index.d.ts +40 -0
- package/dist/mcp/tools/qe/requirements/index.d.ts.map +1 -0
- package/dist/mcp/tools/qe/requirements/index.js +84 -0
- package/dist/mcp/tools/qe/requirements/index.js.map +1 -0
- package/dist/mcp/tools/qe/requirements/validate-requirements.d.ts +196 -0
- package/dist/mcp/tools/qe/requirements/validate-requirements.d.ts.map +1 -0
- package/dist/mcp/tools/qe/requirements/validate-requirements.js +740 -0
- package/dist/mcp/tools/qe/requirements/validate-requirements.js.map +1 -0
- package/dist/mcp/tools/qe/security/detect-vulnerabilities.d.ts +300 -0
- package/dist/mcp/tools/qe/security/detect-vulnerabilities.d.ts.map +1 -0
- package/dist/mcp/tools/qe/security/detect-vulnerabilities.js +492 -0
- package/dist/mcp/tools/qe/security/detect-vulnerabilities.js.map +1 -0
- package/dist/mcp/tools/qe/security/index.d.ts +34 -0
- package/dist/mcp/tools/qe/security/index.d.ts.map +1 -0
- package/dist/mcp/tools/qe/security/index.js +44 -0
- package/dist/mcp/tools/qe/security/index.js.map +1 -0
- package/dist/mcp/tools/qe/security/scan-comprehensive.d.ts +240 -0
- package/dist/mcp/tools/qe/security/scan-comprehensive.d.ts.map +1 -0
- package/dist/mcp/tools/qe/security/scan-comprehensive.js +557 -0
- package/dist/mcp/tools/qe/security/scan-comprehensive.js.map +1 -0
- package/dist/mcp/tools/qe/security/validate-compliance.d.ts +299 -0
- package/dist/mcp/tools/qe/security/validate-compliance.d.ts.map +1 -0
- package/dist/mcp/tools/qe/security/validate-compliance.js +517 -0
- package/dist/mcp/tools/qe/security/validate-compliance.js.map +1 -0
- package/dist/mcp/tools/qe/shared/types.d.ts +840 -0
- package/dist/mcp/tools/qe/shared/types.d.ts.map +1 -0
- package/dist/mcp/tools/qe/shared/types.js +13 -0
- package/dist/mcp/tools/qe/shared/types.js.map +1 -0
- package/dist/mcp/tools/qe/test-data/analyze-schema.d.ts +264 -0
- package/dist/mcp/tools/qe/test-data/analyze-schema.d.ts.map +1 -0
- package/dist/mcp/tools/qe/test-data/analyze-schema.js +553 -0
- package/dist/mcp/tools/qe/test-data/analyze-schema.js.map +1 -0
- package/dist/mcp/tools/qe/test-data/generate-test-data.d.ts +167 -0
- package/dist/mcp/tools/qe/test-data/generate-test-data.d.ts.map +1 -0
- package/dist/mcp/tools/qe/test-data/generate-test-data.js +336 -0
- package/dist/mcp/tools/qe/test-data/generate-test-data.js.map +1 -0
- package/dist/mcp/tools/qe/test-data/index.d.ts +44 -0
- package/dist/mcp/tools/qe/test-data/index.d.ts.map +1 -0
- package/dist/mcp/tools/qe/test-data/index.js +90 -0
- package/dist/mcp/tools/qe/test-data/index.js.map +1 -0
- package/dist/mcp/tools/qe/test-data/mask-sensitive-data.d.ts +165 -0
- package/dist/mcp/tools/qe/test-data/mask-sensitive-data.d.ts.map +1 -0
- package/dist/mcp/tools/qe/test-data/mask-sensitive-data.js +342 -0
- package/dist/mcp/tools/qe/test-data/mask-sensitive-data.js.map +1 -0
- package/dist/mcp/tools/qe/test-generation/analyze-test-quality.d.ts +144 -0
- package/dist/mcp/tools/qe/test-generation/analyze-test-quality.d.ts.map +1 -0
- package/dist/mcp/tools/qe/test-generation/analyze-test-quality.js +432 -0
- package/dist/mcp/tools/qe/test-generation/analyze-test-quality.js.map +1 -0
- package/dist/mcp/tools/qe/test-generation/generate-integration-tests.d.ts +98 -0
- package/dist/mcp/tools/qe/test-generation/generate-integration-tests.d.ts.map +1 -0
- package/dist/mcp/tools/qe/test-generation/generate-integration-tests.js +459 -0
- package/dist/mcp/tools/qe/test-generation/generate-integration-tests.js.map +1 -0
- package/dist/mcp/tools/qe/test-generation/generate-unit-tests.d.ts +83 -0
- package/dist/mcp/tools/qe/test-generation/generate-unit-tests.d.ts.map +1 -0
- package/dist/mcp/tools/qe/test-generation/generate-unit-tests.js +483 -0
- package/dist/mcp/tools/qe/test-generation/generate-unit-tests.js.map +1 -0
- package/dist/mcp/tools/qe/test-generation/index.d.ts +56 -0
- package/dist/mcp/tools/qe/test-generation/index.d.ts.map +1 -0
- package/dist/mcp/tools/qe/test-generation/index.js +97 -0
- package/dist/mcp/tools/qe/test-generation/index.js.map +1 -0
- package/dist/mcp/tools/qe/test-generation/optimize-test-suite.d.ts +124 -0
- package/dist/mcp/tools/qe/test-generation/optimize-test-suite.d.ts.map +1 -0
- package/dist/mcp/tools/qe/test-generation/optimize-test-suite.js +362 -0
- package/dist/mcp/tools/qe/test-generation/optimize-test-suite.js.map +1 -0
- package/dist/mcp/tools/qe/visual/compare-screenshots.d.ts +119 -0
- package/dist/mcp/tools/qe/visual/compare-screenshots.d.ts.map +1 -0
- package/dist/mcp/tools/qe/visual/compare-screenshots.js +280 -0
- package/dist/mcp/tools/qe/visual/compare-screenshots.js.map +1 -0
- package/dist/mcp/tools/qe/visual/detect-regression.d.ts +138 -0
- package/dist/mcp/tools/qe/visual/detect-regression.d.ts.map +1 -0
- package/dist/mcp/tools/qe/visual/detect-regression.js +271 -0
- package/dist/mcp/tools/qe/visual/detect-regression.js.map +1 -0
- package/dist/mcp/tools/qe/visual/index.d.ts +16 -0
- package/dist/mcp/tools/qe/visual/index.d.ts.map +1 -0
- package/dist/mcp/tools/qe/visual/index.js +22 -0
- package/dist/mcp/tools/qe/visual/index.js.map +1 -0
- package/dist/mcp/tools/qe/visual/validate-accessibility.d.ts +276 -0
- package/dist/mcp/tools/qe/visual/validate-accessibility.d.ts.map +1 -0
- package/dist/mcp/tools/qe/visual/validate-accessibility.js +413 -0
- package/dist/mcp/tools/qe/visual/validate-accessibility.js.map +1 -0
- package/dist/mcp/tools.d.ts +44 -0
- package/dist/mcp/tools.d.ts.map +1 -1
- package/dist/mcp/tools.js +1980 -1
- package/dist/mcp/tools.js.map +1 -1
- package/package.json +2 -2
- package/dist/learning/__mocks__/LearningEngine.d.ts +0 -39
- package/dist/learning/__mocks__/LearningEngine.d.ts.map +0 -1
- package/dist/learning/__mocks__/LearningEngine.js +0 -116
- package/dist/learning/__mocks__/LearningEngine.js.map +0 -1
- package/dist/utils/__mocks__/Database.d.ts +0 -85
- package/dist/utils/__mocks__/Database.d.ts.map +0 -1
- package/dist/utils/__mocks__/Database.js +0 -125
- package/dist/utils/__mocks__/Database.js.map +0 -1
- package/dist/utils/__mocks__/Logger.d.ts +0 -26
- package/dist/utils/__mocks__/Logger.d.ts.map +0 -1
- package/dist/utils/__mocks__/Logger.js +0 -44
- package/dist/utils/__mocks__/Logger.js.map +0 -1
|
@@ -1,777 +1,764 @@
|
|
|
1
|
-
---
|
|
2
|
-
name: accessibility-testing
|
|
3
|
-
description: WCAG 2.2 compliance testing, screen reader validation, and inclusive design verification. Use when ensuring legal compliance (ADA, Section 508), testing for disabilities, or building accessible applications for 1 billion disabled users globally.
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
**
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
##
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
**
|
|
32
|
-
-
|
|
33
|
-
-
|
|
34
|
-
- **
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
**
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
**
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
-
|
|
57
|
-
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
|
|
155
|
-
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
|
|
165
|
-
|
|
166
|
-
|
|
167
|
-
|
|
168
|
-
|
|
169
|
-
|
|
170
|
-
|
|
171
|
-
|
|
172
|
-
|
|
173
|
-
|
|
174
|
-
|
|
175
|
-
|
|
176
|
-
|
|
177
|
-
|
|
178
|
-
|
|
179
|
-
|
|
180
|
-
|
|
181
|
-
|
|
182
|
-
|
|
183
|
-
|
|
184
|
-
|
|
185
|
-
|
|
186
|
-
|
|
187
|
-
|
|
188
|
-
|
|
189
|
-
|
|
190
|
-
|
|
191
|
-
|
|
192
|
-
|
|
193
|
-
|
|
194
|
-
|
|
195
|
-
|
|
196
|
-
|
|
197
|
-
|
|
198
|
-
|
|
199
|
-
|
|
200
|
-
|
|
201
|
-
|
|
202
|
-
|
|
203
|
-
|
|
204
|
-
|
|
205
|
-
|
|
206
|
-
|
|
207
|
-
|
|
208
|
-
|
|
209
|
-
|
|
210
|
-
|
|
211
|
-
|
|
212
|
-
|
|
213
|
-
|
|
214
|
-
|
|
215
|
-
|
|
216
|
-
|
|
217
|
-
|
|
218
|
-
|
|
219
|
-
|
|
220
|
-
|
|
221
|
-
|
|
222
|
-
|
|
223
|
-
|
|
224
|
-
|
|
225
|
-
|
|
226
|
-
|
|
227
|
-
|
|
228
|
-
|
|
229
|
-
|
|
230
|
-
|
|
231
|
-
|
|
232
|
-
|
|
233
|
-
|
|
234
|
-
|
|
235
|
-
|
|
236
|
-
|
|
237
|
-
|
|
238
|
-
|
|
239
|
-
|
|
240
|
-
|
|
241
|
-
|
|
242
|
-
-
|
|
243
|
-
|
|
244
|
-
|
|
245
|
-
|
|
246
|
-
|
|
247
|
-
|
|
248
|
-
|
|
249
|
-
|
|
250
|
-
|
|
251
|
-
|
|
252
|
-
```
|
|
253
|
-
|
|
254
|
-
|
|
255
|
-
|
|
256
|
-
|
|
257
|
-
|
|
258
|
-
|
|
259
|
-
|
|
260
|
-
|
|
261
|
-
|
|
262
|
-
|
|
263
|
-
|
|
264
|
-
|
|
265
|
-
|
|
266
|
-
|
|
267
|
-
|
|
268
|
-
|
|
269
|
-
|
|
270
|
-
5
|
|
271
|
-
|
|
272
|
-
|
|
273
|
-
|
|
274
|
-
|
|
275
|
-
|
|
276
|
-
|
|
277
|
-
|
|
278
|
-
|
|
279
|
-
|
|
280
|
-
|
|
281
|
-
|
|
282
|
-
|
|
283
|
-
|
|
284
|
-
|
|
285
|
-
|
|
286
|
-
|
|
287
|
-
|
|
288
|
-
|
|
289
|
-
|
|
290
|
-
|
|
291
|
-
|
|
292
|
-
|
|
293
|
-
|
|
294
|
-
|
|
295
|
-
|
|
296
|
-
|
|
297
|
-
|
|
298
|
-
|
|
299
|
-
|
|
300
|
-
|
|
301
|
-
|
|
302
|
-
|
|
303
|
-
|
|
304
|
-
|
|
305
|
-
|
|
306
|
-
|
|
307
|
-
|
|
308
|
-
|
|
309
|
-
|
|
310
|
-
|
|
311
|
-
|
|
312
|
-
|
|
313
|
-
|
|
314
|
-
|
|
315
|
-
|
|
316
|
-
|
|
317
|
-
|
|
318
|
-
|
|
319
|
-
|
|
320
|
-
|
|
321
|
-
|
|
322
|
-
|
|
323
|
-
|
|
324
|
-
|
|
325
|
-
|
|
326
|
-
|
|
327
|
-
|
|
328
|
-
|
|
329
|
-
|
|
330
|
-
|
|
331
|
-
|
|
332
|
-
```
|
|
333
|
-
|
|
334
|
-
|
|
335
|
-
|
|
336
|
-
|
|
337
|
-
|
|
338
|
-
|
|
339
|
-
|
|
340
|
-
|
|
341
|
-
|
|
342
|
-
|
|
343
|
-
|
|
344
|
-
|
|
345
|
-
|
|
346
|
-
|
|
347
|
-
|
|
348
|
-
|
|
349
|
-
|
|
350
|
-
|
|
351
|
-
|
|
352
|
-
|
|
353
|
-
|
|
354
|
-
|
|
355
|
-
|
|
356
|
-
|
|
357
|
-
|
|
358
|
-
|
|
359
|
-
|
|
360
|
-
|
|
361
|
-
|
|
362
|
-
|
|
363
|
-
|
|
364
|
-
|
|
365
|
-
|
|
366
|
-
|
|
367
|
-
|
|
368
|
-
|
|
369
|
-
|
|
370
|
-
|
|
371
|
-
|
|
372
|
-
|
|
373
|
-
|
|
374
|
-
|
|
375
|
-
|
|
376
|
-
|
|
377
|
-
|
|
378
|
-
|
|
379
|
-
|
|
380
|
-
|
|
381
|
-
|
|
382
|
-
|
|
383
|
-
|
|
384
|
-
|
|
385
|
-
|
|
386
|
-
|
|
387
|
-
|
|
388
|
-
|
|
389
|
-
|
|
390
|
-
|
|
391
|
-
|
|
392
|
-
name:
|
|
393
|
-
|
|
394
|
-
|
|
395
|
-
|
|
396
|
-
|
|
397
|
-
|
|
398
|
-
|
|
399
|
-
|
|
400
|
-
|
|
401
|
-
|
|
402
|
-
|
|
403
|
-
|
|
404
|
-
|
|
405
|
-
|
|
406
|
-
|
|
407
|
-
|
|
408
|
-
|
|
409
|
-
|
|
410
|
-
|
|
411
|
-
|
|
412
|
-
|
|
413
|
-
|
|
414
|
-
|
|
415
|
-
|
|
416
|
-
|
|
417
|
-
|
|
418
|
-
|
|
419
|
-
|
|
420
|
-
|
|
421
|
-
|
|
422
|
-
|
|
423
|
-
|
|
424
|
-
//
|
|
425
|
-
|
|
426
|
-
|
|
427
|
-
|
|
428
|
-
|
|
429
|
-
|
|
430
|
-
|
|
431
|
-
|
|
432
|
-
|
|
433
|
-
|
|
434
|
-
|
|
435
|
-
|
|
436
|
-
|
|
437
|
-
|
|
438
|
-
|
|
439
|
-
|
|
440
|
-
|
|
441
|
-
|
|
442
|
-
|
|
443
|
-
|
|
444
|
-
|
|
445
|
-
|
|
446
|
-
|
|
447
|
-
|
|
448
|
-
|
|
449
|
-
|
|
450
|
-
|
|
451
|
-
|
|
452
|
-
|
|
453
|
-
|
|
454
|
-
|
|
455
|
-
|
|
456
|
-
|
|
457
|
-
|
|
458
|
-
|
|
459
|
-
|
|
460
|
-
|
|
461
|
-
```
|
|
462
|
-
|
|
463
|
-
|
|
464
|
-
|
|
465
|
-
|
|
466
|
-
|
|
467
|
-
|
|
468
|
-
|
|
469
|
-
|
|
470
|
-
|
|
471
|
-
|
|
472
|
-
|
|
473
|
-
|
|
474
|
-
|
|
475
|
-
|
|
476
|
-
|
|
477
|
-
|
|
478
|
-
const
|
|
479
|
-
|
|
480
|
-
|
|
481
|
-
|
|
482
|
-
|
|
483
|
-
|
|
484
|
-
|
|
485
|
-
|
|
486
|
-
|
|
487
|
-
|
|
488
|
-
|
|
489
|
-
|
|
490
|
-
|
|
491
|
-
|
|
492
|
-
|
|
493
|
-
|
|
494
|
-
|
|
495
|
-
|
|
496
|
-
|
|
497
|
-
|
|
498
|
-
|
|
499
|
-
|
|
500
|
-
|
|
501
|
-
|
|
502
|
-
|
|
503
|
-
|
|
504
|
-
|
|
505
|
-
|
|
506
|
-
|
|
507
|
-
|
|
508
|
-
|
|
509
|
-
|
|
510
|
-
|
|
511
|
-
|
|
512
|
-
|
|
513
|
-
|
|
514
|
-
|
|
515
|
-
|
|
516
|
-
<
|
|
517
|
-
|
|
518
|
-
|
|
519
|
-
</
|
|
520
|
-
```
|
|
521
|
-
|
|
522
|
-
|
|
523
|
-
|
|
524
|
-
|
|
525
|
-
|
|
526
|
-
|
|
527
|
-
|
|
528
|
-
|
|
529
|
-
|
|
530
|
-
<
|
|
531
|
-
|
|
532
|
-
|
|
533
|
-
```
|
|
534
|
-
|
|
535
|
-
**
|
|
536
|
-
```html
|
|
537
|
-
|
|
538
|
-
<
|
|
539
|
-
|
|
540
|
-
|
|
541
|
-
|
|
542
|
-
|
|
543
|
-
|
|
544
|
-
|
|
545
|
-
|
|
546
|
-
|
|
547
|
-
|
|
548
|
-
|
|
549
|
-
|
|
550
|
-
|
|
551
|
-
|
|
552
|
-
|
|
553
|
-
|
|
554
|
-
aria-
|
|
555
|
-
aria-describedby="
|
|
556
|
-
|
|
557
|
-
|
|
558
|
-
<
|
|
559
|
-
|
|
560
|
-
</
|
|
561
|
-
|
|
562
|
-
|
|
563
|
-
|
|
564
|
-
|
|
565
|
-
|
|
566
|
-
|
|
567
|
-
|
|
568
|
-
|
|
569
|
-
|
|
570
|
-
|
|
571
|
-
|
|
572
|
-
|
|
573
|
-
|
|
574
|
-
|
|
575
|
-
|
|
576
|
-
|
|
577
|
-
|
|
578
|
-
|
|
579
|
-
|
|
580
|
-
|
|
581
|
-
|
|
582
|
-
|
|
583
|
-
|
|
584
|
-
|
|
585
|
-
|
|
586
|
-
|
|
587
|
-
|
|
588
|
-
|
|
589
|
-
|
|
590
|
-
<!-- ✅
|
|
591
|
-
<
|
|
592
|
-
|
|
593
|
-
|
|
594
|
-
|
|
595
|
-
|
|
596
|
-
|
|
597
|
-
|
|
598
|
-
|
|
599
|
-
|
|
600
|
-
|
|
601
|
-
|
|
602
|
-
|
|
603
|
-
<!-- ✅ Solution -->
|
|
604
|
-
<
|
|
605
|
-
|
|
606
|
-
|
|
607
|
-
|
|
608
|
-
|
|
609
|
-
|
|
610
|
-
|
|
611
|
-
|
|
612
|
-
|
|
613
|
-
|
|
614
|
-
|
|
615
|
-
|
|
616
|
-
|
|
617
|
-
|
|
618
|
-
|
|
619
|
-
|
|
620
|
-
|
|
621
|
-
|
|
622
|
-
|
|
623
|
-
|
|
624
|
-
|
|
625
|
-
|
|
626
|
-
|
|
627
|
-
|
|
628
|
-
|
|
629
|
-
|
|
630
|
-
|
|
631
|
-
|
|
632
|
-
//
|
|
633
|
-
|
|
634
|
-
|
|
635
|
-
|
|
636
|
-
|
|
637
|
-
|
|
638
|
-
|
|
639
|
-
|
|
640
|
-
|
|
641
|
-
|
|
642
|
-
|
|
643
|
-
|
|
644
|
-
|
|
645
|
-
|
|
646
|
-
|
|
647
|
-
|
|
648
|
-
|
|
649
|
-
|
|
650
|
-
|
|
651
|
-
|
|
652
|
-
|
|
653
|
-
|
|
654
|
-
|
|
655
|
-
|
|
656
|
-
|
|
657
|
-
|
|
658
|
-
|
|
659
|
-
|
|
660
|
-
|
|
661
|
-
|
|
662
|
-
|
|
663
|
-
|
|
664
|
-
|
|
665
|
-
|
|
666
|
-
|
|
667
|
-
|
|
668
|
-
|
|
669
|
-
|
|
670
|
-
|
|
671
|
-
|
|
672
|
-
|
|
673
|
-
//
|
|
674
|
-
|
|
675
|
-
|
|
676
|
-
|
|
677
|
-
|
|
678
|
-
|
|
679
|
-
|
|
680
|
-
|
|
681
|
-
//
|
|
682
|
-
//
|
|
683
|
-
|
|
684
|
-
|
|
685
|
-
|
|
686
|
-
|
|
687
|
-
|
|
688
|
-
|
|
689
|
-
|
|
690
|
-
//
|
|
691
|
-
|
|
692
|
-
|
|
693
|
-
|
|
694
|
-
|
|
695
|
-
|
|
696
|
-
|
|
697
|
-
|
|
698
|
-
|
|
699
|
-
|
|
700
|
-
|
|
701
|
-
|
|
702
|
-
|
|
703
|
-
|
|
704
|
-
|
|
705
|
-
|
|
706
|
-
|
|
707
|
-
|
|
708
|
-
|
|
709
|
-
|
|
710
|
-
|
|
711
|
-
//
|
|
712
|
-
//
|
|
713
|
-
//
|
|
714
|
-
|
|
715
|
-
|
|
716
|
-
|
|
717
|
-
|
|
718
|
-
|
|
719
|
-
|
|
720
|
-
|
|
721
|
-
|
|
722
|
-
|
|
723
|
-
|
|
724
|
-
|
|
725
|
-
|
|
726
|
-
|
|
727
|
-
|
|
728
|
-
|
|
729
|
-
|
|
730
|
-
|
|
731
|
-
|
|
732
|
-
|
|
733
|
-
|
|
734
|
-
|
|
735
|
-
|
|
736
|
-
|
|
737
|
-
|
|
738
|
-
|
|
739
|
-
|
|
740
|
-
|
|
741
|
-
|
|
742
|
-
|
|
743
|
-
|
|
744
|
-
|
|
745
|
-
|
|
746
|
-
-
|
|
747
|
-
|
|
748
|
-
|
|
749
|
-
-
|
|
750
|
-
|
|
751
|
-
|
|
752
|
-
|
|
753
|
-
|
|
754
|
-
|
|
755
|
-
|
|
756
|
-
|
|
757
|
-
|
|
758
|
-
|
|
759
|
-
-
|
|
760
|
-
-
|
|
761
|
-
-
|
|
762
|
-
-
|
|
763
|
-
|
|
764
|
-
**
|
|
765
|
-
|
|
766
|
-
Combine automated scans with:
|
|
767
|
-
- Manual keyboard testing
|
|
768
|
-
- Screen reader testing
|
|
769
|
-
- Real user testing with people with disabilities
|
|
770
|
-
|
|
771
|
-
**Shift accessibility left:**
|
|
772
|
-
- Design with accessibility in mind
|
|
773
|
-
- Develop with semantic HTML + ARIA
|
|
774
|
-
- Test throughout development (not at the end)
|
|
775
|
-
- Include a11y in definition of done
|
|
776
|
-
|
|
777
|
-
**With Agents:** `qe-accessibility-validator` automates WCAG 2.2 compliance checking, screen reader simulation, and focus management validation. Use agents to enforce accessibility standards in CI/CD and catch violations before production.
|
|
1
|
+
---
|
|
2
|
+
name: accessibility-testing
|
|
3
|
+
description: WCAG 2.2 compliance testing, screen reader validation, and inclusive design verification. Use when ensuring legal compliance (ADA, Section 508), testing for disabilities, or building accessible applications for 1 billion disabled users globally.
|
|
4
|
+
---
|
|
5
|
+
|
|
6
|
+
# Accessibility Testing
|
|
7
|
+
|
|
8
|
+
## Core Principle
|
|
9
|
+
|
|
10
|
+
**1 billion people have disabilities. Building inaccessible software excludes 15% of humanity.**
|
|
11
|
+
|
|
12
|
+
Accessibility testing ensures software works for everyone, including people with visual, motor, cognitive, and hearing disabilities. It's not just ethical - it's legally required and expands your market by $13 trillion.
|
|
13
|
+
|
|
14
|
+
## What is Accessibility Testing?
|
|
15
|
+
|
|
16
|
+
**Accessibility (a11y):** Ensuring people with disabilities can perceive, understand, navigate, and interact with software using assistive technologies.
|
|
17
|
+
|
|
18
|
+
**Why Critical:**
|
|
19
|
+
- **Legal:** ADA, Section 508, EU Directive 2016/2102 require accessibility
|
|
20
|
+
- **Market:** $13T purchasing power of disabled community
|
|
21
|
+
- **Litigation:** 250%+ increase in a11y lawsuits (2019-2024)
|
|
22
|
+
- **Ethics:** Equal access is a fundamental right
|
|
23
|
+
- **UX:** Accessible design benefits all users (curb-cut effect)
|
|
24
|
+
|
|
25
|
+
**Goal:** WCAG 2.2 Level AA compliance + excellent user experience with assistive tech.
|
|
26
|
+
|
|
27
|
+
## WCAG 2.2 Compliance Levels
|
|
28
|
+
|
|
29
|
+
### Conformance Levels
|
|
30
|
+
|
|
31
|
+
**Level A (Minimum)**
|
|
32
|
+
- Basic accessibility
|
|
33
|
+
- Addresses most critical barriers
|
|
34
|
+
- **Requirement:** Legal minimum in many jurisdictions
|
|
35
|
+
|
|
36
|
+
**Level AA (Standard)**
|
|
37
|
+
- Addresses majority of barriers
|
|
38
|
+
- **Requirement:** US federal government (Section 508)
|
|
39
|
+
- **Recommendation:** Industry standard for most websites
|
|
40
|
+
|
|
41
|
+
**Level AAA (Enhanced)**
|
|
42
|
+
- Highest level of accessibility
|
|
43
|
+
- Not required for full sites (some criteria impossible for all content)
|
|
44
|
+
- **Use when:** Specialized accessibility-focused sites
|
|
45
|
+
|
|
46
|
+
**Most Organizations Target:** WCAG 2.2 Level AA
|
|
47
|
+
|
|
48
|
+
---
|
|
49
|
+
|
|
50
|
+
## POUR Principles
|
|
51
|
+
|
|
52
|
+
### 1. Perceivable
|
|
53
|
+
**Users must be able to perceive information**
|
|
54
|
+
|
|
55
|
+
**Requirements:**
|
|
56
|
+
- Text alternatives for non-text content
|
|
57
|
+
- Captions for videos
|
|
58
|
+
- Audio descriptions for video
|
|
59
|
+
- Adaptable content (different presentations)
|
|
60
|
+
- Distinguishable content (color contrast, text resize)
|
|
61
|
+
|
|
62
|
+
**Example:**
|
|
63
|
+
```html
|
|
64
|
+
<!-- ❌ BAD: Image without alt text -->
|
|
65
|
+
<img src="product.jpg">
|
|
66
|
+
|
|
67
|
+
<!-- ✅ GOOD: Descriptive alt text -->
|
|
68
|
+
<img src="product.jpg" alt="Blue wireless headphones with noise cancellation">
|
|
69
|
+
|
|
70
|
+
<!-- ❌ BAD: Color-only error indication -->
|
|
71
|
+
<span style="color: red">Error</span>
|
|
72
|
+
|
|
73
|
+
<!-- ✅ GOOD: Color + icon + text -->
|
|
74
|
+
<span class="error" role="alert">
|
|
75
|
+
<span aria-hidden="true">⚠️</span>
|
|
76
|
+
Error: Invalid email format
|
|
77
|
+
</span>
|
|
78
|
+
```
|
|
79
|
+
|
|
80
|
+
---
|
|
81
|
+
|
|
82
|
+
### 2. Operable
|
|
83
|
+
**Users must be able to operate the interface**
|
|
84
|
+
|
|
85
|
+
**Requirements:**
|
|
86
|
+
- Keyboard accessible (no mouse required)
|
|
87
|
+
- Enough time to read/use content
|
|
88
|
+
- No content causing seizures (no flashing > 3x/sec)
|
|
89
|
+
- Navigable (skip links, headings, focus order)
|
|
90
|
+
- Input modalities (touch, voice, etc.)
|
|
91
|
+
|
|
92
|
+
**Example:**
|
|
93
|
+
```html
|
|
94
|
+
<!-- ❌ BAD: Mouse-only interaction -->
|
|
95
|
+
<div onclick="submitForm()">Submit</div>
|
|
96
|
+
|
|
97
|
+
<!-- ✅ GOOD: Keyboard accessible button -->
|
|
98
|
+
<button type="submit" onclick="submitForm()">Submit</button>
|
|
99
|
+
|
|
100
|
+
<!-- ✅ GOOD: Skip navigation link -->
|
|
101
|
+
<a href="#main-content" class="skip-link">
|
|
102
|
+
Skip to main content
|
|
103
|
+
</a>
|
|
104
|
+
|
|
105
|
+
<nav>...</nav>
|
|
106
|
+
|
|
107
|
+
<main id="main-content">...</main>
|
|
108
|
+
```
|
|
109
|
+
|
|
110
|
+
---
|
|
111
|
+
|
|
112
|
+
### 3. Understandable
|
|
113
|
+
**Information and operation must be understandable**
|
|
114
|
+
|
|
115
|
+
**Requirements:**
|
|
116
|
+
- Readable text (language identified, unusual words explained)
|
|
117
|
+
- Predictable operation (consistent navigation)
|
|
118
|
+
- Input assistance (error identification, labels, suggestions)
|
|
119
|
+
- Compatible with assistive technologies
|
|
120
|
+
|
|
121
|
+
**Example:**
|
|
122
|
+
```html
|
|
123
|
+
<!-- ❌ BAD: Unclear error -->
|
|
124
|
+
<span>Error</span>
|
|
125
|
+
|
|
126
|
+
<!-- ✅ GOOD: Clear, actionable error -->
|
|
127
|
+
<div role="alert" aria-live="assertive">
|
|
128
|
+
<strong>Error:</strong> Password must be at least 8 characters,
|
|
129
|
+
including one uppercase letter and one number.
|
|
130
|
+
</div>
|
|
131
|
+
|
|
132
|
+
<!-- ✅ GOOD: Form labels -->
|
|
133
|
+
<label for="email">
|
|
134
|
+
Email Address (required)
|
|
135
|
+
</label>
|
|
136
|
+
<input
|
|
137
|
+
type="email"
|
|
138
|
+
id="email"
|
|
139
|
+
name="email"
|
|
140
|
+
required
|
|
141
|
+
aria-required="true"
|
|
142
|
+
aria-describedby="email-help"
|
|
143
|
+
>
|
|
144
|
+
<span id="email-help">We'll never share your email.</span>
|
|
145
|
+
```
|
|
146
|
+
|
|
147
|
+
---
|
|
148
|
+
|
|
149
|
+
### 4. Robust
|
|
150
|
+
**Content must work with current and future tools**
|
|
151
|
+
|
|
152
|
+
**Requirements:**
|
|
153
|
+
- Valid HTML/CSS
|
|
154
|
+
- Name, role, value available to assistive tech
|
|
155
|
+
- Status messages announced
|
|
156
|
+
- Compatible with user agents and assistive tech
|
|
157
|
+
|
|
158
|
+
**Example:**
|
|
159
|
+
```html
|
|
160
|
+
<!-- ✅ GOOD: Custom component with ARIA -->
|
|
161
|
+
<div
|
|
162
|
+
role="button"
|
|
163
|
+
tabindex="0"
|
|
164
|
+
aria-pressed="false"
|
|
165
|
+
onkeydown="handleKeyPress(event)"
|
|
166
|
+
onclick="toggleButton()"
|
|
167
|
+
>
|
|
168
|
+
Toggle Feature
|
|
169
|
+
</div>
|
|
170
|
+
|
|
171
|
+
<!-- ✅ GOOD: Status message -->
|
|
172
|
+
<div role="status" aria-live="polite" aria-atomic="true">
|
|
173
|
+
3 items added to cart
|
|
174
|
+
</div>
|
|
175
|
+
```
|
|
176
|
+
|
|
177
|
+
---
|
|
178
|
+
|
|
179
|
+
## Manual Testing Techniques
|
|
180
|
+
|
|
181
|
+
### 1. Keyboard-Only Navigation
|
|
182
|
+
|
|
183
|
+
**Test keyboard accessibility:**
|
|
184
|
+
```
|
|
185
|
+
Tab → Move to next focusable element
|
|
186
|
+
Shift+Tab → Move to previous focusable element
|
|
187
|
+
Enter → Activate links/buttons
|
|
188
|
+
Space → Activate buttons, toggle checkboxes
|
|
189
|
+
Arrow keys→ Navigate within components (menus, sliders)
|
|
190
|
+
Esc → Close dialogs/menus
|
|
191
|
+
```
|
|
192
|
+
|
|
193
|
+
**Checklist:**
|
|
194
|
+
- [ ] All interactive elements reachable via keyboard
|
|
195
|
+
- [ ] Visible focus indicator (outline/highlight)
|
|
196
|
+
- [ ] Logical tab order (follows visual layout)
|
|
197
|
+
- [ ] No keyboard traps (can navigate away)
|
|
198
|
+
- [ ] Skip navigation link present
|
|
199
|
+
- [ ] Keyboard shortcuts documented
|
|
200
|
+
|
|
201
|
+
**Common Issues:**
|
|
202
|
+
```html
|
|
203
|
+
<!-- ❌ BAD: Custom div without keyboard support -->
|
|
204
|
+
<div onclick="openModal()">Open</div>
|
|
205
|
+
|
|
206
|
+
<!-- ✅ GOOD: Button with keyboard support -->
|
|
207
|
+
<button onclick="openModal()">Open</button>
|
|
208
|
+
|
|
209
|
+
<!-- ✅ GOOD: Custom element with keyboard -->
|
|
210
|
+
<div
|
|
211
|
+
role="button"
|
|
212
|
+
tabindex="0"
|
|
213
|
+
onclick="openModal()"
|
|
214
|
+
onkeydown="if(event.key==='Enter') openModal()"
|
|
215
|
+
>
|
|
216
|
+
Open
|
|
217
|
+
</div>
|
|
218
|
+
```
|
|
219
|
+
|
|
220
|
+
---
|
|
221
|
+
|
|
222
|
+
### 2. Screen Reader Testing
|
|
223
|
+
|
|
224
|
+
**Major Screen Readers:**
|
|
225
|
+
- **JAWS** (Windows) - Most popular, commercial
|
|
226
|
+
- **NVDA** (Windows) - Free, open-source
|
|
227
|
+
- **VoiceOver** (macOS/iOS) - Built-in to Apple devices
|
|
228
|
+
- **TalkBack** (Android) - Built-in to Android
|
|
229
|
+
- **Narrator** (Windows) - Built-in to Windows
|
|
230
|
+
|
|
231
|
+
**VoiceOver Basics (macOS):**
|
|
232
|
+
```
|
|
233
|
+
Cmd+F5 → Toggle VoiceOver
|
|
234
|
+
VO+Right/Left → Navigate elements (VO = Ctrl+Option)
|
|
235
|
+
VO+Shift+Down → Interact with element
|
|
236
|
+
VO+Space → Activate element
|
|
237
|
+
VO+A → Read from top
|
|
238
|
+
VO+U → Rotor (headings, links, landmarks)
|
|
239
|
+
```
|
|
240
|
+
|
|
241
|
+
**Screen Reader Checklist:**
|
|
242
|
+
- [ ] All images have alt text (or alt="" for decorative)
|
|
243
|
+
- [ ] Headings announce correctly (h1, h2, etc.)
|
|
244
|
+
- [ ] Form labels associated with inputs
|
|
245
|
+
- [ ] Links have descriptive text (not "click here")
|
|
246
|
+
- [ ] Dynamic content announced (aria-live)
|
|
247
|
+
- [ ] Custom components have proper roles
|
|
248
|
+
- [ ] Page language identified
|
|
249
|
+
- [ ] Reading order logical
|
|
250
|
+
|
|
251
|
+
**Example Testing Script:**
|
|
252
|
+
```
|
|
253
|
+
1. Enable screen reader
|
|
254
|
+
2. Navigate to page
|
|
255
|
+
3. Verify page title announced
|
|
256
|
+
4. Navigate by headings (h1 → h2 → h3)
|
|
257
|
+
5. Navigate by landmarks (nav, main, footer)
|
|
258
|
+
6. Tab through form, verify labels read
|
|
259
|
+
7. Submit form with errors, verify error messages read
|
|
260
|
+
8. Navigate list of items, verify count announced
|
|
261
|
+
9. Open modal, verify focus trapped
|
|
262
|
+
10. Close modal, verify focus returned
|
|
263
|
+
```
|
|
264
|
+
|
|
265
|
+
---
|
|
266
|
+
|
|
267
|
+
### 3. Color Contrast Testing
|
|
268
|
+
|
|
269
|
+
**WCAG Requirements:**
|
|
270
|
+
- **Normal text:** 4.5:1 contrast ratio (AA), 7:1 (AAA)
|
|
271
|
+
- **Large text (18pt+):** 3:1 contrast ratio (AA), 4.5:1 (AAA)
|
|
272
|
+
- **UI components:** 3:1 contrast ratio
|
|
273
|
+
|
|
274
|
+
**Tools:**
|
|
275
|
+
- Chrome DevTools (built-in contrast checker)
|
|
276
|
+
- WebAIM Contrast Checker
|
|
277
|
+
- Colour Contrast Analyser (CCA)
|
|
278
|
+
|
|
279
|
+
**Manual Test:**
|
|
280
|
+
```html
|
|
281
|
+
<!-- ❌ BAD: Insufficient contrast (2.5:1) -->
|
|
282
|
+
<p style="color: #777; background: #fff;">Low contrast text</p>
|
|
283
|
+
|
|
284
|
+
<!-- ✅ GOOD: Sufficient contrast (4.6:1) -->
|
|
285
|
+
<p style="color: #595959; background: #fff;">Readable text</p>
|
|
286
|
+
|
|
287
|
+
<!-- ✅ GOOD: High contrast (12.6:1) -->
|
|
288
|
+
<p style="color: #000; background: #fff;">High contrast text</p>
|
|
289
|
+
```
|
|
290
|
+
|
|
291
|
+
**Testing Checklist:**
|
|
292
|
+
- [ ] All text meets 4.5:1 ratio
|
|
293
|
+
- [ ] Large text meets 3:1 ratio
|
|
294
|
+
- [ ] Links distinguishable without color alone
|
|
295
|
+
- [ ] UI components meet 3:1 ratio
|
|
296
|
+
- [ ] Focus indicators meet 3:1 ratio
|
|
297
|
+
|
|
298
|
+
---
|
|
299
|
+
|
|
300
|
+
### 4. Text Resize & Zoom
|
|
301
|
+
|
|
302
|
+
**Requirements:**
|
|
303
|
+
- Text resizeable up to 200% without loss of content/functionality
|
|
304
|
+
- No horizontal scrolling at 400% zoom (except data tables)
|
|
305
|
+
|
|
306
|
+
**Manual Test:**
|
|
307
|
+
```
|
|
308
|
+
1. Open page in browser
|
|
309
|
+
2. Zoom to 200% (Cmd/Ctrl + "+")
|
|
310
|
+
- Verify all text readable
|
|
311
|
+
- Verify no content hidden
|
|
312
|
+
- Verify functionality intact
|
|
313
|
+
3. Zoom to 400%
|
|
314
|
+
- Verify no horizontal scrolling
|
|
315
|
+
- Verify content reflows appropriately
|
|
316
|
+
```
|
|
317
|
+
|
|
318
|
+
**CSS Best Practices:**
|
|
319
|
+
```css
|
|
320
|
+
/* ✅ GOOD: Relative units */
|
|
321
|
+
body {
|
|
322
|
+
font-size: 1rem; /* 16px default */
|
|
323
|
+
}
|
|
324
|
+
h1 {
|
|
325
|
+
font-size: 2rem; /* 32px default */
|
|
326
|
+
}
|
|
327
|
+
|
|
328
|
+
/* ❌ BAD: Fixed pixel sizes */
|
|
329
|
+
body {
|
|
330
|
+
font-size: 12px; /* Doesn't scale with user preferences */
|
|
331
|
+
}
|
|
332
|
+
```
|
|
333
|
+
|
|
334
|
+
---
|
|
335
|
+
|
|
336
|
+
## Automated Testing
|
|
337
|
+
|
|
338
|
+
### 1. axe-core Integration
|
|
339
|
+
|
|
340
|
+
**Install:**
|
|
341
|
+
```bash
|
|
342
|
+
npm install --save-dev @axe-core/playwright
|
|
343
|
+
```
|
|
344
|
+
|
|
345
|
+
**Playwright Example:**
|
|
346
|
+
```javascript
|
|
347
|
+
import { test, expect } from '@playwright/test';
|
|
348
|
+
import AxeBuilder from '@axe-core/playwright';
|
|
349
|
+
|
|
350
|
+
test('homepage should not have accessibility violations', async ({ page }) => {
|
|
351
|
+
await page.goto('https://example.com');
|
|
352
|
+
|
|
353
|
+
const accessibilityScanResults = await new AxeBuilder({ page })
|
|
354
|
+
.withTags(['wcag2a', 'wcag2aa', 'wcag21aa', 'wcag22aa'])
|
|
355
|
+
.analyze();
|
|
356
|
+
|
|
357
|
+
expect(accessibilityScanResults.violations).toEqual([]);
|
|
358
|
+
});
|
|
359
|
+
|
|
360
|
+
test('form should have proper labels', async ({ page }) => {
|
|
361
|
+
await page.goto('https://example.com/signup');
|
|
362
|
+
|
|
363
|
+
const results = await new AxeBuilder({ page })
|
|
364
|
+
.include('#signup-form')
|
|
365
|
+
.analyze();
|
|
366
|
+
|
|
367
|
+
// Allow specific known issues
|
|
368
|
+
const allowedViolations = results.violations.filter(v =>
|
|
369
|
+
v.id !== 'color-contrast' // Being fixed in next sprint
|
|
370
|
+
);
|
|
371
|
+
|
|
372
|
+
expect(allowedViolations).toEqual([]);
|
|
373
|
+
});
|
|
374
|
+
```
|
|
375
|
+
|
|
376
|
+
**CI/CD Integration:**
|
|
377
|
+
```yaml
|
|
378
|
+
# .github/workflows/a11y.yml
|
|
379
|
+
name: Accessibility Tests
|
|
380
|
+
|
|
381
|
+
on: [pull_request]
|
|
382
|
+
|
|
383
|
+
jobs:
|
|
384
|
+
a11y:
|
|
385
|
+
runs-on: ubuntu-latest
|
|
386
|
+
steps:
|
|
387
|
+
- uses: actions/checkout@v3
|
|
388
|
+
- uses: actions/setup-node@v3
|
|
389
|
+
- run: npm ci
|
|
390
|
+
- run: npm run test:a11y
|
|
391
|
+
|
|
392
|
+
- name: Upload a11y results
|
|
393
|
+
if: failure()
|
|
394
|
+
uses: actions/upload-artifact@v3
|
|
395
|
+
with:
|
|
396
|
+
name: axe-results
|
|
397
|
+
path: a11y-results/
|
|
398
|
+
```
|
|
399
|
+
|
|
400
|
+
---
|
|
401
|
+
|
|
402
|
+
### 2. Pa11y Testing
|
|
403
|
+
|
|
404
|
+
**Install:**
|
|
405
|
+
```bash
|
|
406
|
+
npm install --save-dev pa11y
|
|
407
|
+
```
|
|
408
|
+
|
|
409
|
+
**Configuration:**
|
|
410
|
+
```javascript
|
|
411
|
+
// .pa11yrc
|
|
412
|
+
{
|
|
413
|
+
"standard": "WCAG2AA",
|
|
414
|
+
"timeout": 30000,
|
|
415
|
+
"wait": 1000,
|
|
416
|
+
"chromeLaunchConfig": {
|
|
417
|
+
"args": ["--no-sandbox"]
|
|
418
|
+
},
|
|
419
|
+
"runners": [
|
|
420
|
+
"axe",
|
|
421
|
+
"htmlcs"
|
|
422
|
+
],
|
|
423
|
+
"ignore": [
|
|
424
|
+
"color-contrast" // Temporarily ignore while fixing
|
|
425
|
+
]
|
|
426
|
+
}
|
|
427
|
+
```
|
|
428
|
+
|
|
429
|
+
**Usage:**
|
|
430
|
+
```javascript
|
|
431
|
+
const pa11y = require('pa11y');
|
|
432
|
+
|
|
433
|
+
async function runA11yTests() {
|
|
434
|
+
const results = await pa11y('https://example.com', {
|
|
435
|
+
standard: 'WCAG2AA',
|
|
436
|
+
includeWarnings: true,
|
|
437
|
+
includeNotices: false
|
|
438
|
+
});
|
|
439
|
+
|
|
440
|
+
console.log(`Found ${results.issues.length} issues`);
|
|
441
|
+
|
|
442
|
+
results.issues.forEach(issue => {
|
|
443
|
+
console.log(`${issue.type}: ${issue.message}`);
|
|
444
|
+
console.log(`Element: ${issue.selector}`);
|
|
445
|
+
console.log(`Code: ${issue.code}\n`);
|
|
446
|
+
});
|
|
447
|
+
}
|
|
448
|
+
```
|
|
449
|
+
|
|
450
|
+
---
|
|
451
|
+
|
|
452
|
+
### 3. Lighthouse Accessibility Audit
|
|
453
|
+
|
|
454
|
+
**Chrome DevTools:**
|
|
455
|
+
```
|
|
456
|
+
1. Open DevTools (F12)
|
|
457
|
+
2. Go to Lighthouse tab
|
|
458
|
+
3. Select "Accessibility" category
|
|
459
|
+
4. Click "Analyze page load"
|
|
460
|
+
5. Review score and recommendations
|
|
461
|
+
```
|
|
462
|
+
|
|
463
|
+
**Programmatic:**
|
|
464
|
+
```javascript
|
|
465
|
+
const lighthouse = require('lighthouse');
|
|
466
|
+
const chromeLauncher = require('chrome-launcher');
|
|
467
|
+
|
|
468
|
+
async function runLighthouse() {
|
|
469
|
+
const chrome = await chromeLauncher.launch({ chromeFlags: ['--headless'] });
|
|
470
|
+
|
|
471
|
+
const options = {
|
|
472
|
+
logLevel: 'info',
|
|
473
|
+
output: 'html',
|
|
474
|
+
onlyCategories: ['accessibility'],
|
|
475
|
+
port: chrome.port
|
|
476
|
+
};
|
|
477
|
+
|
|
478
|
+
const runnerResult = await lighthouse('https://example.com', options);
|
|
479
|
+
|
|
480
|
+
const accessibilityScore = runnerResult.lhr.categories.accessibility.score * 100;
|
|
481
|
+
console.log(`Accessibility Score: ${accessibilityScore}`);
|
|
482
|
+
|
|
483
|
+
await chrome.kill();
|
|
484
|
+
}
|
|
485
|
+
```
|
|
486
|
+
|
|
487
|
+
---
|
|
488
|
+
|
|
489
|
+
## ARIA Best Practices
|
|
490
|
+
|
|
491
|
+
### When to Use ARIA
|
|
492
|
+
|
|
493
|
+
**First Rule of ARIA:** Don't use ARIA if you can use native HTML
|
|
494
|
+
|
|
495
|
+
```html
|
|
496
|
+
<!-- ❌ BAD: ARIA on native element -->
|
|
497
|
+
<div role="button" tabindex="0" onclick="submit()">Submit</div>
|
|
498
|
+
|
|
499
|
+
<!-- ✅ GOOD: Native element -->
|
|
500
|
+
<button onclick="submit()">Submit</button>
|
|
501
|
+
|
|
502
|
+
<!-- ✅ ARIA OK: Custom component with no native equivalent -->
|
|
503
|
+
<div role="tablist">
|
|
504
|
+
<button role="tab" aria-selected="true">Tab 1</button>
|
|
505
|
+
<button role="tab" aria-selected="false">Tab 2</button>
|
|
506
|
+
</div>
|
|
507
|
+
```
|
|
508
|
+
|
|
509
|
+
---
|
|
510
|
+
|
|
511
|
+
### Common ARIA Patterns
|
|
512
|
+
|
|
513
|
+
**Landmark Roles:**
|
|
514
|
+
```html
|
|
515
|
+
<header role="banner">Site header</header>
|
|
516
|
+
<nav role="navigation">Main navigation</nav>
|
|
517
|
+
<main role="main">Main content</main>
|
|
518
|
+
<aside role="complementary">Sidebar</aside>
|
|
519
|
+
<footer role="contentinfo">Site footer</footer>
|
|
520
|
+
```
|
|
521
|
+
|
|
522
|
+
**Live Regions:**
|
|
523
|
+
```html
|
|
524
|
+
<!-- Polite: Announces when convenient -->
|
|
525
|
+
<div role="status" aria-live="polite" aria-atomic="true">
|
|
526
|
+
3 items added to cart
|
|
527
|
+
</div>
|
|
528
|
+
|
|
529
|
+
<!-- Assertive: Announces immediately -->
|
|
530
|
+
<div role="alert" aria-live="assertive">
|
|
531
|
+
Error: Payment failed. Please try again.
|
|
532
|
+
</div>
|
|
533
|
+
```
|
|
534
|
+
|
|
535
|
+
**Form Accessibility:**
|
|
536
|
+
```html
|
|
537
|
+
<label for="username">Username</label>
|
|
538
|
+
<input
|
|
539
|
+
type="text"
|
|
540
|
+
id="username"
|
|
541
|
+
aria-required="true"
|
|
542
|
+
aria-describedby="username-help username-error"
|
|
543
|
+
>
|
|
544
|
+
<span id="username-help">Choose a unique username</span>
|
|
545
|
+
<span id="username-error" role="alert" class="error">
|
|
546
|
+
Username already taken
|
|
547
|
+
</span>
|
|
548
|
+
```
|
|
549
|
+
|
|
550
|
+
**Modals/Dialogs:**
|
|
551
|
+
```html
|
|
552
|
+
<div
|
|
553
|
+
role="dialog"
|
|
554
|
+
aria-labelledby="dialog-title"
|
|
555
|
+
aria-describedby="dialog-desc"
|
|
556
|
+
aria-modal="true"
|
|
557
|
+
>
|
|
558
|
+
<h2 id="dialog-title">Confirm Action</h2>
|
|
559
|
+
<p id="dialog-desc">Are you sure you want to delete?</p>
|
|
560
|
+
<button onclick="confirmDelete()">Confirm</button>
|
|
561
|
+
<button onclick="closeDialog()">Cancel</button>
|
|
562
|
+
</div>
|
|
563
|
+
```
|
|
564
|
+
|
|
565
|
+
---
|
|
566
|
+
|
|
567
|
+
## Common Accessibility Issues
|
|
568
|
+
|
|
569
|
+
### Issue 1: Missing Alt Text
|
|
570
|
+
```html
|
|
571
|
+
<!-- ❌ Problem -->
|
|
572
|
+
<img src="chart.png">
|
|
573
|
+
|
|
574
|
+
<!-- ✅ Solution -->
|
|
575
|
+
<img src="chart.png" alt="Sales growth chart showing 25% increase in Q4">
|
|
576
|
+
|
|
577
|
+
<!-- ✅ Decorative images -->
|
|
578
|
+
<img src="decorative-line.png" alt="" role="presentation">
|
|
579
|
+
```
|
|
580
|
+
|
|
581
|
+
---
|
|
582
|
+
|
|
583
|
+
### Issue 2: Empty Links
|
|
584
|
+
```html
|
|
585
|
+
<!-- ❌ Problem -->
|
|
586
|
+
<a href="/products">
|
|
587
|
+
<img src="icon.png" alt="">
|
|
588
|
+
</a>
|
|
589
|
+
|
|
590
|
+
<!-- ✅ Solution -->
|
|
591
|
+
<a href="/products">
|
|
592
|
+
<img src="icon.png" alt="View all products">
|
|
593
|
+
</a>
|
|
594
|
+
```
|
|
595
|
+
|
|
596
|
+
---
|
|
597
|
+
|
|
598
|
+
### Issue 3: Form Labels Missing
|
|
599
|
+
```html
|
|
600
|
+
<!-- ❌ Problem -->
|
|
601
|
+
<input type="text" placeholder="Email">
|
|
602
|
+
|
|
603
|
+
<!-- ✅ Solution -->
|
|
604
|
+
<label for="email">Email Address</label>
|
|
605
|
+
<input type="email" id="email" placeholder="you@example.com">
|
|
606
|
+
|
|
607
|
+
<!-- ✅ Alternative: aria-label -->
|
|
608
|
+
<input
|
|
609
|
+
type="email"
|
|
610
|
+
aria-label="Email Address"
|
|
611
|
+
placeholder="you@example.com"
|
|
612
|
+
>
|
|
613
|
+
```
|
|
614
|
+
|
|
615
|
+
---
|
|
616
|
+
|
|
617
|
+
### Issue 4: Poor Focus Management
|
|
618
|
+
```javascript
|
|
619
|
+
// ❌ Problem: Focus lost when modal opens
|
|
620
|
+
function openModal() {
|
|
621
|
+
document.getElementById('modal').style.display = 'block';
|
|
622
|
+
}
|
|
623
|
+
|
|
624
|
+
// ✅ Solution: Manage focus properly
|
|
625
|
+
function openModal() {
|
|
626
|
+
const modal = document.getElementById('modal');
|
|
627
|
+
const previouslyFocused = document.activeElement;
|
|
628
|
+
|
|
629
|
+
modal.style.display = 'block';
|
|
630
|
+
modal.querySelector('button').focus(); // Focus first button
|
|
631
|
+
|
|
632
|
+
// Trap focus within modal
|
|
633
|
+
modal.addEventListener('keydown', (e) => {
|
|
634
|
+
if (e.key === 'Tab') {
|
|
635
|
+
trapFocus(modal, e);
|
|
636
|
+
}
|
|
637
|
+
});
|
|
638
|
+
|
|
639
|
+
// Restore focus on close
|
|
640
|
+
modal.dataset.previousFocus = previouslyFocused;
|
|
641
|
+
}
|
|
642
|
+
|
|
643
|
+
function closeModal() {
|
|
644
|
+
const modal = document.getElementById('modal');
|
|
645
|
+
modal.style.display = 'none';
|
|
646
|
+
|
|
647
|
+
// Restore focus
|
|
648
|
+
const previousFocus = document.querySelector(modal.dataset.previousFocus);
|
|
649
|
+
if (previousFocus) previousFocus.focus();
|
|
650
|
+
}
|
|
651
|
+
```
|
|
652
|
+
|
|
653
|
+
---
|
|
654
|
+
|
|
655
|
+
## Using with QE Agents
|
|
656
|
+
|
|
657
|
+
### qe-accessibility-validator: Automated Compliance
|
|
658
|
+
|
|
659
|
+
```typescript
|
|
660
|
+
// Agent runs comprehensive a11y validation
|
|
661
|
+
const a11yResults = await agent.validateAccessibility({
|
|
662
|
+
url: 'https://example.com/checkout',
|
|
663
|
+
standard: 'WCAG2.2',
|
|
664
|
+
level: 'AA',
|
|
665
|
+
includeScreenReaderSimulation: true
|
|
666
|
+
});
|
|
667
|
+
|
|
668
|
+
// Returns:
|
|
669
|
+
// {
|
|
670
|
+
// score: 0.92,
|
|
671
|
+
// violations: [
|
|
672
|
+
// { rule: 'color-contrast', severity: 'serious', count: 3 },
|
|
673
|
+
// { rule: 'label', severity: 'critical', count: 1 }
|
|
674
|
+
// ],
|
|
675
|
+
// passes: 47,
|
|
676
|
+
// incomplete: 2,
|
|
677
|
+
// screenReaderReport: {
|
|
678
|
+
// navigation: 'good',
|
|
679
|
+
// formLabels: 'needs-improvement',
|
|
680
|
+
// landmarkStructure: 'excellent'
|
|
681
|
+
// }
|
|
682
|
+
// }
|
|
683
|
+
```
|
|
684
|
+
|
|
685
|
+
---
|
|
686
|
+
|
|
687
|
+
### qe-visual-tester: Keyboard & Focus Testing
|
|
688
|
+
|
|
689
|
+
```typescript
|
|
690
|
+
// Agent validates focus indicators
|
|
691
|
+
await agent.visualA11yTest({
|
|
692
|
+
page: '/signup',
|
|
693
|
+
checks: ['focus-visible', 'keyboard-navigation', 'tab-order'],
|
|
694
|
+
generateReport: true
|
|
695
|
+
});
|
|
696
|
+
|
|
697
|
+
// Captures screenshots of:
|
|
698
|
+
// - Focus states for all interactive elements
|
|
699
|
+
// - Tab order visualization
|
|
700
|
+
// - Keyboard navigation paths
|
|
701
|
+
```
|
|
702
|
+
|
|
703
|
+
---
|
|
704
|
+
|
|
705
|
+
### Fleet Coordination for Comprehensive A11y
|
|
706
|
+
|
|
707
|
+
```typescript
|
|
708
|
+
const a11yFleet = await FleetManager.coordinate({
|
|
709
|
+
strategy: 'comprehensive-accessibility',
|
|
710
|
+
agents: [
|
|
711
|
+
'qe-accessibility-validator', // Automated scanning
|
|
712
|
+
'qe-visual-tester', // Visual & keyboard checks
|
|
713
|
+
'qe-test-generator', // Generate a11y tests
|
|
714
|
+
'qe-quality-gate' // Enforce compliance
|
|
715
|
+
]
|
|
716
|
+
});
|
|
717
|
+
|
|
718
|
+
await a11yFleet.execute({
|
|
719
|
+
target: 'production-candidate',
|
|
720
|
+
wcagLevel: 'AA',
|
|
721
|
+
failOn: 'critical-violations',
|
|
722
|
+
generateRemediationGuide: true
|
|
723
|
+
});
|
|
724
|
+
```
|
|
725
|
+
|
|
726
|
+
---
|
|
727
|
+
|
|
728
|
+
## Related Skills
|
|
729
|
+
|
|
730
|
+
**Core Testing:**
|
|
731
|
+
- [agentic-quality-engineering](../agentic-quality-engineering/) - Agent-driven a11y testing
|
|
732
|
+
- [regression-testing](../regression-testing/) - A11y in regression suite
|
|
733
|
+
- [visual-testing-advanced](../visual-testing-advanced/) - Visual a11y checks
|
|
734
|
+
|
|
735
|
+
**Specialized Testing:**
|
|
736
|
+
- [mobile-testing](../mobile-testing/) - Mobile a11y (VoiceOver, TalkBack)
|
|
737
|
+
- [compatibility-testing](../compatibility-testing/) - Cross-browser a11y
|
|
738
|
+
- [compliance-testing](../compliance-testing/) - Legal compliance (ADA)
|
|
739
|
+
|
|
740
|
+
---
|
|
741
|
+
|
|
742
|
+
## Remember
|
|
743
|
+
|
|
744
|
+
**Accessibility is a legal requirement, not a nice-to-have.**
|
|
745
|
+
|
|
746
|
+
- 1 billion people with disabilities globally
|
|
747
|
+
- $13 trillion purchasing power
|
|
748
|
+
- 250%+ increase in lawsuits (2019-2024)
|
|
749
|
+
- ADA, Section 508, EU regulations enforced
|
|
750
|
+
|
|
751
|
+
**Automated testing catches only 30-50% of issues.**
|
|
752
|
+
|
|
753
|
+
Combine automated scans with:
|
|
754
|
+
- Manual keyboard testing
|
|
755
|
+
- Screen reader testing
|
|
756
|
+
- Real user testing with people with disabilities
|
|
757
|
+
|
|
758
|
+
**Shift accessibility left:**
|
|
759
|
+
- Design with accessibility in mind
|
|
760
|
+
- Develop with semantic HTML + ARIA
|
|
761
|
+
- Test throughout development (not at the end)
|
|
762
|
+
- Include a11y in definition of done
|
|
763
|
+
|
|
764
|
+
**With Agents:** `qe-accessibility-validator` automates WCAG 2.2 compliance checking, screen reader simulation, and focus management validation. Use agents to enforce accessibility standards in CI/CD and catch violations before production.
|