Phpunit: Ошибка счетчика аргументов поставщика данных

Созданный на 19 дек. 2016  ·  4Комментарии  ·  Источник: sebastianbergmann/phpunit

Я использую последнюю версию PHPUnit (5.7.4). Проблема в том, что когда я запускаю тест, он проходит. Но если я запустил его еще раз, он выйдет из строя со следующей ошибкой:

ArgumentCountError: Too few arguments to function ValidationTest::testValidateType(), 0 passed and at least 3 expected

Если я внесу какие-либо изменения в функцию поставщика данных (т. Е. Изменю возвращаемые данные, имя или тип функции поставщика и т. Д.) И перезапущу ее, она пройдет один раз и завершится неудачно с указанной выше ошибкой для всех последовательных тестовых запусков.

Не уверен, но использует ли PHPUnit какой-либо механизм кеширования для кэширования данных поставщика? Если да, то есть ли способ его очистить (возможно, используя setUp или tearDown )?


Следующий код сработает один раз (пройти один раз):

/**
 * <strong i="15">@covers</strong> Validation
 * <strong i="16">@coversDefaultClass</strong> Validation
 */
class ValidationTest extends TestCase {

    protected $validation;


    protected function setUp() {
        $this->validation = new Validation();
    }


    /**
     * <strong i="17">@covers</strong> ::validateType
     * <strong i="18">@dataProvider</strong> validateTypeProdiver
     */
    public function testValidateType($assertion, $argument, $type) {
        $result = $this->validation->validateType($argument, $type);

        switch ($assertion) {
            case 'True':
                $this->assertTrue($result);
                break;
        }
    }


    public function validateTypeProdiver() {
        return [
            ['True', 'file.txt', 'str']
       ];
    }
}

Следующий код всегда работает (проходит каждый раз):

/**
 * <strong i="24">@covers</strong> Validation
 * <strong i="25">@coversDefaultClass</strong> Validation
 */
class ValidationTest extends TestCase {

    protected $validation;


    protected function setUp() {
        $this->validation = new Validation();
    }


    /**
     * <strong i="26">@covers</strong> ::validateType
     */
    public function testValidateType() {
        foreach ($this->validateTypeProdiver() as $args) {
            $result = call_user_func_array([$this->validation, 'validateType'], array_slice($args, 1));

            switch ($args[0]) {
                case 'True':
                    $this->assertTrue($result);
                    break;
            }
        }
    }


    public function validateTypeProdiver() {
        return [
            ['True', 'file.txt', 'str']
       ];
    }
}

Самый полезный комментарий

Если кто-нибудь когда-нибудь сталкивался с этой проблемой.
У меня был этот тест

class Test extends TestCase {
    protected $tested;

    public function __construct()
    {
        parent::__construct();
        $this->tested = new TestedClass();
    }

    public function provider(): array
    {
        return array(
            array(0, 1, 1),
            array(1, 2, 3),
        );
    }

    /**
     * <strong i="7">@dataProvider</strong> provider
     */
    public function testSum(int $first, int $second, int $expected)
    {
        $this->assertEquals($expected, $this->tested->sum($first + $second));
    }
}

Я изменил __construct на setUp, и он работает.

Все 4 Комментарий

Я не могу воспроизвести проблему с предоставленной вами информацией. Вот что я сделал:

$ composer require phpunit/phpunit:5.7.4
$ vendor/bin/phpunit && vendor/bin/phpunit

$ vendor/bin/phpunit && vendor/bin/phpunit 
PHPUnit 5.7.4 by Sebastian Bergmann and contributors.

Runtime:       PHP 7.0.17-2+deb.sury.org~trusty+1
Configuration: /.../phpunit.xml

.                                                                   1 / 1 (100%)

Time: 44 ms, Memory: 4.00MB

OK (1 test, 1 assertion)
PHPUnit 5.7.4 by Sebastian Bergmann and contributors.

Runtime:       PHP 7.0.17-2+deb.sury.org~trusty+1
Configuration: /.../phpunit.xml

.                                                                   1 / 1 (100%)

Time: 32 ms, Memory: 4.00MB

OK (1 test, 1 assertion)

Это тестовый класс, который я использовал:

use PHPUnit\Framework\TestCase;

class TestMeTest extends TestCase
{

    protected $validation;

    protected function setUp()
    {

        $this->validation = new Validation();
    }

    /**
     * <strong i="9">@covers</strong> ::validateType
     * <strong i="10">@dataProvider</strong> validateTypeProdiver
     */
    public function testValidateType($assertion, $argument, $type)
    {

        $result = $this->validation->validateType($argument, $type);

        switch ($assertion) {
            case 'True':
                $this->assertTrue($result);
                break;
        }
    }

    public function validateTypeProdiver()
    {

        return [
            ['True', 'file.txt', 'str']
        ];
    }
}

И класс Validation :

class Validation
{
    public function validateType() {
        return true;
    }
}

PHPUnit не кэширует поставщиков данных постоянно.

Я тоже не могу воспроизвести это.

Если кто-нибудь когда-нибудь сталкивался с этой проблемой.
У меня был этот тест

class Test extends TestCase {
    protected $tested;

    public function __construct()
    {
        parent::__construct();
        $this->tested = new TestedClass();
    }

    public function provider(): array
    {
        return array(
            array(0, 1, 1),
            array(1, 2, 3),
        );
    }

    /**
     * <strong i="7">@dataProvider</strong> provider
     */
    public function testSum(int $first, int $second, int $expected)
    {
        $this->assertEquals($expected, $this->tested->sum($first + $second));
    }
}

Я изменил __construct на setUp, и он работает.

Решение @dmirogin сделало мой день, phpunit 8.5

Была ли эта страница полезной?
0 / 5 - 0 рейтинги

Смежные вопросы

gellis picture gellis  ·  4Комментарии

nicklevett picture nicklevett  ·  4Комментарии

joubertredrat picture joubertredrat  ·  4Комментарии

TiMESPLiNTER picture TiMESPLiNTER  ·  3Комментарии

stephen-leavitt-sonyatv-com picture stephen-leavitt-sonyatv-com  ·  4Комментарии