From 37ab60d81b92318c1aaddc5a6d79524d38a3cc58 Mon Sep 17 00:00:00 2001 From: Joby Elliott Date: Mon, 11 Sep 2023 03:28:59 +0000 Subject: [PATCH] started working on 0.2 overhaul --- .atoum.php | 30 --- .devcontainer/Dockerfile | 19 ++ .devcontainer/devcontainer.json | 37 ++++ .travis.yml | 9 - README.md | 19 +- composer.json | 8 +- examples/imagick-cli.php | 4 +- src/DefaultDriver.php | 25 +++ src/DriverInterface.php | 22 ++- ...actCLIDriver.php => AbstractCliDriver.php} | 2 +- src/Drivers/AbstractDriver.php | 29 ++- src/Drivers/GDDriver.php | 5 +- ...agickCLIDriver.php => MagickCliDriver.php} | 12 +- src/Image.php | 44 +++-- src/Sizers/Original.php | 3 + tests/{units => }/100x200.jpg | Bin tests/{units => }/200x100.jpg | Bin tests/{units => }/200x200.jpg | Bin tests/units/Drivers/ImagickCLIDriver.php | 0 tests/units/Sizers/Cover.php | 173 ------------------ tests/units/Sizers/Fit.php | 173 ------------------ tests/units/Sizers/Original.php | 36 ---- tests/units/mock/MockDriver.php | 14 -- 23 files changed, 169 insertions(+), 495 deletions(-) delete mode 100644 .atoum.php create mode 100644 .devcontainer/Dockerfile create mode 100644 .devcontainer/devcontainer.json delete mode 100644 .travis.yml create mode 100644 src/DefaultDriver.php rename src/Drivers/{AbstractCLIDriver.php => AbstractCliDriver.php} (86%) rename src/Drivers/{ImagickCLIDriver.php => MagickCliDriver.php} (84%) rename tests/{units => }/100x200.jpg (100%) rename tests/{units => }/200x100.jpg (100%) rename tests/{units => }/200x200.jpg (100%) delete mode 100644 tests/units/Drivers/ImagickCLIDriver.php delete mode 100644 tests/units/Sizers/Cover.php delete mode 100644 tests/units/Sizers/Fit.php delete mode 100644 tests/units/Sizers/Original.php delete mode 100644 tests/units/mock/MockDriver.php diff --git a/.atoum.php b/.atoum.php deleted file mode 100644 index 3d84643..0000000 --- a/.atoum.php +++ /dev/null @@ -1,30 +0,0 @@ -addTestsFromDirectory(__DIR__ . '/tests/units'); - -$runner->getScore()->getCoverage()->excludeDirectory(__DIR__ . '/tests/units/mock'); - -$travis = getenv('TRAVIS'); -if ($travis) { - $script->addDefaultReport(); - $coverallsToken = getenv('COVERALLS_REPO_TOKEN'); - if ($coverallsToken) { - $coverallsReport = new reports\asynchronous\coveralls('classes', $coverallsToken); - $defaultFinder = $coverallsReport->getBranchFinder(); - $coverallsReport - ->setBranchFinder(function () use ($defaultFinder) { - if (($branch = getenv('TRAVIS_BRANCH')) === false) { - $branch = $defaultFinder(); - } - return $branch; - } - ) - ->setServiceName('travis-ci') - ->setServiceJobId(getenv('TRAVIS_JOB_ID')) - ->addDefaultWriter() - ; - $runner->addReport($coverallsReport); - } -} diff --git a/.devcontainer/Dockerfile b/.devcontainer/Dockerfile new file mode 100644 index 0000000..6e704d2 --- /dev/null +++ b/.devcontainer/Dockerfile @@ -0,0 +1,19 @@ +FROM ubuntu:22.04 + +# prepare to install php 8.2 +RUN apt update && apt install -y software-properties-common +RUN add-apt-repository ppa:ondrej/php +RUN apt update + +# install php 8.2 and other fundamental packages +RUN export DEBIAN_FRONTEND=noninteractive; apt install -y --no-install-recommends php8.2 php-curl git openssl unzip + +# install composer and its CA certificates +COPY --from=composer:latest /usr/bin/composer /usr/local/bin/composer +COPY --from=composer:latest /etc/ssl/certs/ca-certificates.crt /etc/ssl/certs/ca-certificates.crt + +# install the PHP extensions that basically all PHP projects should need +RUN export DEBIAN_FRONTEND=noninteractive; apt install -y php8.2-opcache php-xdebug php-mbstring php-zip php-gd php-xml + +# install extensions that are more project-specific +RUN export DEBIAN_FRONTEND=noninteractive; apt install -y php-gmagick diff --git a/.devcontainer/devcontainer.json b/.devcontainer/devcontainer.json new file mode 100644 index 0000000..ea8c5b7 --- /dev/null +++ b/.devcontainer/devcontainer.json @@ -0,0 +1,37 @@ +{ + // build from dockerfile + "build": { + "dockerfile": "Dockerfile", + "context": ".." + }, + // specify run arguments + "runArgs": [ + "--dns=8.8.8.8" // for some reason DNS doesn't work right unless we explicitly name a DNS server + ], + // mount entire sites_v2 directory, so we can access global config and shared DB + "workspaceMount": "source=${localWorkspaceFolder},target=/workspace/${localWorkspaceFolderBasename},type=bind,consistency=cached", + "workspaceFolder": "/workspace/${localWorkspaceFolderBasename}", + // specify extensions that we want + "customizations": { + "vscode": { + "extensions": [ + "DEVSENSE.intelli-php-vscode", + "DEVSENSE.phptools-vscode", + "DEVSENSE.profiler-php-vscode", + "DEVSENSE.composer-php-vscode", + "SanderRonde.phpstan-vscode", + "sibiraj-s.vscode-scss-formatter", + "mrmlnc.vscode-scss", + "Gruntfuggly.todo-tree", + "redhat.vscode-yaml", + "oliversturm.fix-json", + "ecmel.vscode-html-css", + "yzhang.markdown-all-in-one", + "DavidAnson.vscode-markdownlint", + "helixquar.randomeverything", + "neilbrayfield.php-docblocker", + "ms-vscode.test-adapter-converter" + ] + } + } +} \ No newline at end of file diff --git a/.travis.yml b/.travis.yml deleted file mode 100644 index 47f4af2..0000000 --- a/.travis.yml +++ /dev/null @@ -1,9 +0,0 @@ -language: php -php: - - 7.1 - - 7.2 - - 7.3 - - 7.4 -install: - - composer install -script: composer test diff --git a/README.md b/README.md index 07d0a68..bae7426 100644 --- a/README.md +++ b/README.md @@ -1,9 +1,6 @@ # image-transform -[![Build Status](https://travis-ci.org/jobyone/image-transform.svg?branch=main)](https://travis-ci.org/jobyone/image-transform) -[![Coverage Status](https://coveralls.io/repos/github/jobyone/image-transform/badge.svg?branch=main)](https://coveralls.io/github/jobyone/image-transform?branch=main) - -A tightly-focused library for performing a very limited set of simple image transformations. This library's purpose is to eschew the standard kitchen sink approach to PHP image libraries in favor of high performance, wide driver support, and a dead simple API. +A tightly-focused library for performing a very limited set of simple image transformations. This library's purpose is to eschew the standard kitchen sink approach to PHP image libraries in favor of high performance, wider driver support, and a dead simple API. ## Current state @@ -11,12 +8,12 @@ This library is under active development, and until a 1.0 release is made you sh ### Current progress -| Driver | Rotate | Mirror | Resize | Crop | Overlay | Grayscale | Colorize | -| :--------- | :----: | :----: | :----: | :--: | :-----: | :-------: | :------: | -| GD | X | X | X | X | | | | -| Imagick | | | | | | | | -| Gmagick | | | | | | | | -| ImagickCLI | X | X | X | X | | | | +| Driver | Rotate | Mirror | Resize | Crop | +| :--------- | :----: | :----: | :----: | :--: | +| GD | X | X | X | X | +| Imagick | | | | | +| Gmagick | | | | | +| ImagickCLI | X | X | X | X | ## Roadmap @@ -57,7 +54,7 @@ More complex, and also lesser used effects/stages that may or may not make it in #### Order of operations -In the name of simplicity and ease of use, the effective order of operations will always be as reflected above: +In the name of simplicity, ease of use, and performance, the effective order of operations will always and only be: 1. Orientation 2. Resizing and cropping diff --git a/composer.json b/composer.json index bc7bee7..2d40691 100644 --- a/composer.json +++ b/composer.json @@ -15,16 +15,16 @@ } }, "suggest": { - "ext-imagick": "to use the Imagick implementation", + "ext-imagick": "to use the ImageMagick implementation", "ext-gmagick": "to use the Gmagick implementation" }, "require": { - "php": ">=7.1", + "php": ">=8.1", "ext-gd": "*" }, "require-dev": { - "atoum/atoum": "^3.4", - "atoum/stubs": "^2.6" + "ext-gmagick": "*", + "ext-gd": "*" }, "autoload-dev": { "psr-4": { diff --git a/examples/imagick-cli.php b/examples/imagick-cli.php index 11c4780..a9021d5 100644 --- a/examples/imagick-cli.php +++ b/examples/imagick-cli.php @@ -1,12 +1,12 @@ tempDir = null; - } - - public function image(string $src, AbstractSizer $sizer): Image - { - return new Image($src, $this, $sizer); - } - public function tempDir(): string { if (!$this->tempDir) { @@ -31,12 +22,13 @@ abstract class AbstractDriver implements DriverInterface return $this->tempDir; } - protected function setTempDir(string $dir) + public function setTempDir(string $dir): static { if (!$this->mkdir($dir)) { throw new \Exception("Temp directory " . htmlentities($dir) . " doesn't exist or isn't writeable, and couldn't be created."); } $this->tempDir = $dir; + return $this; } protected function mkdir(string $dir) @@ -52,7 +44,7 @@ abstract class AbstractDriver implements DriverInterface if (is_dir($parent)) { // check parent permissions if (!is_writeable($parent)) { - chmod($parent, $this->chmod); + chmod($parent, $this->chmod_dir); } if (!is_writeable($parent)) { return false; @@ -61,7 +53,7 @@ abstract class AbstractDriver implements DriverInterface if (!mkdir($dir)) { return false; } - chmod($dir, $this->chmod); + chmod($dir, $this->chmod_dir); return is_writeable($dir); } else { // parent doesn't exist, so recursive call failed @@ -83,11 +75,14 @@ abstract class AbstractDriver implements DriverInterface touch($filename); } $this->doSave($image, realpath($filename)); + chmod($filename, $this->chmod_file); return null; } else { - $filename = $this->tempDir() . '/save.jpg'; + $filename = $this->tempDir() . '/' . uniqid() . '.jpg'; $this->doSave($image, $filename); - return file_get_contents($filename); + $output = file_get_contents($filename); + unlink($filename); + return $output; } } -} +} \ No newline at end of file diff --git a/src/Drivers/GDDriver.php b/src/Drivers/GDDriver.php index 14e53e7..36bf4b3 100644 --- a/src/Drivers/GDDriver.php +++ b/src/Drivers/GDDriver.php @@ -5,8 +5,9 @@ namespace ByJoby\ImageTransform\Drivers; use ByJoby\ImageTransform\Image; /** - * This driver uses PHP's built-in GD libary. This is by far the slowest - * driver, but support is basically universal. + * This driver uses PHP's built-in GD libary. This is by far the slowest driver, + * and its memory use is absolutely atrocious for large images, but support is + * basically universal. */ class GDDriver extends AbstractExtensionDriver { diff --git a/src/Drivers/ImagickCLIDriver.php b/src/Drivers/MagickCliDriver.php similarity index 84% rename from src/Drivers/ImagickCLIDriver.php rename to src/Drivers/MagickCliDriver.php index 08f9d30..d9af730 100644 --- a/src/Drivers/ImagickCLIDriver.php +++ b/src/Drivers/MagickCliDriver.php @@ -5,13 +5,13 @@ namespace ByJoby\ImageTransform\Drivers; use ByJoby\ImageTransform\Image; /** - * This driver uses exec() and command-line ImageMagick utilities to - * transform images. It is likely approaching the limits of how fast this - * library can possibly be. The downside is that it will only run if - * you have exec() enabled, and your server allows it to execute the - * ImageMagick binaries. + * This driver uses exec() and command-line ImageMagick (or Gmagick) utilities + * to transform images. It is likely approaching the limits of how fast this + * library can possibly be. The downside is that it will only run if you have + * exec() enabled, and your server allows it to execute the ImageMagick/Gmagick + * binaries and use them to read and write image files. */ -class ImagickCLIDriver extends AbstractCLIDriver +class MagickCliDriver extends AbstractCliDriver { protected $mogrify_executable; diff --git a/src/Image.php b/src/Image.php index b8eabfd..6564b4f 100644 --- a/src/Image.php +++ b/src/Image.php @@ -3,21 +3,23 @@ namespace ByJoby\ImageTransform; use ByJoby\ImageTransform\Sizers\AbstractSizer; +use ByJoby\ImageTransform\Sizers\Original; class Image { - protected $source, $driver; - protected $originalWidth, $originalHeight; + protected $source; + protected $driver; + protected $originalWidth; + protected $originalHeight; protected $rotation = 0; protected $flipH = false; protected $flipV = false; protected $sizer = null; - public function __construct(string $source, DriverInterface $driver, AbstractSizer $sizer) + public function __construct(string $source, AbstractSizer|null $sizer = null) { $this->setSource($source); - $this->setSizer($sizer); - $this->driver = clone $driver; + $this->setSizer($sizer ?? new Original()); } public function source(): string @@ -25,7 +27,7 @@ class Image return $this->source; } - public function setSource(string $source) + public function setSource(string $source): static { // set source $this->source = realpath($source); @@ -41,6 +43,8 @@ class Image } // get height/width list($this->originalWidth, $this->originalHeight) = getimagesize($this->source); + // return self + return $this; } public function sizer(): AbstractSizer @@ -48,15 +52,17 @@ class Image return $this->sizer; } - public function setSizer(AbstractSizer $sizer) + public function setSizer(AbstractSizer $sizer): static { $this->sizer = clone $sizer; $this->sizer->image($this); + return $this; } - public function rotate(int $steps = 1) + public function rotate(int $steps = 1): static { $this->rotation = ($this->rotation + $steps) % 4; + return $this; } public function rotation(): int @@ -64,22 +70,24 @@ class Image return $this->rotation; } - public function flipH() + public function flipH(): static { $this->flipH = !$this->flipH; + return $this; } - public function flipV() + public function flipV(): static { $this->flipV = !$this->flipV; + return $this; } - public function getFlipH() + public function getFlipH(): bool { return $this->flipH; } - public function getFlipV() + public function getFlipV(): bool { return $this->flipV; } @@ -114,8 +122,14 @@ class Image return $this->originalHeight; } - public function save(string $file) + public function driver(): DriverInterface { - $this->driver->save($this, $file); + return $this->driver ?? DefaultDriver::get(); } -} + + public function save(string $file): static + { + $this->driver()->save($this, $file); + return $this; + } +} \ No newline at end of file diff --git a/src/Sizers/Original.php b/src/Sizers/Original.php index 38e2e4e..70c77bc 100644 --- a/src/Sizers/Original.php +++ b/src/Sizers/Original.php @@ -2,6 +2,9 @@ /* image-transform | https://github.com/jobyone/image-transform | MIT License */ namespace ByJoby\ImageTransform\Sizers; +/** + * This sizer does no manipulations and keeps the image the size it originally was. + */ class Original extends AbstractSizer { public function resizeToWidth(): ?int diff --git a/tests/units/100x200.jpg b/tests/100x200.jpg similarity index 100% rename from tests/units/100x200.jpg rename to tests/100x200.jpg diff --git a/tests/units/200x100.jpg b/tests/200x100.jpg similarity index 100% rename from tests/units/200x100.jpg rename to tests/200x100.jpg diff --git a/tests/units/200x200.jpg b/tests/200x200.jpg similarity index 100% rename from tests/units/200x200.jpg rename to tests/200x200.jpg diff --git a/tests/units/Drivers/ImagickCLIDriver.php b/tests/units/Drivers/ImagickCLIDriver.php deleted file mode 100644 index e69de29..0000000 diff --git a/tests/units/Sizers/Cover.php b/tests/units/Sizers/Cover.php deleted file mode 100644 index e9a8da9..0000000 --- a/tests/units/Sizers/Cover.php +++ /dev/null @@ -1,173 +0,0 @@ -given($image = $this->image(__DIR__.'/../100x200.jpg',100,150)) - ->integer($image->width())->isEqualTo(100) - ->integer($image->height())->isEqualTo(150) - ->variable($image->sizer()->resizeToWidth())->isEqualTo(100) - ->variable($image->sizer()->resizeToHeight())->isEqualTo(200) - ->variable($image->sizer()->cropToWidth())->isEqualTo(100) - ->variable($image->sizer()->cropToHeight())->isEqualTo(150) - ->given($image->rotate()) - ->integer($image->width())->isEqualTo(100) - ->integer($image->height())->isEqualTo(150) - ->variable($image->sizer()->resizeToWidth())->isEqualTo(300) - ->variable($image->sizer()->resizeToHeight())->isEqualTo(150) - ->variable($image->sizer()->cropToWidth())->isEqualTo(100) - ->variable($image->sizer()->cropToHeight())->isEqualTo(150) - ; - } - - public function testPortraitWhenImageIsShorter() - { - $this - ->given($image = $this->image(__DIR__.'/../100x200.jpg',50,300)) - ->integer($image->width())->isEqualTo(50) - ->integer($image->height())->isEqualTo(300) - ->variable($image->sizer()->resizeToWidth())->isEqualTo(150) - ->variable($image->sizer()->resizeToHeight())->isEqualTo(300) - ->variable($image->sizer()->cropToWidth())->isEqualTo(50) - ->variable($image->sizer()->cropToHeight())->isEqualTo(300) - ->given($image->rotate()) - ->integer($image->width())->isEqualTo(50) - ->integer($image->height())->isEqualTo(300) - ->variable($image->sizer()->resizeToWidth())->isEqualTo(600) - ->variable($image->sizer()->resizeToHeight())->isEqualTo(300) - ->variable($image->sizer()->cropToWidth())->isEqualTo(50) - ->variable($image->sizer()->cropToHeight())->isEqualTo(300) - ; - } - - public function testPortraitWithSquareImage() - { - $this - ->given($image = $this->image(__DIR__.'/../200x200.jpg',75,300)) - ->integer($image->width())->isEqualTo(75) - ->integer($image->height())->isEqualTo(300) - ->variable($image->sizer()->resizeToWidth())->isEqualTo(300) - ->variable($image->sizer()->resizeToHeight())->isEqualTo(300) - ->variable($image->sizer()->cropToWidth())->isEqualTo(75) - ->variable($image->sizer()->cropToHeight())->isEqualTo(300) - ; - } - - public function testPortraitWithLandscapeImage() - { - $this - ->given($image = $this->image(__DIR__.'/../200x100.jpg',100,200)) - ->integer($image->width())->isEqualTo(100) - ->integer($image->height())->isEqualTo(200) - ->variable($image->sizer()->resizeToWidth())->isEqualTo(400) - ->variable($image->sizer()->resizeToHeight())->isEqualTo(200) - ->variable($image->sizer()->cropToWidth())->isEqualTo(100) - ->variable($image->sizer()->cropToHeight())->isEqualTo(200) - ; - } - - public function testLandscapeWhenImageIsTaller() - { - $this - ->given($image = $this->image(__DIR__.'/../200x100.jpg',150,100)) - ->integer($image->width())->isEqualTo(150) - ->integer($image->height())->isEqualTo(100) - ->variable($image->sizer()->resizeToWidth())->isEqualTo(200) - ->variable($image->sizer()->resizeToHeight())->isEqualTo(100) - ->variable($image->sizer()->cropToWidth())->isEqualTo(150) - ->variable($image->sizer()->cropToHeight())->isEqualTo(100) - ; - } - - public function testLandscapeWhenImageIsShorter() - { - $this - ->given($image = $this->image(__DIR__.'/../200x100.jpg',300,75)) - ->integer($image->width())->isEqualTo(300) - ->integer($image->height())->isEqualTo(75) - ->variable($image->sizer()->resizeToWidth())->isEqualTo(300) - ->variable($image->sizer()->resizeToHeight())->isEqualTo(150) - ->variable($image->sizer()->cropToWidth())->isEqualTo(300) - ->variable($image->sizer()->cropToHeight())->isEqualTo(75) - ; - } - - public function testLandscapeWithSquareImage() - { - $this - ->given($image = $this->image(__DIR__.'/../200x200.jpg',300,75)) - ->integer($image->width())->isEqualTo(300) - ->integer($image->height())->isEqualTo(75) - ->variable($image->sizer()->resizeToWidth())->isEqualTo(300) - ->variable($image->sizer()->resizeToHeight())->isEqualTo(300) - ->variable($image->sizer()->cropToWidth())->isEqualTo(300) - ->variable($image->sizer()->cropToHeight())->isEqualTo(75) - ; - } - - public function testLandscapeWithPortraitImage() - { - $this - ->given($image = $this->image(__DIR__.'/../100x200.jpg',200,100)) - ->integer($image->width())->isEqualTo(200) - ->integer($image->height())->isEqualTo(100) - ->variable($image->sizer()->resizeToWidth())->isEqualTo(200) - ->variable($image->sizer()->resizeToHeight())->isEqualTo(400) - ->variable($image->sizer()->cropToWidth())->isEqualTo(200) - ->variable($image->sizer()->cropToHeight())->isEqualTo(100) - ; - } - - public function testWithSmallSquareImage() - { - $this - ->given($image = $this->image(__DIR__.'/../200x200.jpg',300,300)) - ->integer($image->width())->isEqualTo(300) - ->integer($image->height())->isEqualTo(300) - ->variable($image->sizer()->resizeToWidth())->isEqualTo(300) - ->variable($image->sizer()->resizeToHeight())->isEqualTo(300) - ->variable($image->sizer()->cropToWidth())->isEqualTo(300) - ->variable($image->sizer()->cropToHeight())->isEqualTo(300) - ; - } - - public function testWithSmallLandscapeImage() - { - $this - ->given($image = $this->image(__DIR__.'/../200x100.jpg',300,300)) - ->integer($image->width())->isEqualTo(300) - ->integer($image->height())->isEqualTo(300) - ->variable($image->sizer()->resizeToWidth())->isEqualTo(600) - ->variable($image->sizer()->resizeToHeight())->isEqualTo(300) - ->variable($image->sizer()->cropToWidth())->isEqualTo(300) - ->variable($image->sizer()->cropToHeight())->isEqualTo(300) - ; - } - - public function testWithSmallPortraitImage() - { - $this - ->given($image = $this->image(__DIR__.'/../100x200.jpg',300,300)) - ->integer($image->width())->isEqualTo(300) - ->integer($image->height())->isEqualTo(300) - ->variable($image->sizer()->resizeToWidth())->isEqualTo(300) - ->variable($image->sizer()->resizeToHeight())->isEqualTo(600) - ->variable($image->sizer()->cropToWidth())->isEqualTo(300) - ->variable($image->sizer()->cropToHeight())->isEqualTo(300) - ; - } - - protected function image(string $path, int $width, int $height) - { - $driver = new MockDriver(); - return $driver->image($path, new SizerUnderTest($width, $height)); - } -} diff --git a/tests/units/Sizers/Fit.php b/tests/units/Sizers/Fit.php deleted file mode 100644 index d8f9865..0000000 --- a/tests/units/Sizers/Fit.php +++ /dev/null @@ -1,173 +0,0 @@ -given($image = $this->image(__DIR__.'/../100x200.jpg',100,150)) - ->integer($image->width())->isEqualTo(75) - ->integer($image->height())->isEqualTo(150) - ->variable($image->sizer()->resizeToWidth())->isEqualTo(75) - ->variable($image->sizer()->resizeToHeight())->isEqualTo(150) - ->variable($image->sizer()->cropToWidth())->isNull() - ->variable($image->sizer()->cropToHeight())->isNull() - ->given($image->rotate()) - ->integer($image->width())->isEqualTo(100) - ->integer($image->height())->isEqualTo(50) - ->variable($image->sizer()->resizeToWidth())->isEqualTo(100) - ->variable($image->sizer()->resizeToHeight())->isEqualTo(50) - ->variable($image->sizer()->cropToWidth())->isNull() - ->variable($image->sizer()->cropToHeight())->isNull() - ; - } - - public function testPortraitWhenImageIsShorter() - { - $this - ->given($image = $this->image(__DIR__.'/../100x200.jpg',50,300)) - ->integer($image->width())->isEqualTo(50) - ->integer($image->height())->isEqualTo(100) - ->variable($image->sizer()->resizeToWidth())->isEqualTo(50) - ->variable($image->sizer()->resizeToHeight())->isEqualTo(100) - ->variable($image->sizer()->cropToWidth())->isNull() - ->variable($image->sizer()->cropToHeight())->isNull() - ->given($image->rotate()) - ->integer($image->width())->isEqualTo(50) - ->integer($image->height())->isEqualTo(25) - ->variable($image->sizer()->resizeToWidth())->isEqualTo(50) - ->variable($image->sizer()->resizeToHeight())->isEqualTo(25) - ->variable($image->sizer()->cropToWidth())->isNull() - ->variable($image->sizer()->cropToHeight())->isNull() - ; - } - - public function testPortraitWithSquareImage() - { - $this - ->given($image = $this->image(__DIR__.'/../200x200.jpg',75,300)) - ->integer($image->width())->isEqualTo(75) - ->integer($image->height())->isEqualTo(75) - ->variable($image->sizer()->resizeToWidth())->isEqualTo(75) - ->variable($image->sizer()->resizeToHeight())->isEqualTo(75) - ->variable($image->sizer()->cropToWidth())->isNull() - ->variable($image->sizer()->cropToHeight())->isNull() - ; - } - - public function testPortraitWithLandscapeImage() - { - $this - ->given($image = $this->image(__DIR__.'/../200x100.jpg',100,200)) - ->integer($image->width())->isEqualTo(100) - ->integer($image->height())->isEqualTo(50) - ->variable($image->sizer()->resizeToWidth())->isEqualTo(100) - ->variable($image->sizer()->resizeToHeight())->isEqualTo(50) - ->variable($image->sizer()->cropToWidth())->isNull() - ->variable($image->sizer()->cropToHeight())->isNull() - ; - } - - public function testLandscapeWhenImageIsTaller() - { - $this - ->given($image = $this->image(__DIR__.'/../200x100.jpg',150,100)) - ->integer($image->width())->isEqualTo(150) - ->integer($image->height())->isEqualTo(75) - ->variable($image->sizer()->resizeToWidth())->isEqualTo(150) - ->variable($image->sizer()->resizeToHeight())->isEqualTo(75) - ->variable($image->sizer()->cropToWidth())->isNull() - ->variable($image->sizer()->cropToHeight())->isNull() - ; - } - - public function testLandscapeWhenImageIsShorter() - { - $this - ->given($image = $this->image(__DIR__.'/../200x100.jpg',300,75)) - ->integer($image->width())->isEqualTo(150) - ->integer($image->height())->isEqualTo(75) - ->variable($image->sizer()->resizeToWidth())->isEqualTo(150) - ->variable($image->sizer()->resizeToHeight())->isEqualTo(75) - ->variable($image->sizer()->cropToWidth())->isNull() - ->variable($image->sizer()->cropToHeight())->isNull() - ; - } - - public function testLandscapeWithSquareImage() - { - $this - ->given($image = $this->image(__DIR__.'/../200x200.jpg',300,75)) - ->integer($image->width())->isEqualTo(75) - ->integer($image->height())->isEqualTo(75) - ->variable($image->sizer()->resizeToWidth())->isEqualTo(75) - ->variable($image->sizer()->resizeToHeight())->isEqualTo(75) - ->variable($image->sizer()->cropToWidth())->isNull() - ->variable($image->sizer()->cropToHeight())->isNull() - ; - } - - public function testLandscapeWithPortraitImage() - { - $this - ->given($image = $this->image(__DIR__.'/../100x200.jpg',200,100)) - ->integer($image->width())->isEqualTo(50) - ->integer($image->height())->isEqualTo(100) - ->variable($image->sizer()->resizeToWidth())->isEqualTo(50) - ->variable($image->sizer()->resizeToHeight())->isEqualTo(100) - ->variable($image->sizer()->cropToWidth())->isNull() - ->variable($image->sizer()->cropToHeight())->isNull() - ; - } - - public function testWithSmallSquareImage() - { - $this - ->given($image = $this->image(__DIR__.'/../200x200.jpg',300,300)) - ->integer($image->width())->isEqualTo(300) - ->integer($image->height())->isEqualTo(300) - ->variable($image->sizer()->resizeToWidth())->isEqualTo(300) - ->variable($image->sizer()->resizeToHeight())->isEqualTo(300) - ->variable($image->sizer()->cropToWidth())->isNull() - ->variable($image->sizer()->cropToHeight())->isNull() - ; - } - - public function testWithSmallLandscapeImage() - { - $this - ->given($image = $this->image(__DIR__.'/../200x100.jpg',300,300)) - ->integer($image->width())->isEqualTo(300) - ->integer($image->height())->isEqualTo(150) - ->variable($image->sizer()->resizeToWidth())->isEqualTo(300) - ->variable($image->sizer()->resizeToHeight())->isEqualTo(150) - ->variable($image->sizer()->cropToWidth())->isNull() - ->variable($image->sizer()->cropToHeight())->isNull() - ; - } - - public function testWithSmallPortraitImage() - { - $this - ->given($image = $this->image(__DIR__.'/../100x200.jpg',300,300)) - ->integer($image->width())->isEqualTo(150) - ->integer($image->height())->isEqualTo(300) - ->variable($image->sizer()->resizeToWidth())->isEqualTo(150) - ->variable($image->sizer()->resizeToHeight())->isEqualTo(300) - ->variable($image->sizer()->cropToWidth())->isNull() - ->variable($image->sizer()->cropToHeight())->isNull() - ; - } - - protected function image(string $path, int $width, int $height) - { - $driver = new MockDriver(); - return $driver->image($path, new SizerUnderTest($width, $height)); - } -} diff --git a/tests/units/Sizers/Original.php b/tests/units/Sizers/Original.php deleted file mode 100644 index a333368..0000000 --- a/tests/units/Sizers/Original.php +++ /dev/null @@ -1,36 +0,0 @@ -given($image = $this->image(__DIR__.'/../100x200.jpg')) - ->integer($image->width())->isEqualTo(100) - ->integer($image->height())->isEqualTo(200) - ->variable($image->sizer()->resizeToWidth())->isNull() - ->variable($image->sizer()->resizeToHeight())->isNull() - ->variable($image->sizer()->cropToWidth())->isNull() - ->variable($image->sizer()->cropToHeight())->isNull() - ->given($image->rotate()) - ->integer($image->width())->isEqualTo(200) - ->integer($image->height())->isEqualTo(100) - ->variable($image->sizer()->resizeToWidth())->isNull() - ->variable($image->sizer()->resizeToHeight())->isNull() - ->variable($image->sizer()->cropToWidth())->isNull() - ->variable($image->sizer()->cropToHeight())->isNull() - ; - } - - protected function image(string $path) - { - $driver = new MockDriver(); - return $driver->image($path, new SizerUnderTest()); - } -} diff --git a/tests/units/mock/MockDriver.php b/tests/units/mock/MockDriver.php deleted file mode 100644 index fb55806..0000000 --- a/tests/units/mock/MockDriver.php +++ /dev/null @@ -1,14 +0,0 @@ -