23

私は次のテストケースを持っています:

include_once('../Logger.php');

class LoggerTest extends PHPUnit_Framework_TestCase {

    public function providerLogger() {
        return new Logger;
    }

    /**
     * @dataProvider providerLogger
     */
    public function testAddStream($logger) {
        $this->assertTrue(false);
    }

}

PHPUnitで実行すると、次のようになります。

PHPUnit 3.4.14 by Sebastian Bergmann.

..........

Time: 0 seconds, Memory: 5.75Mb

OK (1 tests, 0 assertions)

テストは失敗するはずですが、失敗しません。私は持ってみました:

public function providerLogger() {
    return array(new Logger);
}

しかし、私は得ます:

The data provider specified for LoggerTest::testAddStream is invalid.

私はそれを宣言しようとしましたがstatic(マニュアルに書かれているように)、それでも違いはありません。

以前も同じように機能していたことを覚えていますが、間違っている可能性があります。私は何が欠けていますか?

よろしくお願いします。

PHP5.3.3上のPHPUnit3.4.14(PEARから取得)

4

6 に答える 6

31

マイナー アップデート: バージョン 3.2 (またはそのあたり) 以降、インスタンス メソッドをプロバイダーとして使用しても問題ありません。コメントを見てみましょう


プロバイダは次のように表示される必要があります。

public static function providerLogger() {
    return array(
      array(new Logger)
    );
}

まず第一に: phpunit バージョン 3.3 より前のバージョンを使用している場合、メソッドはstaticでなければなりません。

配列は重要です。理解するのはそれほど難しいことではありません。外側の配列には、テストが呼び出される反復ごとに 1 つの値があります。ここでは、テストは一度だけ呼び出されます。内側の配列は、テストが呼び出されるパラメーター (順番) です。テストは正確に 1 つのパラメーターを想定しているため、内部配列には常に正確に 1 つの値が必要です。もう一つの小さな例

public static function addTestProvider () {
    return array(
        /* First + Second = third? */
        array(1,4,5),
        array(3,3,6),
        array(5,5,6)
    );
}
public function testAdd ($a, $b, $result) {
    $this->assertEquals($result, $a + $b);
}

