2021-11-30 17:39:33 +01:00
|
|
|
<?php
|
|
|
|
|
|
|
|
namespace Tests\Feature\Services;
|
|
|
|
|
2022-07-30 10:46:02 +02:00
|
|
|
use App\Facades\QrCode;
|
2024-09-25 08:37:37 +02:00
|
|
|
use App\Providers\TwoFAuthServiceProvider;
|
2023-08-01 11:28:27 +02:00
|
|
|
use App\Services\QrCodeService;
|
2024-07-03 11:16:08 +02:00
|
|
|
use Exception;
|
2023-08-01 11:28:27 +02:00
|
|
|
use PHPUnit\Framework\Attributes\CoversClass;
|
2024-07-03 11:16:08 +02:00
|
|
|
use PHPUnit\Framework\Attributes\DataProvider;
|
2024-06-26 14:29:13 +02:00
|
|
|
use PHPUnit\Framework\Attributes\Test;
|
2022-11-22 15:15:52 +01:00
|
|
|
use Tests\Classes\LocalFile;
|
|
|
|
use Tests\FeatureTestCase;
|
2024-07-03 11:16:08 +02:00
|
|
|
use Zxing\ChecksumException;
|
|
|
|
use Zxing\FormatException;
|
|
|
|
use Zxing\NotFoundException;
|
|
|
|
use Zxing\QrReader;
|
2021-11-30 17:39:33 +01:00
|
|
|
|
|
|
|
/**
|
2023-08-01 11:28:27 +02:00
|
|
|
* QrCodeServiceTest test class
|
2021-11-30 17:39:33 +01:00
|
|
|
*/
|
2023-08-01 11:28:27 +02:00
|
|
|
#[CoversClass(QrCodeService::class)]
|
|
|
|
#[CoversClass(QrCode::class)]
|
2024-09-25 08:37:37 +02:00
|
|
|
#[CoversClass(TwoFAuthServiceProvider::class)]
|
2021-11-30 17:39:33 +01:00
|
|
|
class QrCodeServiceTest extends FeatureTestCase
|
|
|
|
{
|
2024-09-27 00:00:53 +02:00
|
|
|
private const STRING_TO_ENCODE = 'x';
|
2022-11-22 15:15:52 +01:00
|
|
|
|
2024-09-27 00:00:53 +02:00
|
|
|
private const STRING_ENCODED = '
|
2022-11-22 15:15:52 +01:00
|
|
|
|
2021-11-30 17:39:33 +01:00
|
|
|
private const DECODED_IMAGE = 'otpauth://totp/test@test.com?secret=A4GRFHVIRBGY7UIW';
|
|
|
|
|
2022-12-13 12:07:29 +01:00
|
|
|
public function setUp() : void
|
2021-11-30 17:39:33 +01:00
|
|
|
{
|
|
|
|
parent::setUp();
|
|
|
|
}
|
|
|
|
|
2024-06-26 14:29:13 +02:00
|
|
|
#[Test]
|
2021-11-30 17:39:33 +01:00
|
|
|
public function test_encode_returns_correct_value()
|
|
|
|
{
|
2022-07-30 10:46:02 +02:00
|
|
|
$this->assertEquals(self::STRING_ENCODED, QrCode::encode(self::STRING_TO_ENCODE));
|
2021-11-30 17:39:33 +01:00
|
|
|
}
|
|
|
|
|
2024-06-26 14:29:13 +02:00
|
|
|
#[Test]
|
2021-11-30 17:39:33 +01:00
|
|
|
public function test_decode_valid_image_returns_correct_value()
|
|
|
|
{
|
|
|
|
$file = LocalFile::fake()->validQrcode();
|
|
|
|
|
2022-07-30 10:46:02 +02:00
|
|
|
$this->assertEquals(self::DECODED_IMAGE, QrCode::decode($file));
|
2021-11-30 17:39:33 +01:00
|
|
|
}
|
|
|
|
|
2024-06-26 14:29:13 +02:00
|
|
|
#[Test]
|
2024-07-03 11:16:08 +02:00
|
|
|
public function test_decode_invalid_image_throws_an_exception()
|
2021-11-30 17:39:33 +01:00
|
|
|
{
|
|
|
|
$this->expectException(\App\Exceptions\InvalidQrCodeException::class);
|
|
|
|
|
2022-07-30 10:46:02 +02:00
|
|
|
QrCode::decode(LocalFile::fake()->invalidQrcode());
|
2021-11-30 17:39:33 +01:00
|
|
|
}
|
2024-07-03 11:16:08 +02:00
|
|
|
|
|
|
|
#[Test]
|
|
|
|
#[DataProvider('QrReaderExceptionProvider')]
|
2024-09-27 00:00:53 +02:00
|
|
|
public function test_decode_throws_an_exception($exception)
|
2024-07-03 11:16:08 +02:00
|
|
|
{
|
|
|
|
$this->expectException(\App\Exceptions\InvalidQrCodeException::class);
|
|
|
|
|
|
|
|
// QrReader is a final class, so we need to mock it here with a new object instance
|
|
|
|
// to then bind it to the container
|
|
|
|
$fileContent = LocalFile::fake()->validQrcode()->get();
|
2024-09-26 23:50:01 +02:00
|
|
|
$qrReader = \Mockery::mock(new QrReader($fileContent, QrReader::SOURCE_TYPE_BLOB))->makePartial();
|
2024-07-03 11:16:08 +02:00
|
|
|
$qrReader->shouldReceive('text')->andReturn('');
|
|
|
|
$qrReader->shouldReceive('getError')->andReturn($exception);
|
2024-09-26 23:50:01 +02:00
|
|
|
|
|
|
|
$this->app->bind(QrReader::class, function () use ($qrReader) {
|
2024-07-03 11:16:08 +02:00
|
|
|
return $qrReader;
|
|
|
|
});
|
|
|
|
|
|
|
|
QrCode::decode(LocalFile::fake()->validQrcode());
|
|
|
|
}
|
|
|
|
|
|
|
|
public static function QrReaderExceptionProvider()
|
|
|
|
{
|
|
|
|
return [
|
2024-09-26 23:50:01 +02:00
|
|
|
'NotFoundException' => [new NotFoundException],
|
|
|
|
'FormatException' => [new FormatException],
|
|
|
|
'ChecksumException' => [new ChecksumException],
|
|
|
|
'default' => [new Exception],
|
2024-07-03 11:16:08 +02:00
|
|
|
];
|
|
|
|
}
|
2022-11-22 15:15:52 +01:00
|
|
|
}
|