Skip to main content

Provides CLI scripts and utility functions used by Sun Lab automation pipelines.

Project description

ataraxis-automation

A Python library that provides CLI scripts and utility functions used by Sun Lab automation pipelines.

PyPI - Version PyPI - Python Version uv Ruff type-checked: mypy PyPI - License PyPI - Status PyPI - Wheel


Detailed Description

This library decouples automation-assisting scripts used by most Sun Lab projects from the 'tox' tasks that use them. This allows updating custom automation functions without the need to manually update each module that uses these scripts. Since most functions exposed through this module are 'meta-functions' providing build-system functionality, they currently do not contain an automated test suite, but they have been extensively tested on multiple Ataraxis libraries.

In addition to automation functions, this library provides meta-utility functions, such as message-formatting. Since all other Sun Lab projects use automation functions, bundling them with widely used utilities unifies these critical dependencies in one pacakge.

The library can be used as a standalone module, but it is primarily designed to integrate with other Sun Lab libraries, providing development automation functionality. Additionally, it comes pre-bundled with all Sun Lab templates, private or public.


Features

  • Supports Windows, Linux, and OSx.
  • Optimized for runtime speed.
  • Compliments the extensive suite of tox-automation tasks used by all Sun Lab projects.
  • Pure-python API.
  • GPL 3 License.

Table of Contents


Dependencies

For users, all library dependencies are installed automatically for all supported installation methods (see Installation section). For developers, see the Developers section for information on installing additional development dependencies.


Installation

Source

  1. Download this repository to your local machine using your preferred method, such as git-cloning. Optionally, use one of the stable releases that include precompiled binary wheels in addition to source code.
  2. cd to the root directory of the project using your CLI of choice.
  3. Run python -m pip install . to install the project. Alternatively, if using a distribution with precompiled binaries, use python -m pip install WHEEL_PATH, replacing 'WHEEL_PATH' with the path to the wheel file.

PIP

Use the following command to install the library using PIP: pip install ataraxis-automation

Conda / Mamba

Note. Due to conda-forge contributing process being more nuanced than pip uploads, conda versions may lag behind pip and source code distributions.

Use the following command to install the library using Conda or Mamba: conda install ataraxis-automation


Usage

This library is primarily designed for two purposes: providing a CLI suite of tox-assisting scripts and a set of widely used utility functions.

This is a minimal example of how to use the automation CLI functions:

  • Use automation-cli --help from your shell to display the list of available cli command.
  • Use automation-cli COMMAND-NAME --help to display additional information about each command. For example: automation-cli import-env --help.
  • To use any of the CLI commands as part of tox pipeline, add it to the 'commands' section of the tox.ini:
[testenv:rename-envs]
skip_install = true
deps =
    ataraxis-automation
description =
    Replaces the base environment name used by all files inside the 'envs' directory with the user-input name.
commands =
    automation-cli rename-environments

This is a minimal example of how to use the utility functions from this library:

# Import the desired function(s) from the utilities module.
from ataraxis_automation.utilities import format_message

# Message formatting example. The function is used across all Sun Lab projects to format any emitted messages:
long_message = (
        "This is a very long message that needs to be formatted properly. It should be wrapped at 120 characters "
        "without breaking long words or splitting on hyphens. The formatting should be applied correctly to ensure "
        "readability and consistency across the library."
    )
print(long_message) # Showcases unformatted message
print()
print(format_message(long_message)) # Showcases formatted message

API Documentation

See the API documentation for the detailed description of the methods and classes exposed by components of this library. Note the documentation also includes a list of all CLI functions provided by automation-cli command.


Developers

This section provides installation, dependency, and build-system instructions for the developers that want to modify the source code of this library. Additionally, it contains instructions for recreating the conda environments that were used during development from the included .yml files.

Installing the library

  1. Download this repository to your local machine using your preferred method, such as git-cloning.
  2. cd to the root directory of the project using your CLI of choice.
  3. Install development dependencies. You have multiple options of satisfying this requirement:
    1. Preferred Method: Use conda or pip to install tox or use an environment that has it installed and call tox -e import-env to automatically import the os-specific development environment included with the source code in your local conda distribution. Alternatively, see environments section for other environment installation methods.
    2. Run python -m pip install .'[dev]' command to install development dependencies and the library using pip. On some systems, you may need to use a slightly modified version of this command: python -m pip install .[dev].
    3. As long as you have an environment with tox installed and do not intend to run any code outside the predefined project automation pipelines, tox will automatically install all required dependencies for each task.

Note: When using tox automation, having a local version of the library may interfere with tox methods that attempt to build the library using an isolated environment. It is advised to remove the library from your test environment, or disconnect from the environment, prior to running any tox tasks. This problem is rarely observed with the latest version of the automation pipeline, but is worth mentioning.

Additional Dependencies

In addition to installing the required python packages, separately install the following dependencies:

  1. Python distributions, one for each version that you intend to support. Currently, this library supports version 3.10 and above. The easiest way to get tox to work as intended is to have separate python distributions, but using pyenv is a good alternative too. This is needed for the 'test' task to work as intended.

Development Automation

This project comes with a fully configured set of automation pipelines implemented using tox. Check tox.ini file for details about available pipelines and their implementation. Note, automation pipelines for this specific project list it as a circular dependency in some use cases, which is not ideal, but works.

Note! All commits to this library have to successfully complete the tox task before being pushed to GitHub. To minimize the runtime task for this task, use tox --parallel.

Environments

All environments used during development are exported as .yml files and as spec.txt files to the envs folder. The environment snapshots were taken on each of the three supported OS families: Windows 11, OSx 14.5 and Ubuntu 22.04 LTS.

To install the development environment for your OS:

  1. Download this repository to your local machine using your preferred method, such as git-cloning.
  2. cd into the envs folder.
  3. Use one of the installation methods below:
    1. Preferred Method: Install tox or use another environment with already installed tox and call tox -e import-env.
    2. Alternative Method: Run conda env create -f ENVNAME.yml or mamba env create -f ENVNAME.yml. Replace 'ENVNAME.yml' with the name of the environment you want to install (axa_dev_osx for OSx, axa_dev_win for Windows and axa_dev_lin for Linux).

Note: the OSx environment was built against M1 (Apple Silicon) platform and may not work on Intel-based Apple devices.


Authors


License

This project is licensed under the GPL3 License: see the LICENSE file for details.


Acknowledgments

  • All Sun Lab members for providing the inspiration and comments during the development of this library.

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

ataraxis_automation-1.0.5.tar.gz (60.0 kB view hashes)

Uploaded Source

Built Distribution

ataraxis_automation-1.0.5-py3-none-any.whl (48.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