Skip to main content

CueAdmin is a command-line administration tool for OpenCue that provides full control over jobs, layers, frames, and hosts. It allows administrators to perform advanced management tasks such as setting priorities, killing jobs, or managing resource allocation.

Project description

CueAdmin

CueAdmin is a command-line administration tool for OpenCue that provides full control over jobs, layers, frames, and hosts. It allows administrators to perform advanced management tasks such as setting priorities, killing jobs, or managing resource allocation. It's written in Python and provides a thin layer over the OpenCue Python API.

Table of Contents

Installation

Install CueAdmin with:

pip install opencue-cueadmin

For development:

# Clone repository and install with test dependencies
git clone https://github.com/AcademySoftwareFoundation/OpenCue.git
cd OpenCue/cueadmin
pip install -e ".[dev]"

Usage

Basic CueAdmin commands:

# List jobs
cueadmin -lj

# List job details
cueadmin -lji

# List hosts
cueadmin -lh

# Job management
cueadmin -pause JOB_NAME                    # Pause a job
cueadmin -unpause JOB_NAME                  # Resume a job
cueadmin -kill JOB_NAME                     # Kill a job (with confirmation)
cueadmin -retry JOB_NAME                    # Retry dead frames
cueadmin -priority JOB_NAME 100             # Set job priority
cueadmin -set-min-cores JOB_NAME 4.0        # Set minimum cores
cueadmin -set-max-cores JOB_NAME 16.0       # Set maximum cores
cueadmin -drop-depends JOB_NAME             # Drop job dependencies

For full documentation, see the OpenCue Documentation.

Running Tests

CueAdmin includes a comprehensive test suite with tests covering job management, allocation management, host operations, output formatting, and core functionality.

Quick Start

# Install with test dependencies
pip install -e ".[test]"

# Run all tests
pytest

# Run with coverage
pytest --cov=cueadmin --cov-report=term-missing

Test Infrastructure

Test Dependencies:

  • pytest>=8.0.0 - Modern test framework
  • pytest-cov>=4.0.0 - Coverage reporting
  • pytest-mock>=3.10.0 - Enhanced mocking
  • mock>=4.0.0 - Core mocking library
  • pyfakefs>=5.2.3 - Filesystem mocking

Test Types:

  • Unit tests - Function-level testing (tests/test_*.py)
  • Integration tests - Command workflow testing (tests/integration_tests.py)
  • Job commands tests - Job management operations (tests/test_job_commands.py)
  • Allocation tests - Allocation management functionality (tests/test_allocation_commands.py)
  • Host commands tests - Host operations (tests/test_host_command.py)
  • Subscription tests - Subscription management (tests/test_subscription_commands.py)

Running Tests

# Basic test run
pytest tests/

# Verbose output
pytest -v

# Run specific test file
pytest tests/test_allocation_commands.py

# Run with coverage and HTML report
pytest --cov=cueadmin --cov-report=html --cov-report=term-missing

# Use the convenience script
./run_tests.sh --coverage --html

Coverage Reporting

# Terminal coverage report
pytest --cov=cueadmin --cov-report=term-missing

# HTML coverage report (generates htmlcov/ directory)
pytest --cov=cueadmin --cov-report=html

# XML coverage for CI/CD
pytest --cov=cueadmin --cov-report=xml

Development Testing

For contributors:

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

# Run all tests with linting
pytest && pylint cueadmin tests

# Run tests across Python versions (requires tox)
tox

# Format code
black cueadmin tests
isort cueadmin tests

CI/CD Integration:

# In OpenCue root directory
./ci/run_python_tests.sh     # Includes cueadmin tests
./ci/run_python_lint.sh      # Includes cueadmin linting

# Run cueadmin tests specifically
cd cueadmin && python -m pytest tests/

Test Configuration

Tests are configured via pyproject.toml:

  • pytest.ini_options - Test discovery and execution
  • coverage settings - Coverage reporting configuration
  • markers - Test categorization (unit, integration, slow)

Continuous Integration

The test suite is integrated into:

  • GitHub Actions - Automated testing on PRs
  • Docker builds - Container-based testing
  • Lint pipeline - Code quality checks

Contributing

We welcome contributions to CueAdmin! The project includes comprehensive development infrastructure:

Development Setup

# Clone and setup
git clone https://github.com/AcademySoftwareFoundation/OpenCue.git
cd OpenCue/cueadmin

# Install with development dependencies
pip install -e ".[dev]"

Testing and Quality

# Run comprehensive test suite
pytest --cov=cueadmin --cov-report=term-missing

# Code formatting and linting
black cueadmin tests && isort cueadmin tests
pylint cueadmin tests

# Multi-environment testing
tox

Project Quality

  • Comprehensive test coverage with unit and integration tests
  • Modern testing infrastructure using pytest, coverage, and CI/CD
  • Code quality tools including pylint, black, and isort
  • Multi-Python version support via tox
  • Docker support for containerized development

For detailed contribution guidelines, see CONTRIBUTING.md.

Get Involved

  • Report Issues: GitHub Issues
  • Contribute Code: Submit pull requests with tests and documentation
  • Improve Documentation: Help enhance tutorials and reference docs
  • Share Use Cases: Contribute real-world examples and workflows

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

opencue_cueadmin-1.13.8.tar.gz (55.9 kB view details)

Uploaded Source

Built Distribution

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

opencue_cueadmin-1.13.8-py3-none-any.whl (20.3 kB view details)

Uploaded Python 3

File details

Details for the file opencue_cueadmin-1.13.8.tar.gz.

File metadata

  • Download URL: opencue_cueadmin-1.13.8.tar.gz
  • Upload date:
  • Size: 55.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.11.13

File hashes

Hashes for opencue_cueadmin-1.13.8.tar.gz
Algorithm Hash digest
SHA256 d6b3eceb802b300f2daab84ab9b0a7623a616b0fa703c7892862fd7769b790e4
MD5 9c496dd5706d7cf10afac07489ad50bb
BLAKE2b-256 8f54321fbc4aa3769b3b6387ac6a4a3c98e7e4159f0a48216cd162789434abc1

See more details on using hashes here.

File details

Details for the file opencue_cueadmin-1.13.8-py3-none-any.whl.

File metadata

File hashes

Hashes for opencue_cueadmin-1.13.8-py3-none-any.whl
Algorithm Hash digest
SHA256 92d5cc29744f1dd947c63849e8889077d4dbc6af19c8a4948e8729ece21cc05e
MD5 84c9c065a3b721b6ac98770764efa84b
BLAKE2b-256 f5780024027a26582ddadda5a9b8dc77424a0813024bd2cb33fd2e9ed88caa77

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