2FAuth/tests/Feature/Services/QrCodeServiceTest.php

90 lines
18 KiB
PHP
Raw Permalink Normal View History

2021-11-30 17:39:33 +01:00
<?php
namespace Tests\Feature\Services;
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;
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 14:40:20 +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-09-27 14:40:20 +02:00
// #[Test]
// public function test_encode_returns_correct_value()
// {
// $this->assertEquals(self::STRING_ENCODED, QrCode::encode(self::STRING_TO_ENCODE));
// }
2021-11-30 17:39:33 +01:00
#[Test]
2021-11-30 17:39:33 +01:00
public function test_decode_valid_image_returns_correct_value()
{
$file = LocalFile::fake()->validQrcode();
$this->assertEquals(self::DECODED_IMAGE, QrCode::decode($file));
2021-11-30 17:39:33 +01: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);
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
}