Bundles-forge testing
Use when testing a bundle-plugin locally before release — generating dev-marketplace environments, verifying component discovery, running hook smoke tests, and validating cross-platform readiness
git clone https://github.com/OdradekAI/bundles-forge
T=$(mktemp -d) && git clone --depth=1 https://github.com/OdradekAI/bundles-forge "$T" && mkdir -p ~/.claude/skills && cp -r "$T/skills/testing" ~/.claude/skills/odradekai-bundles-forge-testing && rm -rf "$T"
skills/testing/SKILL.mdTesting Bundle-Plugins
Overview
Dynamic verification of a bundle-plugin project: install it locally, confirm components are discoverable, validate hooks fire correctly, and run cross-platform smoke tests. Complements
bundles-forge:auditing (static analysis) with runtime validation.
Core principle: Audit tells you if the structure is correct; testing tells you if it actually works.
Skill type: Flexible — adapt the test scope based on target platforms and project maturity.
Announce at start: "I'm using the testing skill to verify this plugin works correctly."
Step 1: Resolve Input & Detect Scope
Input Normalization
The target must be a local bundle-plugin project (has
package.json + skills/). Remote URLs and archives are not supported — testing requires a local working directory.
Scope Detection
| Target | Mode |
|---|---|
| Project root with multiple platforms | Full testing — all 5 test phases |
| Project root with single platform | Platform testing — phases 1-4 for the target platform |
| Single skill directory | Skill-only testing — phase 3 (component discovery) only |
Phase 1: Local Test Environment
Generate a temporary dev-marketplace for local installation testing.
For Claude Code
- Create
adjacent to the project directory../dev-marketplace/ - Generate
pointing to the project:.claude-plugin/marketplace.json
{ "name": "<project-name>-dev", "owner": { "name": "dev" }, "plugins": [ { "name": "<project-name>", "source": "../<project-directory-name>" } ] }
- Instruct the user:
Dev marketplace created at ../dev-marketplace/ To install locally: /plugin marketplace add ./dev-marketplace /plugin install <project-name>@<project-name>-dev To reload after changes: /plugin marketplace update <project-name>-dev To clean up when done: /plugin marketplace remove <project-name>-dev
For Cursor
Cursor plugins are installed from local paths directly:
To test locally in Cursor: 1. Open Cursor Settings → Extensions → Install from Path 2. Select the project root directory 3. Reload Cursor to pick up changes
For Other Platforms
- Codex: Symlink
intoskills/
per INSTALL.md~/.agents/skills/ - OpenCode: Register the plugin path in
.opencode/plugins/ - Gemini CLI: Point the extension config to the local directory
See
references/platform-test-guides.md for platform-specific setup instructions.
Phase 2: Hook Smoke Tests
Verify hooks execute without errors by running them directly.
SessionStart Hook
bash hooks/session-start
Expected: Exits 0, prints a one-line prompt containing the project name and available skills. No stderr output.
Verify output format:
- If
is set: valid JSON withCLAUDE_PLUGIN_ROOThookSpecificOutput.additionalContext - If
is set: valid JSON withCURSOR_PLUGIN_ROOTadditional_context - Neither: plain text
Custom Hooks (if configured)
If the project defines
PreToolUse or PostToolUse hooks in hooks.json, run each referenced script directly and verify:
- PreToolUse scripts: exit 0 on a valid project, exit 2 to block writes on critical issues
- PostToolUse scripts: always exit 0, warnings go to stderr
OpenClaw Hook-Pack (if present)
Verify
hooks/openclaw-bootstrap/HOOK.md has valid YAML frontmatter with events declaration, and handler.js uses ESM export default.
Phase 3: Component Discovery
Verify that all declared components can be found by the host platform.
Skills
For each directory under
skills/:
- Contains
SKILL.md - Frontmatter has
andnamedescription -
matches directory namename -
starts with "Use when..."description
Agents
For each
.md file under agents/:
- Has YAML frontmatter
- Body has 5+ non-empty lines (self-contained protocol)
Platform Manifests
For each target platform:
- Manifest file exists and is valid JSON
- Paths in manifest resolve to existing files/directories
- Version matches
versionpackage.json
Phase 4: Cross-Platform Readiness
Generate a platform-specific test checklist based on
references/platform-test-guides.md and known limitations from bundles-forge:scaffolding — references/platform-adapters.md.
Known Limitations to Verify
| Platform | Limitation | Test |
|---|---|---|
| Claude Code | Plugin caching breaks paths | Verify no in hook commands or manifest paths |
| Cursor | Bootstrap lost after | Verify session-start runs independently of prior context |
| Codex | No hook bootstrap | Verify AGENTS.md or INSTALL.md has manual setup instructions |
| OpenCode | Plugin JS must use ESM | Verify in |
| Gemini CLI | Extension needs | Verify has field |
| OpenClaw | Hook-pack wiring uncertain | Document as known risk in test report |
Phase 5: Test Report
Generate a test report summarizing all findings.
Report Structure
# Test Report: <project-name> **Date:** YYYY-MM-DD **Scope:** [Full / Platform / Skill-only] **Platforms tested:** [list] ## Results | Phase | Status | Details | |-------|--------|---------| | 1. Local Environment | PASS/FAIL/SKIP | ... | | 2. Hook Smoke Tests | PASS/FAIL/SKIP | ... | | 3. Component Discovery | PASS/FAIL/SKIP | N skills, K agents | | 4. Cross-Platform | PASS/FAIL/SKIP | ... | ## Issues Found ### Critical - (blocks release) ### Warnings - (should fix before release) ## Recommendations - ...
Report location:
.bundles-forge/audits/<timestamp>-test-report.md
Integration with Releasing
In the releasing pipeline, testing runs after auditing and before version bump:
audit → test → version bump → publish
If testing reveals critical issues, the release pipeline is blocked until they are resolved.
Common Mistakes
| Mistake | Fix |
|---|---|
| Skipping local install test | Always test with a real dev-marketplace — file discovery differs from file existence |
| Testing only on one platform | Run cross-platform checklist for every target platform |
| Ignoring hook exit codes | Hooks must exit 0 to avoid blocking the host; test all code paths |
| Not cleaning up dev-marketplace | Always remove dev-marketplace after testing |
| Testing after version bump | Test before bumping — avoid releasing a broken version |
Inputs
(required) — bundle-plugin project rootproject-directory
Outputs
— comprehensive test results written totest-report.bundles-forge/audits/
(temporary) — local marketplace directory for installation testingdev-marketplace
Integration
Called by:
- bundles-forge:releasing — pre-release dynamic verification (after audit, before version bump)
- User directly — standalone local testing during development
Calls:
- (none — testing is a pure executor, does not dispatch other skills)