PluginBench
Skill
Official
Review
Audit score 70

azure-deployment-preflight

github/awesome-copilot

Validate Bicep deployments to Azure before execution with syntax checks, what-if analysis, and permission verification.

What is azure-deployment-preflight?

This skill performs comprehensive preflight validation of Bicep deployments to Azure, including template syntax validation, what-if analysis, and permission checks. Use it before any deployment to preview changes, identify issues, and ensure deployment success.

  • Detects project type (azd or standalone Bicep) and locates deployment files
  • Validates Bicep syntax using bicep CLI with detailed error reporting
  • Runs what-if analysis to preview resource changes (create, modify, delete, unchanged)
  • Checks deployment permissions and falls back to ProviderNoRbac if RBAC validation fails
  • Generates comprehensive Markdown report with issues, recommendations, and what-if results

How to install azure-deployment-preflight

npx skills add https://github.com/github/awesome-copilot --skill azure-deployment-preflight
Prerequisites
  • Azure CLI (version 2.76.0+ recommended)
  • Azure Developer CLI (azd) for projects with azure.yaml
  • Bicep CLI for syntax validation
  • Azure credentials configured (az login or azd auth login)
Claude Code
Cursor
Windsurf
Cline

How to use azure-deployment-preflight

  1. 1.Run the skill when validating a Bicep deployment or before executing azd provision/az deployment commands
  2. 2.The skill automatically detects project type by checking for azure.yaml
  3. 3.Provide resource group name, subscription, or environment name if prompted
  4. 4.Review the generated preflight-report.md in the project root for validation results, issues, and what-if changes
  5. 5.Address any errors or warnings in the report before proceeding with actual deployment

Use cases

Good for
  • Preview infrastructure changes before running azd up or az deployment commands
  • Validate Bicep templates for syntax errors and configuration issues before committing
  • Check if current Azure credentials have sufficient permissions for deployment
  • Identify resources that will be created, modified, or deleted by a deployment
  • Prepare deployment validation reports for infrastructure review and approval workflows
Who it's for
  • Infrastructure engineers deploying to Azure
  • DevOps teams using Azure Developer CLI (azd) workflows
  • Cloud architects reviewing Bicep infrastructure-as-code
  • Developers preparing infrastructure changes for production deployment

azure-deployment-preflight FAQ

What's the difference between azd and standalone Bicep validation?

The skill auto-detects project type by looking for azure.yaml. For azd projects, it runs azd provision --preview. For standalone Bicep files, it uses az deployment what-if commands with the appropriate scope (resourceGroup, subscription, managementGroup, or tenant).

What if I don't have permission to run full validation?

The skill falls back to ProviderNoRbac validation level if Provider validation fails due to RBAC restrictions. This is noted in the report so you know permissions may be limited.

What happens if Bicep CLI is not installed?

The skill notes the issue in the report and continues with Azure-side validation via what-if analysis. Azure will validate syntax during the what-if step.

Where is the validation report saved?

The preflight-report.md is generated in the project root and includes a summary, tools executed, all issues found, what-if results, and recommendations.

Can this skill validate multiple Bicep files?

Yes, the skill automatically detects all .bicep files in the project (infra/ directory for azd projects, or common locations for standalone) and validates each one.

Full instructions (SKILL.md)

Source of truth, from github/awesome-copilot.


name: azure-deployment-preflight description: 'Performs comprehensive preflight validation of Bicep deployments to Azure, including template syntax validation, what-if analysis, and permission checks. Use this skill before any deployment to Azure to preview changes, identify potential issues, and ensure the deployment will succeed. Activate when users mention deploying to Azure, validating Bicep files, checking deployment permissions, previewing infrastructure changes, running what-if, or preparing for azd provision.'

Azure Deployment Preflight Validation

This skill validates Bicep deployments before execution, supporting both Azure CLI (az) and Azure Developer CLI (azd) workflows.

When to Use This Skill

  • Before deploying infrastructure to Azure
  • When preparing or reviewing Bicep files
  • To preview what changes a deployment will make
  • To verify permissions are sufficient for deployment
  • Before running azd up, azd provision, or az deployment commands

Validation Process

Follow these steps in order. Continue to the next step even if a previous step fails—capture all issues in the final report.

Step 1: Detect Project Type

Determine the deployment workflow by checking for project indicators:

  1. Check for azd project: Look for azure.yaml in the project root

    • If found → Use azd workflow
    • If not found → Use az CLI workflow
  2. Locate Bicep files: Find all .bicep files to validate

    • For azd projects: Check infra/ directory first, then project root
    • For standalone: Use the file specified by the user or search common locations (infra/, deploy/, project root)
  3. Auto-detect parameter files: For each Bicep file, look for matching parameter files:

    • <filename>.bicepparam (Bicep parameters - preferred)
    • <filename>.parameters.json (JSON parameters)
    • parameters.json or parameters/<env>.json in same directory

