Spamworldpro Mini Shell
Spamworldpro


Server : Apache
System : Linux server2.corals.io 4.18.0-348.2.1.el8_5.x86_64 #1 SMP Mon Nov 15 09:17:08 EST 2021 x86_64
User : corals ( 1002)
PHP Version : 7.4.33
Disable Function : exec,passthru,shell_exec,system
Directory :  /home/corals/old/vendor/allure-framework/allure-php-commons/src/

Upload File :
current_dir [ Writeable ] document_root [ Writeable ]

 

Current File : /home/corals/old/vendor/allure-framework/allure-php-commons/src/AllureLifecycle.php
<?php

namespace Qameta\Allure;

use Psr\Log\LoggerInterface;
use Qameta\Allure\Exception\ActiveContainerNotFoundException;
use Qameta\Allure\Exception\ActiveExecutionContextNotFoundException;
use Qameta\Allure\Exception\ActiveStepNotFoundException;
use Qameta\Allure\Exception\ActiveTestNotFoundException;
use Qameta\Allure\Exception\InvalidExecutionContextException;
use Qameta\Allure\Internal\ThreadContextInterface;
use Qameta\Allure\Internal\HooksNotifierInterface;
use Qameta\Allure\Internal\LoggerAwareTrait;
use Qameta\Allure\Internal\ResultStorageInterface;
use Qameta\Allure\Io\ClockInterface;
use Qameta\Allure\Io\DataSourceInterface;
use Qameta\Allure\Io\ResultsWriterInterface;
use Qameta\Allure\Model\AttachmentResult;
use Qameta\Allure\Model\ContainerResult;
use Qameta\Allure\Model\ExecutionContextInterface;
use Qameta\Allure\Model\FixtureResult;
use Qameta\Allure\Model\ResultInterface;
use Qameta\Allure\Model\Stage;
use Qameta\Allure\Model\StepResult;
use Qameta\Allure\Model\TestResult;
use Throwable;

final class AllureLifecycle implements AllureLifecycleInterface
{
    use LoggerAwareTrait;

    public function __construct(
        LoggerInterface $logger,
        private ClockInterface $clock,
        private ResultsWriterInterface $resultsWriter,
        private HooksNotifierInterface $notifier,
        private ResultStorageInterface $storage,
        private ThreadContextInterface $threadContext,
    ) {
        $this->logger = $logger;
    }

    public function switchThread(?string $thread): void
    {
        $this->threadContext->switchThread($thread);
    }

    public function getCurrentTest(): ?string
    {
        return $this->threadContext->getCurrentTest();
    }

    public function getCurrentStep(): ?string
    {
        return $this->threadContext->getCurrentStep();
    }

    public function getCurrentTestOrStep(): ?string
    {
        return $this->threadContext->getCurrentTestOrStep();
    }

    public function startContainer(ContainerResult $container): void
    {
        $this->notifier->beforeContainerStart($container);
        try {
            $this->storage->set(
                $container->setStart($this->clock->now()),
            );
            $this->threadContext->setContainer($container->getUuid());
        } catch (Throwable $e) {
            $this->logException('Container (UUID: {uuid}) not started', $e, ['uuid' => $container->getUuid()]);
            $this->notifier->onLifecycleError($e);
        }
        $this->notifier->afterContainerStart($container);
    }

    /**
     * @param callable    $update
     * @param string|null $uuid
     * @return string|null
     */
    public function updateContainer(callable $update, ?string $uuid = null): ?string
    {
        try {
            $uuid ??= $this->threadContext->getContainer();
            $container = $this->storage->getContainer($uuid ?? throw new ActiveContainerNotFoundException());
        } catch (Throwable $e) {
            $this->logException('Container (UUID: {uuid}) not updated', $e, ['uuid' => $uuid]);
            $this->notifier->onLifecycleError($e);

            return null;
        }
        $this->notifier->beforeContainerUpdate($container);
        try {
            $update($container);
        } catch (Throwable $e) {
            $this->logException('Container (UUID: {uuid}) not updated', $e, ['uuid' => $container->getUuid()]);
            $this->notifier->onLifecycleError($e);
        }
        $this->notifier->afterContainerUpdate($container);

        return $container->getUuid();
    }

