@waensaran/antigravity-skills 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 +355 -0
- package/LICENSE +21 -0
- package/README.md +264 -0
- package/SECURITY.md +15 -0
- package/aliases.json +65 -0
- package/bin/cli.js +485 -0
- package/bundles.json +265 -0
- package/catalog.json +7532 -0
- package/lib/skill-utils.js +164 -0
- package/package.json +49 -0
- package/scripts/build-catalog.js +355 -0
- package/scripts/normalize-frontmatter.js +149 -0
- package/scripts/validate-skills.js +266 -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/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/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/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/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/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-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
- package/validation-baseline.json +7 -0
|
@@ -0,0 +1,455 @@
|
|
|
1
|
+
# Integration Testing with Mocked Activities
|
|
2
|
+
|
|
3
|
+
Comprehensive patterns for testing workflows with mocked external dependencies, error injection, and complex scenarios.
|
|
4
|
+
|
|
5
|
+
## Activity Mocking Strategy
|
|
6
|
+
|
|
7
|
+
**Purpose**: Test workflow orchestration logic without calling real external services
|
|
8
|
+
|
|
9
|
+
### Basic Mock Pattern
|
|
10
|
+
|
|
11
|
+
```python
|
|
12
|
+
import pytest
|
|
13
|
+
from temporalio.testing import WorkflowEnvironment
|
|
14
|
+
from temporalio.worker import Worker
|
|
15
|
+
from unittest.mock import Mock
|
|
16
|
+
|
|
17
|
+
@pytest.mark.asyncio
|
|
18
|
+
async def test_workflow_with_mocked_activity(workflow_env):
|
|
19
|
+
"""Mock activity to test workflow logic"""
|
|
20
|
+
|
|
21
|
+
# Create mock activity
|
|
22
|
+
mock_activity = Mock(return_value="mocked-result")
|
|
23
|
+
|
|
24
|
+
@workflow.defn
|
|
25
|
+
class WorkflowWithActivity:
|
|
26
|
+
@workflow.run
|
|
27
|
+
async def run(self, input: str) -> str:
|
|
28
|
+
result = await workflow.execute_activity(
|
|
29
|
+
process_external_data,
|
|
30
|
+
input,
|
|
31
|
+
start_to_close_timeout=timedelta(seconds=10),
|
|
32
|
+
)
|
|
33
|
+
return f"processed: {result}"
|
|
34
|
+
|
|
35
|
+
async with Worker(
|
|
36
|
+
workflow_env.client,
|
|
37
|
+
task_queue="test",
|
|
38
|
+
workflows=[WorkflowWithActivity],
|
|
39
|
+
activities=[mock_activity], # Use mock instead of real activity
|
|
40
|
+
):
|
|
41
|
+
result = await workflow_env.client.execute_workflow(
|
|
42
|
+
WorkflowWithActivity.run,
|
|
43
|
+
"test-input",
|
|
44
|
+
id="wf-mock",
|
|
45
|
+
task_queue="test",
|
|
46
|
+
)
|
|
47
|
+
assert result == "processed: mocked-result"
|
|
48
|
+
mock_activity.assert_called_once()
|
|
49
|
+
```
|
|
50
|
+
|
|
51
|
+
### Dynamic Mock Responses
|
|
52
|
+
|
|
53
|
+
**Scenario-Based Mocking**:
|
|
54
|
+
|
|
55
|
+
```python
|
|
56
|
+
@pytest.mark.asyncio
|
|
57
|
+
async def test_workflow_multiple_mock_scenarios(workflow_env):
|
|
58
|
+
"""Test different workflow paths with dynamic mocks"""
|
|
59
|
+
|
|
60
|
+
# Mock returns different values based on input
|
|
61
|
+
def dynamic_activity(input: str) -> str:
|
|
62
|
+
if input == "error-case":
|
|
63
|
+
raise ApplicationError("Validation failed", non_retryable=True)
|
|
64
|
+
return f"processed-{input}"
|
|
65
|
+
|
|
66
|
+
@workflow.defn
|
|
67
|
+
class DynamicWorkflow:
|
|
68
|
+
@workflow.run
|
|
69
|
+
async def run(self, input: str) -> str:
|
|
70
|
+
try:
|
|
71
|
+
result = await workflow.execute_activity(
|
|
72
|
+
dynamic_activity,
|
|
73
|
+
input,
|
|
74
|
+
start_to_close_timeout=timedelta(seconds=10),
|
|
75
|
+
)
|
|
76
|
+
return f"success: {result}"
|
|
77
|
+
except ApplicationError as e:
|
|
78
|
+
return f"error: {e.message}"
|
|
79
|
+
|
|
80
|
+
async with Worker(
|
|
81
|
+
workflow_env.client,
|
|
82
|
+
task_queue="test",
|
|
83
|
+
workflows=[DynamicWorkflow],
|
|
84
|
+
activities=[dynamic_activity],
|
|
85
|
+
):
|
|
86
|
+
# Test success path
|
|
87
|
+
result_success = await workflow_env.client.execute_workflow(
|
|
88
|
+
DynamicWorkflow.run,
|
|
89
|
+
"valid-input",
|
|
90
|
+
id="wf-success",
|
|
91
|
+
task_queue="test",
|
|
92
|
+
)
|
|
93
|
+
assert result_success == "success: processed-valid-input"
|
|
94
|
+
|
|
95
|
+
# Test error path
|
|
96
|
+
result_error = await workflow_env.client.execute_workflow(
|
|
97
|
+
DynamicWorkflow.run,
|
|
98
|
+
"error-case",
|
|
99
|
+
id="wf-error",
|
|
100
|
+
task_queue="test",
|
|
101
|
+
)
|
|
102
|
+
assert "Validation failed" in result_error
|
|
103
|
+
```
|
|
104
|
+
|
|
105
|
+
## Error Injection Patterns
|
|
106
|
+
|
|
107
|
+
### Testing Transient Failures
|
|
108
|
+
|
|
109
|
+
**Retry Behavior**:
|
|
110
|
+
|
|
111
|
+
```python
|
|
112
|
+
@pytest.mark.asyncio
|
|
113
|
+
async def test_workflow_transient_errors(workflow_env):
|
|
114
|
+
"""Test retry logic with controlled failures"""
|
|
115
|
+
|
|
116
|
+
attempt_count = 0
|
|
117
|
+
|
|
118
|
+
@activity.defn
|
|
119
|
+
async def transient_activity() -> str:
|
|
120
|
+
nonlocal attempt_count
|
|
121
|
+
attempt_count += 1
|
|
122
|
+
|
|
123
|
+
if attempt_count < 3:
|
|
124
|
+
raise Exception(f"Transient error {attempt_count}")
|
|
125
|
+
return "success-after-retries"
|
|
126
|
+
|
|
127
|
+
@workflow.defn
|
|
128
|
+
class RetryWorkflow:
|
|
129
|
+
@workflow.run
|
|
130
|
+
async def run(self) -> str:
|
|
131
|
+
return await workflow.execute_activity(
|
|
132
|
+
transient_activity,
|
|
133
|
+
start_to_close_timeout=timedelta(seconds=10),
|
|
134
|
+
retry_policy=RetryPolicy(
|
|
135
|
+
initial_interval=timedelta(milliseconds=10),
|
|
136
|
+
maximum_attempts=5,
|
|
137
|
+
backoff_coefficient=1.0,
|
|
138
|
+
),
|
|
139
|
+
)
|
|
140
|
+
|
|
141
|
+
async with Worker(
|
|
142
|
+
workflow_env.client,
|
|
143
|
+
task_queue="test",
|
|
144
|
+
workflows=[RetryWorkflow],
|
|
145
|
+
activities=[transient_activity],
|
|
146
|
+
):
|
|
147
|
+
result = await workflow_env.client.execute_workflow(
|
|
148
|
+
RetryWorkflow.run,
|
|
149
|
+
id="retry-wf",
|
|
150
|
+
task_queue="test",
|
|
151
|
+
)
|
|
152
|
+
assert result == "success-after-retries"
|
|
153
|
+
assert attempt_count == 3
|
|
154
|
+
```
|
|
155
|
+
|
|
156
|
+
### Testing Non-Retryable Errors
|
|
157
|
+
|
|
158
|
+
**Business Validation Failures**:
|
|
159
|
+
|
|
160
|
+
```python
|
|
161
|
+
@pytest.mark.asyncio
|
|
162
|
+
async def test_workflow_non_retryable_error(workflow_env):
|
|
163
|
+
"""Test handling of permanent failures"""
|
|
164
|
+
|
|
165
|
+
@activity.defn
|
|
166
|
+
async def validation_activity(input: dict) -> str:
|
|
167
|
+
if not input.get("valid"):
|
|
168
|
+
raise ApplicationError(
|
|
169
|
+
"Invalid input",
|
|
170
|
+
non_retryable=True, # Don't retry validation errors
|
|
171
|
+
)
|
|
172
|
+
return "validated"
|
|
173
|
+
|
|
174
|
+
@workflow.defn
|
|
175
|
+
class ValidationWorkflow:
|
|
176
|
+
@workflow.run
|
|
177
|
+
async def run(self, input: dict) -> str:
|
|
178
|
+
try:
|
|
179
|
+
return await workflow.execute_activity(
|
|
180
|
+
validation_activity,
|
|
181
|
+
input,
|
|
182
|
+
start_to_close_timeout=timedelta(seconds=10),
|
|
183
|
+
)
|
|
184
|
+
except ApplicationError as e:
|
|
185
|
+
return f"validation-failed: {e.message}"
|
|
186
|
+
|
|
187
|
+
async with Worker(
|
|
188
|
+
workflow_env.client,
|
|
189
|
+
task_queue="test",
|
|
190
|
+
workflows=[ValidationWorkflow],
|
|
191
|
+
activities=[validation_activity],
|
|
192
|
+
):
|
|
193
|
+
result = await workflow_env.client.execute_workflow(
|
|
194
|
+
ValidationWorkflow.run,
|
|
195
|
+
{"valid": False},
|
|
196
|
+
id="validation-wf",
|
|
197
|
+
task_queue="test",
|
|
198
|
+
)
|
|
199
|
+
assert "validation-failed" in result
|
|
200
|
+
```
|
|
201
|
+
|
|
202
|
+
## Multi-Activity Workflow Testing
|
|
203
|
+
|
|
204
|
+
### Sequential Activity Pattern
|
|
205
|
+
|
|
206
|
+
```python
|
|
207
|
+
@pytest.mark.asyncio
|
|
208
|
+
async def test_workflow_sequential_activities(workflow_env):
|
|
209
|
+
"""Test workflow orchestrating multiple activities"""
|
|
210
|
+
|
|
211
|
+
activity_calls = []
|
|
212
|
+
|
|
213
|
+
@activity.defn
|
|
214
|
+
async def step_1(input: str) -> str:
|
|
215
|
+
activity_calls.append("step_1")
|
|
216
|
+
return f"{input}-step1"
|
|
217
|
+
|
|
218
|
+
@activity.defn
|
|
219
|
+
async def step_2(input: str) -> str:
|
|
220
|
+
activity_calls.append("step_2")
|
|
221
|
+
return f"{input}-step2"
|
|
222
|
+
|
|
223
|
+
@activity.defn
|
|
224
|
+
async def step_3(input: str) -> str:
|
|
225
|
+
activity_calls.append("step_3")
|
|
226
|
+
return f"{input}-step3"
|
|
227
|
+
|
|
228
|
+
@workflow.defn
|
|
229
|
+
class SequentialWorkflow:
|
|
230
|
+
@workflow.run
|
|
231
|
+
async def run(self, input: str) -> str:
|
|
232
|
+
result_1 = await workflow.execute_activity(
|
|
233
|
+
step_1,
|
|
234
|
+
input,
|
|
235
|
+
start_to_close_timeout=timedelta(seconds=10),
|
|
236
|
+
)
|
|
237
|
+
result_2 = await workflow.execute_activity(
|
|
238
|
+
step_2,
|
|
239
|
+
result_1,
|
|
240
|
+
start_to_close_timeout=timedelta(seconds=10),
|
|
241
|
+
)
|
|
242
|
+
result_3 = await workflow.execute_activity(
|
|
243
|
+
step_3,
|
|
244
|
+
result_2,
|
|
245
|
+
start_to_close_timeout=timedelta(seconds=10),
|
|
246
|
+
)
|
|
247
|
+
return result_3
|
|
248
|
+
|
|
249
|
+
async with Worker(
|
|
250
|
+
workflow_env.client,
|
|
251
|
+
task_queue="test",
|
|
252
|
+
workflows=[SequentialWorkflow],
|
|
253
|
+
activities=[step_1, step_2, step_3],
|
|
254
|
+
):
|
|
255
|
+
result = await workflow_env.client.execute_workflow(
|
|
256
|
+
SequentialWorkflow.run,
|
|
257
|
+
"start",
|
|
258
|
+
id="seq-wf",
|
|
259
|
+
task_queue="test",
|
|
260
|
+
)
|
|
261
|
+
assert result == "start-step1-step2-step3"
|
|
262
|
+
assert activity_calls == ["step_1", "step_2", "step_3"]
|
|
263
|
+
```
|
|
264
|
+
|
|
265
|
+
### Parallel Activity Pattern
|
|
266
|
+
|
|
267
|
+
```python
|
|
268
|
+
@pytest.mark.asyncio
|
|
269
|
+
async def test_workflow_parallel_activities(workflow_env):
|
|
270
|
+
"""Test concurrent activity execution"""
|
|
271
|
+
|
|
272
|
+
@activity.defn
|
|
273
|
+
async def parallel_task(task_id: int) -> str:
|
|
274
|
+
return f"task-{task_id}"
|
|
275
|
+
|
|
276
|
+
@workflow.defn
|
|
277
|
+
class ParallelWorkflow:
|
|
278
|
+
@workflow.run
|
|
279
|
+
async def run(self, task_count: int) -> list[str]:
|
|
280
|
+
# Execute activities in parallel
|
|
281
|
+
tasks = [
|
|
282
|
+
workflow.execute_activity(
|
|
283
|
+
parallel_task,
|
|
284
|
+
i,
|
|
285
|
+
start_to_close_timeout=timedelta(seconds=10),
|
|
286
|
+
)
|
|
287
|
+
for i in range(task_count)
|
|
288
|
+
]
|
|
289
|
+
return await asyncio.gather(*tasks)
|
|
290
|
+
|
|
291
|
+
async with Worker(
|
|
292
|
+
workflow_env.client,
|
|
293
|
+
task_queue="test",
|
|
294
|
+
workflows=[ParallelWorkflow],
|
|
295
|
+
activities=[parallel_task],
|
|
296
|
+
):
|
|
297
|
+
result = await workflow_env.client.execute_workflow(
|
|
298
|
+
ParallelWorkflow.run,
|
|
299
|
+
3,
|
|
300
|
+
id="parallel-wf",
|
|
301
|
+
task_queue="test",
|
|
302
|
+
)
|
|
303
|
+
assert result == ["task-0", "task-1", "task-2"]
|
|
304
|
+
```
|
|
305
|
+
|
|
306
|
+
## Signal and Query Testing
|
|
307
|
+
|
|
308
|
+
### Signal Handlers
|
|
309
|
+
|
|
310
|
+
```python
|
|
311
|
+
@pytest.mark.asyncio
|
|
312
|
+
async def test_workflow_signals(workflow_env):
|
|
313
|
+
"""Test workflow signal handling"""
|
|
314
|
+
|
|
315
|
+
@workflow.defn
|
|
316
|
+
class SignalWorkflow:
|
|
317
|
+
def __init__(self) -> None:
|
|
318
|
+
self._status = "initialized"
|
|
319
|
+
|
|
320
|
+
@workflow.run
|
|
321
|
+
async def run(self) -> str:
|
|
322
|
+
# Wait for completion signal
|
|
323
|
+
await workflow.wait_condition(lambda: self._status == "completed")
|
|
324
|
+
return self._status
|
|
325
|
+
|
|
326
|
+
@workflow.signal
|
|
327
|
+
async def update_status(self, new_status: str) -> None:
|
|
328
|
+
self._status = new_status
|
|
329
|
+
|
|
330
|
+
@workflow.query
|
|
331
|
+
def get_status(self) -> str:
|
|
332
|
+
return self._status
|
|
333
|
+
|
|
334
|
+
async with Worker(
|
|
335
|
+
workflow_env.client,
|
|
336
|
+
task_queue="test",
|
|
337
|
+
workflows=[SignalWorkflow],
|
|
338
|
+
):
|
|
339
|
+
# Start workflow
|
|
340
|
+
handle = await workflow_env.client.start_workflow(
|
|
341
|
+
SignalWorkflow.run,
|
|
342
|
+
id="signal-wf",
|
|
343
|
+
task_queue="test",
|
|
344
|
+
)
|
|
345
|
+
|
|
346
|
+
# Verify initial state via query
|
|
347
|
+
initial_status = await handle.query(SignalWorkflow.get_status)
|
|
348
|
+
assert initial_status == "initialized"
|
|
349
|
+
|
|
350
|
+
# Send signal
|
|
351
|
+
await handle.signal(SignalWorkflow.update_status, "processing")
|
|
352
|
+
|
|
353
|
+
# Verify updated state
|
|
354
|
+
updated_status = await handle.query(SignalWorkflow.get_status)
|
|
355
|
+
assert updated_status == "processing"
|
|
356
|
+
|
|
357
|
+
# Complete workflow
|
|
358
|
+
await handle.signal(SignalWorkflow.update_status, "completed")
|
|
359
|
+
result = await handle.result()
|
|
360
|
+
assert result == "completed"
|
|
361
|
+
```
|
|
362
|
+
|
|
363
|
+
## Coverage Strategies
|
|
364
|
+
|
|
365
|
+
### Workflow Logic Coverage
|
|
366
|
+
|
|
367
|
+
**Target**: ≥80% coverage of workflow decision logic
|
|
368
|
+
|
|
369
|
+
```python
|
|
370
|
+
# Test all branches
|
|
371
|
+
@pytest.mark.parametrize("condition,expected", [
|
|
372
|
+
(True, "branch-a"),
|
|
373
|
+
(False, "branch-b"),
|
|
374
|
+
])
|
|
375
|
+
async def test_workflow_branches(workflow_env, condition, expected):
|
|
376
|
+
"""Ensure all code paths are tested"""
|
|
377
|
+
# Test implementation
|
|
378
|
+
pass
|
|
379
|
+
```
|
|
380
|
+
|
|
381
|
+
### Activity Coverage
|
|
382
|
+
|
|
383
|
+
**Target**: ≥80% coverage of activity logic
|
|
384
|
+
|
|
385
|
+
```python
|
|
386
|
+
# Test activity edge cases
|
|
387
|
+
@pytest.mark.parametrize("input,expected", [
|
|
388
|
+
("valid", "success"),
|
|
389
|
+
("", "empty-input-error"),
|
|
390
|
+
(None, "null-input-error"),
|
|
391
|
+
])
|
|
392
|
+
async def test_activity_edge_cases(activity_env, input, expected):
|
|
393
|
+
"""Test activity error handling"""
|
|
394
|
+
# Test implementation
|
|
395
|
+
pass
|
|
396
|
+
```
|
|
397
|
+
|
|
398
|
+
## Integration Test Organization
|
|
399
|
+
|
|
400
|
+
### Test Structure
|
|
401
|
+
|
|
402
|
+
```
|
|
403
|
+
tests/
|
|
404
|
+
├── integration/
|
|
405
|
+
│ ├── conftest.py # Shared fixtures
|
|
406
|
+
│ ├── test_order_workflow.py # Order processing tests
|
|
407
|
+
│ ├── test_payment_workflow.py # Payment tests
|
|
408
|
+
│ └── test_fulfillment_workflow.py
|
|
409
|
+
├── unit/
|
|
410
|
+
│ ├── test_order_activities.py
|
|
411
|
+
│ └── test_payment_activities.py
|
|
412
|
+
└── fixtures/
|
|
413
|
+
└── test_data.py # Test data builders
|
|
414
|
+
```
|
|
415
|
+
|
|
416
|
+
### Shared Fixtures
|
|
417
|
+
|
|
418
|
+
```python
|
|
419
|
+
# conftest.py
|
|
420
|
+
import pytest
|
|
421
|
+
from temporalio.testing import WorkflowEnvironment
|
|
422
|
+
|
|
423
|
+
@pytest.fixture(scope="session")
|
|
424
|
+
async def workflow_env():
|
|
425
|
+
"""Session-scoped environment for integration tests"""
|
|
426
|
+
env = await WorkflowEnvironment.start_time_skipping()
|
|
427
|
+
yield env
|
|
428
|
+
await env.shutdown()
|
|
429
|
+
|
|
430
|
+
@pytest.fixture
|
|
431
|
+
def mock_payment_service():
|
|
432
|
+
"""Mock external payment service"""
|
|
433
|
+
return Mock()
|
|
434
|
+
|
|
435
|
+
@pytest.fixture
|
|
436
|
+
def mock_inventory_service():
|
|
437
|
+
"""Mock external inventory service"""
|
|
438
|
+
return Mock()
|
|
439
|
+
```
|
|
440
|
+
|
|
441
|
+
## Best Practices
|
|
442
|
+
|
|
443
|
+
1. **Mock External Dependencies**: Never call real APIs in tests
|
|
444
|
+
2. **Test Error Scenarios**: Verify compensation and retry logic
|
|
445
|
+
3. **Parallel Testing**: Use pytest-xdist for faster test runs
|
|
446
|
+
4. **Isolated Tests**: Each test should be independent
|
|
447
|
+
5. **Clear Assertions**: Verify both results and side effects
|
|
448
|
+
6. **Coverage Target**: ≥80% for critical workflows
|
|
449
|
+
7. **Fast Execution**: Use time-skipping, avoid real delays
|
|
450
|
+
|
|
451
|
+
## Additional Resources
|
|
452
|
+
|
|
453
|
+
- Mocking Strategies: docs.temporal.io/develop/python/testing-suite
|
|
454
|
+
- pytest Best Practices: docs.pytest.org/en/stable/goodpractices.html
|
|
455
|
+
- Python SDK Samples: github.com/temporalio/samples-python
|