Skip to content

Commit

Permalink
Switch snapshot implementation
Browse files Browse the repository at this point in the history
  • Loading branch information
daun committed Mar 21, 2024
1 parent 192da97 commit a77d70c
Show file tree
Hide file tree
Showing 22 changed files with 101 additions and 85 deletions.
4 changes: 2 additions & 2 deletions .github/workflows/ci.yml
Original file line number Diff line number Diff line change
Expand Up @@ -39,15 +39,15 @@ jobs:
with:
timeout_minutes: 3
max_attempts: 3
command: composer require "laravel/framework:9.*" "orchestra/testbench:^7.40" "pestphp/pest:^1.22" "pestphp/pest-plugin-laravel:^1.4" --no-update --no-interaction
command: composer require "laravel/framework:9.*" "orchestra/testbench:^7.40" "pestphp/pest:^1.22" "pestphp/pest-plugin-laravel:^1.4" "spatie/pest-plugin-snapshots:^1.1" --no-update --no-interaction

- name: Select Laravel 10
uses: nick-invision/retry@v3
if: ${{ matrix.laravel == '10' }}
with:
timeout_minutes: 3
max_attempts: 3
command: composer require "laravel/framework:10.*" "orchestra/testbench:^8.21" "pestphp/pest:^2.34" "pestphp/pest-plugin-laravel:^2.3" --no-update --no-interaction
command: composer require "laravel/framework:10.*" "orchestra/testbench:^8.21" "pestphp/pest:^2.34" "pestphp/pest-plugin-laravel:^2.3" "spatie/pest-plugin-snapshots:^2.1" --no-update --no-interaction

- name: Install PHP Dependencies
uses: nick-invision/retry@v3
Expand Down
4 changes: 2 additions & 2 deletions composer.json
Original file line number Diff line number Diff line change
Expand Up @@ -48,8 +48,8 @@
"mockery/mockery": "^1.6",
"orchestra/testbench": "^8.21",
"pestphp/pest-plugin-laravel": "^2.3",
"pestphp/pest": "^2.34",
"spatie/phpunit-snapshot-assertions": "^5.1"
"spatie/pest-plugin-snapshots": "^2.1",
"pestphp/pest": "^2.34"
},
"scripts": {
"format": "./vendor/bin/pint",
Expand Down
64 changes: 63 additions & 1 deletion composer.lock

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

7 changes: 2 additions & 5 deletions tests/Concerns/DealsWithAssets.php
Original file line number Diff line number Diff line change
Expand Up @@ -95,12 +95,9 @@ public function getTestFilesDirectory(...$paths): string
return fixtures_path('tmp', 'testfiles', ...$paths);
}

public function getTestFileData(string $filename): array
public function getTestFileContents(string $filename): string
{
$content = file_get_contents(fixtures_path("testfiles/{$filename}"));
$expected = json_decode(file_get_contents(snapshots_path("placeholders/{$filename}.json")), true);

return [$content, $expected];
return file_get_contents(fixtures_path("testfiles/{$filename}"));
}

public function uploadTestImageToTestContainer(string $image, ?string $filename = null)
Expand Down
31 changes: 0 additions & 31 deletions tests/Concerns/HandlesSnapshots.php

This file was deleted.

14 changes: 7 additions & 7 deletions tests/Feature/PlaceholderProviderAverageColorTest.php
Original file line number Diff line number Diff line change
Expand Up @@ -5,22 +5,22 @@
test('extracts the average color', function () {
$provider = $this->app->make(AverageColor::class);

[$content, $expected] = $this->getTestFileData('test.jpg');
['hash' => $hash, 'uri' => $uri] = $expected[$provider::$handle];
$content = $this->getTestFileContents('test.jpg');
$hash = $provider->encode($content);

expect($hash)->toBeString()->not->toBeEmpty();
expect($provider->encode($content))->toBe($hash);
expect($hash)->toMatchTextSnapshot();
});

test('creates a data uri', function () {
$provider = $this->app->make(AverageColor::class);

[$content, $expected] = $this->getTestFileData('test.jpg');
['hash' => $hash, 'uri' => $uri] = $expected[$provider::$handle];
$content = $this->getTestFileContents('test.jpg');
$hash = $provider->encode($content);
$uri = $provider->decode($hash);

expect($hash)->toBeString()->not->toBeEmpty();
expect($uri)->toBeString()->not->toBeEmpty();
expect($provider->decode($hash))->toEqual($uri);
expect($uri)->toMatchTextSnapshot();
});