    public function stopContainer(?string $uuid = null): ?string
    {
        try {
            $uuid ??= $this->threadContext->getContainer();
            $container = $this->storage->getContainer($uuid ?? throw new ActiveContainerNotFoundException());
        } catch (Throwable $e) {
            $this->logException('Container (UUID: {uuid}) not stopped', $e, ['uuid' => $uuid]);
            $this->notifier->onLifecycleError($e);

            return null;
        }
        $this->notifier->beforeContainerStop($container);
        try {
            $container->setStop($this->clock->now());
            $this->threadContext->resetContainer();
        } catch (Throwable $e) {
            $this->logException('Container (UUID: {uuid}) not stopped', $e, ['uuid' => $container->getUuid()]);
            $this->notifier->onLifecycleError($e);
        }
        $this->notifier->afterContainerStop($container);

        return $container->getUuid();
    }

    public function writeContainer(string $uuid): void
    {
        try {
            $container = $this->storage->getContainer($uuid);
        } catch (Throwable $e) {
            $this->logException('Container (UUID: {uuid}) not written', $e, ['uuid' => $uuid]);
            $this->notifier->onLifecycleError($e);

            return;
        }
        $this->notifier->beforeContainerWrite($container);
        try {
            if ($container->getExcluded()) {
                $this->excludeNestedResults($container);
            }
            $this->removeExcludedNestedResults($container);
            if (!$container->getExcluded()) {
                $this->resultsWriter->writeContainer($container);
            }
            $this->storage->unset($container->getUuid());
        } catch (Throwable $e) {
            $this->logException('Container (UUID: {uuid}) not written', $e, ['uuid' => $container->getUuid()]);
            $this->notifier->onLifecycleError($e);
        }
        $this->notifier->afterContainerWrite($container);
    }

    private function excludeNestedResults(ResultInterface $result): void
    {
        foreach ($result->getNestedResults() as $nestedResult) {
            $nestedResult->setExcluded(true);
            $this->excludeNestedResults($nestedResult);
        }
    }

    private function removeExcludedNestedResults(ResultInterface $result): void
    {
        foreach ($result->getNestedResults() as $nestedResult) {
            $this->removeExcludedNestedResults($nestedResult);
            if ($nestedResult->getExcluded()) {
                if ($nestedResult instanceof AttachmentResult) {
                    $this->removeAttachment($nestedResult);
                } elseif ($nestedResult instanceof TestResult) {
                    $this->removeTest($nestedResult);
                }
            }
        }
    }

    public function startBeforeFixture(FixtureResult $fixture, ?string $containerUuid = null): void
    {
        $this->notifier->beforeFixtureStart($fixture);
        try {
            $containerUuid ??= $this->threadContext->getContainer();
            $this
                ->storage
                ->getContainer($containerUuid ?? throw new ActiveContainerNotFoundException())
                ->addBefores($fixture);
            $this->startFixture($fixture);
        } catch (Throwable $e) {
            $this->logException(
                'Set up fixture (UUID: {uuid}, container UUID: {containerUuid}) not started',
                $e,
                ['uuid' => $fixture->getUuid(), 'containerUuid' => $containerUuid],
            );
            $this->notifier->onLifecycleError($e);
        }
        $this->notifier->afterFixtureStart($fixture);
    }

    public function startAfterFixture(FixtureResult $fixture, ?string $containerUuid = null): void
    {
        $this->notifier->beforeFixtureStart($fixture);
        try {
            $containerUuid ??= $this->threadContext->getContainer();
            $this
                ->storage
                ->getContainer($containerUuid ?? throw new ActiveContainerNotFoundException())
                ->addAfters($fixture);
            $this->startFixture($fixture);
        } catch (Throwable $e) {
            $this->logException(
                'Tear down fixture (UUID: {uuid}, container UUID: {containerUuid}) not started',
                $e,
                ['uuid' => $fixture->getUuid(), 'containerUuid' => $containerUuid],
            );
            $this->notifier->onLifecycleError($e);
        }
        $this->notifier->afterFixtureStart($fixture);
    }

