Skip to main content

Add your description here

Project description

Runnable

Runnable

Transform any Python function into a portable, trackable pipeline in seconds.

python: Pypi License Code style: black MyPy Checked Tests:


🚀 30-Second Transformation

Your existing function (unchanged!):

def analyze_sales():
    total_revenue = 50000
    best_product = "widgets"
    return total_revenue, best_product

Make it runnable everywhere:

from runnable import PythonJob

def main():
    PythonJob(function=analyze_sales).execute()

if __name__ == "__main__":
    main()

🎉 Success! Your function now runs the same on laptop, containers, and Kubernetes with automatic tracking and reproducibility.

🔗 Chain Functions Without Glue Code

def load_customer_data():
    return {"count": 1500, "segments": ["premium", "standard"]}

def analyze_segments(customer_data):  # Name matches = automatic connection
    return {"premium_pct": 30, "growth_potential": "high"}

# What Runnable needs (same logic, no glue):
from runnable import Pipeline, PythonTask

def main():
    Pipeline(steps=[
        PythonTask(function=load_customer_data, returns=["customer_data"]),
        PythonTask(function=analyze_segments, returns=["analysis"])
    ]).execute()

if __name__ == "__main__":
    main()

Same pipeline runs unchanged on laptop, containers, and Kubernetes.

⚡ Installation

pip install runnable

For development:

uv sync --all-extras --dev

Run examples:

uv run examples/01-tasks/python_tasks.py

📊 Why Choose Runnable?

  • 🎯 Easy to adopt: Your code remains as-is, no decorators or imposed structure
  • 🏗️ Bring your infrastructure: Works with your platforms, not a replacement
  • 📝 Reproducibility: Automatic tracking without additional code
  • 🔁 Retry failures: Debug anywhere, retry from failure points
  • 🧪 Testing: Mock/patch pipeline steps, test functions normally
  • 💔 Move on: Easy removal - just delete runnable files, your code stays

🎯 Core Strengths & Extensibility

Runnable excels at data pipeline orchestration:

  • Data processing pipelines
  • ML model training workflows
  • ETL operations
  • Batch job orchestration
  • Scientific computing reproducibility

🧪 Extensible Architecture & Experimental Features:

Runnable's plugin-based architecture demonstrates its extensibility through experimental features like:

  • Async streaming capabilities - Proof of concept for real-time processing (local execution)
  • Loop workflows - Dynamic iteration patterns for complex data processing
  • Custom executors - Extensible to any infrastructure via plugins

For production agentic frameworks, consider specialized tools like Pydantic AI, LangChain, or CrewAI, which are purpose-built for complex LLM applications.

📖 Documentation

Complete Documentation →

🔀 Pipeline Types

Linear Pipelines

Simple sequential execution of Python functions, notebooks, or shell scripts.

Parallel Branches

Execute multiple branches simultaneously for improved performance.

Map Patterns

Execute pipelines over iterable parameters for batch processing.

Arbitrary Nesting

Combine parallel, map, and sequential patterns as needed.

🆚 Why Choose Runnable?

Runnable Kedro Metaflow Airflow
Zero Code Changes ✅ Wrap existing functions ❌ Restructure to nodes ❌ Convert to FlowSpec ❌ Rewrite as DAG tasks
Environment Portability Same code: laptop→container→K8s→Argo Deployment-specific configs AWS-focused with --with flags Platform-specific operators
Mixed Task Types Python + Notebooks + Shell Python nodes only Python steps only Requires separate operators
Plugin Extensibility Auto-discovery via entry points kedro-* packages Limited extensions Complex plugin development
Parameter Passing Automatic by name matching Manual catalog definitions Flow state management Manual XCom operations

🚀 Time to Value

Runnable:

pip install runnable
# Wrap your existing function - done!

Others:

  • Learn framework conventions
  • Restructure existing code
  • Configure project structure
  • Set up deployment configs

Ready to get started? Check out our 30-second demo for immediate results!

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

runnable-0.50.0.tar.gz (131.6 kB view details)

Uploaded Source

Built Distribution

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

runnable-0.50.0-py3-none-any.whl (166.3 kB view details)

Uploaded Python 3

File details

Details for the file runnable-0.50.0.tar.gz.

File metadata

  • Download URL: runnable-0.50.0.tar.gz
  • Upload date:
  • Size: 131.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.9.26 {"installer":{"name":"uv","version":"0.9.26","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for runnable-0.50.0.tar.gz
Algorithm Hash digest
SHA256 c93d061f04125d6ab88d7de29aa5ca55c5493809353e77c237fcf77f41e728f1
MD5 18c58672236e69d65ea29e5182d53f9a
BLAKE2b-256 45720da6556dd71a543d09f2498fc20b88b22844b5da26391db352739b72015c

See more details on using hashes here.

File details

Details for the file runnable-0.50.0-py3-none-any.whl.

File metadata

  • Download URL: runnable-0.50.0-py3-none-any.whl
  • Upload date:
  • Size: 166.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.9.26 {"installer":{"name":"uv","version":"0.9.26","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for runnable-0.50.0-py3-none-any.whl
Algorithm Hash digest
SHA256 c7ad1152037c8df4f534b3285668052ab740e66343e740ec82c3e3a788aa7449
MD5 0fed8a38aa8672dddc0df0771c1d955d
BLAKE2b-256 6a323e60f9cc4809bcdb07b452a5fe248ab056430ea25574bd63844dc260b21d

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