Download the PHP package suin/livexample without Composer
On this page you can find all versions of the php package suin/livexample. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.
Download suin/livexample
More information about suin/livexample
Files in suin/livexample
Package livexample
Short Description Ensures your example codes works well by unit testing.
License MIT
Informations about the package livexample
Livexample
This is a documentation oriented testing framework for from PHP 5.3 to 7.x. Its purpose is ensure your example codes works by unit testing. Inspired by Golang testing "Examples".
A simple test case example
See an example below. The first section is example code which will be tested. The comment which begins with Output
is test code.
This example code is broken. The word "carol" is expected as output, however it does not appear. This test case fails, but you are able to know the example code has a problem and you may fix it.
How does it works?
Livexample does following steps:
- Find
Output
statement in the example code by parsing it. - Run the code in PHPUnit and capture the output.
- Compare the expected output and the actual output.
Benefits
Sometimes example codes are broken, by adding new features, forgetting to update them, pull-requests which don't take care of example codes and so on.
Broken example codes are bad experience for library users.
By using Livexample, you will get benefits:
- 😆 Your example codes are protected from unexpected regression.
- 😇 You can easily check your example codes are valid.
- 😋 Your library users can use the valid example codes by copy and paste.
- 😉 You don't have to add big change to your existing sample codes; just adding some comments.
Features
- Livexample works a part of PHPUnit.
- Very low learning cost.
Getting started
Install suin/livexample
via Composer:
Add ExampleTest.php
to your tests directory:
Run phpunit:
Assertion syntax
There are two syntax for assertion:
- Long:
// Output: {expected output}
- Short:
//=> {expected output}
Tips: var_dump($object)
The var_dump()
function prints object identifiers, which is #some-number
next to the class name. Since the identifiers depend on execution environment, you can not hard-code it in the Output:
statement. Instead of hard-coding the identifier, you may use a placeholder %d
for number:
Tips: run an example script with php
command
Why supports PHP 5.3 in 2017?
The official support for PHP 5.3 has ended, however, RHEL/CentOS keeps supporting PHP 5.3 even in 2017. The old PHP environments still remain in the running service today. Livexample is also suppoed to be used for refactoring such old environments.
Changelog
Please see CHANGELOG for more details.
Contributing
Please see CONTRIBUTING for more details. Please fix my English 😂.