    private function startFixture(FixtureResult $fixture): void
    {
        $this->storage->set(
            $fixture
                ->setStage(Stage::running())
                ->setStart($this->clock->now()),
        );
        $this
            ->threadContext
            ->reset()
            ->push($fixture->getUuid());
    }

    public function updateFixture(callable $update, ?string $uuid = null): ?string
    {
        try {
            $uuid ??= $this->threadContext->getCurrentTest();
            $fixture = $this->storage->getFixture($uuid ?? throw new ActiveTestNotFoundException());
        } catch (Throwable $e) {
            $this->logException('Fixture (UUID: {uuid}) not updated', $e, ['uuid' => $uuid]);
            $this->notifier->onLifecycleError($e);

            return null;
        }
        $this->notifier->beforeFixtureUpdate($fixture);
        try {
            $update($fixture);
        } catch (Throwable $e) {
            $this->logException('Fixture (UUID: {uuid}) not updated', $e, ['uuid' => $fixture->getUuid()]);
            $this->notifier->onLifecycleError($e);
        }
        $this->notifier->afterFixtureUpdate($fixture);

        return $fixture->getUuid();
    }

    public function stopFixture(?string $uuid = null): ?string
    {
        try {
            $uuid ??= $this->threadContext->getCurrentTest();
            $fixture = $this->storage->getFixture($uuid ?? throw new ActiveTestNotFoundException());
        } catch (Throwable $e) {
            $this->logException('Fixture (UUID: {uuid}) not stopped', $e, ['uuid' => $uuid]);
            $this->notifier->onLifecycleError($e);

            return null;
        }
        $this->notifier->beforeFixtureStop($fixture);
        try {
            $fixture
                ->setStage(Stage::finished())
                ->setStop($this->clock->now());
            $this->storage->unset($fixture->getUuid());
            $this->threadContext->reset();
        } catch (Throwable $e) {
            $this->logException('Fixture (UUID: {uuid}) not stopped', $e, ['uuid' => $fixture->getUuid()]);
            $this->notifier->onLifecycleError($e);
        }
        $this->notifier->afterFixtureStop($fixture);

        return $fixture->getUuid();
    }

    public function scheduleTest(TestResult $test, ?string $containerUuid = null): void
    {
        $this->notifier->beforeTestSchedule($test);
        try {
            $containerUuid ??= $this->threadContext->getContainer();
            if (isset($containerUuid)) {
                $this
                    ->storage
                    ->getContainer($containerUuid)
                    ->addChildren($test);
            }
            $this->storage->set(
                $test->setStage(Stage::scheduled()),
            );
        } catch (Throwable $e) {
            $this->logException(
                'Test (UUID: {uuid}) not scheduled (container UUID: {containerUuid})',
                $e,
                ['uuid' => $test->getUuid(), 'containerUuid' => $containerUuid],
            );
            $this->notifier->onLifecycleError($e);
        }
        $this->notifier->afterTestSchedule($test);
    }

    public function startTest(string $uuid): void
    {
        try {
            $test = $this->storage->getTest($uuid);
        } catch (Throwable $e) {
            $this->logException('Test (UUID: {uuid}) not started', $e, ['uuid' => $uuid]);
            $this->notifier->onLifecycleError($e);

            return;
        }
        $this->notifier->beforeTestStart($test);
        try {
            $test
                ->setStage(Stage::running())
                ->setStart($this->clock->now());
            $this
                ->threadContext
                ->reset()
                ->push($test->getUuid());
        } catch (Throwable $e) {
            $this->logException('Test (UUID: {uuid}) not started', $e, ['uuid' => $test->getUuid()]);
            $this->notifier->onLifecycleError($e);
        }
        $this->notifier->afterTestStart($test);
    }

