/docker-phpcs

Alpine-based multistage-build version of phpcs for reproducible usage in CI

Primary LanguageMakefileMIT LicenseMIT

Docker image for phpcs

Tag License

lint build nightly

All #awesome-ci Docker images

ansible-lint ansible awesome-ci bandit black checkmake eslint file-lint gofmt goimports golint jsonlint kubeval linkcheck mypy php-cs-fixer phpcbf phpcs phplint pycodestyle pydocstyle pylint terraform-docs terragrunt-fmt terragrunt yamlfmt yamllint

View Dockerfiles on GitHub.

Available Architectures: amd64, i386, arm64, arm/v7, arm/v6

Tiny Alpine-based multistage-builld dockerized version of phpcs[1]. The image is built nightly against multiple stable versions and pushed to Dockerhub.

[1] Official project: https://github.com/squizlabs/PHP_CodeSniffer

🐳 Available Docker image versions

Docker

Rolling releaess

The following Docker image tags are rolling releases and are built and updated every night.

nightly

Docker Tag Git Ref PHPCS PHP Available Architectures
latest master latest latest amd64, i386, arm64, arm/v7, arm/v6
latest-php8.1 master latest 8.1 amd64, i386, arm64, arm/v7, arm/v6
latest-php8.0 master latest 8.0 amd64, i386, arm64, arm/v7, arm/v6
latest-php7.4 master latest 7.4 amd64, i386, arm64, arm/v7, arm/v6
latest-php7.3 master latest 7.3 amd64, i386, arm64, arm/v7, arm/v6
latest-php7.2 master latest 7.2 amd64, i386, arm64, arm/v7, arm/v6
latest-php7.1 master latest 7.1 amd64, i386, arm64, arm/v7, arm/v6
latest-php7.0 master latest 7.0 amd64, i386, arm64, arm/v7, arm/v6
latest-php5.6 master latest 5.6 amd64, i386, arm64, arm/v7, arm/v6
3 master 3.x.x latest amd64, i386, arm64, arm/v7, arm/v6
3-php8.1 master 3.x.x 8.1 amd64, i386, arm64, arm/v7, arm/v6
3-php8.0 master 3.x.x 8.0 amd64, i386, arm64, arm/v7, arm/v6
3-php7.4 master 3.x.x 7.4 amd64, i386, arm64, arm/v7, arm/v6
3-php7.3 master 3.x.x 7.3 amd64, i386, arm64, arm/v7, arm/v6
3-php7.2 master 3.x.x 7.2 amd64, i386, arm64, arm/v7, arm/v6
3-php7.1 master 3.x.x 7.1 amd64, i386, arm64, arm/v7, arm/v6
3-php7.0 master 3.x.x 7.0 amd64, i386, arm64, arm/v7, arm/v6
3-php5.6 master 3.x.x 5.6 amd64, i386, arm64, arm/v7, arm/v6
2 master 2.x.x latest amd64, i386, arm64, arm/v7, arm/v6
2-php8.1 master 2.x.x 8.1 amd64, i386, arm64, arm/v7, arm/v6
2-php8.0 master 2.x.x 8.0 amd64, i386, arm64, arm/v7, arm/v6
2-php7.4 master 2.x.x 7.4 amd64, i386, arm64, arm/v7, arm/v6
2-php7.3 master 2.x.x 7.3 amd64, i386, arm64, arm/v7, arm/v6
2-php7.2 master 2.x.x 7.2 amd64, i386, arm64, arm/v7, arm/v6
2-php7.1 master 2.x.x 7.1 amd64, i386, arm64, arm/v7, arm/v6
2-php7.0 master 2.x.x 7.0 amd64, i386, arm64, arm/v7, arm/v6
2-php5.6 master 2.x.x 5.6 amd64, i386, arm64, arm/v7, arm/v6

Point in time releases

The following Docker image tags are built once and can be used for reproducible builds. Its version never changes so you will have to update tags in your pipelines from time to time in order to stay up-to-date.

build

