diff options
Diffstat (limited to 'vendor/chillerlan/php-qrcode/tests/Data')
-rw-r--r-- | vendor/chillerlan/php-qrcode/tests/Data/AlphaNumTest.php | 29 | ||||
-rw-r--r-- | vendor/chillerlan/php-qrcode/tests/Data/ByteTest.php | 22 | ||||
-rw-r--r-- | vendor/chillerlan/php-qrcode/tests/Data/DatainterfaceTestAbstract.php | 110 | ||||
-rw-r--r-- | vendor/chillerlan/php-qrcode/tests/Data/KanjiTest.php | 35 | ||||
-rw-r--r-- | vendor/chillerlan/php-qrcode/tests/Data/MaskPatternTesterTest.php | 29 | ||||
-rw-r--r-- | vendor/chillerlan/php-qrcode/tests/Data/NumberTest.php | 29 | ||||
-rwxr-xr-x[-rw-r--r--] | vendor/chillerlan/php-qrcode/tests/Data/QRMatrixTest.php | 281 |
7 files changed, 398 insertions, 137 deletions
diff --git a/vendor/chillerlan/php-qrcode/tests/Data/AlphaNumTest.php b/vendor/chillerlan/php-qrcode/tests/Data/AlphaNumTest.php index c29b1f639..10847633c 100644 --- a/vendor/chillerlan/php-qrcode/tests/Data/AlphaNumTest.php +++ b/vendor/chillerlan/php-qrcode/tests/Data/AlphaNumTest.php @@ -12,13 +12,19 @@ namespace chillerlan\QRCodeTest\Data; -use chillerlan\QRCode\Data\{AlphaNum, QRCodeDataException}; +use chillerlan\QRCode\Data\{AlphaNum, QRCodeDataException, QRDataInterface}; +use chillerlan\QRCode\QROptions; -class AlphaNumTest extends DatainterfaceTestAbstract{ +/** + * Tests the AlphaNum class + */ +final class AlphaNumTest extends DatainterfaceTestAbstract{ + + /** @internal */ + protected string $testdata = '0 $%*+-./:'; - protected $FQCN = AlphaNum::class; - protected $testdata = '0 $%*+-./:'; - protected $expected = [ + /** @internal */ + protected array $expected = [ 32, 80, 36, 212, 252, 15, 175, 251, 176, 236, 17, 236, 17, 236, 17, 236, 17, 236, 17, 236, 17, 236, 17, 236, @@ -34,7 +40,18 @@ class AlphaNumTest extends DatainterfaceTestAbstract{ 92, 112, 20, 198, 27 ]; - public function testGetCharCodeException(){ + /** + * @inheritDoc + * @internal + */ + protected function getDataInterfaceInstance(QROptions $options):QRDataInterface{ + return new AlphaNum($options); + } + + /** + * Tests if an exception is thrown when an invalid character is encountered + */ + public function testGetCharCodeException():void{ $this->expectException(QRCodeDataException::class); $this->expectExceptionMessage('illegal char: "#" [35]'); diff --git a/vendor/chillerlan/php-qrcode/tests/Data/ByteTest.php b/vendor/chillerlan/php-qrcode/tests/Data/ByteTest.php index cbfe1fab2..295603200 100644 --- a/vendor/chillerlan/php-qrcode/tests/Data/ByteTest.php +++ b/vendor/chillerlan/php-qrcode/tests/Data/ByteTest.php @@ -13,12 +13,19 @@ namespace chillerlan\QRCodeTest\Data; use chillerlan\QRCode\Data\Byte; +use chillerlan\QRCode\Data\QRDataInterface; +use chillerlan\QRCode\QROptions; -class ByteTest extends DatainterfaceTestAbstract{ +/** + * Tests the Byte class + */ +final class ByteTest extends DatainterfaceTestAbstract{ + + /** @internal */ + protected string $testdata = '[¯\_(ツ)_/¯]'; - protected $FQCN = Byte::class; - protected $testdata = '[¯\_(ツ)_/¯]'; - protected $expected = [ + /** @internal */ + protected array $expected = [ 64, 245, 188, 42, 245, 197, 242, 142, 56, 56, 66, 149, 242, 252, 42, 245, 208, 236, 17, 236, 17, 236, 17, 236, @@ -34,5 +41,12 @@ class ByteTest extends DatainterfaceTestAbstract{ 21, 47, 250, 101 ]; + /** + * @inheritDoc + * @internal + */ + protected function getDataInterfaceInstance(QROptions $options):QRDataInterface{ + return new Byte($options); + } } diff --git a/vendor/chillerlan/php-qrcode/tests/Data/DatainterfaceTestAbstract.php b/vendor/chillerlan/php-qrcode/tests/Data/DatainterfaceTestAbstract.php index 19d74617a..d533c3f17 100644 --- a/vendor/chillerlan/php-qrcode/tests/Data/DatainterfaceTestAbstract.php +++ b/vendor/chillerlan/php-qrcode/tests/Data/DatainterfaceTestAbstract.php @@ -12,54 +12,116 @@ namespace chillerlan\QRCodeTest\Data; +use chillerlan\QRCode\QRCode; use chillerlan\QRCode\QROptions; +use PHPUnit\Framework\TestCase; use chillerlan\QRCode\Data\{QRCodeDataException, QRDataInterface, QRMatrix}; -use chillerlan\QRCodeTest\QRTestAbstract; +use ReflectionClass; -abstract class DatainterfaceTestAbstract extends QRTestAbstract{ +use function str_repeat; - /** - * @var \chillerlan\QRCode\Data\QRDataAbstract - */ - protected $dataInterface; +/** + * The data interface test abstract + */ +abstract class DatainterfaceTestAbstract extends TestCase{ - protected $testdata; - protected $expected; + /** @internal */ + protected ReflectionClass $reflection; + /** @internal */ + protected QRDataInterface $dataInterface; + /** @internal */ + protected string $testdata; + /** @internal */ + protected array $expected; + /** + * @internal + */ protected function setUp():void{ - parent::setUp(); - - $this->dataInterface = $this->reflection->newInstanceArgs([new QROptions(['version' => 4])]); + $this->dataInterface = $this->getDataInterfaceInstance(new QROptions(['version' => 4])); + $this->reflection = new ReflectionClass($this->dataInterface); } - public function testInstance(){ - $this->dataInterface = $this->reflection->newInstanceArgs([new QROptions, $this->testdata]); + /** + * Returns a data interface instance + * + * @internal + */ + abstract protected function getDataInterfaceInstance(QROptions $options):QRDataInterface; - $this->assertInstanceOf(QRDataInterface::class, $this->dataInterface); + /** + * Verifies the data interface instance + */ + public function testInstance():void{ + $this::assertInstanceOf(QRDataInterface::class, $this->dataInterface); } - public function testSetData(){ + /** + * Tests ecc masking and verifies against a sample + */ + public function testMaskEcc():void{ $this->dataInterface->setData($this->testdata); - $this->assertSame($this->expected, $this->getProperty('matrixdata')->getValue($this->dataInterface)); + $maskECC = $this->reflection->getMethod('maskECC'); + $maskECC->setAccessible(true); + + $this::assertSame($this->expected, $maskECC->invoke($this->dataInterface)); } - public function testInitMatrix(){ - $m = $this->dataInterface->setData($this->testdata)->initMatrix(0); + /** + * @see testInitMatrix() + * @internal + * @return int[][] + */ + public function MaskPatternProvider():array{ + return [[0], [1], [2], [3], [4], [5], [6], [7]]; + } - $this->assertInstanceOf(QRMatrix::class, $m); + /** + * Tests initializing the data matrix + * + * @dataProvider MaskPatternProvider + */ + public function testInitMatrix(int $maskPattern):void{ + $this->dataInterface->setData($this->testdata); + + $matrix = $this->dataInterface->initMatrix($maskPattern); + + $this::assertInstanceOf(QRMatrix::class, $matrix); + $this::assertSame($maskPattern, $matrix->maskPattern()); } - public function testGetMinimumVersion(){ - $this->assertSame(1, $this->getMethod('getMinimumVersion')->invoke($this->dataInterface)); + /** + * Tests getting the minimum QR version for the given data + */ + public function testGetMinimumVersion():void{ + $this->dataInterface->setData($this->testdata); + + $getMinimumVersion = $this->reflection->getMethod('getMinimumVersion'); + $getMinimumVersion->setAccessible(true); + + $this::assertSame(1, $getMinimumVersion->invoke($this->dataInterface)); } - public function testGetMinimumVersionException(){ + /** + * Tests if an exception is thrown when the data exceeds the maximum version while auto detecting + */ + public function testGetMinimumVersionException():void{ $this->expectException(QRCodeDataException::class); $this->expectExceptionMessage('data exceeds'); - $this->getProperty('strlen')->setValue($this->dataInterface, 13370); - $this->getMethod('getMinimumVersion')->invoke($this->dataInterface); + $this->dataInterface = $this->getDataInterfaceInstance(new QROptions(['version' => QRCode::VERSION_AUTO])); + $this->dataInterface->setData(str_repeat($this->testdata, 1337)); + } + + /** + * Tests if an exception is thrown on data overflow + */ + public function testCodeLengthOverflowException():void{ + $this->expectException(QRCodeDataException::class); + $this->expectExceptionMessage('code length overflow'); + + $this->dataInterface->setData(str_repeat($this->testdata, 1337)); } } diff --git a/vendor/chillerlan/php-qrcode/tests/Data/KanjiTest.php b/vendor/chillerlan/php-qrcode/tests/Data/KanjiTest.php index 108b8fed7..484f388dc 100644 --- a/vendor/chillerlan/php-qrcode/tests/Data/KanjiTest.php +++ b/vendor/chillerlan/php-qrcode/tests/Data/KanjiTest.php @@ -12,13 +12,19 @@ namespace chillerlan\QRCodeTest\Data; -use chillerlan\QRCode\Data\{Kanji, QRCodeDataException}; +use chillerlan\QRCode\QROptions; +use chillerlan\QRCode\Data\{Kanji, QRCodeDataException, QRDataInterface}; -class KanjiTest extends DatainterfaceTestAbstract{ +/** + * Tests the Kanji class + */ +final class KanjiTest extends DatainterfaceTestAbstract{ + + /** @internal */ + protected string $testdata = '茗荷茗荷茗荷茗荷茗荷'; - protected $FQCN = Kanji::class; - protected $testdata = '茗荷茗荷茗荷茗荷茗荷'; - protected $expected = [ + /** @internal */ + protected array $expected = [ 128, 173, 85, 26, 95, 85, 70, 151, 213, 81, 165, 245, 84, 105, 125, 85, 26, 92, 0, 236, 17, 236, 17, 236, @@ -34,17 +40,32 @@ class KanjiTest extends DatainterfaceTestAbstract{ 96, 113, 54, 191 ]; - public function testIllegalCharException1(){ + /** + * @inheritDoc + * @internal + */ + protected function getDataInterfaceInstance(QROptions $options):QRDataInterface{ + return new Kanji($options); + } + + /** + * Tests if an exception is thrown when an invalid character is encountered + */ + public function testIllegalCharException1():void{ $this->expectException(QRCodeDataException::class); $this->expectExceptionMessage('illegal char at 1 [16191]'); $this->dataInterface->setData('ÃÃ'); } - public function testIllegalCharException2(){ + /** + * Tests if an exception is thrown when an invalid character is encountered + */ + public function testIllegalCharException2():void{ $this->expectException(QRCodeDataException::class); $this->expectExceptionMessage('illegal char at 1'); $this->dataInterface->setData('Ã'); } + } diff --git a/vendor/chillerlan/php-qrcode/tests/Data/MaskPatternTesterTest.php b/vendor/chillerlan/php-qrcode/tests/Data/MaskPatternTesterTest.php index ae4af9f29..d286b41dc 100644 --- a/vendor/chillerlan/php-qrcode/tests/Data/MaskPatternTesterTest.php +++ b/vendor/chillerlan/php-qrcode/tests/Data/MaskPatternTesterTest.php @@ -12,18 +12,31 @@ namespace chillerlan\QRCodeTest\Data; -use chillerlan\QRCode\{QROptions, Data\Byte, Data\MaskPatternTester}; -use chillerlan\QRCodeTest\QRTestAbstract; +use chillerlan\QRCode\QROptions; +use chillerlan\QRCode\Data\{Byte, MaskPatternTester}; +use PHPUnit\Framework\TestCase; -class MaskPatternTesterTest extends QRTestAbstract{ +/** + * MaskPatternTester coverage test + */ +final class MaskPatternTesterTest extends TestCase{ - protected $FQCN = MaskPatternTester::class; + /** + * Tests getting the best mask pattern + */ + public function testMaskpattern():void{ + $dataInterface = new Byte(new QROptions(['version' => 10]), 'test'); + + $this::assertSame(3, (new MaskPatternTester($dataInterface))->getBestMaskPattern()); + } - // coverage - public function testMaskpattern(){ - $matrix = (new Byte(new QROptions(['version' => 10]), 'test'))->initMatrix(3, true); + /** + * Tests getting the penalty value for a given mask pattern + */ + public function testMaskpatternID():void{ + $dataInterface = new Byte(new QROptions(['version' => 10]), 'test'); - $this->assertSame(4243, (new MaskPatternTester($matrix))->testPattern()); + $this::assertSame(4243, (new MaskPatternTester($dataInterface))->testPattern(3)); } } diff --git a/vendor/chillerlan/php-qrcode/tests/Data/NumberTest.php b/vendor/chillerlan/php-qrcode/tests/Data/NumberTest.php index 983346a34..dcd9507ab 100644 --- a/vendor/chillerlan/php-qrcode/tests/Data/NumberTest.php +++ b/vendor/chillerlan/php-qrcode/tests/Data/NumberTest.php @@ -12,13 +12,19 @@ namespace chillerlan\QRCodeTest\Data; -use chillerlan\QRCode\Data\{Number, QRCodeDataException}; +use chillerlan\QRCode\QROptions; +use chillerlan\QRCode\Data\{Number, QRCodeDataException, QRDataInterface}; -class NumberTest extends DatainterfaceTestAbstract{ +/** + * Tests the Number class + */ +final class NumberTest extends DatainterfaceTestAbstract{ + + /** @internal */ + protected string $testdata = '0123456789'; - protected $FQCN = Number::class; - protected $testdata = '0123456789'; - protected $expected = [ + /** @internal */ + protected array $expected = [ 16, 40, 12, 86, 106, 105, 0, 236, 17, 236, 17, 236, 17, 236, 17, 236, 17, 236, 17, 236, 17, 236, 17, 236, @@ -34,7 +40,18 @@ class NumberTest extends DatainterfaceTestAbstract{ 89, 63, 168, 151 ]; - public function testGetCharCodeException(){ + /** + * @inheritDoc + * @internal + */ + protected function getDataInterfaceInstance(QROptions $options):QRDataInterface{ + return new Number($options); + } + + /** + * Tests if an exception is thrown when an invalid character is encountered + */ + public function testGetCharCodeException():void{ $this->expectException(QRCodeDataException::class); $this->expectExceptionMessage('illegal char: "#" [35]'); diff --git a/vendor/chillerlan/php-qrcode/tests/Data/QRMatrixTest.php b/vendor/chillerlan/php-qrcode/tests/Data/QRMatrixTest.php index 531c82eb2..68b31a5de 100644..100755 --- a/vendor/chillerlan/php-qrcode/tests/Data/QRMatrixTest.php +++ b/vendor/chillerlan/php-qrcode/tests/Data/QRMatrixTest.php @@ -15,177 +15,294 @@ namespace chillerlan\QRCodeTest\Data; use chillerlan\QRCode\QRCode; use chillerlan\QRCode\QROptions; use chillerlan\QRCode\Data\{QRCodeDataException, QRMatrix}; -use chillerlan\QRCodeTest\QRTestAbstract; +use PHPUnit\Framework\TestCase; use ReflectionClass; -class QRMatrixTest extends QRTestAbstract{ - - protected $FQCN = QRMatrix::class; +/** + * Tests the QRMatix class + */ +final class QRMatrixTest extends TestCase{ - protected $version = 7; + /** @internal */ + protected const version = 40; + /** @internal */ + protected QRMatrix $matrix; /** - * @var \chillerlan\QRCode\Data\QRMatrix + * invokes a QRMatrix object + * + * @internal */ - protected $matrix; - protected function setUp():void{ - parent::setUp(); + $this->matrix = $this->getMatrix($this::version); + } + + /** + * shortcut + * + * @internal + */ + protected function getMatrix(int $version):QRMatrix{ + return new QRMatrix($version, QRCode::ECC_L); + } - $this->matrix = $this->reflection->newInstanceArgs([$this->version, QRCode::ECC_L]); + /** + * Validates the QRMatrix instance + */ + public function testInstance():void{ + $this::assertInstanceOf(QRMatrix::class, $this->matrix); } - public function testInvalidVersionException(){ + /** + * Tests if an exception is thrown when an invalid QR version was given + */ + public function testInvalidVersionException():void{ $this->expectException(QRCodeDataException::class); $this->expectExceptionMessage('invalid QR Code version'); - $this->reflection->newInstanceArgs([42, 0]); + $this->matrix = new QRMatrix(42, 0); } - public function testInvalidEccException(){ + /** + * Tests if an exception is thrown when an invalid ECC level was given + */ + public function testInvalidEccException():void{ $this->expectException(QRCodeDataException::class); $this->expectExceptionMessage('invalid ecc level'); - $this->reflection->newInstanceArgs([1, 42]); + $this->matrix = new QRMatrix(1, 42); } - public function testInstance(){ - $this->assertInstanceOf($this->FQCN, $this->matrix); + /** + * Tests if size() returns the actual matrix size/count + */ + public function testSize():void{ + $this::assertCount($this->matrix->size(), $this->matrix->matrix()); } - public function testSize(){ - $this->assertCount($this->matrix->size(), $this->matrix->matrix()); + /** + * Tests if version() returns the current (given) version + */ + public function testVersion():void{ + $this::assertSame($this::version, $this->matrix->version()); } - public function testVersion(){ - $this->assertSame($this->version, $this->matrix->version()); + /** + * Tests if eccLevel() returns the current (given) ECC level + */ + public function testECC():void{ + $this::assertSame(QRCode::ECC_L, $this->matrix->eccLevel()); } - public function testECC(){ - $this->assertSame(QRCode::ECC_L, $this->matrix->eccLevel()); - } + /** + * Tests if maskPattern() returns the current (or default) mask pattern + */ + public function testMaskPattern():void{ + $this::assertSame(-1, $this->matrix->maskPattern()); // default - public function testMaskPattern(){ - $this->assertSame(-1, $this->matrix->maskPattern()); + // @todo: actual mask pattern after mapData() } - public function testGetSetCheck(){ + /** + * Tests the set(), get() and check() methods + */ + public function testGetSetCheck():void{ $this->matrix->set(10, 10, true, QRMatrix::M_TEST); - $this->assertSame(65280, $this->matrix->get(10, 10)); - $this->assertTrue($this->matrix->check(10, 10)); + $this::assertSame(65280, $this->matrix->get(10, 10)); + $this::assertTrue($this->matrix->check(10, 10)); $this->matrix->set(20, 20, false, QRMatrix::M_TEST); - $this->assertSame(255, $this->matrix->get(20, 20)); - $this->assertFalse($this->matrix->check(20, 20)); + $this::assertSame(255, $this->matrix->get(20, 20)); + $this::assertFalse($this->matrix->check(20, 20)); } - public function testSetDarkModule(){ - $this->matrix->setDarkModule(); + /** + * Version data provider for several pattern tests + * + * @return int[][] + * @internal + */ + public function versionProvider():array{ + $versions = []; - $this->assertSame(QRMatrix::M_DARKMODULE << 8, $this->matrix->get(8, $this->matrix->size() - 8)); + for($i = 1; $i <= 40; $i++){ + $versions[] = [$i]; + } + + return $versions; } - public function testSetFinderPattern(){ - $this->matrix->setFinderPattern(); + /** + * Tests setting the dark module and verifies its position + * + * @dataProvider versionProvider + */ + public function testSetDarkModule(int $version):void{ + $matrix = $this->getMatrix($version)->setDarkModule(); + + $this::assertSame(QRMatrix::M_DARKMODULE << 8, $matrix->get(8, $matrix->size() - 8)); + } + + /** + * Tests setting the finder patterns and verifies their positions + * + * @dataProvider versionProvider + */ + public function testSetFinderPattern(int $version):void{ + $matrix = $this->getMatrix($version)->setFinderPattern(); - $this->assertSame(QRMatrix::M_FINDER << 8, $this->matrix->get(0, 0)); - $this->assertSame(QRMatrix::M_FINDER << 8, $this->matrix->get(0, $this->matrix->size() - 1)); - $this->assertSame(QRMatrix::M_FINDER << 8, $this->matrix->get($this->matrix->size() - 1, 0)); + $this::assertSame(QRMatrix::M_FINDER << 8, $matrix->get(0, 0)); + $this::assertSame(QRMatrix::M_FINDER << 8, $matrix->get(0, $matrix->size() - 1)); + $this::assertSame(QRMatrix::M_FINDER << 8, $matrix->get($matrix->size() - 1, 0)); } - public function testSetSeparators(){ - $this->matrix->setSeparators(); + /** + * Tests the separator patterns and verifies their positions + * + * @dataProvider versionProvider + */ + public function testSetSeparators(int $version):void{ + $matrix = $this->getMatrix($version)->setSeparators(); - $this->assertSame(QRMatrix::M_SEPARATOR, $this->matrix->get(7, 0)); - $this->assertSame(QRMatrix::M_SEPARATOR, $this->matrix->get(0, 7)); - $this->assertSame(QRMatrix::M_SEPARATOR, $this->matrix->get(0, $this->matrix->size() - 8)); - $this->assertSame(QRMatrix::M_SEPARATOR, $this->matrix->get($this->matrix->size() - 8, 0)); + $this::assertSame(QRMatrix::M_SEPARATOR, $matrix->get(7, 0)); + $this::assertSame(QRMatrix::M_SEPARATOR, $matrix->get(0, 7)); + $this::assertSame(QRMatrix::M_SEPARATOR, $matrix->get(0, $matrix->size() - 8)); + $this::assertSame(QRMatrix::M_SEPARATOR, $matrix->get($matrix->size() - 8, 0)); } - public function testSetAlignmentPattern(){ - $this->matrix + /** + * Tests the alignment patterns and verifies their positions - version 1 (no pattern) skipped + * + * @dataProvider versionProvider + */ + public function testSetAlignmentPattern(int $version):void{ + + if($version === 1){ + $this->markTestSkipped('N/A'); + + /** @noinspection PhpUnreachableStatementInspection */ + return; + } + + $matrix = $this + ->getMatrix($version) ->setFinderPattern() ->setAlignmentPattern() ; - $alignmentPattern = (new ReflectionClass(QRMatrix::class))->getConstant('alignmentPattern')[$this->version]; + $alignmentPattern = (new ReflectionClass(QRMatrix::class))->getConstant('alignmentPattern')[$version]; foreach($alignmentPattern as $py){ foreach($alignmentPattern as $px){ - if($this->matrix->get($px, $py) === QRMatrix::M_FINDER << 8){ - $this->assertSame(QRMatrix::M_FINDER << 8, $this->matrix->get($px, $py), 'skipped finder pattern'); + if($matrix->get($px, $py) === QRMatrix::M_FINDER << 8){ + $this::assertSame(QRMatrix::M_FINDER << 8, $matrix->get($px, $py), 'skipped finder pattern'); continue; } - $this->assertSame(QRMatrix::M_ALIGNMENT << 8, $this->matrix->get($px, $py)); + $this::assertSame(QRMatrix::M_ALIGNMENT << 8, $matrix->get($px, $py)); } } } - public function testSetTimingPattern(){ - $this->matrix + /** + * Tests the timing patterns and verifies their positions + * + * @dataProvider versionProvider + */ + public function testSetTimingPattern(int $version):void{ + + $matrix = $this + ->getMatrix($version) ->setAlignmentPattern() ->setTimingPattern() ; - $size = $this->matrix->size(); + $size = $matrix->size(); for($i = 7; $i < $size - 7; $i++){ if($i % 2 === 0){ - $p1 = $this->matrix->get(6, $i); + $p1 = $matrix->get(6, $i); if($p1 === QRMatrix::M_ALIGNMENT << 8){ - $this->assertSame(QRMatrix::M_ALIGNMENT << 8, $p1, 'skipped alignment pattern'); + $this::assertSame(QRMatrix::M_ALIGNMENT << 8, $p1, 'skipped alignment pattern'); continue; } - $this->assertSame(QRMatrix::M_TIMING << 8, $p1); - $this->assertSame(QRMatrix::M_TIMING << 8, $this->matrix->get($i, 6)); + $this::assertSame(QRMatrix::M_TIMING << 8, $p1); + $this::assertSame(QRMatrix::M_TIMING << 8, $matrix->get($i, 6)); } } } - public function testSetVersionNumber(){ - $this->matrix->setVersionNumber(true); + /** + * Tests the version patterns and verifies their positions - version < 7 skipped + * + * @dataProvider versionProvider + */ + public function testSetVersionNumber(int $version):void{ + + if($version < 7){ + $this->markTestSkipped('N/A'); + + /** @noinspection PhpUnreachableStatementInspection */ + return; + } + + $matrix = $this->getMatrix($version)->setVersionNumber(true); - $this->assertSame(QRMatrix::M_VERSION, $this->matrix->get($this->matrix->size() - 9, 0)); - $this->assertSame(QRMatrix::M_VERSION, $this->matrix->get($this->matrix->size() - 11, 5)); - $this->assertSame(QRMatrix::M_VERSION, $this->matrix->get(0, $this->matrix->size() - 9)); - $this->assertSame(QRMatrix::M_VERSION, $this->matrix->get(5, $this->matrix->size() - 11)); + $this::assertSame(QRMatrix::M_VERSION, $matrix->get($matrix->size() - 9, 0)); + $this::assertSame(QRMatrix::M_VERSION, $matrix->get($matrix->size() - 11, 5)); + $this::assertSame(QRMatrix::M_VERSION, $matrix->get(0, $matrix->size() - 9)); + $this::assertSame(QRMatrix::M_VERSION, $matrix->get(5, $matrix->size() - 11)); } - public function testSetFormatInfo(){ - $this->matrix->setFormatInfo(0, true); + /** + * Tests the format patterns and verifies their positions + * + * @dataProvider versionProvider + */ + public function testSetFormatInfo(int $version):void{ + $matrix = $this->getMatrix($version)->setFormatInfo(0, true); - $this->assertSame(QRMatrix::M_FORMAT, $this->matrix->get(8, 0)); - $this->assertSame(QRMatrix::M_FORMAT, $this->matrix->get(0, 8)); - $this->assertSame(QRMatrix::M_FORMAT, $this->matrix->get($this->matrix->size() - 1, 8)); - $this->assertSame(QRMatrix::M_FORMAT, $this->matrix->get($this->matrix->size() - 8, 8)); + $this::assertSame(QRMatrix::M_FORMAT, $matrix->get(8, 0)); + $this::assertSame(QRMatrix::M_FORMAT, $matrix->get(0, 8)); + $this::assertSame(QRMatrix::M_FORMAT, $matrix->get($matrix->size() - 1, 8)); + $this::assertSame(QRMatrix::M_FORMAT, $matrix->get($matrix->size() - 8, 8)); } - public function testSetQuietZone(){ - $size = $this->matrix->size(); + /** + * Tests the quiet zone pattern and verifies its position + * + * @dataProvider versionProvider + */ + public function testSetQuietZone(int $version):void{ + $matrix = $this->getMatrix($version); + + $size = $matrix->size(); $q = 5; - $this->matrix->set(0, 0, true, QRMatrix::M_TEST); - $this->matrix->set($size - 1, $size - 1, true, QRMatrix::M_TEST); + $matrix->set(0, 0, true, QRMatrix::M_TEST); + $matrix->set($size - 1, $size - 1, true, QRMatrix::M_TEST); - $this->matrix->setQuietZone($q); + $matrix->setQuietZone($q); - $this->assertCount($size + 2 * $q, $this->matrix->matrix()); - $this->assertCount($size + 2 * $q, $this->matrix->matrix()[$size - 1]); + $this::assertCount($size + 2 * $q, $matrix->matrix()); + $this::assertCount($size + 2 * $q, $matrix->matrix()[$size - 1]); - $size = $this->matrix->size(); - $this->assertSame(QRMatrix::M_QUIETZONE, $this->matrix->get(0, 0)); - $this->assertSame(QRMatrix::M_QUIETZONE, $this->matrix->get($size - 1, $size - 1)); + $size = $matrix->size(); + $this::assertSame(QRMatrix::M_QUIETZONE, $matrix->get(0, 0)); + $this::assertSame(QRMatrix::M_QUIETZONE, $matrix->get($size - 1, $size - 1)); - $this->assertSame(QRMatrix::M_TEST << 8, $this->matrix->get($q, $q)); - $this->assertSame(QRMatrix::M_TEST << 8, $this->matrix->get($size - 1 - $q, $size - 1 - $q)); + $this::assertSame(QRMatrix::M_TEST << 8, $matrix->get($q, $q)); + $this::assertSame(QRMatrix::M_TEST << 8, $matrix->get($size - 1 - $q, $size - 1 - $q)); } - public function testSetQuietZoneException(){ + /** + * Tests if an exception is thrown in an attempt to create it before data was written + */ + public function testSetQuietZoneException():void{ $this->expectException(QRCodeDataException::class); $this->expectExceptionMessage('use only after writing data'); |