/
TestListenerTest.php
104 lines (88 loc) · 3.6 KB
/
TestListenerTest.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
<?php
/**
* Mockery
*
* LICENSE
*
* This source file is subject to the new BSD license that is bundled
* with this package in the file LICENSE.txt.
* It is also available through the world-wide-web at this URL:
* http://github.com/padraic/mockery/blob/master/LICENSE
* If you did not receive a copy of the license and are unable to
* obtain it through the world-wide-web, please send an email
* to padraic@php.net so we can send you a copy immediately.
*
* @category Mockery
* @package Mockery
* @subpackage UnitTests
* @copyright Copyright (c) 2010 Pádraic Brady (http://blog.astrumfutura.com)
* @license http://github.com/padraic/mockery/blob/master/LICENSE New BSD License
*/
namespace tests\Mockery\Adapter\Phpunit;
use Mockery\Adapter\Phpunit\MockeryTestCase;
use PHPUnit\Framework\TestResult;
use Mockery\Adapter\Phpunit\TestListener;
use test\Mockery\Fixtures\EmptyTestCase;
class TestListenerTest extends MockeryTestCase
{
protected $container;
protected $listener;
protected $testResult;
protected $test;
protected function mockeryTestSetUp()
{
// We intentionally test the static container here. That is what the
// listener will check.
$this->container = \Mockery::getContainer();
$this->listener = new TestListener();
$this->testResult = new TestResult();
$this->test = new EmptyTestCase();
$this->test->setTestResultObject($this->testResult);
$this->testResult->addListener($this->listener);
$this->assertTrue($this->testResult->wasSuccessful(), 'sanity check: empty test results should be considered successful');
}
public function testSuccessOnClose()
{
$mock = $this->container->mock();
$mock->shouldReceive('bar')->once();
$mock->bar();
// This is what MockeryPHPUnitIntegration and MockeryTestCase trait
// will do. We intentionally call the static close method.
$this->test->addToAssertionCount($this->container->mockery_getExpectationCount());
\Mockery::close();
$this->listener->endTest($this->test, 0);
$this->assertTrue($this->testResult->wasSuccessful(), 'expected test result to indicate success');
}
public function testFailureOnMissingClose()
{
$mock = $this->container->mock();
$mock->shouldReceive('bar')->once();
$this->listener->endTest($this->test, 0);
$this->assertFalse($this->testResult->wasSuccessful(), 'expected test result to indicate failure');
// Satisfy the expectation and close the global container now so we
// don't taint the environment.
$mock->bar();
\Mockery::close();
}
public function testMockeryIsAddedToBlacklist()
{
$suite = \Mockery::mock(\PHPUnit\Framework\TestSuite::class);
if (method_exists(\PHPUnit\Util\Blacklist::class, 'addDirectory')) {
$this->assertFalse(
(new \PHPUnit\Util\Blacklist())->isBlacklisted(
(new \ReflectionClass(\Mockery::class))->getFileName()
)
);
$this->listener->startTestSuite($suite);
$this->assertTrue(
(new \PHPUnit\Util\Blacklist())->isBlacklisted(
(new \ReflectionClass(\Mockery::class))->getFileName()
)
);
} else {
$this->assertArrayNotHasKey(\Mockery::class, \PHPUnit\Util\Blacklist::$blacklistedClassNames);
$this->listener->startTestSuite($suite);
$this->assertSame(1, \PHPUnit\Util\Blacklist::$blacklistedClassNames[\Mockery::class]);
}
}
}