PHPUnit TestCase

Maintainers

👁 jpcercal

Package info

github.com/jpcercal/tdd

pkg:composer/cekurte/tdd

Statistics

Installs: 576

Dependents: 7

Suggesters: 0

Stars: 2

Open Issues: 0

v1.0.2 2016-04-29 19:19 UTC

Requires

  • php: >=5.3

Requires (Dev)

Suggests

None

Provides

None

Conflicts

None

Replaces

None

MIT 05ca2c9fe3d5ecc88d34b415edb15cc7e68ad689

  • João Paulo Cercal <jpcercal.woop@gmail.com>

This package is auto-updated.

Last update: 2026-06-16 05:50:08 UTC


README

👁 Build Status
👁 Code Climate
👁 Coverage Status
👁 Latest Stable Version
👁 License
👁 SensioLabsInsight

  • Just a simple extension to the PHPUnit library.
  • Currently this package contains only support for one TestCase scenario ReflectionTestCase contribute with this project!

Installation

  • The package is available on Packagist.
  • The source files is PSR-2 compatible.
  • Autoloading is PSR-4 compatible.
composer require cekurte/tdd

If you liked of this library, give me a star =).

Documentation

This library was created to permit that developers write php unit tests using a common base class, including initially the following tasks:

  • Set a private, protected or public property value;
  • Get a private, protected or public property value;
  • Call a private, protected or public method.

Setting a property value

To set a property value (independently of your visibility) you can use the method ReflectionTestCase::propertySetValue like the following example:

<?php

namespace Your\Namespace;

use Cekurte\Tdd\ReflectionTestCase;

class YourClassTest extends ReflectionTestCase
{
 public function testAnything()
 {
 // Instance of a class that has one
 // private property named "yourPrivateProperty".
 $instance = new YourClass();

 // Set the value "newValue" to the property
 // "yourPrivateProperty".
 $this->propertySetValue(
 $instance,
 'yourPrivateProperty',
 'newValue'
 );

 // ...
 }
}

Getting a property value

To get a property value (independently of your visibility) you can use the method ReflectionTestCase::propertyGetValue like the following example:

<?php

namespace Your\Namespace;

use Cekurte\Tdd\ReflectionTestCase;

class YourClassTest extends ReflectionTestCase
{
 public function testAnything()
 {
 // Instance of a class that has one
 // private property named "yourPrivateProperty".
 $instance = new YourClass();

 // Get the value of the property
 // "yourPrivateProperty".
 $currentValue = $this->propertyGetValue(
 $instance,
 'yourPrivateProperty'
 );

 // ...
 }
}

Calling a method

To call a method (independently of your visibility) you can use the method ReflectionTestCase::invokeMethod like the following example:

<?php

namespace Your\Namespace;

use Cekurte\Tdd\ReflectionTestCase;

class YourClassTest extends ReflectionTestCase
{
 public function testAnything()
 {
 // Instance of a class that has one
 // private property named "yourPrivateMethod".
 $instance = new YourClass();

 // Call the method
 // "yourPrivateMethod".
 $valueReturned = $this->invokeMethod(
 $instance,
 'yourPrivateMethod',
 ['param1', 'param2', 'paramN']
 );

 // ...
 }
}

Contributing

  1. Give me a star =)
  2. Fork it
  3. Create your feature branch (git checkout -b my-new-feature)
  4. Make your changes
  5. Run the tests, adding new ones for your own code if necessary (vendor/bin/phpunit)
  6. Commit your changes (git commit -am 'Added some feature')
  7. Push to the branch (git push origin my-new-feature)
  8. Create new Pull Request