You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
Development workflow for building, syncing, packaging, and shipping Copilot Studio agents. Use this skill when working with Copilot Studio YAML files (agent.mcs.yml, topics, actions, variables), when pulling or pushing agent changes, when packaging solutions for distribution, or when troubleshooting common Copilot Studio platform issues. Triggers on: Copilot Studio, MCS, agent.mcs.yml, .mcs.yml files, pac CLI, Power Platform solution, pull from cloud, push to cloud, publish agent, solution packaging, heartbeat flow, Power Automate flows.
allowed-tools
shell
license
MIT
Copilot Studio Workflow
Overview
Copilot Studio agents are YAML-first assets (.mcs.yml) that sync between a local repo and the cloud.
Treat the development/demo environment as the real working environment and the production environment as a packaged distribution target.
Keep generic placeholder URLs in git (for example contoso.sharepoint.com); real demo URLs belong only in the live environment.
Follow the proven loop: pull → revert env-specific files → edit → push → publish → test → commit.
Prerequisites & First-Time Setup
When starting work on a Copilot Studio project for the first time, verify the following tools are installed and configured. Run .\scripts\cps-status.ps1 for a quick health check.
How this skill relates to the Copilot Studio Plugin: The CAT Team plugin handles YAML authoring, schema validation, and agent management. This workflow skill handles the surrounding engineering workflow — source control, environment sync, solution packaging, and platform gotchas. They are complementary: install both for the best experience.
First session checklist
Run .\scripts\cps-status.ps1 to detect the project and check tool availability.
Install the Copilot Studio Plugin if not already installed (see Recommended table above).
If no agent.mcs.yml exists, clone an agent from the cloud using the VS Code extension or Copilot Studio manage flow.
If pac CLI is needed for solution packaging, authenticate: pac auth create --environment <URL>.
Verify the VS Code Copilot Studio extension can connect to your environment (open the agent folder, Sync → Pull).
Development Loop
Pull from cloud using the VS Code Copilot Studio extension (Sync → Pull) or the Copilot Studio manage flow.
Revert workflow files immediately. Cloud pulls often inject environment-specific URLs into workflows/*.json and settings.mcs.yml. Run .\scripts\cps-revert.ps1 (or git checkout -- **/workflows/ **/settings.mcs.yml) before reviewing diffs.
Edit locally in .mcs.yml files: topics, actions, variables, instructions, triggers, and agent settings.
Push to cloud with the VS Code extension (Sync → Push) or manage-agent tooling.
Publish in Copilot Studio so the draft becomes live.
Test in the real channel (Teams or Microsoft 365 Copilot). The test pane is useful for quick checks, but it is not representative of production behavior.
Commit to git only after the live agent behaves correctly and workflow files are clean.
Solution Packaging
Use pac solution export to export the solution from the demo environment.
The solution should include the agent, Power Automate flows, and connection references.
For production distribution: export → unpack → scrub environment URLs → repack as a clean zip.
Teams import the solution zip, reconnect dependencies, re-enable flows, and follow the setup guide.
Adding New Components
A VS Code push creates Dataverse components, but it does not add new bot components to the Power Platform solution.
Add them explicitly with pac solution add-solution-component -sn <SOLUTION> -c <GUID> -ct botcomponent.
Find the component GUID with pac org fetch against botcomponent records.
Use .\scripts\cps-add-component.ps1 for guided lookup and add-to-solution flow.
Platform Gotchas
Initialization
OnConversationStart does not fire in Microsoft 365 Copilot and usually fires only once in Teams. Use OnActivity(type: Message) plus an IsBlank() just-in-time guard instead.
Copilot Studio does not stream partial messages; the platform batches output.
Packaging
VS Code push ≠ solution membership. New components must be added to the solution separately.
Global variables need YAML definitions in variables/ or solution imports can fail or create broken references.
Solution import deactivates Power Automate flows; always re-enable them after import.
Cloud pull brings environment-specific URLs into workflow files; always revert them before commit.
Extension push/pull is all-or-nothing; there is no selective sync.
Development
ConcurrencyVersionMismatch on push usually means someone changed the cloud copy. Pull again before pushing.
The Copilot Studio test pane does not match real channel behavior; validate in Teams or Microsoft 365 Copilot.
Housekeeping flow push error 0x80040216 is a known benign issue.
Deployment
Export scripts capture the state that exists at export time. Do not run packaging scripts after a YAML push unless you intend to rebuild from that exact state.
pac component type codes are brittle across environments; prefer the name-based -ct botcomponent pattern in your workflow.
Best Practices
Agent Architecture
Use a constitution file pattern (markdown files in SharePoint or OneDrive) for dynamic instructions — edit behavior without YAML surgery.
Keep agent instructions concise in agent.mcs.yml; load detailed context via global variables populated at runtime by a Power Automate flow.
Use OnActivity(type: Message) with an IsBlank() JIT guard for reliable context initialization across all channels (Teams, M365 Copilot).
YAML Hygiene
One topic per file. Name files to match the topic's purpose (for example Greeting.mcs.yml, EscalateToHuman.mcs.yml).
Define all global variables explicitly in variables/ with YAML files — never rely on UI-only definitions.
Use descriptive schemaName values — they appear in Dataverse queries and logs.
Testing
Always test in the real channel (Teams or M365 Copilot), not just the test pane.
MCP tools, connectors, and OAuth flows only work in published agents on real channels.
Use calendar-driven routines (for example [AgentName Routine] Weekly Review) for testing autonomous behaviors.
Solution Packaging
Establish a URL placeholder convention from day one (for example contoso.sharepoint.com). Retrofitting is painful.
Always revert workflow files after cloud pulls — one missed revert leaks production URLs into source control.
After pushing new components via VS Code, explicitly add them to the solution with pac solution add-solution-component.
Re-enable all Power Automate flows after every solution import — imports deactivate them silently.
Memory & State (for agents with persistent memory)
Use SharePoint lists for structured memory (facts, preferences, tasks) and markdown files for narrative or journal memory.
Design memory with expiration — stale facts degrade agent quality over time.
Keep memory scoped (for example preference:timezone, person:manager) for efficient retrieval.
Security & Governance
Review all MCP tools and connectors before enabling — each one expands the agent's access surface.
Use the KillSwitch pattern (a config flag that halts autonomous behavior) for any agent that acts without user prompting.
Audit agent activity through logging lists or flows — autonomous agents need observability.
Included Scripts
scripts/cps-status.ps1 — quick project health check: agent info, counts, git state, dirty workflow files, and pac availability.
scripts/cps-revert.ps1 — run after every cloud pull to revert workflows/*.json and settings.mcs.yml back to the repo-safe version.
scripts/cps-preflight.ps1 — run before push to check workflow hygiene, git state, and missing global variable definitions.
scripts/cps-add-component.ps1 — locate a bot component by schema pattern and add it to the Power Platform solution.
Quick Reference
Task
Command / Path
First-time setup
.\scripts\cps-status.ps1
Install pac CLI
winget install Microsoft.PowerPlatformCLI (Windows) or dotnet tool install --global Microsoft.PowerApps.CLI.Tool
Authenticate pac
pac auth create --environment <URL>
Clone agent from cloud
VS Code extension → open folder → Sync → Pull
Pull from cloud
VS Code Copilot Studio extension → Sync → Pull
Push to cloud
VS Code Copilot Studio extension → Sync → Push
Revert workflows
.\scripts\cps-revert.ps1 or git checkout -- **/workflows/ **/settings.mcs.yml