phpunit没有填充Laravel 4中的灯具

时间:2015-04-18 21:58:26

标签: sqlite unit-testing laravel phpunit dbunit

我正在尝试将一个单元测试框架添加到已经存在的Laravel项目中。我已经阅读了PHPUnit manual,我正在尝试使用.xml数据集来设置一个sqlite环境来填充测试数据和一个主迁移来创建模式,但实际的测试数据似乎没有填充到表格。

我开始将phpunit和dbunit添加到composer.json文件并更新它们。我将vendor / bin添加到$ PATH,以便VM知道在哪里找到它。

然后我使用getConnection(),getDataSet()和setUp()扩展现有的TestCase类,其中包含

 class TestCase extends Illuminate\Foundation\Testing\TestCase {

    static private $pdo = null;

    private $conn = null;


    public function setUp() {
        parent::setUp();

        Artisan::call('migrate');

        $this->seed();
    }

    public function createApplication() {
        $unitTesting = true;

        $testEnvironment = 'testing';

        return require __DIR__ . '/../../bootstrap/start.php';
    }

    public function getDataSet() {
        parent::getDataSet();
    }

    public function getConnection() {
        if ($this->conn === null) {
            if (self::$pdo == null) {
                self::$pdo = new PDO('sqlite::memory:');
            }
            $this->conn = $this->createDefaultDBConnection(self::$pdo, ':memory:');
        }

        return $this->conn;

    }
}

Illuminate \ Foundation \ Testing \ Testcase我改为:

abstract class TestCase extends \PHPUnit_Extensions_Database_TestCase {
....
}

这样做了,我创建了一个XML数据集

<?xml version="1.0" ?>
<dataset>
    <table name="a_table">
       <column>id</column>
       <column>data1</column>
       <column>data2</column>
       <row>
           <value>1</value>
           .....
           .....
       </row>
       <row>
           .....
       </row>
   </table>
</dataset>

我使用artisan convert migrations命令创建架构。

然后我写了我的第一个测试。

class ImportantClassTest extends TestCase {

    /**
     * @author Me
     * 
     * 
     * Tests the functionality of some function
     * @dataProvider ImportantFunctionData();
     */
    public function testthisImportantFunction($an_id,$an_amount,$another_amount,$starting_rows,$expected_rows)
    {
        $this->assertEquals($this->getConnection()->getRowCount('a_table'),$starting_rows);
        $result = ImportantClass::ImportantFunction($an_id, $an_amount);
        $this->assertEquals($another_amount,$result);
        $this->assertEquals($this->getConnection()->getRowCount('a_table'),$expected_rows);
    }

    public function ImportantFunctionData()
    {
        return array(
            array(1337,1000,180,10,10),
            array(1338,3900,900,10,11)
        );
    }

    public function getDataSet()
    {
        return $this->createXMLDataSet(dirname(__FILE__) . '/_files/ImportantFunctionData.xml');
    } }

我添加了config / testing / database.php:

return array(


    'default' => 'sqlite',
    'connections' => array(
        'sqlite' => array(
            'driver'   => 'sqlite',
            'database' => ':memory:',
            'prefix'   => '',
        )
    ),
);

当我运行测试时,会发生迁移以在sqlite内存中创建db,但数据似乎不会填充。行检查我得到这个错误:

  

1)ImportantClass :: testthisImportantFunction,数据集#0(1337,   1000,180,10,10)PDOException:SQLSTATE [HY000]:一般错误:1没有   这样的表:a_table

只是结果断言就在它自己的

  

1)ImportantClass :: testthisImportantFunction,数据集#0(1337,   1000,180,10,10)断言1000个匹配预期为180。

因此,在两种情况下,似乎phpunit都没有正确填充灯具。

谁能看到我出错的地方?

0 个答案:

没有答案