jimigrunge / invoke-private-methods
This is a class to aid in unit testing of private methods.
Installs: 23 919
Dependents: 0
Suggesters: 0
Security: 0
Stars: 3
Watchers: 2
Forks: 0
Open Issues: 0
Requires
- php: ^8.1
Requires (Dev)
- php-coveralls/php-coveralls: ^2.5
- phpunit/phpcov: ^8.2
- phpunit/phpunit: ^9.5
- sebastian/phpcpd: ^6.0
- squizlabs/php_codesniffer: ^3.7
This package is auto-updated.
Last update: 2024-12-20 00:52:53 UTC
README
This is a class to aid in unit testing of private methods. It can be used either as a stand alone class or as a trait and called either programmatically or statically.
Although testing of private methods is not recommended in most cases, sometimes it is necessary. Such as to insure correct calculations in a protected method aside form the methods that currently utilize it. Hence this repository.
Note: I mainly use PhpUnit for all testing so I make no guaranties when it comes to other testing utilities as I have not utilized them yet.
Installation
$ composer require jimigrunge/invoke-private-methods
Note on version requirements
If you are using a version of PHP less than 8.1 please use the 2.0 branch If you are using a version of PHP less than 7.1 please use the 1.0 branch
$ composer require jimigrunge/invoke-private-methods:~1.0
Usage
class InvokePrivateMethod
This class can be used to test private and protected methods.
Once you include the class with the 'use' statement, you can utilize it on one of two ways.
You can either create an instance of InvokePrivateMethod
and call invokeMethod
, as in testMyMethod()
,
or call invoke()
statically as in testMyMethodStatically()
<?php // Include class to call private methods use Jimigrunge\InvokePrivateMethods\InvokePrivateMethod; class testclass extends \PHPUnit_Framework_TestCase { /** @var InvokePrivateMethod */ private $invoker; private $dummyObject; public function setUp() { // Instantiate the class $this->invoker = new InvokePrivateMethod(); $this->dummyObject = new DummyClass(); } public function testMyMethod() { // Call invoke method on private function $result = $this->invoker->invokeMethod($this->dummyObject, 'myPrivateFunction', ['param1']); $this->assertEquals('Test Success', trim($result)); } public function testMyMethodStatically() { // Can also be used statically $result = InvokePrivateMethod::invoke($this->dummyObject, 'myPrivateFunction', ['param1']); $this->assertEquals('Test Success', trim($result)); } }
trait InvokePrivateMethodTrait
This trait can be used to add the functionality directly to you test class so that it can call it internally.
As with the full class usage, you can utilize it on one of two ways.
You can either call $this->invokeMethod
, as in testMyMethod()
,
or call self::invoke()
statically as in testMyMethodStatically()
<?php // Include trait to call private methods use Jimigrunge\InvokePrivateMethods\Traits\InvokePrivateMethodTrait; class testclass extends \PHPUnit_Framework_TestCase { use InvokePrivateMethodTrait; private $dummyObject; public function setUp() { $this->dummyObject = new DummyClass(); } public function testMyMethod() { // Call invoke method on private function $result = $this->invokeMethod($this->dummyObject, 'myPrivateFunction', ['param1']); $this->assertEquals('Test Success', trim($result)); } public function testMyMethodStatically() { // Can also be used statically $result = self::invoke($this->dummyObject, 'myPrivateFunction', ['param1']); $this->assertEquals('Test Success', trim($result)); } }
Further detail
More detailed usage examples can be found by studying the tests in the /tests
directory.
Reporting an issue or a feature request
Issues and feature requests are tracked in the Github issue tracker.
TODO
Nothing at the moment