Skip to main content

DevContainer Management Tool - Manage multiple named devcontainers for any project

Project description

devs - DevContainer Management Tool

A Python command-line tool that simplifies managing multiple named devcontainers for any project.

Features

  • Multiple Named Containers: Start multiple devcontainers with custom names (e.g., "sally", "bob", "charlie")
  • VS Code Integration: Open containers in separate VS Code windows with clear titles
  • Project Isolation: Containers are prefixed with git repository names (org-repo format)
  • Environment Variable Management: Layered DEVS.yml configuration with user-specific overrides
  • Shared Authentication: Claude credentials are shared between containers for the same project
  • Cross-Platform: Works on any project with devcontainer configuration

Installation

pip install devs

Usage

# Start development environments
devs start frontend backend

# Open both in VS Code (separate windows)
devs vscode frontend backend

# Work in a specific container
devs shell frontend

# Run Claude in a container
devs claude frontend "Summarize this codebase"

# Run tests in a container
devs runtests frontend

# Environment variables support
devs start frontend --env DEBUG=true --env API_URL=http://localhost:3000
devs claude frontend "Fix the tests" --env NODE_ENV=test

# Set up Claude authentication (once per host)
devs claude --auth
# Or with API key
devs claude --auth --api-key <YOUR_API_KEY>

# Clean up when done
devs stop frontend backend

# List active containers
devs list

Configuration

Environment Variables

devs supports layered environment variable configuration through DEVS.yml files:

Priority order (highest to lowest):

  1. CLI --env flags
  2. ~/.devs/envs/{org-repo}/DEVS.yml (user-specific project overrides)
  3. ~/.devs/envs/default/DEVS.yml (user defaults)
  4. {project-root}/DEVS.yml (repository configuration)

Example DEVS.yml in your project:

env_vars:
  default:
    NODE_ENV: development
    API_URL: https://api.example.com
    DEBUG: "false"
  
  frontend:  # Container-specific overrides
    DEBUG: "true"
    FRONTEND_PORT: "3000"
    
  backend:
    NODE_ENV: production
    API_URL: https://prod-api.example.com

User-specific configuration:

# Global user defaults
mkdir -p ~/.devs/envs/default
echo 'env_vars:
  default:
    GLOBAL_SETTING: "user_preference"
    MY_SECRET: "user_secret"' > ~/.devs/envs/default/DEVS.yml

# Project-specific overrides (org-repo format)
mkdir -p ~/.devs/envs/myorg-myproject
echo 'env_vars:
  frontend:
    DEBUG: "true"
    LOCAL_SECRET: "dev_secret"' > ~/.devs/envs/myorg-myproject/DEVS.yml

📖 See ../../example-usage.md for detailed examples and scenarios

Requirements

  • Docker: Container runtime
  • VS Code: With code command in PATH
  • DevContainer CLI: npm install -g @devcontainers/cli
  • Project Requirements: .devcontainer/devcontainer.json in target projects

Architecture

Container Naming

Containers follow the pattern: dev-<org>-<repo>-<dev-name>

Example: dev-ideonate-devs-sally, dev-ideonate-devs-bob

VS Code Window Management

Each container gets unique workspace paths to ensure VS Code treats them as separate sessions.

Claude Authentication Sharing

The tool creates symlinks so all containers for the same project share Claude authentication.

Development

# Clone repository
git clone https://github.com/ideonate/devs.git
cd devs/python-devs

# Install in development mode
pip install -e ".[dev]"

# Run tests
pytest

# Format code
black devs tests

# Type checking
mypy devs

License

MIT License

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

devs_cli-3.1.0.tar.gz (35.4 kB view details)

Uploaded Source

Built Distribution

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

devs_cli-3.1.0-py3-none-any.whl (17.4 kB view details)

Uploaded Python 3

File details

Details for the file devs_cli-3.1.0.tar.gz.

File metadata

  • Download URL: devs_cli-3.1.0.tar.gz
  • Upload date:
  • Size: 35.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for devs_cli-3.1.0.tar.gz
Algorithm Hash digest
SHA256 da0ee4cc85daf2f7f2c9e4b9a3c1f4a9e2a8f4f62601b7cc9b4886b04b35da67
MD5 4c8341f9f9999dd7eea5679300a213f2
BLAKE2b-256 46ac17461c7d84930ff0f8773013aa1a648ea280555421113f61efeb7d3f29d3

See more details on using hashes here.

Provenance

The following attestation bundles were made for devs_cli-3.1.0.tar.gz:

Publisher: bump-and-publish.yml on ideonate/devs

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file devs_cli-3.1.0-py3-none-any.whl.

File metadata

  • Download URL: devs_cli-3.1.0-py3-none-any.whl
  • Upload date:
  • Size: 17.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for devs_cli-3.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 47ced37be7ddd4a1201313e0c4981296d0de69a1faf0ffe4146717fdc69d8ea1
MD5 1dc51b3f3d40fc59e05146516e897958
BLAKE2b-256 96f33efdd86aff86a094bc14929f5f9e5d6ba567a52164a7b3ba80ecd96bbb9a

See more details on using hashes here.

Provenance

The following attestation bundles were made for devs_cli-3.1.0-py3-none-any.whl:

Publisher: bump-and-publish.yml on ideonate/devs

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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