test('generates a thumb and calculates average', function () {
Expand Down
14 changes: 7 additions & 7 deletions tests/Feature/PlaceholderProviderBlurHashTest.php
Original file line number Diff line number Diff line change
Expand Up @@ -5,22 +5,22 @@
test('creates a blurhash', function () {
$provider = $this->app->make(BlurHash::class);

[$content, $expected] = $this->getTestFileData('test.jpg');
['hash' => $hash, 'uri' => $uri] = $expected[$provider::$handle];
$content = $this->getTestFileContents('test.jpg');
$hash = $provider->encode($content);

expect($hash)->toBeString()->not->toBeEmpty();
expect($provider->encode($content))->toBe($hash);
expect($hash)->toMatchTextSnapshot();
});

test('creates a data uri', function () {
$provider = $this->app->make(BlurHash::class);

[$content, $expected] = $this->getTestFileData('test.jpg');
['hash' => $hash, 'uri' => $uri] = $expected[$provider::$handle];
$content = $this->getTestFileContents('test.jpg');
$hash = $provider->encode($content);
$uri = $provider->decode($hash);

expect($hash)->toBeString()->not->toBeEmpty();
expect($uri)->toBeString()->not->toBeEmpty();
expect($provider->decode($hash))->toEqual($uri);
expect($uri)->toMatchTextSnapshot();
});

test('generates a thumb and extracts pixels', function () {
Expand Down
14 changes: 7 additions & 7 deletions tests/Feature/PlaceholderProviderThumbhashTest.php
Original file line number Diff line number Diff line change
Expand Up @@ -5,22 +5,22 @@
test('creates a thumbhash', function () {
$provider = $this->app->make(ThumbHash::class);

[$content, $expected] = $this->getTestFileData('test.jpg');
['hash' => $hash, 'uri' => $uri] = $expected[$provider::$handle];
$content = $this->getTestFileContents('test.jpg');
$hash = $provider->encode($content);

expect($hash)->toBeString()->not->toBeEmpty();
expect($provider->encode($content))->toBe($hash);
expect($hash)->toMatchTextSnapshot();
});

test('creates a data uri', function () {
$provider = $this->app->make(ThumbHash::class);

[$content, $expected] = $this->getTestFileData('test.jpg');
['hash' => $hash, 'uri' => $uri] = $expected[$provider::$handle];
$content = $this->getTestFileContents('test.jpg');
$hash = $provider->encode($content);
$uri = $provider->decode($hash);

expect($hash)->toBeString()->not->toBeEmpty();
expect($uri)->toBeString()->not->toBeEmpty();
expect($provider->decode($hash))->toEqual($uri);
expect($uri)->toMatchTextSnapshot();
});

test('generates a thumb and extracts pixels', function () {
Expand Down
12 changes: 5 additions & 7 deletions tests/Feature/PlaceholderTagTest.php
Original file line number Diff line number Diff line change
Expand Up @@ -20,38 +20,36 @@

test('renders uri', function () {
$uri = $this->tag->uri();

expect($uri)->toBeString()->toContain('data:image/');
$this->assertMatchesSnapshot($uri);
expect($uri)->toMatchTextSnapshot();

$index = $this->tag->index();
expect($index)->toBe($uri);
});

test('renders hash', function () {
$hash = $this->tag->hash();

expect($hash)->toBeString();
$this->assertMatchesSnapshot($hash);
expect($hash)->toMatchTextSnapshot();
});

test('renders img', function () {
$img = $this->tag->img();

expect($img)->toBeString()->toContain('<img src="data:image/');
$this->assertMatchesSnapshot($img);
expect($img)->toMatchTextSnapshot();
});

test('renders img attributes', function () {
$img = $this->tag->setParameters(['data-lazyload' => 'yes'])->img();

expect($img)->toBeString()->toContain('<img src="data:image/')->toContain('data-lazyload="yes"');
$this->assertMatchesSnapshot($img);
expect($img)->toMatchTextSnapshot();
});

test('returns available data', function () {
$data = $this->tag->data();

expect($data)->toBeArray()->toHaveKeys(['uri', 'hash', 'type', 'exists']);
$this->assertMatchesObjectSnapshot($data);
expect($data)->toMatchObjectSnapshot();
});
2 changes: 0 additions & 2 deletions tests/TestCase.php
Original file line number Diff line number Diff line change
Expand Up @@ -9,15 +9,13 @@
use Statamic\Providers\StatamicServiceProvider;
use Statamic\Statamic;
use Tests\Concerns\DealsWithAssets;
use Tests\Concerns\HandlesSnapshots;
use Tests\Concerns\PreventSavingStacheItemsToDisk;
use Tests\Concerns\ResolvesStatamicConfig;
use Wilderborn\Partyline\ServiceProvider as PartyLineServiceProvider;

abstract class TestCase extends OrchestraTestCase
{
use DealsWithAssets;
use HandlesSnapshots;
use InteractsWithViews;
use PreventSavingStacheItemsToDisk;
use ResolvesStatamicConfig;
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@

Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
#8e8a8501
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
LFJH,TkLo*{-B;kYO#Q;~nrgD,G8
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@

Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
IggKFoTXibiHZ3mPdoaGeniYD2E9B4c
1 change: 1 addition & 0 deletions tests/__snapshots__/PlaceholderTagTest__renders_uri__1.txt
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@

Loading

0 comments on commit a77d70c

Please sign in to comment.