Skip to main content

A CLI-based AutoGen agent team simulating a software company.

Project description

Autogen Software Company

This project implements an AI agent team using the Microsoft AutoGen framework. It simulates a Software Company Workflow that orchestrates multiple CLI-based agents (Product Owner, PM, Tech Lead, Dev, Reviewer, Tester) to deliver software features and bug fixes.

Features

  • Software Company Workflow: A full lifecycle workflow simulating a software team, from product ideation to testing.
  • CLI Agents: Wrappers for Gemini, Amazon Q, and OpenCode CLI tools, enabling them to act as autonomous agents within the workflow.
  • Robust Persistence: Workflows are saved to .tasks/ directory. Each step's output is stored in a readable Markdown file, while task metadata is tracked in JSON.
  • Resumability & Reversion: Tasks can be resumed from the last successful step. If a step produces incorrect results, it can be manually reverted and retried.
  • Step-by-Step Execution: Execute only a single step at a time for fine-grained control and debugging.
  • User Intervention: Configure steps to pause for user review, allowing manual editing of outputs before continuing.
  • Conditional Logic & Loops: Workflows support conditional transitions (e.g., if the Reviewer rejects code, the workflow loops back to the Developer) based on specific output keys.
  • Configurable Timeouts: Prevent long-running agents from hanging indefinitely by setting timeouts globally or per step.
  • Flexible Tooling: Assign specific CLI tools to individual roles, set defaults, and configure fallback strategies for reliability.
  • Structured Data Passing: Agents exchange data via JSON objects, allowing for multiple outputs and inputs per step.

Prerequisites

  • Python: >= 3.11
  • Poetry: For dependency management.
  • CLI Tools: Ensure the desired CLI tools (gemini, q (Amazon Q), or opencode) are installed, configured, and authenticated on your system.

Installation

  1. Clone the repository:

    git clone <repository_url>
    cd autogen
    
  2. Install dependencies:

    poetry install
    

Usage

Use the installed CLI command software-company to manage tasks.

Starting a New Task

To initiate a new software development task, provide a descriptive prompt. A unique task ID will be automatically generated.

# Example: Creating a new feature
poetry run software-company "Develop a user authentication module with OAuth2 support."

Resuming a Task

If a task is interrupted or you wish to continue it later, use the --id flag with the Task ID (found in the output or .tasks/ folder).

poetry run software-company --id <TASK_ID>

Executing a Single Step

For fine-grained control or debugging, you can execute only the next pending step of a task.

# Execute only the next step for the given task ID
poetry run software-company --id <TASK_ID> --step

If no --id is provided, it runs the first step of a new task.

Running a Specific Step

You can also jump directly to and run a specific step by name using the --run-step flag. This is useful for restarting a failed step, re-running a step after manually editing its inputs, or focusing on a particular part of the workflow.

# Example: Jump to and run the 'Code Reviewer' step
poetry run software-company --id <TASK_ID> --run-step "Code Reviewer"

# Combine with --step to run only the specified step and then pause
poetry run software-company --id <TASK_ID> --run-step "Developer Team" --step

Important: When jumping to a step, the workflow will validate that all input_keys required by that step are present in the current context. If inputs are missing, an error will be raised.

Reverting a Step

If a specific step produces unsatisfactory results (e.g., the code is buggy or the spec is incomplete), you can manually revert the last completed step. This deletes the output file and resets the workflow pointer, allowing you to retry that step (possibly with different parameters).

poetry run software-company --id <TASK_ID> --revert

Configuration

The application is highly configurable via config.json.

Configuration File Loading

The system loads configuration in the following order:

  1. Explicit Path: --config-file <path>
  2. Current Working Directory: config.json
  3. Internal Default: software_company/default_config.json

Example config.json

This example demonstrates how to configure tools, retries, multi-variable inputs/outputs, conditional logic, and timeouts.

