PHPUnit会跳过每次测试
我使用PHPUnit和CakePHP来测试一个自定义查找程序,但每次都会跳过测试,我不知道原因是什么 可以,但测试不完整、跳过或有风险 测试用例:PHPUnit会跳过每次测试,php,cakephp,phpunit,cakephp-3.0,Php,Cakephp,Phpunit,Cakephp 3.0,我使用PHPUnit和CakePHP来测试一个自定义查找程序,但每次都会跳过测试,我不知道原因是什么 可以,但测试不完整、跳过或有风险 测试用例: class UsersTableTest extends TestCase { public $fixtures = [ 'app.users', 'app.user_types', 'app.bookings', 'app.stores' ]; public function s
class UsersTableTest extends TestCase
{
public $fixtures = [
'app.users',
'app.user_types',
'app.bookings',
'app.stores'
];
public function setUp()
{
parent::setUp();
$this->Users = TableRegistry::get('Users');
}
public function testFindUser(){
$query = $this->Users->find('user', [
'fields' => ['Users.id', 'Users.email', 'Users.password',
'Users.username'],
'conditions' => ['Users.id' => 900000]
]);
$this->assertInstanceOf('Cake\ORM\Query', $query);
$result = $query->hydrate(false)->toArray();
$expected = [
[
'id' => 900000,
'email' => 'usuariocomum1@gmail.com',
'password' => 'usuariocomum1senha',
'username' => 'usuariocomum1username'
]
];
$this->assertEquals($expected, $result);
}
测试方法:
public function findUser(Query $query, array $options){
$query->where($options);
return $query;
}
用户固定装置:
public $records = [
[
'id' => 900000,
'email' => 'usuariocomum1@gmail.com',
'password' => 'usuariocomum1senha',
'username' => 'usuariocomum1username',
'user_type_id' => 900000,
'created' => '2015-07-17 18:46:47',
'modified' => '2015-07-17 18:46:47'
]
]
我正在学习这个教程
[编辑1]
使用--verbose标志:
c:\xampp\htdocs\PROJETOS\Shopping>vendor\bin\phpunit --verbose tests\TestCase\Mo
del\Table\UsersTableTest
PHPUnit 4.8.6 by Sebastian Bergmann and contributors.
Runtime: PHP 5.6.3
Configuration: C:\xampp\htdocs\PROJETOS\Shopping\phpunit.xml.dist
III.
Time: 15.87 seconds, Memory: 7.50Mb
There were 3 incomplete tests:
1) App\Test\TestCase\Model\Table\UsersTableTest::testInitialize
Not implemented yet.
C:\xampp\htdocs\PROJETOS\Shopping\tests\TestCase\Model\Table\UsersTableTest.php:
58
2) App\Test\TestCase\Model\Table\UsersTableTest::testValidationDefault
Not implemented yet.
C:\xampp\htdocs\PROJETOS\Shopping\tests\TestCase\Model\Table\UsersTableTest.php:
71
3) App\Test\TestCase\Model\Table\UsersTableTest::testBuildRules
Not implemented yet.
C:\xampp\htdocs\PROJETOS\Shopping\tests\TestCase\Model\Table\UsersTableTest.php:
81
OK, but incomplete, skipped, or risky tests!
Tests: 4, Assertions: 2, Incomplete: 3.
[编辑2]
当我将测试更改为:
public function testFindUser(){
$query = $this->Users->find('user', [
'fields' => ['Users.id', 'Users.email', 'Users.password',
'Users.username', 'Users.user_type_id', 'Users.created',
'Users.modified'],
'conditions' => ['Users.id' => 900000]
]);
$this->assertInstanceOf('Cake\ORM\Query', $query);
$result = $query->hydrate(false)->toArray();
$expected = [
[
'id' => 900000,
'email' => 'usuariocomum1@gmail.com',
'password' => 'usuariocomum1senha',
'username' => 'usuariocomum1username',
'user_type_id' => 900000,
'created' => '2015-07-17 18:46:47',
'modified' => '2015-07-17 18:46:47'
]
];
$this->assertEquals($expected, $result);
}
测试已执行但失败(hidrate(false)
可以创建和修改基本体对象)(为什么现在可以工作?为什么'user\u type\u id'=>900000
显示)
我的控制台:
c:\xampp\htdocs\PROJETOS\Shopping>vendor\bin\phpunit tests\TestCase\Model\Table\
UsersTableTest
PHPUnit 4.8.6 by Sebastian Bergmann and contributors.
IIIF
Time: 8.13 seconds, Memory: 7.75Mb
There was 1 failure:
1) App\Test\TestCase\Model\Table\UsersTableTest::testFindUser
Failed asserting that two arrays are equal.
--- Expected
+++ Actual
@@ @@
'user_type_id' => 900000
- 'created' => '2015-07-17 18:46:47'
- 'modified' => '2015-07-17 18:46:47'
+ 'created' => Cake\I18n\Time Object (...)
+ 'modified' => Cake\I18n\Time Object (...)
)
)
C:\xampp\htdocs\PROJETOS\Shopping\tests\TestCase\Model\Table\UsersTableTest.php:
107
FAILURES!
Tests: 4, Assertions: 2, Failures: 1, Incomplete: 3.
[编辑3]
我清理我的测试用例并删除所有未实现的测试(由bake创建),这是输出:
c:\xampp\htdocs\PROJETOS\Shopping>vendor\bin\phpunit tests\TestCase\Model\Table\
UsersTableTest
PHPUnit 4.8.6 by Sebastian Bergmann and contributors.
.
Time: 6.06 seconds, Memory: 7.50Mb
OK (1 test, 2 assertions)
**NOTE** CakePHP 3.0.11 PHPUnit 4.8.6
我们在你的另一个问题中有这个,不是吗?
testFindUser
测试没有被跳过,从PHPUnit输出以及更改代码时收到失败消息这一事实可以看出,它运行得很好,因此它会产生错误,如果被跳过,则不会出现故障,并且输出会是iis
正常,但测试不完整、跳过或有风险测试:4,断言:2,不完整:3 *重点矿山 总共4次测试,3次未完成,=1次测试运行 该消息只是说有未完成/未实现的测试,另外运行的测试
OK
详细级别的输出更清楚地表明了这一点,它准确地向您显示了哪些测试是不完整的-它们都不是您的testFindUser
测试
您可能需要仔细查看文档,以掌握如何解释输出
好的,我删除了所有未执行的测试(由bake创建),并将结果放入我的问题的编辑3中,你看到了吗?@ricardo是的,我看到了,这是预期的输出,它显示1个测试和2个断言成功运行。@ndn你可以解释我如何在[edit 2]中进行测试吗?因为我期待一个字符串,但我收到一个object@ricardo水合作用是将数据转换为实体对象结构的过程,值的数据类型不受影响,即基于时间的列将始终转换为时间类实例(除非重写),整数保持整数,等等。。。在比较数据集中创建时间实例,如
'created'=>new\Cake\I18n\time('2015-07-17 18:46:47')
,应该可以正常工作。