justintime50 / vcr-accessories
Various accessories for your PHP VCR
Fund package maintenance!
Justintime50
Installs: 1 631
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 1
Forks: 0
Open Issues: 0
Requires
- php: ^8.0
- allejo/php-vcr-sanitizer: ^1.1
- php-vcr/php-vcr: ^1.7
Requires (Dev)
- guzzlehttp/guzzle: ^7.5
- justintime50/styles: ^0.6.0
- php-coveralls/php-coveralls: ^2.7
- phpstan/phpstan: ^1.12
- phpunit/phpunit: ^9.0
- rregeer/phpunit-coverage-check: ^0.3.1
- squizlabs/php_codesniffer: ^3.10
README
Various tools and accessories for your PHP VCR.
When working with VCR solutions, I'm often finding I need a few extra "accessories" to get them working the way I want. This package includes the following:
- Cassette scrubbing (eg: sensitive data)
- Expire and warn or error on stale cassettes
- Setup a cassette directory
- Setup and teardown VCR tests
Install
# Install in your project composer require --dev justintime50/vcr-accessories # Install locally composer install
Usage
bootstrap.php
use allejo\VCR\VCRCleaner; use VCR\VCR; use VCRAccessories\CassetteScrubber; use VCRAccessories\CassetteSetup; const CASSETTE_DIR = 'tests/cassettes'; CassetteSetup::setupCassetteDirectory(CASSETTE_DIR); VCR::configure()->setCassettePath(CASSETTE_DIR) ->setStorage('yaml') ->setMode('once') ->setWhiteList(['vendor/guzzle']); const REDACTED_STRING = '<REDACTED>'; // SCRUBBERS must be a multidimensional array where the first index of each nested array is the key // you want to scrub and the second index is what you want it to be replaced with before persisting to disk define('SCRUBBERS', [ ['origin', REDACTED_STRING], ]); VCRCleaner::enable([ 'response' => [ 'bodyScrubbers' => [ function ($responseBody) { $responseBodyJson = json_decode($responseBody, true); $responseBodyEncoded = CassetteScrubber::scrubCassette(SCRUBBERS, $responseBodyJson); // Re-encode the data so we can properly store it in the cassette return json_encode($responseBodyEncoded); } ], ], ]);
Test File
use VCRAccessories\CassetteSetup; public static function setUpBeforeClass(): void { CassetteSetup::setupVcrTests(); } public static function tearDownAfterClass(): void { CassetteSetup::teardownVcrTests(); } public function myTest() { CassetteSetup::setupCassette( cassetteName: 'nameOfCassette.yaml', expirationDays: 180, expirationError: true ); // Your test here }
Development
# Install dependencies composer install # Lint composer lint composer fix composer phpstan # Test composer test composer coverage