jimigrunge/invoke-private-methods 问题修复 & 功能扩展

解决BUG、新增功能、兼容多环境部署,快速响应你的开发需求

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

jimigrunge/invoke-private-methods

最新稳定版本:3.0.1

Composer 安装命令:

composer require --dev jimigrunge/invoke-private-methods

包简介

This is a class to aid in unit testing of private methods.

README 文档

README

Latest Stable Version Build Status Coverage Status License Total Downloads This is a forkable respository

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

Contributing

CONTRIBUTING.md

License

The MIT License (MIT)

统计信息

  • 总下载量: 26.56k
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 4
  • 点击次数: 1
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 3
  • Watchers: 1
  • Forks: 0
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2016-03-04