Validate your GitLab CI with GitLab's API endpoint.
Project description
GitLab CI lint pre-commit-hook
This is a pre-commit hook that uses GitLab's /api/v4/ci/lint
linting endpoint to validate the contents of .gitlab-ci.yml
files. This is similar to how CircleCI pre-commit hooks validate that product's required configs: by uploading your config to their API.
$ gitlabci-lint --help
usage: gitlabci-lint [-h] [-c CONFIGS] [-C GITLABCI_LINT_CONFIG] [-B [BASE_URL]] [--version] [-q]
Validate your GitLab CI with GitLab's API endpoint.
options:
-h, --help show this help message and exit
-c CONFIGS, --configs CONFIGS
CI Config files to check. (default: .gitlab-ci.yml)
-C GITLABCI_LINT_CONFIG, --gitlabci-lint-config GITLABCI_LINT_CONFIG
Pass parameters via config file. Looks first at '.gitlabci-lint.toml', then '$HOME/.config/gitlabci-lint/config.toml', unless otherwise specified.
-B [BASE_URL], --base-url [BASE_URL]
Base GitLab URL. (default: https://gitlab.com/)
--version show program's version number and exit
-q, -Q, --quiet Silently fail and pass, without output, unless improperly configured. (default: False)
By default, this tool sends your configuration to https://gitlab.com, though this can be overridden (see below for an example or the help text above).
Usage
Requirements
GitLab Lint API now requires authorization.
- Create Access Token with
api
scope. - Set access token value as a
GITLAB_TOKEN
orGITLABCI_LINT_TOKEN
environment variable. - Ensure Python version available is 3.8 or later.
Warning Please note the token should not be shared and if leaked can cause significant harm.
Example
An example .pre-commit-config.yaml
:
---
repos:
- repo: https://github.com/bjd2385/pre-commit-gitlabci-lint
rev: <latest release>
hooks:
- id: gitlabci-lint
# args: [-b, 'https://custom.gitlab.host.com']
Configuration files
No configuration file is required for use. However, if you'd rather specify configuration options in your repo, you may create a config file .gitlabci-lint.toml
in the repo, or $HOME/.config/.gitlabci-lint/config.toml
, such as the following.
Development
Install dependencies by running ./scripts/dependencies.sh
. Or, if you already have yarn
in your path, yarn install:deps
.
Releases
Update setup.py/version
-string and tag this repo's master branch with the same version string (prefixed by 'v
.)
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 pre-commit-gitlabci-lint-1.2.0.tar.gz
Algorithm | Hash digest | |
---|---|---|
SHA256 | 0f63c9593c461688b6dd20707b7b675d439457adfb43f931243b27205ed680b9 |
|
MD5 | 24f523ea7b1ed6bb9a2b175eb2575f3c |
|
BLAKE2b-256 | e7f3a537038b3f8b5165469801b0dee876344bcbc453834c0f65f0f16d874a6c |
Hashes for pre_commit_gitlabci_lint-1.2.0-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | b00caefb6edc68a063d7dd4647c009a6da0574ade2a11f509bf8f70811d4c17c |
|
MD5 | 7777bd451d8821d98126a430ff98309c |
|
BLAKE2b-256 | f178af03e08ce25bb6b4b9c70e398a6ece6d663ecdfe8a66a3ccb44f652a3c17 |