{
  "state_directory": ".tasks",
  "default_tool": "gemini",
  "max_workflow_iterations": 30,
  "default_timeout": 600, // Global default timeout for all steps (in seconds)
  "steps": [
    {
      "name": "Product Owner",
      "user_review_required": true, // Example: Pause here for manual review of the PRD
      "role_description": "You are an expert Product Owner. Analyze the requested feature/bug from 'user_request'. Create a comprehensive Product Requirement Document (PRD) that defines the goals, user stories, acceptance criteria, and constraints. Your output MUST be a JSON object with a single key 'prd'.",
      "input_keys": ["user_request"],
      "output_keys": ["prd"],
      "arg_name": "po-tool",
      "tool": null,
      "model": null,
      "fallback_tool": null,
      "fallback_model": null,
      "max_retries": 1,
      "timeout": 3600,
      "transitions": []
    },
    {
      "name": "Developer Team",
      "role_description": "Implement the feature...",
      "input_keys": ["tech_spec"],
      "output_keys": ["implementation"],
      "arg_name": "dev-tool",
      "tool": "amazonq",
      "max_retries": 1,
      "timeout": 3600 // Step-specific timeout, overrides default_timeout
    },
    {
      "name": "Code Reviewer",
      "role_description": "Review the code. Return JSON with 'status' (APPROVED/REJECTED) and 'review_comments'.",
      "input_keys": ["implementation"],
      "output_keys": ["status", "review_comments"],
      "arg_name": "reviewer-tool",
      "tool": "gemini",
      "max_retries": 2,
      "transitions": [
        {
          "condition_type": "contains",
          "condition_value": "REJECTED",
          "condition_key": "status",
          "target_step": "Developer Team"
        }
      ]
    }
  ]
}

Key Configuration Fields

  • input_keys: (List[String]) The keys from the workflow context to pass as input to this step.
  • output_keys: (List[String]) The keys the agent is expected to return in a JSON object.
  • max_retries: (Integer) Number of times to automatically retry a step if the agent/tool fails.
  • timeout: (Integer, Optional) Timeout in seconds for this specific step. Overrides default_timeout.
  • transitions: (List) Defines conditional jumps.
    • condition_type: Currently supports "contains".
    • condition_value: The string to look for (case-insensitive).
    • condition_key: The specific output key to check (e.g., "status").
    • target_step: The exact name of the step to jump to if the condition is met.
  • max_workflow_iterations: (Integer) A safety limit to prevent infinite loops (e.g., endless Dev <-> Review cycles).
  • default_timeout: (Integer, Global) Default timeout in seconds for all steps that don't specify their own timeout.
  • user_review_required: (Boolean) If true, the workflow will pause after this step for user inspection and manual editing of the output files.

Fallbacks

You can specify a fallback tool/model to use if the primary tool fails.

Via CLI:

poetry run software-company "Task..." \
  --dev-tool amazonq --dev-fallback-tool opencode

Output Structure

All task data is stored in the configured state_directory (default: .tasks/).

  • task_{ID}.json: Contains task metadata, current step index, and references to output files.
  • task_{ID}_step_{N}_{NAME}_{KEY}.md: The actual content output generated by each step. This allows for easy reading and manual inspection.

Project Structure

  • src/software_company/: Main package directory.
    • main.py: CLI entry point (software-company).
    • workflow.py: Workflow engine (orchestration, state, logic).
    • config.py: Configuration loader.
    • agent_adapter.py: AutoGen adapter for CLI wrappers.
    • cli/: Tool wrappers.
  • cli_agent/: Standalone ReAct agent implementation.
  • pyproject.toml: Poetry configuration and dependency definitions.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

autogen_software_company-0.12.3.tar.gz (38.8 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

autogen_software_company-0.12.3-py3-none-any.whl (50.6 kB view details)

Uploaded Python 3

File details

Details for the file autogen_software_company-0.12.3.tar.gz.

File metadata

  • Download URL: autogen_software_company-0.12.3.tar.gz
  • Upload date:
  • Size: 38.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/2.2.1 CPython/3.12.3 Linux/6.14.0-37-generic

File hashes

Hashes for autogen_software_company-0.12.3.tar.gz
Algorithm Hash digest
SHA256 fe7efd4a326bf8391fc73ffb1c08ae738dffbd4313257dba93f8c2e348f6ffb6
MD5 15df3100b4e75f61065be19201a6f9e2
BLAKE2b-256 0ce89b3882586175f2e89bf34022c22815cab915af2840db5d8b1c26bf33c1d1

See more details on using hashes here.

File details

Details for the file autogen_software_company-0.12.3-py3-none-any.whl.

File metadata

File hashes

Hashes for autogen_software_company-0.12.3-py3-none-any.whl
Algorithm Hash digest
SHA256 e42776d2898ebab84818966784757a77444d4455c015c16b0ae521d76102faf6
MD5 9ec84f55a88b784bc0dc262a054ffa6d
BLAKE2b-256 8c64db43f73a438c25aa88d4e9d9b5b1ecc3b89ea9515783a7ac7b759f5f02b9

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page