Tool to check generic rules/best-practices for containers/images/dockerfiles.
Project description
Colin
Tool to check generic rules and best-practices for container images and dockerfiles.
For more information, please check our documentation on colin.readthedocs.io.
Features
- Validate a selected artifact against a ruleset.
- Artifacts can be container images and dockerfiles.
- We provide a default ruleset we believe every container image should satisfy.
- There is a ruleset to validate an artifact whether it complies to Fedora Container Guidelines
- Colin can list available rulesets and list checks in a ruleset.
- There is a python API available
- Colin can be integrated into your workflow easily - it can provide results in json format.
Installation
Via pip
If you are on Fedora distribution, please install python3-pyxattr so you don't have to compile it yourself when getting it from PyPI.
$ pip3 install --user colin
colin
is supported on python 3.6+ only.
On Fedora distribution
colin is packaged in official Fedora repositories:
$ dnf install -y colin
Requirements
-
For checking
image
target-type, you have to install podman. If you need to check local docker images, you need to prefix your images withdocker-daemon
(e.g.colin check docker-daemon:docker.io/openshift/origin-web-console:v3.11
). -
If you want to use
ostree
target, you need to install following tools:
Usage
$ colin --help
Usage: colin [OPTIONS] COMMAND [ARGS]...
COLIN -- Container Linter
Options:
-V, --version Show the version and exit.
-h, --help Show this message and exit.
Commands:
check Check the image/dockerfile (default).
info Show info about colin and its dependencies.
list-checks Print the checks.
list-rulesets List available rulesets.
$ colin check --help
Usage: colin check [OPTIONS] TARGET
Check the image/dockerfile (default).
Options:
-r, --ruleset TEXT Select a predefined ruleset (e.g. fedora).
-f, --ruleset-file FILENAME Path to a file to use for validation (by
default they are placed in
/usr/share/colin/rulesets).
--debug Enable debugging mode (debugging logs, full
tracebacks).
--json FILENAME File to save the output as json to.
--stat Print statistics instead of full results.
-s, --skip TEXT Name of the check to skip. (this option is
repeatable)
-t, --tag TEXT Filter checks with the tag.
-v, --verbose Verbose mode.
--checks-path DIRECTORY Path to directory containing checks (default
['/home/flachman/.local/lib/python3.7/site-
packages/colin/checks']).
--pull Pull the image from registry.
--target-type TEXT Type of selected target (one of image,
dockerfile, ostree). For ostree, please specify
image name and path like this: image@path
--timeout INTEGER Timeout for each check in seconds.
(default=600)
--insecure Pull from an insecure registry (HTTP or invalid
TLS).
-h, --help Show this message and exit.
Let's give it a shot:
$ colin -f ./rulesets/fedora.json registry.fedoraproject.org/f29/cockpit
PASS:Label 'architecture' has to be specified.
PASS:Label 'build-date' has to be specified.
FAIL:Label 'description' has to be specified.
PASS:Label 'distribution-scope' has to be specified.
:
:
PASS:10 FAIL:8
Directly from git
It's possible to use colin directly from git:
$ git clone https://github.com/user-cont/colin.git
$ cd colin
We can now run the analysis:
$ python3 -m colin.cli.colin -f ./rulesets/fedora.json registry.fedoraproject.org/f29/cockpit
PASS:Label 'architecture' has to be specified.
PASS:Label 'build-date' has to be specified.
FAIL:Label 'description' has to be specified.
PASS:Label 'distribution-scope' has to be specified.
:
:
PASS:10 FAIL:8
Exit codes
Colin can exit with several codes:
0
--> OK1
--> error in the execution2
--> CLI error, wrong parameters3
--> at least one check failed
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
File details
Details for the file colin-0.4.0.tar.gz
.
File metadata
- Download URL: colin-0.4.0.tar.gz
- Upload date:
- Size: 659.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/1.12.1 pkginfo/1.5.0.1 requests/2.21.0 setuptools/40.6.3 requests-toolbelt/0.8.0 tqdm/4.29.1 CPython/3.7.3
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 23778403ebc9453aad98ac40eebfb820ffbacf84e8ee13f276f5471cb8ab2bc6 |
|
MD5 | 20299be1074d54eba0b289bdf97896c8 |
|
BLAKE2b-256 | ea57ae9af99b0514d6e2dc4cfa96c98f7396c2a863472baf4041968683c386c4 |
File details
Details for the file colin-0.4.0-py3-none-any.whl
.
File metadata
- Download URL: colin-0.4.0-py3-none-any.whl
- Upload date:
- Size: 164.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/1.12.1 pkginfo/1.5.0.1 requests/2.21.0 setuptools/40.6.3 requests-toolbelt/0.8.0 tqdm/4.29.1 CPython/3.7.3
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 4f1fe13f99b0c64a746c75309ce2af723cd9b1fb0b2c7f05685f7aaf0f5105d8 |
|
MD5 | c87b1ce4385fc17ee225d25afcedfb76 |
|
BLAKE2b-256 | f18f702b3d7e811659bd80700b532cfe1b97d3ad0cc3f35ffd900fa0578eff26 |