Skip to content

Latest commit

 

History

History
83 lines (64 loc) · 1.79 KB

troubleshooting.md

File metadata and controls

83 lines (64 loc) · 1.79 KB

Troubleshooting

Output Logging

There are several ways to print the logs:

Logger Singleton Instance

You can run these code (once) before running tests:

use PhpPact\Log\Logger;
use PhpPact\Log\Enum\LogLevel;
use PhpPact\Log\Model\File;
use PhpPact\Log\Model\Buffer;
use PhpPact\Log\Model\Stdout;
use PhpPact\Log\Model\Stderr;

$logger = Logger::instance();
$logger->attach(new File('/path/to/file', LogLevel::DEBUG));
$logger->attach(new Buffer(LogLevel::ERROR));
$logger->attach(new Stdout(LogLevel::WARN));
$logger->attach(new Stderr(LogLevel::INFO));
$logger->apply();
  • Pros
    • Flexible, can be used in any test framework
    • Support plugins (e.g. csv, gRPC)
    • Support multiple sinks
  • Cons
    • Need to modify the code (once, before the tests)

PHPUnit Extension

You can put these elements to PHPUnit's configuration file:

<?xml version="1.0" encoding="UTF-8"?>
<phpunit bootstrap="vendor/autoload.php" colors="true">
    ...
    <php>
        <env name="PACT_LOG" value="./log/pact.txt"/>
        <env name="PACT_LOGLEVEL" value="DEBUG"/>
    </php>
    <extensions>
        <bootstrap class="PhpPact\Log\PHPUnit\PactLoggingExtension"/>
    </extensions>
</phpunit>
  • Pros
    • Support plugins (e.g. csv, gRPC)
    • No need to modify the code
  • Cons
    • Support only single sink (stdout or file, depend on the value of the environment variables)
    • Only for PHPUnit

Config

Consumer:

use PhpPact\Standalone\MockService\MockServerConfig;

$config = new VerifierConfig();
$config->setLogLevel('DEBUG');

Provider:

use PhpPact\Standalone\ProviderVerifier\Model\VerifierConfig;

$config = new VerifierConfig();
$config->setLogLevel('DEBUG');
  • Pros
    • Simple
  • Cons
    • Do not support plugins (e.g. csv, gRPC)
    • Only single sink (stdout)