Step 2: Validate Bicep Syntax

Run Bicep CLI to check template syntax before attempting deployment validation:

bicep build <bicep-file> --stdout

What to capture:

  • Syntax errors with line/column numbers
  • Warning messages
  • Build success/failure status

If Bicep CLI is not installed:

  • Note the issue in the report
  • Continue to Step 3 (Azure will validate syntax during what-if)

Step 3: Run Preflight Validation

Choose the appropriate validation based on project type detected in Step 1.

For azd Projects (azure.yaml exists)

Use azd provision --preview to validate the deployment:

azd provision --preview

If an environment is specified or multiple environments exist:

azd provision --preview --environment <env-name>

For Standalone Bicep (no azure.yaml)

Determine the deployment scope from the Bicep file's targetScope declaration:

Target ScopeCommand
resourceGroup (default)az deployment group what-if
subscriptionaz deployment sub what-if
managementGroupaz deployment mg what-if
tenantaz deployment tenant what-if

Run with Provider validation level first:

# Resource Group scope (most common)
az deployment group what-if \
  --resource-group <rg-name> \
  --template-file <bicep-file> \
  --parameters <param-file> \
  --validation-level Provider

# Subscription scope
az deployment sub what-if \
  --location <location> \
  --template-file <bicep-file> \
  --parameters <param-file> \
  --validation-level Provider

# Management Group scope
az deployment mg what-if \
  --location <location> \
  --management-group-id <mg-id> \
  --template-file <bicep-file> \
  --parameters <param-file> \
  --validation-level Provider

# Tenant scope
az deployment tenant what-if \
  --location <location> \
  --template-file <bicep-file> \
  --parameters <param-file> \
  --validation-level Provider

Fallback Strategy:

If --validation-level Provider fails with permission errors (RBAC), retry with ProviderNoRbac:

az deployment group what-if \
  --resource-group <rg-name> \
  --template-file <bicep-file> \
  --validation-level ProviderNoRbac

Note the fallback in the report—the user may lack full deployment permissions.

Step 4: Capture What-If Results

Parse the what-if output to categorize resource changes:

Change TypeSymbolMeaning
Create+New resource will be created
Delete-Resource will be deleted
Modify~Resource properties will change
NoChange=Resource unchanged
Ignore*Resource not analyzed (limits reached)
Deploy!Resource will be deployed (changes unknown)

For modified resources, capture the specific property changes.

Step 5: Generate Report

Create a Markdown report file in the project root named:

  • preflight-report.md

Use the template structure from references/REPORT-TEMPLATE.md.

Report sections:

  1. Summary - Overall status, timestamp, files validated, target scope
  2. Tools Executed - Commands run, versions, validation levels used
  3. Issues - All errors and warnings with severity and remediation
  4. What-If Results - Resources to create/modify/delete/unchanged
  5. Recommendations - Actionable next steps

Required Information

Before running validation, gather:

InformationRequired ForHow to Obtain
Resource Groupaz deployment groupAsk user or check existing .azure/ config
SubscriptionAll deploymentsaz account show or ask user
LocationSub/MG/Tenant scopeAsk user or use default from config
Environmentazd projectsazd env list or ask user

If required information is missing, prompt the user before proceeding.

Error Handling

See references/ERROR-HANDLING.md for detailed error handling guidance.

Key principle: Continue validation even when errors occur. Capture all issues in the final report.

Error TypeAction
Not logged inNote in report, suggest az login or azd auth login
Permission deniedFall back to ProviderNoRbac, note in report
Bicep syntax errorInclude all errors, continue to other files
Tool not installedNote in report, skip that validation step
Resource group not foundNote in report, suggest creating it

Tool Requirements

This skill uses the following tools:

  • Azure CLI (az) - Version 2.76.0+ recommended for --validation-level
  • Azure Developer CLI (azd) - For projects with azure.yaml
  • Bicep CLI (bicep) - For syntax validation
  • Azure MCP Tools - For documentation lookups and best practices

Check tool availability before starting:

az --version
azd version
bicep --version

Example Workflow

  1. User: "Validate my Bicep deployment before I run it"
  2. Agent detects azure.yaml → azd project
  3. Agent finds infra/main.bicep and infra/main.bicepparam
  4. Agent runs bicep build infra/main.bicep --stdout
  5. Agent runs azd provision --preview
  6. Agent generates preflight-report.md in project root
  7. Agent summarizes findings to user

Reference Documentation