2017 © Pedro Peláez
 

library contracts

A library which helps to specify, check and reflect code contracts.

image

hediet/contracts

A library which helps to specify, check and reflect code contracts.

  • Saturday, March 14, 2015
  • by Henning Dieterichs
  • Repository
  • 0 Watchers
  • 1 Stars
  • 26 Installations
  • PHP
  • 2 Dependents
  • 0 Suggesters
  • 0 Forks
  • 0 Open issues
  • 2 Versions
  • 0 % Grown

The README.md

PHP Contracts - A Powerful Assertion Library for PHP

PHP Contracts is an assertion library for PHP to validate arguments and invariants. This library aims to replace my library nunzion/php-expect., (*1)

Warning

This library is still in development! However, the signature of the method Contract::requires will not change and it is guaranteed that an exception is beeing thrown if the condition evaluates to false., (*2)

Installation

You can use Composer to download and install PHP Contracts. To add PHP Contracts to your project, simply add a dependency on hediet/contracts to your project's composer.json file., (*3)

Here is a minimal example of a composer.json file that just defines a dependency on PHP Contracts:, (*4)

``` json { "require": { "hediet/contracts": "dev-master" } }, (*5)


Usage ----- Using this library is as simple as calling `Contract::requires` with an arbitrary condition: ``` php use Hediet\Contract; function sum($a, $b) { Contract::requires(is_int($a) && is_int($b)); }

If the specified condition evaluates to false, PHP Contracts analyzes the condition and throws an exception with an appropriate error message., (*6)

The following code will throw an \InvalidArgumentException with the message Argument 'b' must be of type 'integer', but is of type 'string'.: ``` php sum(1, "test");, (*7)


### Explicitly Supported Tests Currently PHP Contracts understands the following conditions: * All is_TYPE functions for TYPE being a primitive. * Comparison operators like `<`, `<=`, `>`, `>=`. * Disjunction of type constraints, e.g. `is_int($a) || is_float($a) || $a === null`. Internally, a type constraint is being created for $a which denotes that $a must be of type `int|float|null`. * Conjunction of constraints. However, currently all expressions must be constants or arguments. ### Examples ``` php public function intArgumentsProvider() { return array(array(7, 1)); } /** * @dataProvider intArgumentsProvider * @expectedException \InvalidArgumentException * @expectedExceptionMessage Argument 'a' must be greater than '1' * and less than or equal to argument 'b', but 'a' is 7 and 'b' is 1. */ public function testExampleRange($a, $b) { Contract::requires(1 < $a && $a <= $b); } /** * @dataProvider intArgumentsProvider * @expectedException \InvalidArgumentException * @expectedExceptionMessage Argument 'a' must be of type 'null|string', but is of type 'integer'. */ public function testExampleUnionType($a) { Contract::requires($a === null || is_string($a)); } /** * @dataProvider intArgumentsProvider * @expectedException \InvalidArgumentException * @expectedExceptionMessage Argument 'a' must be greater than '10', * but is 7 or argument 'a' must be of type 'null', but is of type 'integer'. */ public function testExample4($a) { Contract::requires(($a === null) || ($a > 10)); }

Internals

If the condition evaluates to true, the requires method returns immediately. Thus, if a condition does not fail, there is no significant performance decrease., (*8)

If a condition fails, i.e. evaluates to false, the stacktrace is used to determine the location of the requires call. After that, the invocation is parsed with nikic/PHP-Parser and converted to a set of constraints. These constraints may reference expressions to which the constraints are applied to. By using the stacktrace a second time, the arguments and the value of $this can be obtained for the context of the invocation to evaluate these expressions, so that a constraint can add an explanation of why he has failed., (*9)

Todos

  • Support deep expressions, so that conditions like Contract::requires(count($a) > 0) can be analyzed. Since $a may be obtained from the stacktrace and count is a pure method, count($a) can be evaluated without side effects.
  • Support various array tests.
  • Throw an invariant exception if no argument is referenced in the condition.
  • Use optionally provided values to evaluate expressions which uses variables that are neither arguments nor $this.
  • Add a reflection API which parses the first Contract::requires calls of a method and returns their corresponding constraints. This enables propagating constraints to the UI.

Author

Henning Dieterichs - henning.dieterichs@hediet.de, (*10)

License

PHP Expect is licensed under the MIT License., (*11)

The Versions

14/03 2015

dev-master

9999999-dev

A library which helps to specify, check and reflect code contracts.

  Sources   Download

MIT

The Requires

 

The Development Requires

by Avatar Henning Dieterichs

validation code assert exception assertion contract precondition invariant argument

14/03 2015

v0.1.0

0.1.0.0

A library which helps to specify, check and reflect code contracts.

  Sources   Download

MIT

The Requires

 

The Development Requires

by Avatar Henning Dieterichs

validation code assert exception assertion contract precondition invariant argument