Skip to content

filda/PhpMetrics

 
 

Repository files navigation

PhpMetrics

Gives metrics about PHP project and classes.

License Build Status Scrutinizer Quality Score Latest Stable Version Dependency Status

Installation

As phar archive:

wget https://github.com/Halleck45/PhpMetrics/raw/master/build/phpmetrics.phar
chmod +x phpmetrics.phar
mv phpmetrics.phar /usr/local/bin/phpmetrics

With Composer (Make sure you have ~/.composer/vendor/bin/ in your path):

php composer.phar global config -e # add ,"minimum-stability":"dev"
php composer.phar global require 'halleck45/phpmetrics=@dev'

Usage

Do not hesitate to visit the official documentation.

The command command phpmetrics <folder or filename> will output:

Standard report

If you want to get the summary HTML report (with charts):

phpmetrics --report-html=/path/of/your/choice.html <folder or filename>

No panic : you can read the How to read the HTML report page

If you need a pure string representation of the reports in StdOut, just use phpmetrics -q --report-xml=php://stdout <folder or filename>

Conditions of failure

Customizing the conditions of failure is very easy with the--failure-condition option. For example:

--failure-condition="average.maintainabilityIndex < 100 or sum.loc > 10000"

With this example, PhpMetrics script returns 1 if the average of Maintainability index is lower than 100 or if the total number of lines of code is greater than 10000.

You can also work with package:

--failure-condition="My/Package1/XXXX.average.bugs > 0.35"

Remember that in PhpMetrics packages are file oriented (and not object oriented).

Conditions are evaluated with the Hoa Ruler component. Available operators are and, or, xor, not, = (is as an alias), !=, >, >=, <, <=, in and sum

List of availables metrics is documented here.

## IDE integration

## Jenkins and IC integration

You'll find a complete tutorial in the documentation

You can easily export results to XML with the --report-xml option:

phpmetrics --report-xml=/path/of/your/choice.xml <folder or filename>

You can also export results as violations (MessDetector report), in XML format with the --violations-xml option:

phpmetrics --violations-xml=/path/of/your/choice.xml <folder or filename>

## Configuration file

You can customize configuration with the --config=<file> option.

The file should be a valid yaml file. For example:

# file <my-config.yml>

# paths to explore
path:
    extensions: php|inc
    exclude: Features|Tests|tests

# report and violations files
logging:
    report:
        xml:    ./log/phpmetrics.xml
        html:   ./log/phpmetrics.html
        csv:    ./log/phpmetrics.csv
    violations:
        xml:    ./log/violations.xml
    chart:
        bubbles: ./log/bubbles.svg

# condition of failure
failure: average.maintenabilityIndex < 50 or sum.loc > 10000

# rules used for color
rules:
  cyclomaticComplexity: [ 10, 6, 2 ]
  maintenabilityIndex: [ 0, 69, 85 ]
  [...]

Each rule is composed from three values.

  • If A < B < C : A: min, B: yellow limit, C: max
  • If A > B > C : A: max, B: yellow limit, C: min

Contribute

In order to run unit tests, please install the dev dependencies:

curl -sS https://getcomposer.org/installer | php
php composer.phar install --dev

Then, to run the test suite:

./vendor/bin/phpunit

# Author

# Licence

See the LICENCE file.

About

Static analysis tool for PHP

Resources

License

Stars

Watchers

Forks

Packages

No packages published