How to Delegate Code
Reviews to CI

It's easy with a little guide

How to Delegate Code Reviews to CI

Are you doing code reviews? No? Yes? In both cases, you won't have too. Just add a couple of YAML lines to your CI. I'm very grateful that Rector is getting traction lately. More and more PHP developers save dozens of hours by running simple CLI commands on their codebases. It's a lot. But you want more laziness, right? Rector can do much more without you even running it.

What do you Review in Code? If you do code-review, what do you mostly do?

  1. Look for patterns, explain them, report them everywhere or just somewhere and hope the other person will fix them all.
  2. Discuss the design and why and what should be done about it.

Well, the 2nd cannot be automated, unless you’re able to put it in clear step-by-step, e.g SOLID laws in procedural code. So you still have to do that, sorry.

Dead Fat Code

But 1st step can be easily automated. How? Well, let’s take a dead code for example. In the last project I’ve helped to improve with Rector, there were 2 years of dead-code piled up. A dead that you have to:

  • test
  • maintain
  • debug if broken
  • review if changed anything related to it

So many human-hours wasted. In the end, we removed over 12 % of “dead fat code”. Wouldn’t it be better if that fat would never be got it?

Add Rector in CI in 3 Steps

1. Install Rector

composer require rector/rector --dev

2. Create rector-ci.yaml config just for code-reviews

# rector-ci.yaml
        - "dead-code"

3. And add to your CI bash

vendor/bin/rector process src --config rector-ci.yaml --dry-run
Learn more about International PHP Conference 2021

How to add Rector CI to your Favorite CI?

I’ve prepared a demo with PHP code and a testing pipeline for all widely used CI services.

  • GitHub Actions
  • GitHub + Travis CI
  • Gitlab CI
  • BitBucket

There you’ll find all the configuration you need to let your CI do code-reviews.

1. GitHub Actions [1]

# .github/workflows/php.yml
name: Rector Code Review

on: [push]


        runs-on: ubuntu-latest

        - uses: actions/checkout@v1

        - name: Validate composer.json and composer.lock
          run: composer validate

        - name: Install dependencies
          run: composer install --prefer-dist --no-progress --no-suggest

        - name: Code Review
          run: ./vendor/bin/rector process --config rector-ci.yaml --dry-run

2. GitHub + Travis CI [1]

# .travis.yml
os: linux
language: php

    - '7.2'

    # install composer dependencies for all stages
    - composer install --prefer-dist --no-ansi --no-interaction --no-progress

            stage: test
            name: "Tests"
                - vendor/bin/phpunit

            stage: test
            name: "Code Review"
                - vendor/bin/rector process --config rector-ci.yaml --dry-run

3. Gitlab CI

# .gitlab-ci.yml
# inspired from

# see
image: robbrazier/php:7.2

    # install composer dependencies for all stages
    - composer install --prefer-dist --no-ansi --no-interaction --no-progress

    - test

    stage: test
        - vendor/bin/phpunit

    stage: test
        - vendor/bin/rector process --config rector-ci.yaml --dry-run

4. Bitbucket [2]

# bitbucket-pipelines.yml
# see
image: robbrazier/php:7.2

        - step:
              name: "Build"
                  - composer install --prefer-dist --no-ansi --no-interaction --no-progress

                  - build/**
                  - vendor/**
                  - composer.json # beacause of scripts
                  - composer

        # @see
        - parallel:
              - step:
                    name: "Tests"
                        - composer
                        - vendor/bin/phpunit

              # Run Rector CI
              - step:
                    name: "Code Review"
                        - composer
                        - vendor/bin/rector process src --config rector-ci.yaml

What sets to Start With?

Here are my favorite sets I apply first:

# rector.yaml
        - 'coding-style'
        - 'code-quality'
        - 'dead-code'
        - 'nette-utils-code-quality'

But you don’t have to stop there. Pick any of 103 sets that Rector provides. E.g.:

# rector.yaml
        - 'php70'
        - 'php71'
        - 'php72'
        - 'php73'
        - 'php74'

That’s it!

Oh… one more thing. You don’t have to resolve all the Rector reported flaws manually, just remove the –dry-run option and run it locally before pushing:

vendor/bin/rector process src --config rector-ci.yaml

Enjoy your coffee!


This article first appeared on Tomas Votruba’s blog:

Links & Literature



Stay tuned!

Behind the Tracks of IPC

PHP Core & Coding
Best practices & applications

General Web Development
Broader web development topics

DevOps & Continuous Delivery
Learn about DevOps and transform your development pipeline

Software Architecture
All about PHP frameworks, concepts & environments

Web Security
All about web security

Software Quality
More about software testing tools & strategies

Agile & Company Culture
Getting agile right is so important

Content Management Systems
Sessions on content management systems

#slideless (pure coding)
See how technology really works

PHP Frameworks
All about PHP Frameworks

Docker, Kubernetes, Cloud
Cloud-based & native apps