Skip to main content

The Python library behind great charms

Project description

The ops library

The ops library is a Python framework (available on PyPI) for developing and testing Juju charms in a consistent way, using standard Python constructs to allow for clean, maintainable, and reusable code.

A charm is an operator -- business logic encapsulated in a reusable software package that automates every aspect of an application's life.

Charms written with ops support Kubernetes using Juju's "sidecar charm" pattern, as well as charms that deploy to Linux-based machines and containers.

Charms should do one thing and do it well. Each charm drives a single application and can be integrated with other charms to deliver a complex system. A charm handles creating the application in addition to scaling, configuration, optimisation, networking, service mesh, observability, and other day-2 operations specific to the application.

The ops library is part of the Charm SDK (the other part being Charmcraft). Full developer documentation for the Charm SDK is available at https://juju.is/docs/sdk.

To learn more about Juju, visit https://juju.is/docs/olm.

Pure Python

The framework provides a standardised Python object model that represents the application graph, as well as an event-handling mechanism for distributed system coordination and communication.

The latest version of ops requires Python 3.8 or above.

Juju itself is written in Go for efficient concurrency even in large deployments. Charms can be written in any language, however, we recommend using Python with this framework to make development easier and more standardised. All new charms at Canonical are written using it.

Getting started

A package of operator code is called a charmed operator or simply "charm". You'll use charmcraft to register your charm name and publish it when you are ready. You can follow one of our charming tutorials to get started writing your first charm.

Testing your charms

The framework provides a testing harness, so you can ensure that your charm does the right thing in different scenarios, without having to create a full deployment. Our API documentation has the details, including this example:

class TestCharm(unittest.TestCase):
    def test_foo(self):
        harness = Harness(MyCharm)
        self.addCleanup(harness.cleanup)  # always clean up after ourselves

        # Instantiate the charm and trigger events that Juju would on startup
        harness.begin_with_initial_hooks()

        # Update charm config and trigger config-changed
        harness.update_config({'log_level': 'warn'})

        # Check that charm properly handled config-changed, for example,
        # the charm added the correct Pebble layer
        plan = harness.get_container_pebble_plan('prometheus')
        self.assertIn('--log.level=warn', plan.services['prometheus'].command)

Talk to us

If you need help, have ideas, or would just like to chat with us, reach out on the Charmhub Mattermost.

We also pay attention to the Charmhub Discourse.

And of course you can deep dive into the API reference.

Development of the framework

See HACKING.md for details on dev environments, testing, and so on.

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

ops-2.6.0.tar.gz (239.4 kB view details)

Uploaded Source

Built Distribution

ops-2.6.0-py3-none-any.whl (146.7 kB view details)

Uploaded Python 3

File details

Details for the file ops-2.6.0.tar.gz.

File metadata

  • Download URL: ops-2.6.0.tar.gz
  • Upload date:
  • Size: 239.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.11.5

File hashes

Hashes for ops-2.6.0.tar.gz
Algorithm Hash digest
SHA256 387d5f5bd004b865f575ea4e25ca298bdca05b2b2beb2c51f203d5856c460cf6
MD5 11f39fba1d2a79a9932196f31c0d09e3
BLAKE2b-256 d6e6862daa2e279cdf63a0688bf5d9409aba8006637a53c2ddb1956aa1c586e6

See more details on using hashes here.

File details

Details for the file ops-2.6.0-py3-none-any.whl.

File metadata

  • Download URL: ops-2.6.0-py3-none-any.whl
  • Upload date:
  • Size: 146.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.11.5

File hashes

Hashes for ops-2.6.0-py3-none-any.whl
Algorithm Hash digest
SHA256 b8ce352df4d17de483173dd2f8caf397e89585212d73b4d466b541b1ad3b8966
MD5 6fbea5cee540cd693fe48d5c8b1ff86c
BLAKE2b-256 f3ad70516f278f35f8648906d770701db331f318eea400f46250c4dc1e20c5e2

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page