Server : Apache/2.4.43 (Win64) OpenSSL/1.1.1g PHP/7.4.6
System : Windows NT USER-PC 6.1 build 7601 (Windows 7 Professional Edition Service Pack 1) AMD64
User : User ( 0)
PHP Version : 7.4.6
Disable Function : NONE
Directory :  C:/xampp/phpMyAdmin/vendor/pragmarx/google2fa-qrcode/tests/
Upload File :
Current Directory [ Writeable ] Root Directory [ Writeable ]


Current File : C:/xampp/phpMyAdmin/vendor/pragmarx/google2fa-qrcode/tests/Google2FATest.php
<?php

namespace PragmaRX\Google2FAQRCode\Tests;

use BaconQrCode\Renderer\Image\ImagickImageBackEnd;
use BaconQrCode\Renderer\Image\Png;
use PHPUnit\Framework\TestCase;
use PragmaRX\Google2FAQRCode\Google2FA;
use Zxing\QrReader;

class Google2FATest extends TestCase
{
    const EMAIL = 'acr+pragmarx@antoniocarlosribeiro.com';

    const OTP_URL = 'otpauth://totp/PragmaRX:acr+pragmarx@antoniocarlosribeiro.com?secret=ADUMJO5634NPDEKW&issuer=PragmaRX';

    public function setUp()
    {
        $this->google2fa = new Google2FA();
    }

    public function readQRCode($data)
    {
        list(, $data) = explode(';', $data);

        list(, $data) = explode(',', $data);

        return rawurldecode((new QrReader(base64_decode($data), QrReader::SOURCE_TYPE_BLOB))->text());
    }

    public function testQrcodeInline()
    {
        $this->assertEquals(
            static::OTP_URL,
            $this->readQRCode($this->google2fa->getQRCodeInline('PragmaRX', static::EMAIL, Constants::SECRET))
        );

        if ($this->google2fa->getBaconQRCodeVersion() === 1) {
            $google2fa = new Google2FA(new Png());
            $this->assertEquals(
                static::OTP_URL,
                $this->readQRCode($google2fa->getQRCodeInline('PragmaRX', static::EMAIL, Constants::SECRET))
            );
        } else {
            $google2fa = new Google2FA(new ImagickImageBackEnd());
            $this->assertEquals(
                static::OTP_URL,
                $this->readQRCode($google2fa->getQRCodeInline('PragmaRX', static::EMAIL, Constants::SECRET))
            );
        }
    }
}