Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/fedora-copr/forge-webhook-parser
Library for parsing webhook payloads from popular git forges
https://github.com/fedora-copr/forge-webhook-parser
Last synced: 14 days ago
JSON representation
Library for parsing webhook payloads from popular git forges
- Host: GitHub
- URL: https://github.com/fedora-copr/forge-webhook-parser
- Owner: fedora-copr
- License: gpl-3.0
- Created: 2024-09-17T12:30:28.000Z (4 months ago)
- Default Branch: main
- Last Pushed: 2024-10-22T09:30:12.000Z (3 months ago)
- Last Synced: 2024-11-14T09:52:20.730Z (about 2 months ago)
- Language: Python
- Size: 29.3 KB
- Stars: 0
- Watchers: 3
- Forks: 1
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- License: COPYING
Awesome Lists containing this project
README
# forge-webhook-parser
[![Repository License](https://img.shields.io/badge/license-GPL%20v3.0-brightgreen.svg)](COPYING)
Library for parsing webhook payloads from popular git forges
## Verifying your pull request
We welcome all contributions.
If you plan to submit a pull request with changes, you should run the automated tests to check for issues.### Setting up nox
This project includes a `nox` configuration to automate tests, checks, and other functions.
You can use these automated tests to help you verify changes before you submit a PR.* Install `nox` using `python3 -m pip install nox` or your distribution's package manager.
* Execute `nox` from the repository root with no arguments to run all Python code checkers.
* Alternatively, you can run only certain tasks as outlined in the following sections.
Run `nox --list` to view available sessions.### Running automated tests
* Perform static analysis with [ruff](https://docs.astral.sh/ruff/).
``` bash
nox -s static
```* Reformat code with [black](https://black.readthedocs.io/en/stable/) and [isort](https://pycqa.github.io/isort/).
``` bash
nox -s formatters
```* Check code for formatting issues without applying changes.
``` bash
nox -s formatters_check
```* Perform static type checking with [mypy](https://mypy.readthedocs.io/en/stable/).
``` bash
nox -s typing
```## Dependency files
`nox` sessions use dependencies from requirements files in the `requirements/` directory.
Each session has a `requirements/*.in` file with direct dependencies and a lock file in `requirements/*.txt` that pins exact versions for both direct and transitive dependencies.* Use the following `nox` session to update all dependency lock files:
``` bash
nox -s pip-compile
```* Update specific dependency lock files with individual `nox` sessions, for example:
``` bash
nox -s "pip-compile-3.12(formatters)"
```By default, the `nox` sessions upgrade dependencies.
You can pass `pip-compile` options `--no-upgrade` and `--upgrade-package` to update only specific packages and keep other dependencies at their current version.
For example, to upgrade the `isort` package only:``` bash
nox -s "pip-compile-3.12(formatters)" -- --no-upgrade --upgrade-package=isort
```