Agent Development Life Cycle — Build, deploy, test, and optimize Agentforce agents using Claude Code skills and Agent Script DSL.
npx skills add https://github.com/salesforceairesearch/agentforce-adlc --skill observing-agentforceInstale esta skill com a CLI e comece a usar o fluxo de trabalho SKILL.md em seu espaço de trabalho.
Agent Development Life Cycle — Build, deploy, test, and optimize Agentforce agents
using Claude Code skills and Agent Script DSL.
agentforce-adlc provides a complete set of Claude Code skills for the full Agentforce agent lifecycle — from requirements to production optimization. Claude writes .agent files directly using the Agent Script DSL.
.agent files natively, not via markdown-to-agent conversionUser prompt
| /developing-agentforce
v
+--------------------------+
| Safety Review (Phase 0) |<-- LLM-driven, 7 categories
| .agent file generated |
+--------+-----------------+
| /developing-agentforce (discover)
v
+--------------------------+
| Check org for targets |--missing--> scaffold stubs
+--------+-----------------+
| /developing-agentforce (deploy)
v
+--------------------------+
| Safety Gate -> Validate |<-- Pre-publish check
| -> Publish -> Activate |
+--------+-----------------+
| /testing-agentforce
v
+--------------------------+
| Preview + Batch tests |<-- Safety probe utterances (adversarial)
| + Action execution |
+--------+-----------------+
| /observing-agentforce
v
+--------------------------+
| STDM session analysis |<-- Safety issue detection in traces
| -> Reproduce -> Improve |
+--------------------------+
Each skill can be invoked independently. Run /testing-agentforce on an existing agent without touching the development steps. Run /observing-agentforce on production session data without redeploying.
# Clone the repo
git clone https://github.com/SalesforceAIResearch/agentforce-adlc.git
# Option A: Load directly (development)
claude --plugin-dir ./agentforce-adlc
# Option B: Install via marketplace
claude plugin marketplace add ./agentforce-adlc
claude plugin install adlc@agentforce-adlc
When installed as a plugin, skills are namespaced: /adlc:developing-agentforce, /adlc:testing-agentforce, /adlc:observing-agentforce.
# One-command install
curl -sSL https://raw.githubusercontent.com/SalesforceAIResearch/agentforce-adlc/main/tools/install.sh | bash
# Or from local clone
python3 tools/install.py # Auto-detects Claude Code / Cursor
python3 tools/install.py --target cursor # Cursor only
# Plugin management
claude plugin list # List installed plugins
claude plugin update adlc@agentforce-adlc # Update plugin
claude plugin uninstall adlc@agentforce-adlc # Remove plugin
# File-copy management (legacy)
python3 ~/.claude/adlc-install.py --status
python3 ~/.claude/adlc-install.py --update
python3 ~/.claude/adlc-install.py --uninstall
After install, restart your IDE. Skills are available in any project.
| Component | Plugin (Claude Code) | File-copy (~/.claude/) |
File-copy (~/.cursor/) |
|---|---|---|---|
| Skills | Auto-discovered from skills/ |
skills/*-agentforce/ |
skills/*-agentforce/ |
| Agents | Auto-discovered from agents/ |
agents/adlc-*.md |
N/A |
| Hooks | Via hooks/hooks.json |
hooks/scripts/adlc-*.py |
N/A |
| Settings | settings.json (default agent) |
settings.json entries |
N/A |
Plugin installation is self-contained — no files are copied to ~/.claude/. The file-copy installer is for Cursor and legacy Claude Code setups.
python3 --version. If older, upgrade: brew install [email protected] (macOS) / sudo apt install python3.13 (Ubuntu) / python.org (Windows)sf) v2.x — install guide~/.claude/) or Cursor (~/.cursor/) — at least one must be installed/developing-agentforce)This single skill handles the full development workflow — authoring, discovery, scaffolding, and deployment:
/developing-agentforce
Build a service agent that helps customers check order status,
request returns, and track shipments. It should verify identity
before showing order details. Deploy to my-org.
The skill will:
.agent file with topics, actions, variables, and deterministic logicEach phase can also be triggered individually (e.g., "just discover targets for OrderService.agent").
/testing-agentforce)/testing-agentforce
Smoke test OrderService against my-org with these utterances:
- "Where is my order #12345?"
- "I want to return my recent purchase"
- "What's the shipping status?"
Runs preview sessions, analyzes traces, and reports topic routing accuracy and action success rates. Also supports batch testing via Testing Center and individual action execution.
/observing-agentforce)/observing-agentforce
Analyze the last 50 sessions for OrderService on my-org.
Find routing failures and suggest improvements.
Extracts STDM session traces from Data Cloud, identifies patterns (wrong topic, missing actions, ungrounded responses), reproduces issues with live preview, and applies fixes directly to the .agent file.
| Skill | Description | Covers |
|---|---|---|
/developing-agentforce |
Build, review, discover, scaffold, deploy, and ensure safety of Agentforce agents | Author, discover, scaffold, deploy, safety review, feedback |
/testing-agentforce |
Test Agentforce agents via preview, batch testing, and individual action execution | Preview, batch test, action execution |
/observing-agentforce |
Analyze session traces from Data Cloud, reproduce issues, and improve the .agent file | STDM analysis, reproduce, fix loop |
Old skill names still work as aliases:
| Old Command | Maps To |
|---|---|
/adlc-author |
/developing-agentforce |
/adlc-discover |
/developing-agentforce |
/adlc-scaffold |
/developing-agentforce |
/adlc-deploy |
/developing-agentforce |
/adlc-safety |
/developing-agentforce |
/adlc-feedback |
/developing-agentforce |
/adlc-test |
/testing-agentforce |
/adlc-run |
/testing-agentforce |
/adlc-optimize |
/observing-agentforce |
Safety is integrated across the full ADLC lifecycle, not bolted on as an afterthought.
The safety review (Section 15 of /developing-agentforce) uses Claude's reasoning to evaluate agents against 7 categories:
| Category | What it catches |
|---|---|
| Identity & Transparency | Impersonation of regulated professionals or authorities without AI disclosure |
| User Safety & Wellbeing | Pressure tactics, dark patterns, unqualified medical/legal/financial advice |
| Data Handling & Privacy | Excessive PII collection, phishing-like identity verification, missing data policies |
| Content Safety | Harmful content through euphemism or indirection (e.g., "energetic materials" for explosives) |
| Fairness & Non-Discrimination | Direct discrimination and proxy discrimination (zip code filtering, name-based assumptions) |
| Deception & Manipulation | Social engineering, fabricated urgency, false claims, hidden terms |
| Scope & Boundaries | Missing scope definitions, no escalation paths, overly broad agents |
| Lifecycle phase | Integration point |
|---|---|
Author (/developing-agentforce) |
Phase 0: pre-authoring safety gate. Phase 5: safety scoring (15 of 100 points) |
Deploy (/developing-agentforce) |
Phase 0: safety gate before publishing to any org |
Test (/testing-agentforce) |
Auto-generates adversarial safety probe utterances for every test run |
Optimize (/observing-agentforce) |
Flags unsafe agent behavior in session traces (prompt leakage, injection compliance, etc.) |
Every .agent write |
PostToolUse hook prompts for safety review |
Regex catches exact keyword patterns but misses intent. These 8 harmful agents all bypass regex checks:
Claude's reasoning catches all of these because it understands intent, not just keywords.
agentforce-adlc/
├── .claude-plugin/ # Claude Code plugin manifest
│ ├── plugin.json # Plugin definition (name: "adlc")
│ └── marketplace.json # Self-hosted marketplace
├── agents/ # Claude Code agent definitions (.md)
│ ├── adlc-orchestrator.md # Plan-mode orchestrator
│ ├── adlc-author.md # Agent Script authoring specialist
│ ├── adlc-engineer.md # Platform engineer (discover/scaffold/deploy)
│ └── adlc-qa.md # Testing and optimization specialist
├── skills/ # Claude Code skills (3 consolidated, agentskills.io standard)
│ ├── developing-agentforce/ # Author + discover + scaffold + deploy + safety + feedback
│ ├── testing-agentforce/ # Preview testing + batch testing + action execution
│ └── observing-agentforce/ # STDM trace analysis + fix loop
├── hooks/ # Plugin hook definitions
│ └── hooks.json # PreToolUse/PostToolUse hook config
├── shared/ # Cross-skill shared code
│ ├── hooks/scripts/ # Hook scripts (guardrails.py, agent-validator.py)
│ └── sf-cli/ # SF CLI subprocess wrapper
├── scripts/ # Python helper scripts (standalone)
│ ├── discover.py # CLI: discover missing targets
│ ├── scaffold.py # CLI: scaffold Flow/Apex stubs
│ ├── org_describe.py # CLI: describe SObject fields
│ └── generators/ # Flow XML, Apex, PermSet generators
├── tools/ # File-copy installer (Cursor + legacy)
│ ├── install.py # Python installer (local + remote)
│ └── install.sh # Bash bootstrap for curl | bash
├── settings.json # Plugin default settings (default agent)
├── tests/ # pytest test suite (88 tests)
└── force-app/ # Example Salesforce DX output
.agent files (tabs break the Agent Script compiler)True / False (capitalized, Python-style)mutable (read-write) or linked (bound to external source)definitions (in topic) and invocations (in reasoning)developer_name must match the folder name under aiAuthoringBundles/|) for static text, procedural (->) for conditional logic# Clone and set up dev environment
git clone https://github.com/SalesforceAIResearch/agentforce-adlc.git
cd agentforce-adlc
pip install -e ".[dev]"
# Run tests
pytest tests/ -v
# Install from local clone (for development)
python3 tools/install.py --force
These scripts can be run directly without installing the skills:
# Discover missing targets
python3 scripts/discover.py --agent-file path/to/Agent.agent -o OrgAlias
# Scaffold stubs for missing targets
python3 scripts/scaffold.py --agent-file path/to/Agent.agent -o OrgAlias --output-dir force-app/main/default
# Describe SObject fields (for smart scaffold)
python3 scripts/org_describe.py --sobject Account -o OrgAlias
agentforce-adlc works well alongside this related project:
Both can be installed side-by-side without conflicts.
This project is licensed under the Creative Commons Attribution-NonCommercial 4.0 International (CC BY-NC 4.0) license.