Skip to main content

Shared library functions to be used for all autobots projects

Project description

Autobots DevTools Shared Library

Dynamic Agent (Dynagent) is the core of this library. It turns your prompts and business processes into production-ready, multi-agent applications—chatbots and unsupervised workflows—in hours. You focus on prompts, output schemas, and domain logic; Dynagent handles multi-LLM wiring, UI integration, observability, and batch processing out of the box.

Quickstart Build your first agent by following Scaffolding guide here.

Essential features

Feature Description
Dynagent framework Build dynamic AI agents with YAML configs, prompts, and tools. Agent handoff and default/coordinator agents for mesh-style flows.
Multi-LLM support Swap LLMs like swapping batteries. Use Gemini, Claude, or others via a single integration layer.
Chainlit UI Pre-built streaming, tool steps, and structured output for Chainlit. OAuth-ready.
State & context Session state and context management with caching and durable storage. Tools receive ToolRuntime with shared state across handoffs.
Batch processing Run prompts in parallel for batch-enabled agents. Sync API with batch_invoker and BatchResult.
Observability Langfuse integration for tracing and monitoring. TraceMetadata for session, app, and tags.
Pythonic Native Python and LangChain tools. Type hints, async/sync, pytest—no DSLs.
Extensible File server, workspace management, Jenkins integration, and helpers that plug into the framework.
Containerization Docker images with bundled dependencies for consistent deployment.
Prompt versioning Prompts as source — version-controlled markdown files alongside code.
Prompt evaluation Tooling to tweak and evaluate prompt quality across versions.

Batteries included

Helper Description
File server Serve and manage files within agent sessions.
Workspace management Manage working directories and session artifacts.
Context management Caching and durable storage for session context.
Jenkins integration Trigger and monitor Jenkins pipelines from agents.

Quickstart

Guide Description
Try Jarvis See Dynagent in action with a multi-domain multi-agent demo (Concierge, Customer Support, Sales).
Install Set up the shared workspace, virtual environment, and install this library.
Development Run tests, format, lint, type-check, and use the Makefile from this repo or the workspace root.

How-to guides

Guide Description
Workspace setup Clone the workspace, create the shared .venv, clone this repo, and install dependencies.
Development Available make targets: test, format, lint, type-check, install, build, clean.
Project structure Layout of autobots_devtools_shared_lib (dynagent, chainlit_ui, llm_tools, observability, batch).
Testing Unit, integration, and e2e tests. Run with make test, make test-fast, or make test-one.
Contributing See CONTRIBUTING.md for guidelines and workflow.
Publishing See PUBLISHING.md for PyPI publishing.

Advanced

Topic Description
Code quality Type safety (Pyright), pytest, Ruff format/lint, pre-commit hooks.
Type checking Pyright in basic mode; type annotations required.
Workspace commands From workspace root: make test, make lint, make format, make type-check, make all-checks across all repos.

Workspace setup

This library is part of a multi-repository workspace. Use a shared virtual environment at the workspace root.

Prerequisites: Python 3.12+, Poetry (e.g. brew install poetry on macOS).

1. Clone the workspace

cd /path/to/your/work
git clone <workspace-url> ws-jarvis
cd ws-jarvis

2. Create shared virtual environment

make setup

This creates a shared .venv at the workspace root.

3. Clone this repository

git clone https://github.com/Pratishthan/autobots-devtools-shared-lib.git
cd autobots-devtools-shared-lib

4. Install dependencies

make install-dev   # with dev dependencies (recommended)
# or
make install       # runtime only

5. Pre-commit hooks

make install-hooks

Development

Run from autobots-devtools-shared-lib/:

# Testing
make test              # with coverage
make test-fast         # no coverage
make test-one TEST=tests/unit/test_example.py::test_function

# Code quality
make format            # Ruff format
make lint              # Ruff lint (auto-fix)
make check-format      # check only
make type-check        # Pyright
make all-checks        # format, type, test

# Dependencies & build
make install / make install-dev / make update-deps
make build
make clean
make help

Workspace-level commands

From the workspace root:

make test
make lint
make format
make type-check
make all-checks

Project structure

autobots-devtools-shared-lib/
├── src/autobots_devtools_shared_lib/
│   ├── dynagent/           # Multi-agent framework
│   ├── chainlit_ui/        # Chainlit UI components
│   ├── llm_tools/          # LLM integrations
│   ├── observability/      # Observability helpers
│   └── batch_processing/   # Batch utilities
├── tests/
│   ├── unit/
│   ├── integration/
│   └── e2e/
├── .github/workflows/
├── pyproject.toml
├── poetry.toml             # Poetry settings (uses workspace .venv)
├── Makefile
├── CONTRIBUTING.md
└── PUBLISHING.md

Code quality standards

  • Type safety: Type annotations; Pyright (basic mode).
  • Testing: pytest; unit, integration, e2e.
  • Formatting: Ruff, line length 100.
  • Linting: Ruff, strict rules.
  • Pre-commit: Format, lint, type-check, tests on commit.

Testing

make test
make test-one TEST=tests/unit/test_example.py
make test-cov   # HTML coverage report
  • Unit (tests/unit/): Functions and classes.
  • Integration (tests/integration/): Component interactions.
  • E2E (tests/e2e/): Full workflows.

Type checking

make type-check

All code must have type annotations. Pyright runs in basic mode.

Contributing

See CONTRIBUTING.md for development workflow and guidelines.

Publishing

See PUBLISHING.md for PyPI publishing.

License

MIT

Authors

Questions?

Open an issue on the project repository.

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

autobots_devtools_shared_lib-0.2.3a2.tar.gz (53.9 kB view details)

Uploaded Source

Built Distribution

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

File details

Details for the file autobots_devtools_shared_lib-0.2.3a2.tar.gz.

File metadata

  • Download URL: autobots_devtools_shared_lib-0.2.3a2.tar.gz
  • Upload date:
  • Size: 53.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/2.3.2 CPython/3.12.12 Linux/6.14.0-1017-azure

File hashes

Hashes for autobots_devtools_shared_lib-0.2.3a2.tar.gz
Algorithm Hash digest
SHA256 ce2d70908d681bf18b42de1f2e50540dc3c3aaa54b857d511158810178d46e84
MD5 ec10909be5ae91ba90f218fa3601663b
BLAKE2b-256 7b3323eeb9569ffa86ae4a1973294de4517d36f5dedd1f2af7394728e2824a8e

See more details on using hashes here.

File details

Details for the file autobots_devtools_shared_lib-0.2.3a2-py3-none-any.whl.

File metadata

File hashes

Hashes for autobots_devtools_shared_lib-0.2.3a2-py3-none-any.whl
Algorithm Hash digest
SHA256 60efae877ed22271e23fc8ea58df22a1ffda44da07a1cfe76295a4ddacbaa561
MD5 d386eebfc5442bf0fe94c1345d7f945d
BLAKE2b-256 15139c96df643ec2744120aded7507698791ff4f23c1ef0a2315ba70647f13ef

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