summaryrefslogtreecommitdiff
path: root/vendor/phpunit/phpunit/src/Runner/Hook/TestListenerAdapter.php
diff options
context:
space:
mode:
Diffstat (limited to 'vendor/phpunit/phpunit/src/Runner/Hook/TestListenerAdapter.php')
-rw-r--r--vendor/phpunit/phpunit/src/Runner/Hook/TestListenerAdapter.php141
1 files changed, 141 insertions, 0 deletions
diff --git a/vendor/phpunit/phpunit/src/Runner/Hook/TestListenerAdapter.php b/vendor/phpunit/phpunit/src/Runner/Hook/TestListenerAdapter.php
new file mode 100644
index 000000000..60fbfba31
--- /dev/null
+++ b/vendor/phpunit/phpunit/src/Runner/Hook/TestListenerAdapter.php
@@ -0,0 +1,141 @@
+<?php declare(strict_types=1);
+/*
+ * This file is part of PHPUnit.
+ *
+ * (c) Sebastian Bergmann <[email protected]>
+ *
+ * For the full copyright and license information, please view the LICENSE
+ * file that was distributed with this source code.
+ */
+namespace PHPUnit\Runner;
+
+use PHPUnit\Framework\AssertionFailedError;
+use PHPUnit\Framework\Test;
+use PHPUnit\Framework\TestListener;
+use PHPUnit\Framework\TestSuite;
+use PHPUnit\Framework\Warning;
+use PHPUnit\Util\Test as TestUtil;
+use Throwable;
+
+/**
+ * @internal This class is not covered by the backward compatibility promise for PHPUnit
+ */
+final class TestListenerAdapter implements TestListener
+{
+ /**
+ * @var TestHook[]
+ */
+ private $hooks = [];
+
+ /**
+ * @var bool
+ */
+ private $lastTestWasNotSuccessful;
+
+ public function add(TestHook $hook): void
+ {
+ $this->hooks[] = $hook;
+ }
+
+ public function startTest(Test $test): void
+ {
+ foreach ($this->hooks as $hook) {
+ if ($hook instanceof BeforeTestHook) {
+ $hook->executeBeforeTest(TestUtil::describeAsString($test));
+ }
+ }
+
+ $this->lastTestWasNotSuccessful = false;
+ }
+
+ public function addError(Test $test, Throwable $t, float $time): void
+ {
+ foreach ($this->hooks as $hook) {
+ if ($hook instanceof AfterTestErrorHook) {
+ $hook->executeAfterTestError(TestUtil::describeAsString($test), $t->getMessage(), $time);
+ }
+ }
+
+ $this->lastTestWasNotSuccessful = true;
+ }
+
+ public function addWarning(Test $test, Warning $e, float $time): void
+ {
+ foreach ($this->hooks as $hook) {
+ if ($hook instanceof AfterTestWarningHook) {
+ $hook->executeAfterTestWarning(TestUtil::describeAsString($test), $e->getMessage(), $time);
+ }
+ }
+
+ $this->lastTestWasNotSuccessful = true;
+ }
+
+ public function addFailure(Test $test, AssertionFailedError $e, float $time): void
+ {
+ foreach ($this->hooks as $hook) {
+ if ($hook instanceof AfterTestFailureHook) {
+ $hook->executeAfterTestFailure(TestUtil::describeAsString($test), $e->getMessage(), $time);
+ }
+ }
+
+ $this->lastTestWasNotSuccessful = true;
+ }
+
+ public function addIncompleteTest(Test $test, Throwable $t, float $time): void
+ {
+ foreach ($this->hooks as $hook) {
+ if ($hook instanceof AfterIncompleteTestHook) {
+ $hook->executeAfterIncompleteTest(TestUtil::describeAsString($test), $t->getMessage(), $time);
+ }
+ }
+
+ $this->lastTestWasNotSuccessful = true;
+ }
+
+ public function addRiskyTest(Test $test, Throwable $t, float $time): void
+ {
+ foreach ($this->hooks as $hook) {
+ if ($hook instanceof AfterRiskyTestHook) {
+ $hook->executeAfterRiskyTest(TestUtil::describeAsString($test), $t->getMessage(), $time);
+ }
+ }
+
+ $this->lastTestWasNotSuccessful = true;
+ }
+
+ public function addSkippedTest(Test $test, Throwable $t, float $time): void
+ {
+ foreach ($this->hooks as $hook) {
+ if ($hook instanceof AfterSkippedTestHook) {
+ $hook->executeAfterSkippedTest(TestUtil::describeAsString($test), $t->getMessage(), $time);
+ }
+ }
+
+ $this->lastTestWasNotSuccessful = true;
+ }
+
+ public function endTest(Test $test, float $time): void
+ {
+ if (!$this->lastTestWasNotSuccessful) {
+ foreach ($this->hooks as $hook) {
+ if ($hook instanceof AfterSuccessfulTestHook) {
+ $hook->executeAfterSuccessfulTest(TestUtil::describeAsString($test), $time);
+ }
+ }
+ }
+
+ foreach ($this->hooks as $hook) {
+ if ($hook instanceof AfterTestHook) {
+ $hook->executeAfterTest(TestUtil::describeAsString($test), $time);
+ }
+ }
+ }
+
+ public function startTestSuite(TestSuite $suite): void
+ {
+ }
+
+ public function endTestSuite(TestSuite $suite): void
+ {
+ }
+}