DSL-based intent execution system with iterative refinement, featuring AI-powered suggestions via Ollama, safe simulation, and automatic health validation.
Project description
ITERUN
DSL-based intent execution system with iterative refinement, ITERUN boundary, and AI-powered assistance
AI Cost Tracking
- ๐ค LLM usage: $2.3314 (14 commits)
- ๐ค Human dev: ~$504 (5.0h @ $100/h, 30min dedup)
Generated on 2026-06-06 using openrouter/qwen/qwen3-coder-next
Overview
ITERUN is a system that allows you to:
- Generate intents from prompts (LiteLLM / OpenRouter / Ollama) โ
iterun.yaml - Define intents manually in YAML DSL (sekcja
INTENT:) - Simulate execution with dry-run planning
- Deploy services in Docker with optional contract verify (TestQL + retry loop)
- Get AI suggestions in the interactive shell (Ollama / LiteLLM)
- Execute safely with the ITERUN boundary (explicit approval when enabled)
One-liner (prompt โ running service):
iterun generate "Create a REST API for user management" \
-o generated/ --execute --verify
Architecture
โโโโโโโโโโโโโโโโโโโโโโโ
โ CLI / Web / SDK โ โ User interface
โโโโโโโโโโโฌโโโโโโโโโโโโ
โ
โโโโโโโโโโโโโโโโโโโโโโโ
โ Generator (LLM) โ โ prompt โ iterun.yaml + intract + testql
โโโโโโโโโโโฌโโโโโโโโโโโโ
โ
โโโโโโโโโโโโโโโโโโโโโโโ
โ Parser / Validator โ โ DSL โ IR
โโโโโโโโโโโฌโโโโโโโโโโโโ
โ
โโโโโโโโโโโโโโโโโโโโโโโ
โ Planner / Simulator โ โ Dry-run โ app.py, Dockerfile
โโโโโโโโโโโฌโโโโโโโโโโโโ
โ
โโโโโโโโโโโโโโโโโโโโโโโ
โ Executor (Docker) โ โ Deploy service
โโโโโโโโโโโฌโโโโโโโโโโโโ
โ
โโโโโโโโโโโโโโโโโโโโโโโ
โ Contract verify โ โ TestQL + expectations; retry on fail
โโโโโโโโโโโฌโโโโโโโโโโโโ
โ
โโโโโโโโโโโโโโโโโโโโโโโ
โ session.json โ โ Full session log in generated/
โโโโโโโโโโโโโโโโโโโโโโโ
Quick Start
Installation
# Clone repository
git clone https://github.com/softreck/iterun.git
cd iterun
# Full setup (recommended)
make setup
# Editable install (recommended)
python3 -m venv venv && source venv/bin/activate
pip install -e ".[ai]"
cp .env.example .env
Configuration (.env)
Copy .env.example to .env and adjust:
# LLM for `iterun generate` (priority: --model > LLM_MODEL > DEFAULT_MODEL)
OPENROUTER_API_KEY=sk-or-...
LLM_MODEL=openrouter/deepseek/deepseek-v4-pro
# Local Ollama (shell suggest/chat fallback)
OLLAMA_BASE_URL=http://localhost:11434
DEFAULT_MODEL=llama3.2
# Server / execution
HOST=0.0.0.0
PORT=8080
SKIP_ITERUN_CONFIRMATION=true
CONTAINER_PORT=8000
Generate from prompt
source venv/bin/activate
# YAML only
iterun generate "Create a ping API" -o generated/
# Plan + artifacts
iterun generate "..." -o generated/ --run
# Docker + contract verify + repair loop
iterun generate "..." -o generated/ --execute --verify --max-verify-iterations 5
# Full JSON session log
iterun generate "..." -o generated/ --execute --verify --json
Output directory (generated/ by default) โ see Session artifacts.
AI Gateway Setup (Ollama)
# Install Ollama
curl -fsSL https://ollama.com/install.sh | sh
# Start and pull model
make ollama-start
make ollama-pull
# Or manually
ollama serve
ollama pull llama3.2
Using Makefile
make help # Show all commands
make setup # Full setup
make web # Start web server
make shell # Interactive shell
make execute # Execute example intent
make test # Run all tests
make ollama-models # List available models
make clean # Clean temp files
Shell Interface
# Start interactive shell
make shell
# Or: python -m cli.main
# Generate + execute from prompt
make execute
# Or: iterun generate "$(cat examples/01-user-api/prompt.txt)" -o examples/01-user-api/generated/ --execute --verify
Interactive Shell Commands:
intent> new my-api # Create new intent
intent> load iterun.yaml # Load package (generated/iterun.yaml)
intent> plan # Run dry-run
intent> suggest # Get AI suggestions
intent> apply # Auto-apply AI suggestions
intent> chat # Chat with AI
intent> iterate # Apply manual changes
intent> iterun # Approve execution
intent> execute # Execute approved intent
intent> show [json] # Show current state
intent> models # List AI models
intent> ai-health # Check AI Gateway status
intent> help # Show help
intent> exit # Exit shell
Web Interface
# Start web server
python -m web.app
# Open browser at http://localhost:8080
AI Gateway
The AI Gateway uses LiteLLM for:
iterun generateโ cloud models via OpenRouter (OPENROUTER_API_KEY,LLM_MODEL)- Shell
suggest/chatโ local Ollama (OLLAMA_BASE_URL,DEFAULT_MODEL)
Supported Models (โค12B parameters)
| Model | Size | Description |
|---|---|---|
llama3.2 |
3B | Default - Fast and efficient |
llama3.2:1b |
1B | Ultra lightweight |
llama3.1:8b |
8B | Balanced performance |
mistral |
7B | Fast inference |
mistral-nemo |
12B | Best quality under 12B |
gemma2 |
9B | Google Gemma 2 |
gemma2:2b |
2B | Lightweight |
phi3 |
3.8B | Microsoft Phi-3 |
qwen2.5 |
7B | Alibaba Qwen 2.5 |
codellama |
7B | Code generation |
codegemma |
7B | Google CodeGemma |
deepseek-coder |
6.7B | DeepSeek Coder |
Configuration
Environment variables:
export OLLAMA_BASE_URL="http://localhost:11434"
export DEFAULT_MODEL="llama3.2"
export MAX_MODEL_PARAMS="12.0"
Package file: iterun.yaml
The canonical workspace filename is iterun.yaml (not intent.yaml). Full spec: docs/INTENT_DSL_SPEC.md.
INTENT:
name: user-api
goal: Create a REST API for user management
ENVIRONMENT:
runtime: docker
base_image: python:3.12-slim
ports:
- 8000
IMPLEMENTATION:
language: python
framework: fastapi
actions:
- api.expose GET /ping
- api.expose GET /users
- api.expose POST /users
- api.expose DELETE /users/{id}
EXECUTION:
mode: dry-run
Supported Actions
| Action | Format | Description |
|---|---|---|
api.expose |
api.expose METHOD /path |
Expose HTTP endpoint |
db.create |
db.create table_name |
Create database table |
db.add_column |
db.add_column table column type |
Add column to table |
shell.exec |
shell.exec command |
Execute shell command |
rest.call |
rest.call METHOD url |
Call external REST API |
file.create |
file.create path |
Create file |
API Reference
Peลna dokumentacja: docs/API.md โ REST, SDK, MCP, STACK.
Rejestr usลug/artefaktรณw: docs/REGISTRY.md โ Backstage, OCI, OTel.
Runtime markpact+pactown: docs/RUNTIME.md โ odchudzone uruchamianie.
Integration surfaces
| Surface | Entry |
|---|---|
| REST | uvicorn web.app:app โ /api/*, OpenAPI /docs |
| CLI | iterun generate, iterun plan, โฆ |
| SDK | IterunClient() โ local lub base_url="http://โฆ" |
| MCP | iterun-mcp โ narzฤdzia dla agentรณw LLM |
REST Endpoints (skrรณt)
| Method | Endpoint | Description |
|---|---|---|
GET |
/api/health |
Liveness |
GET |
/api/interfaces |
Lista powierzchni API |
GET |
/api/schema |
JSON Schema for DSL |
POST |
/api/intents/validate-yaml |
Validate YAML (is_stack) |
POST |
/api/intents/plan-yaml |
Plan z YAML (STACK โ compose) |
POST |
/api/pipeline/run |
generate โ plan โ execute? โ verify? |
POST |
/api/intents/generate |
LLM โ YAML |
POST |
/api/intents/generate-and-run |
Alias /api/pipeline/run |
GET |
/api/intents |
List all intents |
POST |
/api/intents/parse |
Parse DSL and create intent |
GET |
/api/intents/{id} |
Get intent by ID |
POST |
/api/intents/{id}/plan |
Dry-run (compose_yaml dla STACK) |
POST |
/api/intents/{id}/execute |
Execute approved intent |
AI Gateway Endpoints
| Method | Endpoint | Description |
|---|---|---|
GET |
/api/ai/status |
Check AI Gateway status |
GET |
/api/ai/models |
List available models |
POST |
/api/ai/complete |
Generate AI completion |
POST |
/api/ai/chat |
Chat with AI |
POST |
/api/intents/{id}/ai/suggest |
Get AI suggestions |
POST |
/api/intents/{id}/ai/apply |
Auto-apply suggestions |
Python API
from generator.pipeline import run_pipeline
from parser import parse_dsl
from planner import plan_intent
from sdk import IterunClient
# Prompt โ full pipeline
result = run_pipeline(
"Create a REST API for user management",
output_dir="generated",
execute=True,
verify=True,
)
print(result.yaml_path) # generated/iterun.yaml
print(result.verification) # testql + HTTP result
# Or SDK (local or remote REST)
client = IterunClient()
out = client.run_pipeline("Create a ping API", output_dir="generated", execute=True, verify=True)
# remote = IterunClient(base_url="http://localhost:8000")
# Manual DSL
ir = parse_dsl(open("generated/iterun.yaml").read())
plan = plan_intent(ir)
print(plan.generated_code)
Examples
| Script | Opis |
|---|---|
./examples/run-all.sh |
01โ08: prompt โ iterun.yaml โ plan |
./examples/run-e2e.sh |
09โ12: execute + TestQL + Intract |
./examples/run-resilience.sh |
13โ16: skrajne prompty, pฤtla naprawcza |
Szczegรณลy: examples/README.md.
Session artifacts
Everything from one iterun generate run lands in --output-dir (default generated/):
| File | Content |
|---|---|
iterun.yaml |
DSL package from LLM |
session.json |
Full session โ prompt, generate attempts, plan, execute, verify |
intract.yaml |
Intract contract manifest |
service.testql.toon.yaml |
Auto-generated TestQL scenario |
plan.result.json |
Plan logs + IR |
execution.json |
Execute logs, endpoints, container id |
container.log |
Docker logs (tail) |
verify.result.json |
Contract verify result |
verify.rounds.json |
Repair loop history (--verify) |
app.py / Dockerfile |
Generated service |
Testing
pytest
pytest tests/e2e/test_intent_generator.py -v
pytest tests/e2e/test_shell.py -v
pytest tests/e2e/test_web.py -v
pytest tests/e2e/test_ai_gateway.py -v
Project Structure
iterun/
โโโ generator/ # LLM generate, pipeline, testql, intract, verify loop
โ โโโ intent_generator.py
โ โโโ pipeline.py
โ โโโ contract_verify.py
โ โโโ session.py
โโโ dsl/ # Pydantic schema for LLM validation
โโโ ir/ # Intermediate Representation
โโโ parser/ # DSL parser
โโโ planner/ # Dry-run simulator
โโโ executor/ # Docker execution + HTTP validation
โโโ ai_gateway/ # LiteLLM (Ollama + OpenRouter)
โโโ cli/ # `iterun` CLI
โโโ web/ # FastAPI web UI
โโโ sdk/ # Python SDK client
โโโ iterun_mcp/ # MCP server (optional; not `mcp/` โ conflicts with PyPI mcp)
โโโ examples/ # prompt.txt + run.sh โ generated/
โโโ docs/ # DSL spec, docs index
โโโ tests/e2e/
โโโ config.py # PACKAGE_FILENAME = "iterun.yaml"
โโโ README.md
Workflow
Prompt-first (recommended)
- Prompt โ
iterun generate "..." -o generated/ - Contracts โ auto
intract.yaml+service.testql.toon.yaml - Plan โ
app.py,Dockerfile,plan.result.json - Execute โ Docker container
- Verify โ TestQL + HTTP (
--verify); retry with error context on failure - Session โ
session.jsonaggregates all steps
Manual / interactive
- Edit
iterun.yamlor use shellnew/load - Plan โ dry-run
- Suggest / iterate โ AI or manual refinement
- ITERUN โ approve (unless
SKIP_ITERUN_CONFIRMATION) - Execute โ deploy + endpoint validation
Documentation: docs/README.md ยท docs/INTENT_DSL_SPEC.md
Validation & Auto-Fix
After container deployment, the system automatically:
- Waits for container startup (configurable
STARTUP_WAIT) - Validates all exposed endpoints with HTTP requests
- Detects issues like connection refused, timeouts, HTTP errors
- Auto-fixes common problems:
- Missing
__main__block - Wrong port configuration
- Missing dependencies
- Missing
- Restarts container with fixes
- Re-validates until success or max iterations reached
Configuration
# In .env
VALIDATE_AFTER_EXECUTE=true
AUTO_FIX_ENABLED=true
MAX_FIX_ITERATIONS=3
STARTUP_WAIT=2
VALIDATION_TIMEOUT=10
Example Output
Execution Logs:
[12:38:55] Container started: 8f35e0a2fb27
[12:38:55] Waiting 2s for container startup...
[12:38:57] โ http://localhost:8002 โ 200
[12:38:57] โ http://localhost:8002/ping โ 200
[12:38:57] โ http://localhost:8002/health โ 200
[12:38:57] โ All endpoints validated successfully
โ Execution completed in 2.56s
Validation:
โ All endpoints validated
API Endpoints
| Method | Endpoint | Description |
|---|---|---|
POST |
/api/intents/{id}/validate |
Validate running container |
GET |
/api/containers/{id}/logs |
Get container logs |
License
Licensed under Apache-2.0.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file iterun-0.1.9.tar.gz.
File metadata
- Download URL: iterun-0.1.9.tar.gz
- Upload date:
- Size: 78.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
78e1418036ab2d126db2aa5e6a6eed68e009199edb29bf3e0689f4bdd83f3051
|
|
| MD5 |
e197946bcf9f2f174ac4a7f3b1759728
|
|
| BLAKE2b-256 |
4aacf2c0d74d23a3747d5a87c3ceaca9f5a5420669c1d95f47d73217db541fbe
|
File details
Details for the file iterun-0.1.9-py3-none-any.whl.
File metadata
- Download URL: iterun-0.1.9-py3-none-any.whl
- Upload date:
- Size: 86.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
ca139255c0a3e7cc839998e7d4024608c74b020e1e66887b2eed3654df550d7c
|
|
| MD5 |
206094c1ce7bdc3b14ab20f62ece8add
|
|
| BLAKE2b-256 |
fdd2d36abde1ef46ea3a80418d08acba4e10aae102d20e34a97c81dbddc7eb73
|