ここで、 testAddは 2 番目のレベルのarrayごとに 1 回ずつ、3 回実行され、内側の配列sから値を受け取ります。テストが失敗し、データセットの反復 (ここでは #3、5+5 は 6 ではないため ;)) のアサーションが失敗したというメッセージが表示されることに気付くかもしれません。

于 2010-11-24T01:45:33.443 に答える
6

私は同じ問題を抱えていましたが、自動生成された空のコンストラクターを削除すると解決しました。これで問題が解決する理由がわかりません。クラスのような名前のテストメソッドもありませんでした。プロバイダー メソッドは静的である必要はありません。これまでのところ、静的なしでテストを実行しています。しかし、プロバイダーメソッドを静的にしたときにも実行されます

于 2011-08-25T10:03:29.940 に答える
1
<?php

require_once 'calculator.php';

/**
 * Calculator test case.
 */
class CalculatorTest extends PHPUnit_Framework_TestCase {

    /**
     * @var Calculator
     */
    private $Calculator;

    /**
     * Prepares the environment before running a test.
     */
    protected function setUp() {
        parent::setUp ();
        // TODO Auto-generated CalculatorTest::setUp()
        $this->Calculator = new Calculator(/* parameters */);
    }

    /**
     * Cleans up the environment after running a test.
     */
    protected function tearDown() {
        // TODO Auto-generated CalculatorTest::tearDown()
        $this->Calculator = null;
        parent::tearDown ();
    }

    /**
     * Constructs the test case.
     */
    public function __construct() {
        // TODO Auto-generated constructor
    }

    /**
     * Tests Calculator->add()
     *
         * @dataProvider provider
         */
    public function testAdd($a, $b, $c) {
        // TODO Auto-generated CalculatorTest->testAdd()
        //$this->markTestIncomplete ( "add test not implemented" );

        //$this->Calculator->add(/* parameters */);
        $this->assertEquals($this->Calculator->add($a, $b), $c);
    }

    public static function provider()
    {
        return array(
          array(1, 1, 1),
          array(1, 1, -1),
          array(4, 2, 2),
          array(1, 1, 1)
        );
    }
}

コードの完全なセットです

于 2011-09-15T13:09:39.947 に答える
0

また、データ プロバイダーを直接チェーンできないこともわかりました。

class ProviderTest extends PHPUnit_Framework_TestCase {

    public function provider() {
        return array(array('test'));
    }

    /**
     * @dataProvider provider
     */
    public function providerTest1($test) {
        $this->assertTrue($test);
        return array(array($test));
    }

    /**
     * @dataProvider providerTest1
     */
    public function providerTest2($test) {
        $this->assertEquals('test', $test);
    }

}

どうやら、PHPUnit はテストを実行する前にすべてのプロバイダー関数を呼び出すため、別のプロバイダー関数を使用してテスト結果データを他のテストにフィードすることさえできません。あなたができる最善のことは、シミュレートすることです:

class ProviderTest extends PHPUnit_Framework_TestCase {

    private $provider_data = array();

    public function provider() {
        return array(array('test'));
    }

    /**
     * @dataProvider provider
     */
    public function testProvider1($test) {
        $this->assertFalse(empty($test));
        array_push($this->provider_data, array($test));
    }

    /**
     * @depends testProvider1
     */
    public function testProvider2($test = NULL) {
        if(is_null($test)) {
            // simulate a provider
            foreach($this->provider_data as $row) {
                call_user_func_array(array($this, __METHOD__), $row);
            }
        } else {
            $this->assertEquals('test', $test);
        }
    }

}
于 2011-10-14T04:47:07.873 に答える
-1

見よ、dataProvider のテスト依存関係を達成するためのパターンを達成した! このようにして、dataProvider を連鎖させることができます。

class ProviderDependencyTest extends PHPUnit_Framework_TestCase
{
    private static $dataSet;

    public function provideData()
    {
        self::$dataSet = array(
                    array(2,2,4),
                    array(1,0,2),
                    array(0,0,0)
                );

        //use static storage so you don't have to call the dataProvider again
        return self::$dataSet;
    }

    public function testProvideAdd()
    {
        $data = self::$dataSet;

        $this->assertEquals(3,count($data[0]));

        return $data[0];
    }

    /**
     * @depends testProvideAdd
     */
    public function testAdd($data)
    {
        $sum = $data[0] + $data[1];

        $this->assertEquals($data[2], $sum);

        return array($sum,$data[0],$data[1]);
    }

    /**
     * @depends testAdd
     */
    public function testSubtract($data)
    {
        $difference = $data[0] - $data[1];

        $this->assertEquals($data[2], $difference);

        return array($difference,$data[0],$data[1]);
    }

    /**
     * @depends testSubtract
     */
    public function testMultiply($data)
    {
        $product = $data[0] * $data[2];

        $this->assertEquals($data[1], $product);

        return $product;
    }

    /**
     * @depends testMultiply
     *
     * @dataProvider provideData
     */
    public function testMath($a,$b,$c)
    {
        //don't redo the first set of tests
        if(array($a,$b,$c) == self::$dataSet[0])
        {
            return;
        }

        $sum = $this->testAdd(array($a,$b,$c));
        $difference= $this->testSubtract($sum);
        $product = $this->testMultiply($difference);

        $this->assertInternalType('integer', $product);
    }
}

2 番目のデータ セットは、説明のために 1 つのテストに失敗します。

于 2013-02-16T04:32:06.787 に答える
-1

パブリック関数 testAddStream($logger) からパラメーターを削除して、再試行してください。PHPUnit が渡すことができないパラメーターを必要とするテストを呼び出すとは思えません。

于 2010-11-24T00:19:41.390 に答える