Skip to content

Alpine-based multistage-build version of php-cs-fixer for reproducible usage in CI

License

Notifications You must be signed in to change notification settings

igor-ermentraut/docker-php-cs-fixer

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

19 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Docker image for php-cs-fixer

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 • linkcheck • mypy • php-cs-fixer • phpcbf • phpcs • phplint • pycodestyle • pydocstyle • pylint • terraform-docs • terragrunt-fmt • terragrunt • yamlfmt • yamllint

All #awesome-ci Makefiles

Visit cytopia/makefiles for seamless project integration, minimum required best-practice code linting and CI.

View Dockerfile on GitHub.

Docker hub

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

[1] Official project: https://github.com/FriendsOfPHP/PHP-CS-Fixer

Available Docker image versions

Docker images for PHP Coding Standards Fixer come with all available PHP versions. In doubt use latest tag.

Latest stable php-cs-fixer version

Docker tag php-cs-fixer version PHP version
latest latest stable latest stable
latest-php8.0 latest stable latest stable 8.0.x
latest-php7.4 latest stable latest stable 7.4.x
latest-php7.3 latest stable latest stable 7.3.x
latest-php7.2 latest stable latest stable 7.2.x
latest-php7.1 latest stable latest stable 7.1.x

Latest stable php-cs-fixer 3.x.x version

Docker tag php-cs-fixer version PHP version
3 latest stable 3.x.x latest stable
3-php8.0 latest stable 3.x.x latest stable 8.0.x
3-php7.4 latest stable 3.x.x latest stable 7.4.x
3-php7.3 latest stable 3.x.x latest stable 7.3.x
3-php7.2 latest stable 3.x.x latest stable 7.2.x
3-php7.1 latest stable 3.x.x latest stable 7.1.x

Latest stable php-cs-fixer 2.x.x version

Docker tag php-cs-fixer version PHP version
2 latest stable 2.x.x latest stable
2-php8.0 latest stable 2.x.x latest stable 8.0.x
2-php7.4 latest stable 2.x.x latest stable 7.4.x
2-php7.3 latest stable 2.x.x latest stable 7.3.x
2-php7.2 latest stable 2.x.x latest stable 7.2.x
2-php7.1 latest stable 2.x.x latest stable 7.1.x
2-php7.0 latest stable 2.x.x latest stable 7.0.x
2-php5.6 latest stable 2.x.x latest stable 5.6.x

Latest stable php-cs-fixer 1.x.x version

Docker tag php-cs-fixer version PHP version
1 latest stable 1.x.x latest stable supported version
1-php7.1 latest stable 1.x.x latest stable 7.1.x
1-php7.0 latest stable 1.x.x latest stable 7.0.x
1-php5.6 latest stable 1.x.x latest stable 5.6.x

Docker mounts

The working directory inside the Docker container is /data/ and should be mounted locally to the root of your project.

Usage

Generic

$ docker run --rm cytopia/php-cs-fixer --help

Usage:
  list [options] [--] [<namespace>]

Arguments:
  namespace            The namespace name

Options:
      --raw            To output raw command list
      --format=FORMAT  The output format (txt, xml, json, or md) [default: "txt"]

Help:
  The list command lists all commands:

    php /usr/bin/php-cs-fixer list

  You can also display the commands for a specific namespace:

    php /usr/bin/php-cs-fixer list test

  You can also output the information in other formats by using the --format option:

    php /usr/bin/php-cs-fixer list --format=xml

  It's also possible to get raw list of commands (useful for embedding command runner):

    php /usr/bin/php-cs-fixer list --raw

Dry-run

$ docker run --rm -v $(pwd):/data cytopia/php-cs-fixer fix --dry-run --diff .
Loaded config default.
Using cache file ".php_cs.cache".
   1) fail.php
      ---------- begin diff ----------
--- Original
+++ New
@@ @@
 <?php

  echo "test";

-if (  1 ==2) {
- echo "asd"; }
+if (1 ==2) {
+    echo "asd";
+}
      ----------- end diff -----------

Checked all files in 0.004 seconds, 10.000 MB memory used

Example Makefile

You can add the following Makefile to your project for easy generation of php-cs-fixer.

ifneq (,)
.error This Makefile requires GNU Make.
endif

.PHONY: lint _lint-pcf _update-pcf

CURRENT_DIR = $(dir $(abspath $(lastword $(MAKEFILE_LIST))))
PCF_VERSION = 2

lint:
	@echo "################################################################################"
	@echo "# Linting Stage"
	@echo "################################################################################"
	@$(MAKE) --no-print-directory _lint-pcf

_lint-pcf: _update-pcf
	@echo "------------------------------------------------------------"
	@echo " PHP Code Style Fixer"
	@echo "------------------------------------------------------------"
	@if docker run --rm \
		-v $(CURRENT_DIR):/data \
		cytopia/php-cs-fixer:$(PCF_VERSION) \
		fix --dry-run --diff .; then \
		echo "OK"; \
	else \
		echo "Failed"; \
		exit 1; \
	fi

_update-pcf:
	docker pull cytopia/php-cs-fixer:$(PCF_VERSION)

Travis CI integration

---
sudo: required
language: minimal
services:
  - docker
script:
  - make lint

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]
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

About

Alpine-based multistage-build version of php-cs-fixer for reproducible usage in CI

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Makefile 82.5%
  • Dockerfile 13.6%
  • PHP 3.9%