# Black GitLab Code Quality
This project aim to convert [Black](https://github.com/psf/black) report to
[CodeClimate](https://github.com/codeclimate/platform/blob/master/spec/analyzers/SPEC.md)
format that can be ingest by GitLab.
```
→ poetry run black_gl_cq src/black_gl_code_quality | jq
[
{
"type": "issue",
"description": "Black would reformat",
"location": {
"lines": {
"begin": 1,
"end": 1
},
"path": "src/black_gl_code_quality/__main__.py"
},
"severity": "major"
},
{
"type": "issue",
"description": "Black would reformat",
"location": {
"lines": {
"begin": 1,
"end": 1
},
"path": "src/black_gl_code_quality/error.py"
},
"severity": "major"
}
]
```
## Motivation
For security concerns, Docker-in-Docker has been disabled in all GitLab runners that I
have access/manage. Because the Code Quality template shipped with GitLab instances use
CodeClimate CLI that requires a Docker environment, we can't use it and an alternative
solution was required to obtain Black errors in our Code Quality reports.
## How to install
Simply run the following command:
```
pip install black_gl_code_quality
```
If you use Poetry, you can add it to your dev-dependencies:
```
poetry add --group dev black_gl_code_quality
```
## Usage
There is two ways to use this tool:
- by piping Black
- by calling `black_gl_code_quality` (or by it's alias `black_gl_cq`) directly
### Piping with Black
Piping with Black requires to forward `stderr` to `stdout`. You can use the following
command in the `.gitlab-ci.yml`:
```
black --check src/ 2>&1 | black_gl_cq > black-code-quality-report.json
```
Here's an example for a GitLab-CI job:
```yaml
lint:black:
stage: test
script:
- source .venv/bin/activate
- black --check src/ 2>&1 | black_gl_cq > black-code-quality-report.json
artifacts:
when: always
reports:
codequality: black-code-quality-report.json
```
### Calling `black_gl_code_quality` directly
Calling `black_gl_code_quality` (or it's alias `black_gl_cq`) execute Black with the
`--check` argument. It forwards all arguments you pass if you need to configure Black
via the CLI.
Specifying source folders is **MANDATORY**.
Here's an example for a GitLab-CI job:
```yaml
lint:black:
stage: test
script:
- source .venv/bin/activate
- black_gl_cq src/ > black-code-quality-report.json
artifacts:
when: always
reports:
codequality: black-code-quality-report.json
```
Admit we want to skip string normalization:
```yaml
lint:black:
stage: test
script:
- source .venv/bin/activate
- black_gl_cq -S src/ > black-code-quality-report.json
artifacts:
when: always
reports:
codequality: black-code-quality-report.json
```
### Change severity
By default, all errors have the severity `major`. Depending how you consider Black issues
important, you can change the severity for all errors returned by the report by using
one of the following [values](https://github.com/codeclimate/platform/blob/master/spec/analyzers/SPEC.md#issues)
with the `BLACK_GL_SEVERITY` environment variable: `info`, `minor`, `major`, `critical`, `blocker`.
Here's an example for a GitLab-CI job:
```yaml
lint:black:
stage: test
variables:
BLACK_GL_SEVERITY: minor
script:
- source .venv/bin/activate
- black_gl_cq src/ > black-code-quality-report.json
artifacts:
when: always
reports:
codequality: black-code-quality-report.json
```
## Contributions
In case you have a suggestion or want a new feature, feel free to open a
[discussion](https://github.com/Themimitoof/black-gl-code-quality/discussions).
If you found a bug, you can [open an issue](https://github.com/Themimitoof/black-gl-code-quality/issues).
In order to maintain an overall good code quality, this project use the following tools:
- [Black](https://github.com/psf/black)
- [Isort](https://github.com/PyCQA/isort)
- [Flake8](https://flake8.pycqa.org/en/latest/)
Linting and formatting tools are configured to match the [current default rules of Black](https://black.readthedocs.io/en/stable/the_black_code_style/current_style.html).
Please ensure to run these tools before commiting and submiting a Pull request. In case one of
these mentionned tools report an error, the CI will automatically fail.
In case you are able to fix by yourself a bug, enhance the code or implement a new
feature, feel free to send a [Pull request](https://github.com/Themimitoof/black-gl-code-quality/pulls).
## License
This project is released under the [BSD-3 Clause](LICENSE). Feel free to use,
contribute, fork and do what you want with it. Please keep all licenses, copyright
notices and mentions in case you use, re-use, steal, fork code from this repository.
Raw data
{
"_id": null,
"home_page": "https://github.com/themimitoof/black-gl-code-quality",
"name": "black-gl-code-quality",
"maintainer": "",
"docs_url": null,
"requires_python": ">=3.7,<4.0",
"maintainer_email": "",
"keywords": "Black,CodeClimate,GitLab,GitLab-CI,Code Quality",
"author": "Michael Vieira",
"author_email": "dev@mvieira.fr",
"download_url": "https://files.pythonhosted.org/packages/56/3f/aae4fad34d85d3fef25291af63a01b7b77ff5f592be606885f219bc20db0/black_gl_code_quality-0.1.1.tar.gz",
"platform": null,
"description": "# Black GitLab Code Quality\n\nThis project aim to convert [Black](https://github.com/psf/black) report to\n[CodeClimate](https://github.com/codeclimate/platform/blob/master/spec/analyzers/SPEC.md)\nformat that can be ingest by GitLab.\n\n```\n\u2192 poetry run black_gl_cq src/black_gl_code_quality | jq\n[\n {\n \"type\": \"issue\",\n \"description\": \"Black would reformat\",\n \"location\": {\n \"lines\": {\n \"begin\": 1,\n \"end\": 1\n },\n \"path\": \"src/black_gl_code_quality/__main__.py\"\n },\n \"severity\": \"major\"\n },\n {\n \"type\": \"issue\",\n \"description\": \"Black would reformat\",\n \"location\": {\n \"lines\": {\n \"begin\": 1,\n \"end\": 1\n },\n \"path\": \"src/black_gl_code_quality/error.py\"\n },\n \"severity\": \"major\"\n }\n]\n```\n\n## Motivation\n\nFor security concerns, Docker-in-Docker has been disabled in all GitLab runners that I\nhave access/manage. Because the Code Quality template shipped with GitLab instances use\nCodeClimate CLI that requires a Docker environment, we can't use it and an alternative\nsolution was required to obtain Black errors in our Code Quality reports.\n\n\n## How to install\n\nSimply run the following command:\n\n```\npip install black_gl_code_quality\n```\n\nIf you use Poetry, you can add it to your dev-dependencies:\n\n```\npoetry add --group dev black_gl_code_quality\n```\n\n## Usage\n\nThere is two ways to use this tool:\n\n - by piping Black\n - by calling `black_gl_code_quality` (or by it's alias `black_gl_cq`) directly\n\n\n### Piping with Black\n\nPiping with Black requires to forward `stderr` to `stdout`. You can use the following\ncommand in the `.gitlab-ci.yml`:\n\n```\nblack --check src/ 2>&1 | black_gl_cq > black-code-quality-report.json\n```\n\nHere's an example for a GitLab-CI job:\n\n```yaml\nlint:black:\n stage: test\n script:\n - source .venv/bin/activate\n - black --check src/ 2>&1 | black_gl_cq > black-code-quality-report.json\n artifacts:\n when: always\n reports:\n codequality: black-code-quality-report.json\n```\n\n### Calling `black_gl_code_quality` directly\n\nCalling `black_gl_code_quality` (or it's alias `black_gl_cq`) execute Black with the\n`--check` argument. It forwards all arguments you pass if you need to configure Black\nvia the CLI.\n\nSpecifying source folders is **MANDATORY**.\n\nHere's an example for a GitLab-CI job:\n\n```yaml\nlint:black:\n stage: test\n script:\n - source .venv/bin/activate\n - black_gl_cq src/ > black-code-quality-report.json\n artifacts:\n when: always\n reports:\n codequality: black-code-quality-report.json\n```\n\nAdmit we want to skip string normalization:\n\n```yaml\nlint:black:\n stage: test\n script:\n - source .venv/bin/activate\n - black_gl_cq -S src/ > black-code-quality-report.json\n artifacts:\n when: always\n reports:\n codequality: black-code-quality-report.json\n```\n\n### Change severity\n\nBy default, all errors have the severity `major`. Depending how you consider Black issues\nimportant, you can change the severity for all errors returned by the report by using\none of the following [values](https://github.com/codeclimate/platform/blob/master/spec/analyzers/SPEC.md#issues)\nwith the `BLACK_GL_SEVERITY` environment variable: `info`, `minor`, `major`, `critical`, `blocker`.\n\nHere's an example for a GitLab-CI job:\n\n```yaml\nlint:black:\n stage: test\n variables:\n BLACK_GL_SEVERITY: minor\n script:\n - source .venv/bin/activate\n - black_gl_cq src/ > black-code-quality-report.json\n artifacts:\n when: always\n reports:\n codequality: black-code-quality-report.json\n```\n\n\n## Contributions\n\nIn case you have a suggestion or want a new feature, feel free to open a\n[discussion](https://github.com/Themimitoof/black-gl-code-quality/discussions).\n\nIf you found a bug, you can [open an issue](https://github.com/Themimitoof/black-gl-code-quality/issues).\n\nIn order to maintain an overall good code quality, this project use the following tools:\n\n - [Black](https://github.com/psf/black)\n - [Isort](https://github.com/PyCQA/isort)\n - [Flake8](https://flake8.pycqa.org/en/latest/)\n\nLinting and formatting tools are configured to match the [current default rules of Black](https://black.readthedocs.io/en/stable/the_black_code_style/current_style.html).\n\nPlease ensure to run these tools before commiting and submiting a Pull request. In case one of\nthese mentionned tools report an error, the CI will automatically fail.\n\nIn case you are able to fix by yourself a bug, enhance the code or implement a new\nfeature, feel free to send a [Pull request](https://github.com/Themimitoof/black-gl-code-quality/pulls).\n\n## License\n\nThis project is released under the [BSD-3 Clause](LICENSE). Feel free to use,\ncontribute, fork and do what you want with it. Please keep all licenses, copyright\nnotices and mentions in case you use, re-use, steal, fork code from this repository.\n",
"bugtrack_url": null,
"license": "BSD-3-Clause",
"summary": "A simple wrapper to convert Black outputs to codeclimate report format for GitLab-CI",
"version": "0.1.1",
"project_urls": {
"Homepage": "https://github.com/themimitoof/black-gl-code-quality",
"Repository": "https://github.com/themimitoof/black-gl-code-quality"
},
"split_keywords": [
"black",
"codeclimate",
"gitlab",
"gitlab-ci",
"code quality"
],
"urls": [
{
"comment_text": "",
"digests": {
"blake2b_256": "754091c6b37da7a210de2f2420460df072c0b6b232cdbf2001f62411c439dcde",
"md5": "8518e5c3b22eaef565cb65ffed465e36",
"sha256": "f967b531d85da644fcd72f6b1f2e6d50ae71c1a05c66dfe1f1bc01152f7a8b2c"
},
"downloads": -1,
"filename": "black_gl_code_quality-0.1.1-py3-none-any.whl",
"has_sig": false,
"md5_digest": "8518e5c3b22eaef565cb65ffed465e36",
"packagetype": "bdist_wheel",
"python_version": "py3",
"requires_python": ">=3.7,<4.0",
"size": 5932,
"upload_time": "2023-12-07T19:46:34",
"upload_time_iso_8601": "2023-12-07T19:46:34.349324Z",
"url": "https://files.pythonhosted.org/packages/75/40/91c6b37da7a210de2f2420460df072c0b6b232cdbf2001f62411c439dcde/black_gl_code_quality-0.1.1-py3-none-any.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "563faae4fad34d85d3fef25291af63a01b7b77ff5f592be606885f219bc20db0",
"md5": "8814018a90e698f0292e3f8687c7ed80",
"sha256": "8cc2bccf53bc1ccd363143ca3a168cacd71eac42e0c30c2527af7a213105d428"
},
"downloads": -1,
"filename": "black_gl_code_quality-0.1.1.tar.gz",
"has_sig": false,
"md5_digest": "8814018a90e698f0292e3f8687c7ed80",
"packagetype": "sdist",
"python_version": "source",
"requires_python": ">=3.7,<4.0",
"size": 4465,
"upload_time": "2023-12-07T19:46:35",
"upload_time_iso_8601": "2023-12-07T19:46:35.828701Z",
"url": "https://files.pythonhosted.org/packages/56/3f/aae4fad34d85d3fef25291af63a01b7b77ff5f592be606885f219bc20db0/black_gl_code_quality-0.1.1.tar.gz",
"yanked": false,
"yanked_reason": null
}
],
"upload_time": "2023-12-07 19:46:35",
"github": true,
"gitlab": false,
"bitbucket": false,
"codeberg": false,
"github_user": "themimitoof",
"github_project": "black-gl-code-quality",
"travis_ci": false,
"coveralls": false,
"github_actions": false,
"lcname": "black-gl-code-quality"
}