@ruaruababa/vibe-kit 1.0.0
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/CATALOG.md +317 -0
- package/README.md +121 -0
- package/aliases.json +65 -0
- package/bin/vibe.js +2 -0
- package/bundles.json +265 -0
- package/catalog.json +1560 -0
- package/dist/antigravity-skills/bin/cli.js +438 -0
- package/dist/antigravity-skills/lib/skill-utils.js +158 -0
- package/dist/antigravity-skills/scripts/build-catalog.js +305 -0
- package/dist/antigravity-skills/scripts/normalize-frontmatter.js +144 -0
- package/dist/antigravity-skills/scripts/validate-skills.js +230 -0
- package/dist/bin/vibe.js +2 -0
- package/dist/dist/src/cli/index.js +26 -0
- package/dist/lib/skill-utils.js +158 -0
- package/dist/scripts/build-catalog.js +50 -0
- package/dist/scripts/normalize-frontmatter.js +144 -0
- package/dist/scripts/validate-skills.js +56 -0
- package/dist/src/cli/index.js +146 -0
- package/dist/src/types/index.js +13 -0
- package/dist/src/utils/fs.js +1 -0
- package/package.json +43 -0
- package/skills/accessibility-compliance-accessibility-audit/SKILL.md +42 -0
- package/skills/accessibility-compliance-accessibility-audit/resources/implementation-playbook.md +502 -0
- package/skills/agent-orchestration-improve-agent/SKILL.md +349 -0
- package/skills/agent-orchestration-multi-agent-optimize/SKILL.md +239 -0
- package/skills/agent-orchestrator/SKILL.md +24 -0
- package/skills/ai-engineer/SKILL.md +171 -0
- package/skills/airflow-dag-patterns/SKILL.md +41 -0
- package/skills/airflow-dag-patterns/resources/implementation-playbook.md +509 -0
- package/skills/angular-migration/SKILL.md +428 -0
- package/skills/anti-reversing-techniques/SKILL.md +42 -0
- package/skills/anti-reversing-techniques/resources/implementation-playbook.md +539 -0
- package/skills/api-design-principles/SKILL.md +37 -0
- package/skills/api-design-principles/assets/api-design-checklist.md +155 -0
- package/skills/api-design-principles/assets/rest-api-template.py +182 -0
- package/skills/api-design-principles/references/graphql-schema-design.md +583 -0
- package/skills/api-design-principles/references/rest-best-practices.md +408 -0
- package/skills/api-design-principles/resources/implementation-playbook.md +513 -0
- package/skills/api-documenter/SKILL.md +184 -0
- package/skills/api-testing-observability-api-mock/SKILL.md +46 -0
- package/skills/api-testing-observability-api-mock/resources/implementation-playbook.md +1327 -0
- package/skills/application-performance-performance-optimization/SKILL.md +154 -0
- package/skills/architect-review/SKILL.md +174 -0
- package/skills/architecture-decision-records/SKILL.md +441 -0
- package/skills/architecture-patterns/SKILL.md +37 -0
- package/skills/architecture-patterns/resources/implementation-playbook.md +479 -0
- package/skills/arm-cortex-expert/SKILL.md +306 -0
- package/skills/async-python-patterns/SKILL.md +39 -0
- package/skills/async-python-patterns/resources/implementation-playbook.md +678 -0
- package/skills/attack-tree-construction/SKILL.md +38 -0
- package/skills/attack-tree-construction/resources/implementation-playbook.md +671 -0
- package/skills/auth-implementation-patterns/SKILL.md +39 -0
- package/skills/auth-implementation-patterns/resources/implementation-playbook.md +618 -0
- package/skills/backend-architect/SKILL.md +333 -0
- package/skills/backend-development-feature-development/SKILL.md +180 -0
- package/skills/backend-security-coder/SKILL.md +156 -0
- package/skills/backtesting-frameworks/SKILL.md +39 -0
- package/skills/backtesting-frameworks/resources/implementation-playbook.md +647 -0
- package/skills/bash-defensive-patterns/SKILL.md +43 -0
- package/skills/bash-defensive-patterns/resources/implementation-playbook.md +517 -0
- package/skills/bash-pro/SKILL.md +310 -0
- package/skills/bats-testing-patterns/SKILL.md +34 -0
- package/skills/bats-testing-patterns/resources/implementation-playbook.md +614 -0
- package/skills/bazel-build-optimization/SKILL.md +397 -0
- package/skills/billing-automation/SKILL.md +42 -0
- package/skills/billing-automation/resources/implementation-playbook.md +544 -0
- package/skills/binary-analysis-patterns/SKILL.md +450 -0
- package/skills/blockchain-developer/SKILL.md +208 -0
- package/skills/business-analyst/SKILL.md +182 -0
- package/skills/c-pro/SKILL.md +56 -0
- package/skills/c4-architecture-c4-architecture/SKILL.md +389 -0
- package/skills/c4-code/SKILL.md +244 -0
- package/skills/c4-component/SKILL.md +153 -0
- package/skills/c4-container/SKILL.md +171 -0
- package/skills/c4-context/SKILL.md +150 -0
- package/skills/changelog-automation/SKILL.md +38 -0
- package/skills/changelog-automation/resources/implementation-playbook.md +538 -0
- package/skills/cicd-automation-workflow-automate/SKILL.md +51 -0
- package/skills/cicd-automation-workflow-automate/resources/implementation-playbook.md +1333 -0
- package/skills/clean-markdown/SKILL.md +23 -0
- package/skills/cloud-architect/SKILL.md +135 -0
- package/skills/code-documentation-code-explain/SKILL.md +46 -0
- package/skills/code-documentation-code-explain/resources/implementation-playbook.md +802 -0
- package/skills/code-documentation-doc-generate/SKILL.md +48 -0
- package/skills/code-documentation-doc-generate/resources/implementation-playbook.md +640 -0
- package/skills/code-refactoring-context-restore/SKILL.md +179 -0
- package/skills/code-refactoring-refactor-clean/SKILL.md +51 -0
- package/skills/code-refactoring-refactor-clean/resources/implementation-playbook.md +879 -0
- package/skills/code-refactoring-tech-debt/SKILL.md +386 -0
- package/skills/code-review-ai-ai-review/SKILL.md +450 -0
- package/skills/code-review-excellence/SKILL.md +40 -0
- package/skills/code-review-excellence/resources/implementation-playbook.md +515 -0
- package/skills/code-reviewer/SKILL.md +178 -0
- package/skills/codebase-cleanup-deps-audit/SKILL.md +51 -0
- package/skills/codebase-cleanup-deps-audit/resources/implementation-playbook.md +766 -0
- package/skills/codebase-cleanup-refactor-clean/SKILL.md +51 -0
- package/skills/codebase-cleanup-refactor-clean/resources/implementation-playbook.md +879 -0
- package/skills/codebase-cleanup-tech-debt/SKILL.md +386 -0
- package/skills/competitive-landscape/SKILL.md +34 -0
- package/skills/competitive-landscape/resources/implementation-playbook.md +494 -0
- package/skills/comprehensive-review-full-review/SKILL.md +146 -0
- package/skills/comprehensive-review-pr-enhance/SKILL.md +46 -0
- package/skills/comprehensive-review-pr-enhance/resources/implementation-playbook.md +691 -0
- package/skills/conductor-implement/SKILL.md +388 -0
- package/skills/conductor-manage/SKILL.md +39 -0
- package/skills/conductor-manage/resources/implementation-playbook.md +1120 -0
- package/skills/conductor-new-track/SKILL.md +433 -0
- package/skills/conductor-revert/SKILL.md +372 -0
- package/skills/conductor-setup/SKILL.md +426 -0
- package/skills/conductor-status/SKILL.md +338 -0
- package/skills/conductor-validator/SKILL.md +62 -0
- package/skills/content-marketer/SKILL.md +170 -0
- package/skills/context-driven-development/SKILL.md +400 -0
- package/skills/context-management-context-restore/SKILL.md +179 -0
- package/skills/context-management-context-save/SKILL.md +177 -0
- package/skills/context-manager/SKILL.md +185 -0
- package/skills/cost-optimization/SKILL.md +286 -0
- package/skills/cpp-pro/SKILL.md +59 -0
- package/skills/cqrs-implementation/SKILL.md +35 -0
- package/skills/cqrs-implementation/resources/implementation-playbook.md +540 -0
- package/skills/csharp-pro/SKILL.md +59 -0
- package/skills/customer-support/SKILL.md +170 -0
- package/skills/data-engineer/SKILL.md +224 -0
- package/skills/data-engineering-data-driven-feature/SKILL.md +182 -0
- package/skills/data-engineering-data-pipeline/SKILL.md +201 -0
- package/skills/data-quality-frameworks/SKILL.md +40 -0
- package/skills/data-quality-frameworks/resources/implementation-playbook.md +573 -0
- package/skills/data-scientist/SKILL.md +199 -0
- package/skills/data-storytelling/SKILL.md +465 -0
- package/skills/database-admin/SKILL.md +165 -0
- package/skills/database-architect/SKILL.md +268 -0
- package/skills/database-cloud-optimization-cost-optimize/SKILL.md +44 -0
- package/skills/database-cloud-optimization-cost-optimize/resources/implementation-playbook.md +1441 -0
- package/skills/database-migration/SKILL.md +436 -0
- package/skills/database-migrations-migration-observability/SKILL.md +420 -0
- package/skills/database-migrations-sql-migrations/SKILL.md +53 -0
- package/skills/database-migrations-sql-migrations/resources/implementation-playbook.md +499 -0
- package/skills/database-optimizer/SKILL.md +167 -0
- package/skills/dbt-transformation-patterns/SKILL.md +34 -0
- package/skills/dbt-transformation-patterns/resources/implementation-playbook.md +547 -0
- package/skills/debugger/SKILL.md +49 -0
- package/skills/debugging-strategies/SKILL.md +34 -0
- package/skills/debugging-strategies/resources/implementation-playbook.md +511 -0
- package/skills/debugging-toolkit-smart-debug/SKILL.md +197 -0
- package/skills/defi-protocol-templates/SKILL.md +466 -0
- package/skills/dependency-management-deps-audit/SKILL.md +44 -0
- package/skills/dependency-management-deps-audit/resources/implementation-playbook.md +766 -0
- package/skills/dependency-upgrade/SKILL.md +421 -0
- package/skills/deployment-engineer/SKILL.md +170 -0
- package/skills/deployment-pipeline-design/SKILL.md +371 -0
- package/skills/deployment-validation-config-validate/SKILL.md +496 -0
- package/skills/devops-troubleshooter/SKILL.md +161 -0
- package/skills/distributed-debugging-debug-trace/SKILL.md +44 -0
- package/skills/distributed-debugging-debug-trace/resources/implementation-playbook.md +1307 -0
- package/skills/distributed-tracing/SKILL.md +450 -0
- package/skills/django-pro/SKILL.md +180 -0
- package/skills/docs-architect/SKILL.md +98 -0
- package/skills/documentation-generation-doc-generate/SKILL.md +48 -0
- package/skills/documentation-generation-doc-generate/resources/implementation-playbook.md +640 -0
- package/skills/dotnet-architect/SKILL.md +197 -0
- package/skills/dotnet-backend-patterns/SKILL.md +37 -0
- package/skills/dotnet-backend-patterns/assets/repository-template.cs +523 -0
- package/skills/dotnet-backend-patterns/assets/service-template.cs +336 -0
- package/skills/dotnet-backend-patterns/references/dapper-patterns.md +544 -0
- package/skills/dotnet-backend-patterns/references/ef-core-best-practices.md +355 -0
- package/skills/dotnet-backend-patterns/resources/implementation-playbook.md +799 -0
- package/skills/dummy-skill/SKILL.md +5 -0
- package/skills/dx-optimizer/SKILL.md +83 -0
- package/skills/e2e-testing-patterns/SKILL.md +41 -0
- package/skills/e2e-testing-patterns/resources/implementation-playbook.md +531 -0
- package/skills/elixir-pro/SKILL.md +59 -0
- package/skills/embedding-strategies/SKILL.md +491 -0
- package/skills/employment-contract-templates/SKILL.md +39 -0
- package/skills/employment-contract-templates/resources/implementation-playbook.md +493 -0
- package/skills/error-debugging-error-analysis/SKILL.md +47 -0
- package/skills/error-debugging-error-analysis/resources/implementation-playbook.md +1143 -0
- package/skills/error-debugging-error-trace/SKILL.md +43 -0
- package/skills/error-debugging-error-trace/resources/implementation-playbook.md +1361 -0
- package/skills/error-debugging-multi-agent-review/SKILL.md +216 -0
- package/skills/error-detective/SKILL.md +53 -0
- package/skills/error-diagnostics-error-analysis/SKILL.md +47 -0
- package/skills/error-diagnostics-error-analysis/resources/implementation-playbook.md +1143 -0
- package/skills/error-diagnostics-error-trace/SKILL.md +48 -0
- package/skills/error-diagnostics-error-trace/resources/implementation-playbook.md +1371 -0
- package/skills/error-diagnostics-smart-debug/SKILL.md +197 -0
- package/skills/error-handling-patterns/SKILL.md +35 -0
- package/skills/error-handling-patterns/resources/implementation-playbook.md +635 -0
- package/skills/event-sourcing-architect/SKILL.md +58 -0
- package/skills/event-store-design/SKILL.md +449 -0
- package/skills/fastapi-pro/SKILL.md +192 -0
- package/skills/fastapi-templates/SKILL.md +32 -0
- package/skills/fastapi-templates/resources/implementation-playbook.md +566 -0
- package/skills/final-test/SKILL.md +5 -0
- package/skills/firmware-analyst/SKILL.md +320 -0
- package/skills/flutter-expert/SKILL.md +200 -0
- package/skills/framework-migration-code-migrate/SKILL.md +48 -0
- package/skills/framework-migration-code-migrate/resources/implementation-playbook.md +1052 -0
- package/skills/framework-migration-deps-upgrade/SKILL.md +48 -0
- package/skills/framework-migration-deps-upgrade/resources/implementation-playbook.md +755 -0
- package/skills/framework-migration-legacy-modernize/SKILL.md +132 -0
- package/skills/frontend-developer/SKILL.md +171 -0
- package/skills/frontend-mobile-development-component-scaffold/SKILL.md +403 -0
- package/skills/frontend-mobile-security-xss-scan/SKILL.md +322 -0
- package/skills/frontend-security-coder/SKILL.md +170 -0
- package/skills/full-stack-orchestration-full-stack-feature/SKILL.md +135 -0
- package/skills/gdpr-data-handling/SKILL.md +33 -0
- package/skills/gdpr-data-handling/resources/implementation-playbook.md +615 -0
- package/skills/git-advanced-workflows/SKILL.md +412 -0
- package/skills/git-pr-workflows-git-workflow/SKILL.md +140 -0
- package/skills/git-pr-workflows-onboard/SKILL.md +416 -0
- package/skills/git-pr-workflows-pr-enhance/SKILL.md +48 -0
- package/skills/git-pr-workflows-pr-enhance/resources/implementation-playbook.md +701 -0
- package/skills/github-actions-templates/SKILL.md +345 -0
- package/skills/gitlab-ci-patterns/SKILL.md +283 -0
- package/skills/gitops-workflow/SKILL.md +303 -0
- package/skills/gitops-workflow/references/argocd-setup.md +134 -0
- package/skills/gitops-workflow/references/sync-policies.md +131 -0
- package/skills/go-concurrency-patterns/SKILL.md +33 -0
- package/skills/go-concurrency-patterns/resources/implementation-playbook.md +654 -0
- package/skills/godot-gdscript-patterns/SKILL.md +33 -0
- package/skills/godot-gdscript-patterns/resources/implementation-playbook.md +804 -0
- package/skills/golang-pro/SKILL.md +179 -0
- package/skills/grafana-dashboards/SKILL.md +381 -0
- package/skills/graphql-architect/SKILL.md +182 -0
- package/skills/haskell-pro/SKILL.md +56 -0
- package/skills/helm-chart-scaffolding/SKILL.md +34 -0
- package/skills/helm-chart-scaffolding/assets/Chart.yaml.template +42 -0
- package/skills/helm-chart-scaffolding/assets/values.yaml.template +185 -0
- package/skills/helm-chart-scaffolding/references/chart-structure.md +500 -0
- package/skills/helm-chart-scaffolding/resources/implementation-playbook.md +543 -0
- package/skills/helm-chart-scaffolding/scripts/validate-chart.sh +244 -0
- package/skills/hr-pro/SKILL.md +126 -0
- package/skills/hybrid-cloud-architect/SKILL.md +168 -0
- package/skills/hybrid-cloud-networking/SKILL.md +238 -0
- package/skills/hybrid-search-implementation/SKILL.md +32 -0
- package/skills/hybrid-search-implementation/resources/implementation-playbook.md +567 -0
- package/skills/incident-responder/SKILL.md +213 -0
- package/skills/incident-response-incident-response/SKILL.md +168 -0
- package/skills/incident-response-smart-fix/SKILL.md +29 -0
- package/skills/incident-response-smart-fix/resources/implementation-playbook.md +838 -0
- package/skills/incident-runbook-templates/SKILL.md +395 -0
- package/skills/ios-developer/SKILL.md +219 -0
- package/skills/istio-traffic-management/SKILL.md +337 -0
- package/skills/java-pro/SKILL.md +177 -0
- package/skills/javascript-pro/SKILL.md +57 -0
- package/skills/javascript-testing-patterns/SKILL.md +35 -0
- package/skills/javascript-testing-patterns/resources/implementation-playbook.md +1024 -0
- package/skills/javascript-typescript-typescript-scaffold/SKILL.md +361 -0
- package/skills/julia-pro/SKILL.md +209 -0
- package/skills/k8s-manifest-generator/SKILL.md +35 -0
- package/skills/k8s-manifest-generator/assets/configmap-template.yaml +296 -0
- package/skills/k8s-manifest-generator/assets/deployment-template.yaml +203 -0
- package/skills/k8s-manifest-generator/assets/service-template.yaml +171 -0
- package/skills/k8s-manifest-generator/references/deployment-spec.md +753 -0
- package/skills/k8s-manifest-generator/references/service-spec.md +724 -0
- package/skills/k8s-manifest-generator/resources/implementation-playbook.md +510 -0
- package/skills/k8s-security-policies/SKILL.md +346 -0
- package/skills/k8s-security-policies/assets/network-policy-template.yaml +177 -0
- package/skills/k8s-security-policies/references/rbac-patterns.md +187 -0
- package/skills/kpi-dashboard-design/SKILL.md +440 -0
- package/skills/kubernetes-architect/SKILL.md +170 -0
- package/skills/langchain-architecture/SKILL.md +350 -0
- package/skills/legacy-modernizer/SKILL.md +53 -0
- package/skills/legal-advisor/SKILL.md +70 -0
- package/skills/linkerd-patterns/SKILL.md +321 -0
- package/skills/llm-application-dev-ai-assistant/SKILL.md +35 -0
- package/skills/llm-application-dev-ai-assistant/resources/implementation-playbook.md +1236 -0
- package/skills/llm-application-dev-langchain-agent/SKILL.md +246 -0
- package/skills/llm-application-dev-prompt-optimize/SKILL.md +37 -0
- package/skills/llm-application-dev-prompt-optimize/resources/implementation-playbook.md +591 -0
- package/skills/llm-evaluation/SKILL.md +483 -0
- package/skills/machine-learning-ops-ml-pipeline/SKILL.md +314 -0
- package/skills/malware-analyst/SKILL.md +247 -0
- package/skills/market-sizing-analysis/SKILL.md +425 -0
- package/skills/market-sizing-analysis/examples/saas-market-sizing.md +349 -0
- package/skills/market-sizing-analysis/references/data-sources.md +360 -0
- package/skills/memory-forensics/SKILL.md +491 -0
- package/skills/memory-safety-patterns/SKILL.md +33 -0
- package/skills/memory-safety-patterns/resources/implementation-playbook.md +603 -0
- package/skills/mermaid-expert/SKILL.md +59 -0
- package/skills/microservices-patterns/SKILL.md +35 -0
- package/skills/microservices-patterns/resources/implementation-playbook.md +607 -0
- package/skills/minecraft-bukkit-pro/SKILL.md +126 -0
- package/skills/ml-engineer/SKILL.md +168 -0
- package/skills/ml-pipeline-workflow/SKILL.md +257 -0
- package/skills/mlops-engineer/SKILL.md +219 -0
- package/skills/mobile-developer/SKILL.md +205 -0
- package/skills/mobile-security-coder/SKILL.md +184 -0
- package/skills/modern-javascript-patterns/SKILL.md +35 -0
- package/skills/modern-javascript-patterns/resources/implementation-playbook.md +910 -0
- package/skills/monorepo-architect/SKILL.md +61 -0
- package/skills/monorepo-management/SKILL.md +35 -0
- package/skills/monorepo-management/resources/implementation-playbook.md +621 -0
- package/skills/mtls-configuration/SKILL.md +359 -0
- package/skills/multi-cloud-architecture/SKILL.md +189 -0
- package/skills/multi-platform-apps-multi-platform/SKILL.md +203 -0
- package/skills/network-engineer/SKILL.md +169 -0
- package/skills/nextjs-app-router-patterns/SKILL.md +33 -0
- package/skills/nextjs-app-router-patterns/resources/implementation-playbook.md +543 -0
- package/skills/nft-standards/SKILL.md +395 -0
- package/skills/node-expert/SKILL.md +23 -0
- package/skills/nodejs-backend-patterns/SKILL.md +35 -0
- package/skills/nodejs-backend-patterns/resources/implementation-playbook.md +1019 -0
- package/skills/nx-workspace-patterns/SKILL.md +464 -0
- package/skills/observability-engineer/SKILL.md +237 -0
- package/skills/observability-monitoring-monitor-setup/SKILL.md +48 -0
- package/skills/observability-monitoring-monitor-setup/resources/implementation-playbook.md +505 -0
- package/skills/observability-monitoring-slo-implement/SKILL.md +43 -0
- package/skills/observability-monitoring-slo-implement/resources/implementation-playbook.md +1077 -0
- package/skills/on-call-handoff-patterns/SKILL.md +453 -0
- package/skills/openapi-spec-generation/SKILL.md +33 -0
- package/skills/openapi-spec-generation/resources/implementation-playbook.md +1027 -0
- package/skills/payment-integration/SKILL.md +77 -0
- package/skills/paypal-integration/SKILL.md +479 -0
- package/skills/pci-compliance/SKILL.md +478 -0
- package/skills/performance-engineer/SKILL.md +180 -0
- package/skills/performance-testing-review-ai-review/SKILL.md +450 -0
- package/skills/performance-testing-review-multi-agent-review/SKILL.md +216 -0
- package/skills/php-pro/SKILL.md +63 -0
- package/skills/posix-shell-pro/SKILL.md +304 -0
- package/skills/postgresql/SKILL.md +230 -0
- package/skills/postmortem-writing/SKILL.md +386 -0
- package/skills/projection-patterns/SKILL.md +33 -0
- package/skills/projection-patterns/resources/implementation-playbook.md +501 -0
- package/skills/prometheus-configuration/SKILL.md +404 -0
- package/skills/prompt-engineer/SKILL.md +272 -0
- package/skills/prompt-engineering-patterns/SKILL.md +213 -0
- package/skills/prompt-engineering-patterns/assets/few-shot-examples.json +106 -0
- package/skills/prompt-engineering-patterns/assets/prompt-template-library.md +246 -0
- package/skills/prompt-engineering-patterns/references/chain-of-thought.md +399 -0
- package/skills/prompt-engineering-patterns/references/few-shot-learning.md +369 -0
- package/skills/prompt-engineering-patterns/references/prompt-optimization.md +414 -0
- package/skills/prompt-engineering-patterns/references/prompt-templates.md +470 -0
- package/skills/prompt-engineering-patterns/references/system-prompts.md +189 -0
- package/skills/prompt-engineering-patterns/scripts/optimize-prompt.py +279 -0
- package/skills/protocol-reverse-engineering/SKILL.md +29 -0
- package/skills/protocol-reverse-engineering/resources/implementation-playbook.md +509 -0
- package/skills/python-development-python-scaffold/SKILL.md +331 -0
- package/skills/python-packaging/SKILL.md +36 -0
- package/skills/python-packaging/resources/implementation-playbook.md +869 -0
- package/skills/python-performance-optimization/SKILL.md +36 -0
- package/skills/python-performance-optimization/resources/implementation-playbook.md +868 -0
- package/skills/python-pro/SKILL.md +158 -0
- package/skills/python-testing-patterns/SKILL.md +37 -0
- package/skills/python-testing-patterns/resources/implementation-playbook.md +906 -0
- package/skills/quant-analyst/SKILL.md +53 -0
- package/skills/rag-implementation/SKILL.md +421 -0
- package/skills/react-modernization/SKILL.md +34 -0
- package/skills/react-modernization/resources/implementation-playbook.md +512 -0
- package/skills/react-native-architecture/SKILL.md +33 -0
- package/skills/react-native-architecture/resources/implementation-playbook.md +670 -0
- package/skills/react-state-management/SKILL.md +441 -0
- package/skills/reference-builder/SKILL.md +188 -0
- package/skills/reverse-engineer/SKILL.md +173 -0
- package/skills/risk-manager/SKILL.md +61 -0
- package/skills/risk-metrics-calculation/SKILL.md +33 -0
- package/skills/risk-metrics-calculation/resources/implementation-playbook.md +554 -0
- package/skills/ruby-pro/SKILL.md +56 -0
- package/skills/rust-async-patterns/SKILL.md +33 -0
- package/skills/rust-async-patterns/resources/implementation-playbook.md +516 -0
- package/skills/rust-pro/SKILL.md +178 -0
- package/skills/saga-orchestration/SKILL.md +496 -0
- package/skills/sales-automator/SKILL.md +55 -0
- package/skills/sast-configuration/SKILL.md +212 -0
- package/skills/scala-pro/SKILL.md +82 -0
- package/skills/screen-reader-testing/SKILL.md +33 -0
- package/skills/screen-reader-testing/resources/implementation-playbook.md +544 -0
- package/skills/search-specialist/SKILL.md +80 -0
- package/skills/secrets-management/SKILL.md +364 -0
- package/skills/security-auditor/SKILL.md +169 -0
- package/skills/security-compliance-compliance-check/SKILL.md +55 -0
- package/skills/security-compliance-compliance-check/resources/implementation-playbook.md +963 -0
- package/skills/security-requirement-extraction/SKILL.md +33 -0
- package/skills/security-requirement-extraction/resources/implementation-playbook.md +676 -0
- package/skills/security-scanning-security-dependencies/SKILL.md +43 -0
- package/skills/security-scanning-security-dependencies/resources/implementation-playbook.md +544 -0
- package/skills/security-scanning-security-hardening/SKILL.md +147 -0
- package/skills/security-scanning-security-sast/SKILL.md +495 -0
- package/skills/seo-authority-builder/SKILL.md +136 -0
- package/skills/seo-cannibalization-detector/SKILL.md +123 -0
- package/skills/seo-content-auditor/SKILL.md +83 -0
- package/skills/seo-content-planner/SKILL.md +108 -0
- package/skills/seo-content-refresher/SKILL.md +118 -0
- package/skills/seo-content-writer/SKILL.md +96 -0
- package/skills/seo-keyword-strategist/SKILL.md +95 -0
- package/skills/seo-meta-optimizer/SKILL.md +92 -0
- package/skills/seo-snippet-hunter/SKILL.md +114 -0
- package/skills/seo-structure-architect/SKILL.md +108 -0
- package/skills/service-mesh-expert/SKILL.md +58 -0
- package/skills/service-mesh-observability/SKILL.md +395 -0
- package/skills/shellcheck-configuration/SKILL.md +466 -0
- package/skills/similarity-search-patterns/SKILL.md +33 -0
- package/skills/similarity-search-patterns/resources/implementation-playbook.md +557 -0
- package/skills/slo-implementation/SKILL.md +341 -0
- package/skills/solidity-security/SKILL.md +34 -0
- package/skills/solidity-security/resources/implementation-playbook.md +524 -0
- package/skills/spark-optimization/SKILL.md +427 -0
- package/skills/sql-optimization-patterns/SKILL.md +35 -0
- package/skills/sql-optimization-patterns/resources/implementation-playbook.md +504 -0
- package/skills/sql-pro/SKILL.md +173 -0
- package/skills/startup-analyst/SKILL.md +328 -0
- package/skills/startup-business-analyst-business-case/SKILL.md +487 -0
- package/skills/startup-business-analyst-financial-projections/SKILL.md +353 -0
- package/skills/startup-business-analyst-market-opportunity/SKILL.md +240 -0
- package/skills/startup-financial-modeling/SKILL.md +467 -0
- package/skills/startup-metrics-framework/SKILL.md +34 -0
- package/skills/startup-metrics-framework/resources/implementation-playbook.md +500 -0
- package/skills/stride-analysis-patterns/SKILL.md +33 -0
- package/skills/stride-analysis-patterns/resources/implementation-playbook.md +655 -0
- package/skills/stripe-integration/SKILL.md +454 -0
- package/skills/systems-programming-rust-project/SKILL.md +440 -0
- package/skills/tailwind-design-system/SKILL.md +33 -0
- package/skills/tailwind-design-system/resources/implementation-playbook.md +665 -0
- package/skills/tdd-orchestrator/SKILL.md +205 -0
- package/skills/tdd-workflows-tdd-cycle/SKILL.md +221 -0
- package/skills/tdd-workflows-tdd-green/SKILL.md +73 -0
- package/skills/tdd-workflows-tdd-green/resources/implementation-playbook.md +870 -0
- package/skills/tdd-workflows-tdd-red/SKILL.md +164 -0
- package/skills/tdd-workflows-tdd-refactor/SKILL.md +187 -0
- package/skills/team-collaboration-issue/SKILL.md +37 -0
- package/skills/team-collaboration-issue/resources/implementation-playbook.md +640 -0
- package/skills/team-collaboration-standup-notes/SKILL.md +44 -0
- package/skills/team-collaboration-standup-notes/resources/implementation-playbook.md +768 -0
- package/skills/team-composition-analysis/SKILL.md +413 -0
- package/skills/temporal-python-pro/SKILL.md +370 -0
- package/skills/temporal-python-testing/SKILL.md +170 -0
- package/skills/temporal-python-testing/resources/integration-testing.md +455 -0
- package/skills/temporal-python-testing/resources/local-setup.md +553 -0
- package/skills/temporal-python-testing/resources/replay-testing.md +462 -0
- package/skills/temporal-python-testing/resources/unit-testing.md +328 -0
- package/skills/terraform-module-library/SKILL.md +261 -0
- package/skills/terraform-module-library/references/aws-modules.md +63 -0
- package/skills/terraform-specialist/SKILL.md +166 -0
- package/skills/test-automator/SKILL.md +224 -0
- package/skills/threat-mitigation-mapping/SKILL.md +33 -0
- package/skills/threat-mitigation-mapping/resources/implementation-playbook.md +744 -0
- package/skills/threat-modeling-expert/SKILL.md +60 -0
- package/skills/track-management/SKILL.md +38 -0
- package/skills/track-management/resources/implementation-playbook.md +591 -0
- package/skills/turborepo-caching/SKILL.md +419 -0
- package/skills/tutorial-engineer/SKILL.md +139 -0
- package/skills/typescript-advanced-types/SKILL.md +35 -0
- package/skills/typescript-advanced-types/resources/implementation-playbook.md +716 -0
- package/skills/typescript-pro/SKILL.md +55 -0
- package/skills/ui-minimal/SKILL.md +23 -0
- package/skills/ui-ux-designer/SKILL.md +209 -0
- package/skills/ui-visual-validator/SKILL.md +214 -0
- package/skills/unit-testing-test-generate/SKILL.md +319 -0
- package/skills/unity-developer/SKILL.md +230 -0
- package/skills/unity-ecs-patterns/SKILL.md +33 -0
- package/skills/unity-ecs-patterns/resources/implementation-playbook.md +625 -0
- package/skills/uv-package-manager/SKILL.md +37 -0
- package/skills/uv-package-manager/resources/implementation-playbook.md +830 -0
- package/skills/vector-database-engineer/SKILL.md +60 -0
- package/skills/vector-index-tuning/SKILL.md +42 -0
- package/skills/vector-index-tuning/resources/implementation-playbook.md +507 -0
- package/skills/wcag-audit-patterns/SKILL.md +41 -0
- package/skills/wcag-audit-patterns/resources/implementation-playbook.md +541 -0
- package/skills/web3-testing/SKILL.md +427 -0
- package/skills/workflow-orchestration-patterns/SKILL.md +333 -0
- package/skills/workflow-patterns/SKILL.md +38 -0
- package/skills/workflow-patterns/resources/implementation-playbook.md +621 -0
|
@@ -0,0 +1,427 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: web3-testing
|
|
3
|
+
description: Test smart contracts comprehensively using Hardhat and Foundry with unit tests, integration tests, and mainnet forking. Use when testing Solidity contracts, setting up blockchain test suites, or validating DeFi protocols.
|
|
4
|
+
---
|
|
5
|
+
|
|
6
|
+
# Web3 Smart Contract Testing
|
|
7
|
+
|
|
8
|
+
Master comprehensive testing strategies for smart contracts using Hardhat, Foundry, and advanced testing patterns.
|
|
9
|
+
|
|
10
|
+
## Do not use this skill when
|
|
11
|
+
|
|
12
|
+
- The task is unrelated to web3 smart contract testing
|
|
13
|
+
- You need a different domain or tool outside this scope
|
|
14
|
+
|
|
15
|
+
## Instructions
|
|
16
|
+
|
|
17
|
+
- Clarify goals, constraints, and required inputs.
|
|
18
|
+
- Apply relevant best practices and validate outcomes.
|
|
19
|
+
- Provide actionable steps and verification.
|
|
20
|
+
- If detailed examples are required, open `resources/implementation-playbook.md`.
|
|
21
|
+
|
|
22
|
+
## Use this skill when
|
|
23
|
+
|
|
24
|
+
- Writing unit tests for smart contracts
|
|
25
|
+
- Setting up integration test suites
|
|
26
|
+
- Performing gas optimization testing
|
|
27
|
+
- Fuzzing for edge cases
|
|
28
|
+
- Forking mainnet for realistic testing
|
|
29
|
+
- Automating test coverage reporting
|
|
30
|
+
- Verifying contracts on Etherscan
|
|
31
|
+
|
|
32
|
+
## Hardhat Testing Setup
|
|
33
|
+
|
|
34
|
+
```javascript
|
|
35
|
+
// hardhat.config.js
|
|
36
|
+
require("@nomicfoundation/hardhat-toolbox");
|
|
37
|
+
require("@nomiclabs/hardhat-etherscan");
|
|
38
|
+
require("hardhat-gas-reporter");
|
|
39
|
+
require("solidity-coverage");
|
|
40
|
+
|
|
41
|
+
module.exports = {
|
|
42
|
+
solidity: {
|
|
43
|
+
version: "0.8.19",
|
|
44
|
+
settings: {
|
|
45
|
+
optimizer: {
|
|
46
|
+
enabled: true,
|
|
47
|
+
runs: 200,
|
|
48
|
+
},
|
|
49
|
+
},
|
|
50
|
+
},
|
|
51
|
+
networks: {
|
|
52
|
+
hardhat: {
|
|
53
|
+
forking: {
|
|
54
|
+
url: process.env.MAINNET_RPC_URL,
|
|
55
|
+
blockNumber: 15000000,
|
|
56
|
+
},
|
|
57
|
+
},
|
|
58
|
+
goerli: {
|
|
59
|
+
url: process.env.GOERLI_RPC_URL,
|
|
60
|
+
accounts: [process.env.PRIVATE_KEY],
|
|
61
|
+
},
|
|
62
|
+
},
|
|
63
|
+
gasReporter: {
|
|
64
|
+
enabled: true,
|
|
65
|
+
currency: "USD",
|
|
66
|
+
coinmarketcap: process.env.COINMARKETCAP_API_KEY,
|
|
67
|
+
},
|
|
68
|
+
etherscan: {
|
|
69
|
+
apiKey: process.env.ETHERSCAN_API_KEY,
|
|
70
|
+
},
|
|
71
|
+
};
|
|
72
|
+
```
|
|
73
|
+
|
|
74
|
+
## Unit Testing Patterns
|
|
75
|
+
|
|
76
|
+
```javascript
|
|
77
|
+
const { expect } = require("chai");
|
|
78
|
+
const { ethers } = require("hardhat");
|
|
79
|
+
const {
|
|
80
|
+
loadFixture,
|
|
81
|
+
time,
|
|
82
|
+
} = require("@nomicfoundation/hardhat-network-helpers");
|
|
83
|
+
|
|
84
|
+
describe("Token Contract", function () {
|
|
85
|
+
// Fixture for test setup
|
|
86
|
+
async function deployTokenFixture() {
|
|
87
|
+
const [owner, addr1, addr2] = await ethers.getSigners();
|
|
88
|
+
|
|
89
|
+
const Token = await ethers.getContractFactory("Token");
|
|
90
|
+
const token = await Token.deploy();
|
|
91
|
+
|
|
92
|
+
return { token, owner, addr1, addr2 };
|
|
93
|
+
}
|
|
94
|
+
|
|
95
|
+
describe("Deployment", function () {
|
|
96
|
+
it("Should set the right owner", async function () {
|
|
97
|
+
const { token, owner } = await loadFixture(deployTokenFixture);
|
|
98
|
+
expect(await token.owner()).to.equal(owner.address);
|
|
99
|
+
});
|
|
100
|
+
|
|
101
|
+
it("Should assign total supply to owner", async function () {
|
|
102
|
+
const { token, owner } = await loadFixture(deployTokenFixture);
|
|
103
|
+
const ownerBalance = await token.balanceOf(owner.address);
|
|
104
|
+
expect(await token.totalSupply()).to.equal(ownerBalance);
|
|
105
|
+
});
|
|
106
|
+
});
|
|
107
|
+
|
|
108
|
+
describe("Transactions", function () {
|
|
109
|
+
it("Should transfer tokens between accounts", async function () {
|
|
110
|
+
const { token, owner, addr1 } = await loadFixture(deployTokenFixture);
|
|
111
|
+
|
|
112
|
+
await expect(token.transfer(addr1.address, 50)).to.changeTokenBalances(
|
|
113
|
+
token,
|
|
114
|
+
[owner, addr1],
|
|
115
|
+
[-50, 50],
|
|
116
|
+
);
|
|
117
|
+
});
|
|
118
|
+
|
|
119
|
+
it("Should fail if sender doesn't have enough tokens", async function () {
|
|
120
|
+
const { token, addr1 } = await loadFixture(deployTokenFixture);
|
|
121
|
+
const initialBalance = await token.balanceOf(addr1.address);
|
|
122
|
+
|
|
123
|
+
await expect(
|
|
124
|
+
token.connect(addr1).transfer(owner.address, 1),
|
|
125
|
+
).to.be.revertedWith("Insufficient balance");
|
|
126
|
+
});
|
|
127
|
+
|
|
128
|
+
it("Should emit Transfer event", async function () {
|
|
129
|
+
const { token, owner, addr1 } = await loadFixture(deployTokenFixture);
|
|
130
|
+
|
|
131
|
+
await expect(token.transfer(addr1.address, 50))
|
|
132
|
+
.to.emit(token, "Transfer")
|
|
133
|
+
.withArgs(owner.address, addr1.address, 50);
|
|
134
|
+
});
|
|
135
|
+
});
|
|
136
|
+
|
|
137
|
+
describe("Time-based tests", function () {
|
|
138
|
+
it("Should handle time-locked operations", async function () {
|
|
139
|
+
const { token } = await loadFixture(deployTokenFixture);
|
|
140
|
+
|
|
141
|
+
// Increase time by 1 day
|
|
142
|
+
await time.increase(86400);
|
|
143
|
+
|
|
144
|
+
// Test time-dependent functionality
|
|
145
|
+
});
|
|
146
|
+
});
|
|
147
|
+
|
|
148
|
+
describe("Gas optimization", function () {
|
|
149
|
+
it("Should use gas efficiently", async function () {
|
|
150
|
+
const { token } = await loadFixture(deployTokenFixture);
|
|
151
|
+
|
|
152
|
+
const tx = await token.transfer(addr1.address, 100);
|
|
153
|
+
const receipt = await tx.wait();
|
|
154
|
+
|
|
155
|
+
expect(receipt.gasUsed).to.be.lessThan(50000);
|
|
156
|
+
});
|
|
157
|
+
});
|
|
158
|
+
});
|
|
159
|
+
```
|
|
160
|
+
|
|
161
|
+
## Foundry Testing (Forge)
|
|
162
|
+
|
|
163
|
+
```solidity
|
|
164
|
+
// SPDX-License-Identifier: MIT
|
|
165
|
+
pragma solidity ^0.8.0;
|
|
166
|
+
|
|
167
|
+
import "forge-std/Test.sol";
|
|
168
|
+
import "../src/Token.sol";
|
|
169
|
+
|
|
170
|
+
contract TokenTest is Test {
|
|
171
|
+
Token token;
|
|
172
|
+
address owner = address(1);
|
|
173
|
+
address user1 = address(2);
|
|
174
|
+
address user2 = address(3);
|
|
175
|
+
|
|
176
|
+
function setUp() public {
|
|
177
|
+
vm.prank(owner);
|
|
178
|
+
token = new Token();
|
|
179
|
+
}
|
|
180
|
+
|
|
181
|
+
function testInitialSupply() public {
|
|
182
|
+
assertEq(token.totalSupply(), 1000000 * 10**18);
|
|
183
|
+
}
|
|
184
|
+
|
|
185
|
+
function testTransfer() public {
|
|
186
|
+
vm.prank(owner);
|
|
187
|
+
token.transfer(user1, 100);
|
|
188
|
+
|
|
189
|
+
assertEq(token.balanceOf(user1), 100);
|
|
190
|
+
assertEq(token.balanceOf(owner), token.totalSupply() - 100);
|
|
191
|
+
}
|
|
192
|
+
|
|
193
|
+
function testFailTransferInsufficientBalance() public {
|
|
194
|
+
vm.prank(user1);
|
|
195
|
+
token.transfer(user2, 100); // Should fail
|
|
196
|
+
}
|
|
197
|
+
|
|
198
|
+
function testCannotTransferToZeroAddress() public {
|
|
199
|
+
vm.prank(owner);
|
|
200
|
+
vm.expectRevert("Invalid recipient");
|
|
201
|
+
token.transfer(address(0), 100);
|
|
202
|
+
}
|
|
203
|
+
|
|
204
|
+
// Fuzzing test
|
|
205
|
+
function testFuzzTransfer(uint256 amount) public {
|
|
206
|
+
vm.assume(amount > 0 && amount <= token.totalSupply());
|
|
207
|
+
|
|
208
|
+
vm.prank(owner);
|
|
209
|
+
token.transfer(user1, amount);
|
|
210
|
+
|
|
211
|
+
assertEq(token.balanceOf(user1), amount);
|
|
212
|
+
}
|
|
213
|
+
|
|
214
|
+
// Test with cheatcodes
|
|
215
|
+
function testDealAndPrank() public {
|
|
216
|
+
// Give ETH to address
|
|
217
|
+
vm.deal(user1, 10 ether);
|
|
218
|
+
|
|
219
|
+
// Impersonate address
|
|
220
|
+
vm.prank(user1);
|
|
221
|
+
|
|
222
|
+
// Test functionality
|
|
223
|
+
assertEq(user1.balance, 10 ether);
|
|
224
|
+
}
|
|
225
|
+
|
|
226
|
+
// Mainnet fork test
|
|
227
|
+
function testForkMainnet() public {
|
|
228
|
+
vm.createSelectFork("https://eth-mainnet.alchemyapi.io/v2/...");
|
|
229
|
+
|
|
230
|
+
// Interact with mainnet contracts
|
|
231
|
+
address dai = 0x6B175474E89094C44Da98b954EedeAC495271d0F;
|
|
232
|
+
assertEq(IERC20(dai).symbol(), "DAI");
|
|
233
|
+
}
|
|
234
|
+
}
|
|
235
|
+
```
|
|
236
|
+
|
|
237
|
+
## Advanced Testing Patterns
|
|
238
|
+
|
|
239
|
+
### Snapshot and Revert
|
|
240
|
+
|
|
241
|
+
```javascript
|
|
242
|
+
describe("Complex State Changes", function () {
|
|
243
|
+
let snapshotId;
|
|
244
|
+
|
|
245
|
+
beforeEach(async function () {
|
|
246
|
+
snapshotId = await network.provider.send("evm_snapshot");
|
|
247
|
+
});
|
|
248
|
+
|
|
249
|
+
afterEach(async function () {
|
|
250
|
+
await network.provider.send("evm_revert", [snapshotId]);
|
|
251
|
+
});
|
|
252
|
+
|
|
253
|
+
it("Test 1", async function () {
|
|
254
|
+
// Make state changes
|
|
255
|
+
});
|
|
256
|
+
|
|
257
|
+
it("Test 2", async function () {
|
|
258
|
+
// State reverted, clean slate
|
|
259
|
+
});
|
|
260
|
+
});
|
|
261
|
+
```
|
|
262
|
+
|
|
263
|
+
### Mainnet Forking
|
|
264
|
+
|
|
265
|
+
```javascript
|
|
266
|
+
describe("Mainnet Fork Tests", function () {
|
|
267
|
+
let uniswapRouter, dai, usdc;
|
|
268
|
+
|
|
269
|
+
before(async function () {
|
|
270
|
+
await network.provider.request({
|
|
271
|
+
method: "hardhat_reset",
|
|
272
|
+
params: [
|
|
273
|
+
{
|
|
274
|
+
forking: {
|
|
275
|
+
jsonRpcUrl: process.env.MAINNET_RPC_URL,
|
|
276
|
+
blockNumber: 15000000,
|
|
277
|
+
},
|
|
278
|
+
},
|
|
279
|
+
],
|
|
280
|
+
});
|
|
281
|
+
|
|
282
|
+
// Connect to existing mainnet contracts
|
|
283
|
+
uniswapRouter = await ethers.getContractAt(
|
|
284
|
+
"IUniswapV2Router",
|
|
285
|
+
"0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D",
|
|
286
|
+
);
|
|
287
|
+
|
|
288
|
+
dai = await ethers.getContractAt(
|
|
289
|
+
"IERC20",
|
|
290
|
+
"0x6B175474E89094C44Da98b954EedeAC495271d0F",
|
|
291
|
+
);
|
|
292
|
+
});
|
|
293
|
+
|
|
294
|
+
it("Should swap on Uniswap", async function () {
|
|
295
|
+
// Test with real Uniswap contracts
|
|
296
|
+
});
|
|
297
|
+
});
|
|
298
|
+
```
|
|
299
|
+
|
|
300
|
+
### Impersonating Accounts
|
|
301
|
+
|
|
302
|
+
```javascript
|
|
303
|
+
it("Should impersonate whale account", async function () {
|
|
304
|
+
const whaleAddress = "0x...";
|
|
305
|
+
|
|
306
|
+
await network.provider.request({
|
|
307
|
+
method: "hardhat_impersonateAccount",
|
|
308
|
+
params: [whaleAddress],
|
|
309
|
+
});
|
|
310
|
+
|
|
311
|
+
const whale = await ethers.getSigner(whaleAddress);
|
|
312
|
+
|
|
313
|
+
// Use whale's tokens
|
|
314
|
+
await dai
|
|
315
|
+
.connect(whale)
|
|
316
|
+
.transfer(addr1.address, ethers.utils.parseEther("1000"));
|
|
317
|
+
});
|
|
318
|
+
```
|
|
319
|
+
|
|
320
|
+
## Gas Optimization Testing
|
|
321
|
+
|
|
322
|
+
```javascript
|
|
323
|
+
const { expect } = require("chai");
|
|
324
|
+
|
|
325
|
+
describe("Gas Optimization", function () {
|
|
326
|
+
it("Compare gas usage between implementations", async function () {
|
|
327
|
+
const Implementation1 =
|
|
328
|
+
await ethers.getContractFactory("OptimizedContract");
|
|
329
|
+
const Implementation2 = await ethers.getContractFactory(
|
|
330
|
+
"UnoptimizedContract",
|
|
331
|
+
);
|
|
332
|
+
|
|
333
|
+
const contract1 = await Implementation1.deploy();
|
|
334
|
+
const contract2 = await Implementation2.deploy();
|
|
335
|
+
|
|
336
|
+
const tx1 = await contract1.doSomething();
|
|
337
|
+
const receipt1 = await tx1.wait();
|
|
338
|
+
|
|
339
|
+
const tx2 = await contract2.doSomething();
|
|
340
|
+
const receipt2 = await tx2.wait();
|
|
341
|
+
|
|
342
|
+
console.log("Optimized gas:", receipt1.gasUsed.toString());
|
|
343
|
+
console.log("Unoptimized gas:", receipt2.gasUsed.toString());
|
|
344
|
+
|
|
345
|
+
expect(receipt1.gasUsed).to.be.lessThan(receipt2.gasUsed);
|
|
346
|
+
});
|
|
347
|
+
});
|
|
348
|
+
```
|
|
349
|
+
|
|
350
|
+
## Coverage Reporting
|
|
351
|
+
|
|
352
|
+
```bash
|
|
353
|
+
# Generate coverage report
|
|
354
|
+
npx hardhat coverage
|
|
355
|
+
|
|
356
|
+
# Output shows:
|
|
357
|
+
# File | % Stmts | % Branch | % Funcs | % Lines |
|
|
358
|
+
# -------------------|---------|----------|---------|---------|
|
|
359
|
+
# contracts/Token.sol | 100 | 90 | 100 | 95 |
|
|
360
|
+
```
|
|
361
|
+
|
|
362
|
+
## Contract Verification
|
|
363
|
+
|
|
364
|
+
```javascript
|
|
365
|
+
// Verify on Etherscan
|
|
366
|
+
await hre.run("verify:verify", {
|
|
367
|
+
address: contractAddress,
|
|
368
|
+
constructorArguments: [arg1, arg2],
|
|
369
|
+
});
|
|
370
|
+
```
|
|
371
|
+
|
|
372
|
+
```bash
|
|
373
|
+
# Or via CLI
|
|
374
|
+
npx hardhat verify --network mainnet CONTRACT_ADDRESS "Constructor arg1" "arg2"
|
|
375
|
+
```
|
|
376
|
+
|
|
377
|
+
## CI/CD Integration
|
|
378
|
+
|
|
379
|
+
```yaml
|
|
380
|
+
# .github/workflows/test.yml
|
|
381
|
+
name: Tests
|
|
382
|
+
|
|
383
|
+
on: [push, pull_request]
|
|
384
|
+
|
|
385
|
+
jobs:
|
|
386
|
+
test:
|
|
387
|
+
runs-on: ubuntu-latest
|
|
388
|
+
|
|
389
|
+
steps:
|
|
390
|
+
- uses: actions/checkout@v2
|
|
391
|
+
- uses: actions/setup-node@v2
|
|
392
|
+
with:
|
|
393
|
+
node-version: "16"
|
|
394
|
+
|
|
395
|
+
- run: npm install
|
|
396
|
+
- run: npx hardhat compile
|
|
397
|
+
- run: npx hardhat test
|
|
398
|
+
- run: npx hardhat coverage
|
|
399
|
+
|
|
400
|
+
- name: Upload coverage to Codecov
|
|
401
|
+
uses: codecov/codecov-action@v2
|
|
402
|
+
```
|
|
403
|
+
|
|
404
|
+
## Resources
|
|
405
|
+
|
|
406
|
+
- **references/hardhat-setup.md**: Hardhat configuration guide
|
|
407
|
+
- **references/foundry-setup.md**: Foundry testing framework
|
|
408
|
+
- **references/test-patterns.md**: Testing best practices
|
|
409
|
+
- **references/mainnet-forking.md**: Fork testing strategies
|
|
410
|
+
- **references/contract-verification.md**: Etherscan verification
|
|
411
|
+
- **assets/hardhat-config.js**: Complete Hardhat configuration
|
|
412
|
+
- **assets/test-suite.js**: Comprehensive test examples
|
|
413
|
+
- **assets/foundry.toml**: Foundry configuration
|
|
414
|
+
- **scripts/test-contract.sh**: Automated testing script
|
|
415
|
+
|
|
416
|
+
## Best Practices
|
|
417
|
+
|
|
418
|
+
1. **Test Coverage**: Aim for >90% coverage
|
|
419
|
+
2. **Edge Cases**: Test boundary conditions
|
|
420
|
+
3. **Gas Limits**: Verify functions don't hit block gas limit
|
|
421
|
+
4. **Reentrancy**: Test for reentrancy vulnerabilities
|
|
422
|
+
5. **Access Control**: Test unauthorized access attempts
|
|
423
|
+
6. **Events**: Verify event emissions
|
|
424
|
+
7. **Fixtures**: Use fixtures to avoid code duplication
|
|
425
|
+
8. **Mainnet Fork**: Test with real contracts
|
|
426
|
+
9. **Fuzzing**: Use property-based testing
|
|
427
|
+
10. **CI/CD**: Automate testing on every commit
|