    public function updateTest(callable $update, ?string $uuid = null): ?string
    {
        try {
            $uuid ??= $this->threadContext->getCurrentTest();
            $test = $this->storage->getTest($uuid ?? throw new ActiveTestNotFoundException());
        } catch (Throwable $e) {
            $this->logException('Test (UUID: {uuid}) not updated', $e, ['uuid' => $uuid]);
            $this->notifier->onLifecycleError($e);

            return null;
        }
        $this->notifier->beforeTestUpdate($test);
        try {
            $update($test);
        } catch (Throwable $e) {
            $this->logException('Test (UUID: {uuid}) not updated', $e, ['uuid' => $test->getUuid()]);
            $this->notifier->onLifecycleError($e);
        }
        $this->notifier->afterTestUpdate($test);

        return $test->getUuid();
    }

    public function stopTest(?string $uuid = null): ?string
    {
        try {
            $uuid ??= $this->threadContext->getCurrentTest();
            $test = $this->storage->getTest($uuid ?? throw new ActiveTestNotFoundException());
        } catch (Throwable $e) {
            $this->logException('Test (UUID: {uuid}) not stopped', $e, ['uuid' => $uuid]);
            $this->notifier->onLifecycleError($e);

            return null;
        }
        $this->notifier->beforeTestStop($test);
        try {
            $test
                ->setStage(Stage::finished())
                ->setStop($this->clock->now());
            $this->threadContext->reset();
        } catch (Throwable $e) {
            $this->logException('Test (UUID: {uuid}) not stopped', $e, ['uuid' => $test->getUuid()]);
            $this->notifier->onLifecycleError($e);
        }
        $this->notifier->afterTestStop($test);

        return $test->getUuid();
    }

    public function writeTest(string $uuid): void
    {
        try {
            $test = $this->storage->getTest($uuid);
        } catch (Throwable $e) {
            $this->logException('Test (UUID: {uuid}) not written', $e, ['uuid' => $uuid]);
            $this->notifier->onLifecycleError($e);

            return;
        }
        $this->notifier->beforeTestWrite($test);
        try {
            if ($test->getExcluded()) {
                $this->excludeNestedResults($test);
            }
            $this->removeExcludedNestedResults($test);
            if (!$test->getExcluded()) {
                $this->resultsWriter->writeTest($test);
            }
            $this->storage->unset($test->getUuid());
        } catch (Throwable $e) {
            $this->logException('Test (UUID: {uuid}) not written', $e, ['uuid' => $test->getUuid()]);
            $this->notifier->onLifecycleError($e);
        }
        $this->notifier->afterTestWrite($test);
    }

    private function removeTest(TestResult $test): void
    {
        try {
            $this->resultsWriter->removeTest($test);
        } catch (Throwable $e) {
            $this->logException('Test (UUID: {uuid}) not removed', $e, ['uuid' => $test->getUuid()]);
            $this->notifier->onLifecycleError($e);
        }
    }

    public function startStep(StepResult $step, ?string $parentUuid = null): void
    {
        $this->notifier->beforeStepStart($step);
        try {
            $parentUuid ??= $this->threadContext->getCurrentTestOrStep();
            $this
                ->storage
                ->getExecutionContext($parentUuid ?? throw new ActiveExecutionContextNotFoundException())
                ->addSteps($step);
            $this
                ->storage
                ->set(
                    $step
                        ->setStage(Stage::running())
                        ->setStart($this->clock->now()),
                );
            $this->threadContext->push($step->getUuid());
        } catch (Throwable $e) {
            $this->logException(
                'Step (UUID: {uuid}) not started (parent UUID: {parentUuid})',
                $e,
                ['uuid' => $step->getUuid(), 'parentUuid' => $parentUuid],
            );
            $this->notifier->onLifecycleError($e);
        }
        $this->notifier->afterStepStart($step);
    }

    public function updateStep(callable $update, ?string $uuid = null): ?string
    {
        try {
            $uuid ??= $this->threadContext->getCurrentStep();
            $step = $this->storage->getStep($uuid ?? throw new ActiveStepNotFoundException());
        } catch (Throwable $e) {
            $this->logException('Step (UUID: {uuid}) not updated', $e, ['uuid' => $uuid]);
            $this->notifier->onLifecycleError($e);

            return null;
        }
        $this->notifier->beforeStepUpdate($step);
        try {
            $update($step);
        } catch (Throwable $e) {
            $this->logException('Step (UUID: {uuid}) not updated', $e, ['uuid' => $step->getUuid()]);
            $this->notifier->onLifecycleError($e);
        }
        $this->notifier->afterStepUpdate($step);

        return $step->getUuid();
    }

