mirror of
https://github.com/microsoft/agent-framework.git
synced 2026-06-16 21:04:09 +08:00
f48c4512d3
* updated automation tasks and commands, with alias for the time being * Restore aggregate test exclusions Preserve the legacy all-tests scope for test --all by excluding lab and devui from the default aggregate sweep, while still allowing explicit package selection. Also ignore hidden/generated test directories such as .mypy_cache during aggregate discovery. Co-authored-by: Copilot <223556219+Copilot@users.noreply.github.com> * updated versions in pre-commit --------- Co-authored-by: Copilot <223556219+Copilot@users.noreply.github.com>
120 lines
4.6 KiB
Markdown
120 lines
4.6 KiB
Markdown
# Agent Framework Lab
|
|
|
|
This is the experimental package for Microsoft Agent Framework, `agent-framework-lab`, which contains
|
|
various lab modules built on top of the core framework.
|
|
Lab modules are not part of the core framework and may experience breaking changes or be deprecated in the future.
|
|
|
|
## What are Lab Modules?
|
|
|
|
Lab modules are extensions to the core Agent Framework that fall into
|
|
one of the following categories:
|
|
|
|
1. Incubation of new features that may get incorporated by the core framework.
|
|
2. Research prototypes built on the core framework.
|
|
3. Benchmarks and experimentation tools.
|
|
|
|
## Lab Modules
|
|
|
|
- [**gaia**](./gaia/): Evaluate your agents using the GAIA benchmark for general assistant tasks
|
|
- [**tau2**](./tau2/): Evaluate your agents using the TAU2 benchmark for customer support tasks
|
|
- [**lightning**](./lightning/): RL training for agents using Agent Lightning
|
|
|
|
## Repository Structure
|
|
|
|
```
|
|
agent-framework-lab/
|
|
├── pyproject.toml # Single package configuration for agent-framework-lab
|
|
├── README.md # This file
|
|
├── LICENSE # License file
|
|
├── namespace/ # Centralized namespace package files
|
|
│ └── agent_framework/
|
|
│ └── lab/
|
|
│ ├── gaia/ # Re-exports from agent_framework_lab_gaia
|
|
│ ├── lightning/ # Re-exports from agent_framework_lab_lightning
|
|
│ └── tau2/ # Re-exports from agent_framework_lab_tau2
|
|
├── gaia/ # GAIA module implementation
|
|
│ └── agent_framework_lab_gaia/
|
|
├── lightning/ # Lightning module implementation
|
|
│ └── agent_framework_lab_lightning/
|
|
└── tau2/ # TAU2 module implementation
|
|
└── agent_framework_lab_tau2/
|
|
```
|
|
|
|
This structure maintains a single PyPI package `agent-framework-lab` while supporting modular imports through the namespace package mechanism.
|
|
|
|
## Installation
|
|
|
|
To install each lab module, use the extras syntax with `pip`:
|
|
|
|
```bash
|
|
pip install "agent-framework-lab[gaia]"
|
|
pip install "agent-framework-lab[tau2]"
|
|
pip install "agent-framework-lab[lightning]"
|
|
```
|
|
|
|
## Usage
|
|
|
|
Import and use lab modules from the `agent_framework.lab` namespace.
|
|
For example, to use the GAIA module:
|
|
|
|
```python
|
|
# Using GAIA module
|
|
from agent_framework.lab.gaia import GAIA
|
|
```
|
|
|
|
## Running Tests Locally
|
|
|
|
For machine-safe local runs, prefer package-scoped commands first:
|
|
|
|
```bash
|
|
uv run --directory packages/lab poe test
|
|
uv run --directory packages/lab pytest -q -m "not integration"
|
|
```
|
|
|
|
When you need to run lab tests from the repository root, scope the root task to the lab package:
|
|
|
|
```bash
|
|
uv run poe test -P lab
|
|
```
|
|
|
|
Lightning observability tests intentionally exercise heavier tracing paths and are marked as `resource_intensive`:
|
|
|
|
```bash
|
|
uv run --directory packages/lab pytest lightning/tests/test_lightning.py -m "resource_intensive" -q
|
|
```
|
|
|
|
## Should I consume Lab Modules?
|
|
|
|
If you are looking for stable and production-ready features, you should not use lab modules. Stick to the core framework.
|
|
|
|
If you are looking for experimentation, research, or want to
|
|
benchmark different approaches -- most importantly, if you don't mind breaking changes and potential deprecations --
|
|
then lab modules are for you.
|
|
|
|
## Contributing to Lab Modules
|
|
|
|
### Microsoft-maintained modules
|
|
|
|
For Microsoft-maintained modules in this repository, please follow standard contribution guidelines and submit pull requests directly to this repository.
|
|
|
|
### Community modules
|
|
|
|
If you want to contribute a community-maintained lab module:
|
|
|
|
1. Create a new repository on GitHub for your module
|
|
2. Tag your repository with `agent-framework-lab` for discoverability
|
|
3. Submit a PR to add a link to your repository in the [Lab Modules](#lab-modules) section above
|
|
4. Use the PR title format: `[New Lab Module] Your Module Name`
|
|
|
|
We will review your submission based on the guidelines below.
|
|
|
|
### Guidelines
|
|
|
|
1. **Purpose**: Community modules should fit into one of the three categories of lab modules (incubation, research, benchmarks)
|
|
2. **Namespace**: Community modules should avoid the `agent_framework.lab` namespace (reserved for modules maintained in this repository)
|
|
3. **Dependencies**: Minimize external dependencies, always include `agent-framework` as a base dependency
|
|
4. **Documentation**: Include comprehensive README with installation instructions and usage examples
|
|
5. **Tests**: Write comprehensive tests with good coverage
|
|
6. **Type hints**: Always include type hints and a `py.typed` file
|
|
7. **Versioning**: Use semantic versioning, start with `0.1.0` for initial releases
|