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
Built Distribution
Hashes for yourbase-1.0.1rc4-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 2754be893c88d9ac55a839bc45faf3e04ffe0d1271742d94ed9af41f9d60faa1 |
|
MD5 | 4a0787c9dea90fe505703f6a39aa1f5b |
|
BLAKE2b-256 | 31db4e3fda8aa8e9515356a147f7cf9641fc20112ba11ebbea698ef2c52497a1 |