Weave Code
Code Weaver
Helps Laravel developers discover, compare, and choose open-source packages. See popularity, security, maintainers, and scores at a glance to make better decisions.
Feedback
Share your thoughts, report bugs, or suggest improvements.
Subject
Message

Pao Laravel Package

nunomaduro/pao

Laravel PAO provides agent-optimized output for PHP tools. When it detects AI agents (Claude Code, Cursor, Devin, Gemini CLI), it replaces verbose CLI output from PHPUnit/Pest/Paratest/PHPStan/Rector/Artisan with minimal structured JSON—zero config, no impact on human terminal runs.

View on GitHub
Deep Wiki
Context7

Agent-optimized output for PHP testing tools

Frequently asked questions about Pao
How does Laravel PAO improve AI agent integration for PHPUnit/Pest tests?
PAO detects AI agents (like Claude Code or Cursor) and replaces verbose test output with minimal JSON, making it easier for agents to parse results. This reduces noise in CI/CD pipelines and speeds up automated analysis without altering human-readable terminal output.
Will PAO break my existing Laravel Artisan commands or CLI workflows?
No, PAO only activates when an AI agent is detected. Your terminal output remains unchanged for humans, and Artisan commands retain ANSI styling and formatting. It’s a zero-config, opt-in optimization.
Does PAO work with Laravel 11 or older versions?
PAO is officially supported for Laravel 12+ due to its service provider auto-discovery. For older versions, you’ll need to manually register the service provider or use it in non-Laravel PHP projects via Composer autoloading.
How do I force PAO to output JSON even in a non-agent environment for testing?
Set the `PAO_AGENT=1` environment variable before running your tools. This overrides auto-detection and forces JSON output, useful for testing CI/CD pipelines or custom integrations.
Can PAO handle partial test failures (e.g., PHPUnit --stop-on-failure) reliably?
Yes, PAO v1.1.1 includes fixes to retain partial results even if tests exit early. JSON output will still capture all available test outcomes, though crashes mid-execution may still cause data loss.
What if my CI system (GitHub Actions/GitLab) misidentifies the agent environment?
Explicitly set `PAO_AGENT=true` in your CI environment variables to ensure PAO activates. This bypasses auto-detection and guarantees JSON output for structured processing.
Does PAO support custom PHPUnit/Pest configurations or parallel test runners?
PAO works out-of-the-box with standard configurations, but custom test runners (e.g., parallel streams) may require additional setup. For Artisan, whitelist commands with `PAO_IGNORE_COMMANDS` if needed.
How does PAO’s JSON output compare to manual parsing or custom loggers?
PAO’s JSON schema is lightweight and optimized for AI agents, reducing token usage and parsing complexity. Unlike custom loggers, it integrates seamlessly with existing tools without requiring manual setup.
Are there performance concerns with PAO in high-throughput CI environments?
PAO adds minimal overhead for JSON serialization, but high-throughput CI may still benefit from benchmarking. The impact is negligible for most use cases, especially compared to the efficiency gains in AI parsing.
What alternatives exist if PAO doesn’t fit my workflow (e.g., Symfony or non-Laravel projects)?
For non-Laravel projects, PAO still works via Composer autoloading. Alternatives include custom loggers (e.g., Monolog with JSON handlers) or tool-specific plugins, but PAO offers the simplest zero-config solution for PHP tooling.
Weaver

How can I help you explore Laravel packages today?

Conversation history is not saved when not logged in.
Prompt
Add packages to context
No packages found.
directorytree/privacy-filter-classifier
directorytree/privacy-filter
datacore/hub-sdk
develia/commons
cuci/prototurk-sdk
cuci/prototurk-sdk-symfony
develia/geo-bundle
dreamzy/livewire-charts
touchestate-sdk/php-sdk
22h/doctrine-garbage-collection-bundle
agtp/agtp-php
agtp/mod-php
splash/sonata-admin
splash/metadata
splash/openapi
splash/scopes
splash/toolkit
testo/output-teamcity
testo/bridge-symfony
spatie/flare-daemon-runtime