2FAuth/tests/Unit/QrcodeTest.php
2020-11-17 21:56:06 +01:00

107 lines
2.7 KiB
PHP

<?php
namespace Tests\Unit;
use App\User;
use Zxing\QrReader;
use Tests\TestCase;
use App\TwoFAccount;
use App\Classes\Options;
use Tests\Classes\LocalFile;
use Illuminate\Http\UploadedFile;
use Illuminate\Support\Facades\Storage;
use Illuminate\Foundation\Testing\WithoutMiddleware;
class QrcodeTest extends TestCase
{
use WithoutMiddleware;
/**
* test Decode a qrcode without providing a file resource via API
*
* @test
*/
public function testQrcodeDecodeWithMissingImage()
{
$response = $this->json('POST', '/api/qrcode/decode', [
'qrcode' => '',
])
->assertStatus(422);
}
/**
* test decode an invalid QR code uplloaded via API
*
* @test
*/
public function testDecodeInvalidQrcode()
{
$file = LocalFile::fake()->invalidQrcode();
$response = $this->withHeaders([
'Content-Type' => 'multipart/form-data',
])
->json('POST', '/api/qrcode/decode', [
'qrcode' => $file,
'inputFormat' => 'fileUpload'
]);
$response->assertStatus(422);
}
/**
* test Decode a qrcode via API
*
* @test
*/
public function testDecodeValidUri()
{
$response = $this->json('POST', '/api/qrcode/decode', [
'uri' => 'otpauth://totp/service:account?secret=A4GRFHVIRBGY7UIW'
]);
$response->assertStatus(200)
->assertJsonFragment([
'service' => 'service',
'account' => 'account',
'algorithm' => 'sha1',
'digits' => 6,
'totpPeriod' => 30,
'secret' => 'A4GRFHVIRBGY7UIW'
]);
}
/**
* test Decode a qrcode via API
*
* @test
*/
public function testDecodeValidQrcode()
{
Options::store(array('useBasicQrcodeReader' => true));
$file = LocalFile::fake()->validQrcode();
$response = $this->withHeaders(['Content-Type' => 'multipart/form-data'])
->json('POST', '/api/qrcode/decode', [
'qrcode' => $file,
'inputFormat' => 'fileUpload'
]);
$response->assertStatus(200)
->assertJsonFragment([
'account' => 'test@test.com',
'algorithm' => 'sha1',
'digits' => 6,
'totpPeriod' => 30,
'secret' => 'A4GRFHVIRBGY7UIW'
]);
}
}