Docker Tag Git Ref PHPCS PHP Available Architectures
latest-<tag> git: <tag> latest latest amd64, i386, arm64, arm/v7, arm/v6
latest-php8.1-<tag> git: <tag> latest 8.1 amd64, i386, arm64, arm/v7, arm/v6
latest-php8.0-<tag> git: <tag> latest 8.0 amd64, i386, arm64, arm/v7, arm/v6
latest-php7.4-<tag> git: <tag> latest 7.4 amd64, i386, arm64, arm/v7, arm/v6
latest-php7.3-<tag> git: <tag> latest 7.3 amd64, i386, arm64, arm/v7, arm/v6
latest-php7.2-<tag> git: <tag> latest 7.2 amd64, i386, arm64, arm/v7, arm/v6
latest-php7.1-<tag> git: <tag> latest 7.1 amd64, i386, arm64, arm/v7, arm/v6
latest-php7.0-<tag> git: <tag> latest 7.0 amd64, i386, arm64, arm/v7, arm/v6
latest-php5.6-<tag> git: <tag> latest 5.6 amd64, i386, arm64, arm/v7, arm/v6
git: <tag>
3-<tag> git: <tag> 3.x.x latest amd64, i386, arm64, arm/v7, arm/v6
3-php8.1-<tag> git: <tag> 3.x.x 8.1 amd64, i386, arm64, arm/v7, arm/v6
3-php8.0-<tag> git: <tag> 3.x.x 8.0 amd64, i386, arm64, arm/v7, arm/v6
3-php7.4-<tag> git: <tag> 3.x.x 7.4 amd64, i386, arm64, arm/v7, arm/v6
3-php7.3-<tag> git: <tag> 3.x.x 7.3 amd64, i386, arm64, arm/v7, arm/v6
3-php7.2-<tag> git: <tag> 3.x.x 7.2 amd64, i386, arm64, arm/v7, arm/v6
3-php7.1-<tag> git: <tag> 3.x.x 7.1 amd64, i386, arm64, arm/v7, arm/v6
3-php7.0-<tag> git: <tag> 3.x.x 7.0 amd64, i386, arm64, arm/v7, arm/v6
3-php5.6-<tag> git: <tag> 3.x.x 5.6 amd64, i386, arm64, arm/v7, arm/v6
git: <tag>
2-<tag> git: <tag> 2.x.x latest amd64, i386, arm64, arm/v7, arm/v6
2-php8.1-<tag> git: <tag> 2.x.x 8.1 amd64, i386, arm64, arm/v7, arm/v6
2-php8.0-<tag> git: <tag> 2.x.x 8.0 amd64, i386, arm64, arm/v7, arm/v6
2-php7.4-<tag> git: <tag> 2.x.x 7.4 amd64, i386, arm64, arm/v7, arm/v6
2-php7.3-<tag> git: <tag> 2.x.x 7.3 amd64, i386, arm64, arm/v7, arm/v6
2-php7.2-<tag> git: <tag> 2.x.x 7.2 amd64, i386, arm64, arm/v7, arm/v6
2-php7.1-<tag> git: <tag> 2.x.x 7.1 amd64, i386, arm64, arm/v7, arm/v6
2-php7.0-<tag> git: <tag> 2.x.x 7.0 amd64, i386, arm64, arm/v7, arm/v6
2-php5.6-<tag> git: <tag> 2.x.x 5.6 amd64, i386, arm64, arm/v7, arm/v6

Where <tag> refers to the chosen git tag from this repository.

📂 Docker mounts

The working directory inside the Docker container is /data/ and should be mounted locally.

💻 Usage

Basic

$ docker run --rm -v $(pwd):/data cytopia/phpcs .

----------------------------------------------------------------------
FOUND 4 ERRORS AFFECTING 3 LINES
----------------------------------------------------------------------
 2 | ERROR | [ ] Missing file doc comment
 5 | ERROR | [x] First condition of a multi-line IF statement must
   |       |     directly follow the opening parenthesis
 6 | ERROR | [x] Line indented incorrectly; expected at least 4
   |       |     spaces, found 1
 6 | ERROR | [x] Closing brace must be on a line by itself
----------------------------------------------------------------------
PHPCBF CAN FIX THE 3 MARKED SNIFF VIOLATIONS AUTOMATICALLY
----------------------------------------------------------------------

Custom standard

Custom standards must be mounted inside the container to /usr/bin/CodeSniffer.conf

# Via command line
$ docker run --rm -v $(pwd):/data -v CodeSniffer.conf:/usr/bin/CodeSniffer.conf cytopia/phpcs .
# Docker compose
phpcs:
  image: cytopia/phpcs
  volumes:
    - .:/data
    - CodeSniffer.conf:/usr/bin/CodeSniffer.conf

🔄 Related #awesome-ci projects

Docker images

Save yourself from installing lot's of dependencies and pick a dockerized version of your favourite linter below for reproducible local or remote CI tests:

GitHub DockerHub Type Description
awesome-ci aci-hub-img Basic Tools for git, file and static source code analysis
file-lint flint-hub-img Basic Baisc source code analysis
linkcheck linkcheck-hub-img Basic Search for URLs in files and validate their HTTP status code
ansible ansible-hub-img Ansible Multiple versions and flavours of Ansible
ansible-lint alint-hub-img Ansible Lint Ansible
gofmt gfmt-hub-img Go Format Go source code [1]
goimports gimp-hub-img Go Format Go source code [1]
golint glint-hub-img Go Lint Go code
eslint elint-hub-img Javascript Lint Javascript code
jsonlint jlint-hub-img JSON Lint JSON files [1]
kubeval kubeval-hub-img K8s Lint Kubernetes files
checkmake cm-hub-img Make Lint Makefiles
phpcbf pcbf-hub-img PHP PHP Code Beautifier and Fixer
phpcs pcs-hub-img PHP PHP Code Sniffer
phplint plint-hub-img PHP PHP Code Linter [1]
php-cs-fixer pcsf-hub-img PHP PHP Coding Standards Fixer
bandit bandit-hub-img Python A security linter from PyCQA
black black-hub-img Python The uncompromising Python code formatter
mypy mypy-hub-img Python Static source code analysis
pycodestyle pycs-hub-img Python Python style guide checker
pydocstyle pyds-hub-img Python Python docstyle checker
pylint pylint-hub-img Python Python source code, bug and quality checker
terraform-docs tfdocs-hub-img Terraform Terraform doc generator (TF 0.12 ready) [1]
terragrunt tg-hub-img Terraform Terragrunt and Terraform
terragrunt-fmt tgfmt-hub-img Terraform terraform fmt for Terragrunt files [1]
yamlfmt yfmt-hub-img Yaml Format Yaml files [1]
yamllint ylint-hub-img Yaml Lint Yaml files

[1] Uses a shell wrapper to add enhanced functionality not available by original project.

Makefiles

Visit cytopia/makefiles for dependency-less, seamless project integration and minimum required best-practice code linting for CI. The provided Makefiles will only require GNU Make and Docker itself removing the need to install anything else.

📄 License

MIT License

Copyright (c) 2019 cytopia