<!--
Copyright (C) 2020-2025 Arm Limited or its affiliates and Contributors. All rights reserved.
SPDX-License-Identifier: Apache-2.0
-->
# Automation Scripts for CI/CD
![Package](https://badgen.net/badge/Package/continuous-delivery-scripts/grey)
[![Documentation](https://badgen.net/badge/Documentation/GitHub%20Pages/blue?icon=github)](https://armmbed.github.io/continuous-delivery-scripts)
[![PyPI](https://badgen.net/pypi/v/continuous-delivery-scripts)](https://pypi.org/project/continuous-delivery-scripts/)
[![PyPI - Status](https://img.shields.io/pypi/status/continuous-delivery-scripts)](https://pypi.org/project/continuous-delivery-scripts/)
[![PyPI - Python Version](https://img.shields.io/pypi/pyversions/continuous-delivery-scripts)](https://pypi.org/project/continuous-delivery-scripts/)
[![Downloads](https://pepy.tech/badge/continuous-delivery-scripts)](https://pepy.tech/project/continuous-delivery-scripts)
[![License](https://badgen.net/pypi/license/continuous-delivery-scripts)](https://github.com/ARMmbed/continuous-delivery-scripts/blob/master/LICENSE)
[![Compliance](https://badgen.net/badge/License%20Report/compliant/green?icon=libraries)](https://armmbed.github.io/continuous-delivery-scripts/third_party_IP_report.html)
[![Build Status](https://github.com/ARMmbed/continuous-delivery-scripts/actions/workflows/ci.yml/badge.svg)](https://github.com/ARMmbed/continuous-delivery-scripts/actions/workflows/ci.yml)
[![Test Coverage](https://codecov.io/gh/ARMmbed/continuous-delivery-scripts/branch/main/graph/badge.svg?token=EAW9owYyjW)](https://codecov.io/gh/ARMmbed/continuous-delivery-scripts)
[![Maintainability](https://api.codeclimate.com/v1/badges/41301e959f22986b7b2b/maintainability)](https://codeclimate.com/github/ARMmbed/continuous-delivery-scripts/maintainability)
## Overview
Project initially forked from [ARMmbed/mbed-tools-ci-scripts](https://github.com/ARMmbed/continuous-delivery-scripts) but modified so that it can be used for any projects and any languages.
Continuous Delivery scripts for any projects:
- Automated release flows (i.e. changelog generation, git tags, versioning)
- third party IP auditing and reporting
## Releases
For release notes and a history of changes of all **production** releases, please see the following:
- [Changelog](https://github.com/ARMmbed/continuous-delivery-scripts/blob/master/CHANGELOG.md)
For a the list of all available versions please, please see the:
- [PyPI Release History](https://pypi.org/project/continuous-delivery-scripts/#history)
## Versioning
The version scheme used follows [PEP440](https://www.python.org/dev/peps/pep-0440/) and
[Semantic Versioning](https://semver.org/). For production quality releases the version will look as follows:
- `<major>.<minor>.<patch>`
Beta releases are used to give early access to new functionality, for testing and to get feedback on experimental
features. As such these releases may not be stable and should not be used for production. Additionally any interfaces
introduced in a beta release may be removed or changed without notice. For **beta** releases the version will look as
follows:
- `<major>.<minor>.<patch>-beta.<pre-release-number>`
## Installation
It is recommended that a virtual environment such as [Pipenv](https://github.com/pypa/pipenv/blob/master/README.md) is
used for all installations to avoid Python dependency conflicts.
To install the most recent production quality release use:
```
pip install continuous-delivery-scripts
```
To install a specific release:
```
pip install continuous-delivery-scripts==<version>
```
## Usage & Documentation
Code documentation is available for the most recent
production release here:
- [GitHub Pages](https://armmbed.github.io/continuous-delivery-scripts)
The package follows the [**Unix tools philosophy**](https://tldp.org/LDP/GNU-Linux-Tools-Summary/html/c1089.htm):
> The tools philosophy was to have small programs to accomplish a particular task instead of trying to develop large monolithic programs to do a large number of tasks. To accomplish more complex tasks, tools would simply be connected together, using pipes.
Therefore, it installs the following tools which can be used anywhere within a project/repository comprising a pyproject.toml file such as the [one defining this project](./pyproject.toml):
* `cd-assert-news`: Asserts that the PR/Branch contains a news file describing the changes introduced
* `cd-determine-version`: Returns the version of the tool
* `cd-generate-news`: Generates a changelog file based on the news files present in the repository
* `cd-get-config`: Returns project configuration values
* `cd-tag-and-release`: Releases the project (Language specific actions are run, See [plugins](./continuous_delivery_scripts/plugins))
* `cd-create-news-file`: Generates a news file
* `cd-generate-docs`: Generates project Code documentation which can then be rendered by GitHub pages (See [docs folder](./docs))
* `cd-generate-spdx`: Generates SPDX documents for the project (3rd party IP reporting/ OpenChain)
* `cd-license-files`: Updates the Licence header and copyright to all the source code files
## Project Structure
The follow described the major aspects of the project structure:
- `.github` - CI and GitHub configuration files.
- `docs/` - Interface definition and usage documentation.
- `examples/` - Usage examples.
- `continuous-delivery-scripts/` - Python source files.
- `news/` - Collection of news files for unreleased changes.
- `tests/` - Unit and integration tests.
## Getting Help
- For interface definition and usage documentation, please see [GitHub Pages](https://armmbed.github.io/continuous-delivery-scripts).
- For a list of known issues and possible workarounds, please see [Known Issues](./KNOWN_ISSUES.md).
- To raise a defect or enhancement please use [GitHub Issues](https://github.com/ARMmbed/continuous-delivery-scripts/issues).
## Contributing
- We are committed to fostering a welcoming community, please see our
[Code of Conduct](./CODE_OF_CONDUCT.md) for more information.
- For ways to contribute to the project, please see the [Contributions Guidelines](./CONTRIBUTING.md)
- For a technical introduction into developing this package, please see the [Development Guide](./DEVELOPMENT.md)
Raw data
{
"_id": null,
"home_page": "https://github.com/ARMmbed/continuous-delivery-scripts",
"name": "continuous-delivery-scripts",
"maintainer": null,
"docs_url": null,
"requires_python": "<4,>=3.8",
"maintainer_email": null,
"keywords": "Arm Tools CI CD Continuous Delivery Scripts Automation",
"author": "CMSIS team",
"author_email": "adrien.cabarbaye@arm.com",
"download_url": "https://files.pythonhosted.org/packages/30/40/5508c1ff4d17448fb52be43b419a8306795565371e73697b18acdca6c69c/continuous_delivery_scripts-3.2.5.tar.gz",
"platform": null,
"description": "<!--\nCopyright (C) 2020-2025 Arm Limited or its affiliates and Contributors. All rights reserved.\nSPDX-License-Identifier: Apache-2.0\n-->\n# Automation Scripts for CI/CD\n\n![Package](https://badgen.net/badge/Package/continuous-delivery-scripts/grey)\n[![Documentation](https://badgen.net/badge/Documentation/GitHub%20Pages/blue?icon=github)](https://armmbed.github.io/continuous-delivery-scripts)\n[![PyPI](https://badgen.net/pypi/v/continuous-delivery-scripts)](https://pypi.org/project/continuous-delivery-scripts/)\n[![PyPI - Status](https://img.shields.io/pypi/status/continuous-delivery-scripts)](https://pypi.org/project/continuous-delivery-scripts/)\n[![PyPI - Python Version](https://img.shields.io/pypi/pyversions/continuous-delivery-scripts)](https://pypi.org/project/continuous-delivery-scripts/)\n[![Downloads](https://pepy.tech/badge/continuous-delivery-scripts)](https://pepy.tech/project/continuous-delivery-scripts)\n\n[![License](https://badgen.net/pypi/license/continuous-delivery-scripts)](https://github.com/ARMmbed/continuous-delivery-scripts/blob/master/LICENSE)\n[![Compliance](https://badgen.net/badge/License%20Report/compliant/green?icon=libraries)](https://armmbed.github.io/continuous-delivery-scripts/third_party_IP_report.html)\n\n[![Build Status](https://github.com/ARMmbed/continuous-delivery-scripts/actions/workflows/ci.yml/badge.svg)](https://github.com/ARMmbed/continuous-delivery-scripts/actions/workflows/ci.yml)\n\n[![Test Coverage](https://codecov.io/gh/ARMmbed/continuous-delivery-scripts/branch/main/graph/badge.svg?token=EAW9owYyjW)](https://codecov.io/gh/ARMmbed/continuous-delivery-scripts)\n[![Maintainability](https://api.codeclimate.com/v1/badges/41301e959f22986b7b2b/maintainability)](https://codeclimate.com/github/ARMmbed/continuous-delivery-scripts/maintainability)\n\n## Overview\n\nProject initially forked from [ARMmbed/mbed-tools-ci-scripts](https://github.com/ARMmbed/continuous-delivery-scripts) but modified so that it can be used for any projects and any languages.\n\nContinuous Delivery scripts for any projects:\n- Automated release flows (i.e. changelog generation, git tags, versioning)\n- third party IP auditing and reporting\n\n\n## Releases\n\nFor release notes and a history of changes of all **production** releases, please see the following:\n\n- [Changelog](https://github.com/ARMmbed/continuous-delivery-scripts/blob/master/CHANGELOG.md)\n\nFor a the list of all available versions please, please see the:\n\n- [PyPI Release History](https://pypi.org/project/continuous-delivery-scripts/#history)\n\n## Versioning\n\nThe version scheme used follows [PEP440](https://www.python.org/dev/peps/pep-0440/) and \n[Semantic Versioning](https://semver.org/). For production quality releases the version will look as follows:\n\n- `<major>.<minor>.<patch>`\n\nBeta releases are used to give early access to new functionality, for testing and to get feedback on experimental \nfeatures. As such these releases may not be stable and should not be used for production. Additionally any interfaces\nintroduced in a beta release may be removed or changed without notice. For **beta** releases the version will look as\nfollows:\n\n- `<major>.<minor>.<patch>-beta.<pre-release-number>`\n\n## Installation\n\nIt is recommended that a virtual environment such as [Pipenv](https://github.com/pypa/pipenv/blob/master/README.md) is\nused for all installations to avoid Python dependency conflicts.\n\nTo install the most recent production quality release use:\n\n```\npip install continuous-delivery-scripts\n```\n\nTo install a specific release:\n\n```\npip install continuous-delivery-scripts==<version>\n```\n\n## Usage & Documentation\n\nCode documentation is available for the most recent\nproduction release here:\n\n- [GitHub Pages](https://armmbed.github.io/continuous-delivery-scripts)\n\nThe package follows the [**Unix tools philosophy**](https://tldp.org/LDP/GNU-Linux-Tools-Summary/html/c1089.htm):\n\n> The tools philosophy was to have small programs to accomplish a particular task instead of trying to develop large monolithic programs to do a large number of tasks. To accomplish more complex tasks, tools would simply be connected together, using pipes.\n\nTherefore, it installs the following tools which can be used anywhere within a project/repository comprising a pyproject.toml file such as the [one defining this project](./pyproject.toml):\n* `cd-assert-news`: Asserts that the PR/Branch contains a news file describing the changes introduced\n* `cd-determine-version`: Returns the version of the tool\n* `cd-generate-news`: Generates a changelog file based on the news files present in the repository\n* `cd-get-config`: Returns project configuration values\n* `cd-tag-and-release`: Releases the project (Language specific actions are run, See [plugins](./continuous_delivery_scripts/plugins))\n* `cd-create-news-file`: Generates a news file\n* `cd-generate-docs`: Generates project Code documentation which can then be rendered by GitHub pages (See [docs folder](./docs))\n* `cd-generate-spdx`: Generates SPDX documents for the project (3rd party IP reporting/ OpenChain)\n* `cd-license-files`: Updates the Licence header and copyright to all the source code files\n\n## Project Structure\n\nThe follow described the major aspects of the project structure:\n\n- `.github` - CI and GitHub configuration files.\n- `docs/` - Interface definition and usage documentation.\n- `examples/` - Usage examples.\n- `continuous-delivery-scripts/` - Python source files.\n- `news/` - Collection of news files for unreleased changes.\n- `tests/` - Unit and integration tests.\n\n## Getting Help\n\n- For interface definition and usage documentation, please see [GitHub Pages](https://armmbed.github.io/continuous-delivery-scripts).\n- For a list of known issues and possible workarounds, please see [Known Issues](./KNOWN_ISSUES.md).\n- To raise a defect or enhancement please use [GitHub Issues](https://github.com/ARMmbed/continuous-delivery-scripts/issues).\n\n## Contributing\n\n- We are committed to fostering a welcoming community, please see our\n [Code of Conduct](./CODE_OF_CONDUCT.md) for more information.\n- For ways to contribute to the project, please see the [Contributions Guidelines](./CONTRIBUTING.md)\n- For a technical introduction into developing this package, please see the [Development Guide](./DEVELOPMENT.md)\n",
"bugtrack_url": null,
"license": "Apache 2.0",
"summary": "Continuous Delivery scripts to increase automation",
"version": "3.2.5",
"project_urls": {
"Homepage": "https://github.com/ARMmbed/continuous-delivery-scripts"
},
"split_keywords": [
"arm",
"tools",
"ci",
"cd",
"continuous",
"delivery",
"scripts",
"automation"
],
"urls": [
{
"comment_text": "",
"digests": {
"blake2b_256": "dc59f2eb700306ec6afca6af08e3b13e84c283b3751a5794a2d63453d52d57a4",
"md5": "f01a52731e9d80d22430657c022dbf7a",
"sha256": "d41d264b2a084cda6d7f16c31a74efcf60633667677373e16b7c55cff4768c51"
},
"downloads": -1,
"filename": "continuous_delivery_scripts-3.2.5-py3-none-any.whl",
"has_sig": false,
"md5_digest": "f01a52731e9d80d22430657c022dbf7a",
"packagetype": "bdist_wheel",
"python_version": "py3",
"requires_python": "<4,>=3.8",
"size": 84044,
"upload_time": "2025-01-13T09:19:25",
"upload_time_iso_8601": "2025-01-13T09:19:25.518055Z",
"url": "https://files.pythonhosted.org/packages/dc/59/f2eb700306ec6afca6af08e3b13e84c283b3751a5794a2d63453d52d57a4/continuous_delivery_scripts-3.2.5-py3-none-any.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "30405508c1ff4d17448fb52be43b419a8306795565371e73697b18acdca6c69c",
"md5": "526f26e52cd38d220abc6b900c11763e",
"sha256": "1db1de62e3cebc4dfcfb8b3f9feef7a35fe04793f28a63aa72896256691ec339"
},
"downloads": -1,
"filename": "continuous_delivery_scripts-3.2.5.tar.gz",
"has_sig": false,
"md5_digest": "526f26e52cd38d220abc6b900c11763e",
"packagetype": "sdist",
"python_version": "source",
"requires_python": "<4,>=3.8",
"size": 100268,
"upload_time": "2025-01-13T09:19:27",
"upload_time_iso_8601": "2025-01-13T09:19:27.938554Z",
"url": "https://files.pythonhosted.org/packages/30/40/5508c1ff4d17448fb52be43b419a8306795565371e73697b18acdca6c69c/continuous_delivery_scripts-3.2.5.tar.gz",
"yanked": false,
"yanked_reason": null
}
],
"upload_time": "2025-01-13 09:19:27",
"github": true,
"gitlab": false,
"bitbucket": false,
"codeberg": false,
"github_user": "ARMmbed",
"github_project": "continuous-delivery-scripts",
"travis_ci": false,
"coveralls": false,
"github_actions": true,
"lcname": "continuous-delivery-scripts"
}