    public function updateExecutionContext(callable $update, ?string $uuid = null): ?string
    {
        try {
            $uuid ??= $this->threadContext->getCurrentTestOrStep();
            $context = $this->storage->getExecutionContext(
                $uuid ?? throw new ActiveExecutionContextNotFoundException(),
            );
        } catch (Throwable $e) {
            $this->logException('Execution context (UUID: {uuid}) not updated', $e, ['uuid' => $uuid]);
            $this->notifier->onLifecycleError($e);

            return null;
        }

        return match (true) {
            $context instanceof FixtureResult => $this->updateFixture($update, $context->getUuid()),
            $context instanceof TestResult => $this->updateTest($update, $context->getUuid()),
            $context instanceof StepResult => $this->updateStep($update, $context->getUuid()),
            default => $this->reportInvalidContext($context),
        };
    }

    private function reportInvalidContext(ExecutionContextInterface $context): ?string
    {
        $this->logger->error(
            'Execution context (UUID: {uuid}) not updated',
            ['uuid' => $context->getUuid()],
        );
        $this->notifier->onLifecycleError(new InvalidExecutionContextException($context));

        return null;
    }

    public function stopStep(?string $uuid = null): ?string
    {
        try {
            $uuid ??= $this->threadContext->getCurrentStep();
            $step = $this->storage->getStep($uuid ?? throw new ActiveStepNotFoundException());
        } catch (Throwable $e) {
            $this->logException('Step (UUID: {uuid}) not stopped', $e, ['uuid' => $uuid]);
            $this->notifier->onLifecycleError($e);

            return null;
        }
        $this->notifier->beforeStepStop($step);
        try {
            $step
                ->setStage(Stage::finished())
                ->setStop($this->clock->now());
            $this->storage->unset($step->getUuid());
            $this->threadContext->pop();
        } catch (Throwable $e) {
            $this->logException('Step (UUID: {uuid}) not stopped', $e, ['uuid' => $step->getUuid()]);
            $this->notifier->onLifecycleError($e);
        }
        $this->notifier->afterStepStop($step);

        return $step->getUuid();
    }

    public function addAttachment(AttachmentResult $attachment, DataSourceInterface $data): void
    {
        try {
            $parentUuid = $this->threadContext->getCurrentTestOrStep();
            $context = $this
                ->storage
                ->getExecutionContext($parentUuid ?? throw new ActiveExecutionContextNotFoundException())
                ->addAttachments($attachment);
        } catch (Throwable $e) {
            $this->logException(
                'Attachment (UUID: {uuid}) not added (parent UUID: {parentUuid})',
                $e,
                ['uuid' => $attachment->getUuid(), 'parentUuid' => $parentUuid ?? null],
            );
            $this->notifier->onLifecycleError($e);

            return;
        }
        $this->notifier->beforeAttachmentWrite($attachment);
        try {
            if (!$attachment->getExcluded()) {
                $this->resultsWriter->writeAttachment($attachment, $data);
            }
        } catch (Throwable $e) {
            $this->logException(
                'Attachment (UUID: {uuid}) not added (parent UUID: {parentUuid})',
                $e,
                ['uuid' => $attachment->getUuid(), 'parentUuid' => $context->getUuid()],
            );
            $this->notifier->onLifecycleError($e);
        }
        $this->notifier->afterAttachmentWrite($attachment);
    }

    private function removeAttachment(AttachmentResult $attachment): void
    {
        try {
            $this->resultsWriter->removeAttachment($attachment);
        } catch (Throwable $e) {
            $this->logException('Attachment (UUID: {uuid}) not removed', $e, ['uuid' => $attachment->getUuid()]);
            $this->notifier->onLifecycleError($e);
        }
    }
}

Spamworldpro Mini