Skip to main content

Test acceleration usable in the YourBase CI

Reason this release was yanked:

Please upgrade to YourBase 4.4 or higher.

Project description

YourBase Python Skipper

What is this?

This is a Python package you can use in conjunction with YourBase.

What does it do?

YourBase has a unique test acceleration that records the execution of your tests, builds a dependency graph, and uses it to bypass tests that do not need to be run based on the changes in a commit. This Python package makes those commands much finer-grained for Python projects, enabling more acceleration.

To achieve this, when running in the YourBase CI, this package will load a lighweight wrapper for Python that will determine if a test needs to run based on the YourBase runtime dependency graph.

How do I use this?

Simply run

pip install yourbase
pip freeze > requirements.txt

YourBase supports pytest and unittest.

If you are using pytest, you're done!

If you are using unittest, we have two integration options:

Option 1

Add import yourbase to the top of your testing files. You don't have to do anything else. This option is in early preview, so please open an issue if you encounter bugs with it.

Option 2

Decorate your tests with @accelerate_tests. This option is tried and true, but requires that you decorate each test individually, like so:

from yourbase import accelerate_tests

# ...

@accelerate_tests()
class TestApplication:
    # ...

If you are using another testing framework, please create an issue to let us know! We'd love to support it 🎈

No matter your testing framework, after installation you will not be impacted locally other than seeing a message during testing that your tests will not be accelerated. When you run your tests in the YourBase CI, they will be accelerated.

Contributing

This open source package is a lightweight wrapper for your code that plugs it into the more complex proprietary systems powering YourBase CI servers. We welcome contributions to this wrapper, but at this time we have not built shims or mocks to allow it to be tested front to back outside our systems.

Code style

We use Black for code formatting, which is similar in personality to gofmt -- ruthless consistency, no configuration. Your build will not pass CI if the Black run doesn't come back clean, so we recommend you have your editor automatically run it on save. You can run it manually with

black .

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

yourbase-0.1.4.tar.gz (4.7 kB view hashes)

Uploaded Source

Built Distribution

yourbase-0.1.4-py3-none-any.whl (5.5 kB view hashes)

Uploaded Python 3

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