improve assertions
This commit is contained in:
parent
018e91bc0c
commit
c63724c064
@ -17,6 +17,7 @@ namespace D3\Webauthn\Application\Controller\Admin;
|
|||||||
|
|
||||||
use Assert\Assert;
|
use Assert\Assert;
|
||||||
use Assert\AssertionFailedException;
|
use Assert\AssertionFailedException;
|
||||||
|
use Assert\InvalidArgumentException;
|
||||||
use D3\TestingTools\Production\IsMockable;
|
use D3\TestingTools\Production\IsMockable;
|
||||||
use D3\Webauthn\Application\Model\Credential\PublicKeyCredential;
|
use D3\Webauthn\Application\Model\Credential\PublicKeyCredential;
|
||||||
use D3\Webauthn\Application\Model\Credential\PublicKeyCredentialList;
|
use D3\Webauthn\Application\Model\Credential\PublicKeyCredentialList;
|
||||||
@ -84,7 +85,7 @@ class d3user_webauthn extends AdminDetailsController
|
|||||||
try {
|
try {
|
||||||
$this->setPageType('requestnew');
|
$this->setPageType('requestnew');
|
||||||
$this->setAuthnRegister();
|
$this->setAuthnRegister();
|
||||||
} catch (Exception|ContainerExceptionInterface|NotFoundExceptionInterface|DoctrineDriverException $e) {
|
} catch (AssertionFailedException|ContainerExceptionInterface|NotFoundExceptionInterface|DoctrineDriverException $e) {
|
||||||
d3GetOxidDIC()->get('d3ox.webauthn.'.UtilsView::class)->addErrorToDisplay($e->getMessage());
|
d3GetOxidDIC()->get('d3ox.webauthn.'.UtilsView::class)->addErrorToDisplay($e->getMessage());
|
||||||
d3GetOxidDIC()->get('d3ox.webauthn.'.LoggerInterface::class)->error($e->getMessage(), ['UserId' => $this->getEditObjectId()]);
|
d3GetOxidDIC()->get('d3ox.webauthn.'.LoggerInterface::class)->error($e->getMessage(), ['UserId' => $this->getEditObjectId()]);
|
||||||
d3GetOxidDIC()->get('d3ox.webauthn.'.LoggerInterface::class)->debug($e->getTraceAsString());
|
d3GetOxidDIC()->get('d3ox.webauthn.'.LoggerInterface::class)->debug($e->getTraceAsString());
|
||||||
@ -140,11 +141,14 @@ class d3user_webauthn extends AdminDetailsController
|
|||||||
/**
|
/**
|
||||||
* @throws DoctrineDriverException
|
* @throws DoctrineDriverException
|
||||||
* @throws DoctrineException
|
* @throws DoctrineException
|
||||||
|
* @throws InvalidArgumentException
|
||||||
*/
|
*/
|
||||||
public function setAuthnRegister(): void
|
public function setAuthnRegister(): void
|
||||||
{
|
{
|
||||||
|
/** @var Webauthn $authn */
|
||||||
$authn = d3GetOxidDIC()->get(Webauthn::class);
|
$authn = d3GetOxidDIC()->get(Webauthn::class);
|
||||||
|
|
||||||
|
/** @var User $user */
|
||||||
$user = d3GetOxidDIC()->get('d3ox.webauthn.'.User::class);
|
$user = d3GetOxidDIC()->get('d3ox.webauthn.'.User::class);
|
||||||
$user->load($this->getEditObjectId());
|
$user->load($this->getEditObjectId());
|
||||||
$publicKeyCredentialCreationOptions = $authn->getCreationOptions($user);
|
$publicKeyCredentialCreationOptions = $authn->getCreationOptions($user);
|
||||||
@ -169,6 +173,7 @@ class d3user_webauthn extends AdminDetailsController
|
|||||||
*/
|
*/
|
||||||
public function getCredentialList($userId): array
|
public function getCredentialList($userId): array
|
||||||
{
|
{
|
||||||
|
/** @var User $oUser */
|
||||||
$oUser = d3GetOxidDIC()->get('d3ox.webauthn.'.User::class);
|
$oUser = d3GetOxidDIC()->get('d3ox.webauthn.'.User::class);
|
||||||
$oUser->load($userId);
|
$oUser->load($userId);
|
||||||
|
|
||||||
|
@ -29,7 +29,6 @@ use Doctrine\DBAL\Driver\Exception as DoctrineDriverException;
|
|||||||
use Doctrine\DBAL\Exception as DoctrineException;
|
use Doctrine\DBAL\Exception as DoctrineException;
|
||||||
use OxidEsales\Eshop\Application\Controller\Admin\AdminController;
|
use OxidEsales\Eshop\Application\Controller\Admin\AdminController;
|
||||||
use OxidEsales\Eshop\Application\Controller\FrontendController;
|
use OxidEsales\Eshop\Application\Controller\FrontendController;
|
||||||
use OxidEsales\Eshop\Core\Registry;
|
|
||||||
use OxidEsales\Eshop\Core\Request;
|
use OxidEsales\Eshop\Core\Request;
|
||||||
use OxidEsales\Eshop\Core\Routing\ControllerClassNameResolver;
|
use OxidEsales\Eshop\Core\Routing\ControllerClassNameResolver;
|
||||||
use OxidEsales\Eshop\Core\Session;
|
use OxidEsales\Eshop\Core\Session;
|
||||||
|
@ -17,6 +17,7 @@ namespace D3\Webauthn\Application\Controller;
|
|||||||
|
|
||||||
use Assert\Assert;
|
use Assert\Assert;
|
||||||
use Assert\AssertionFailedException;
|
use Assert\AssertionFailedException;
|
||||||
|
use Assert\InvalidArgumentException;
|
||||||
use D3\TestingTools\Production\IsMockable;
|
use D3\TestingTools\Production\IsMockable;
|
||||||
use D3\Webauthn\Application\Controller\Traits\accountTrait;
|
use D3\Webauthn\Application\Controller\Traits\accountTrait;
|
||||||
use D3\Webauthn\Application\Model\Credential\PublicKeyCredential;
|
use D3\Webauthn\Application\Model\Credential\PublicKeyCredential;
|
||||||
@ -87,6 +88,10 @@ class d3_account_webauthn extends AccountController
|
|||||||
d3GetOxidDIC()->get('d3ox.webauthn.'.LoggerInterface::class)->error($e->getDetailedErrorMessage(), ['UserId: ' => $this->getUser()->getId()]);
|
d3GetOxidDIC()->get('d3ox.webauthn.'.LoggerInterface::class)->error($e->getDetailedErrorMessage(), ['UserId: ' => $this->getUser()->getId()]);
|
||||||
d3GetOxidDIC()->get('d3ox.webauthn.'.LoggerInterface::class)->debug($e->getTraceAsString());
|
d3GetOxidDIC()->get('d3ox.webauthn.'.LoggerInterface::class)->debug($e->getTraceAsString());
|
||||||
d3GetOxidDIC()->get('d3ox.webauthn.'.UtilsView::class)->addErrorToDisplay($e);
|
d3GetOxidDIC()->get('d3ox.webauthn.'.UtilsView::class)->addErrorToDisplay($e);
|
||||||
|
} catch (AssertionFailedException $e) {
|
||||||
|
d3GetOxidDIC()->get('d3ox.webauthn.'.LoggerInterface::class)->error($e->getMessage(), ['UserId: ' => $this->getUser()->getId()]);
|
||||||
|
d3GetOxidDIC()->get('d3ox.webauthn.'.LoggerInterface::class)->debug($e->getTraceAsString());
|
||||||
|
d3GetOxidDIC()->get('d3ox.webauthn.'.UtilsView::class)->addErrorToDisplay($e);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -104,6 +109,7 @@ class d3_account_webauthn extends AccountController
|
|||||||
* @throws DoctrineException
|
* @throws DoctrineException
|
||||||
* @throws ContainerExceptionInterface
|
* @throws ContainerExceptionInterface
|
||||||
* @throws NotFoundExceptionInterface
|
* @throws NotFoundExceptionInterface
|
||||||
|
* @throws InvalidArgumentException
|
||||||
* @return void
|
* @return void
|
||||||
*/
|
*/
|
||||||
public function setAuthnRegister(): void
|
public function setAuthnRegister(): void
|
||||||
|
@ -109,7 +109,7 @@ class d3webauthnlogin extends FrontendController
|
|||||||
->setVariable(WebauthnConf::GLOBAL_SWITCH, true);
|
->setVariable(WebauthnConf::GLOBAL_SWITCH, true);
|
||||||
d3GetOxidDIC()->get('d3ox.webauthn.'.LoggerInterface::class)->error($e->getMessage(), ['UserId' => $userId]);
|
d3GetOxidDIC()->get('d3ox.webauthn.'.LoggerInterface::class)->error($e->getMessage(), ['UserId' => $userId]);
|
||||||
d3GetOxidDIC()->get('d3ox.webauthn.'.LoggerInterface::class)->debug($e->getTraceAsString());
|
d3GetOxidDIC()->get('d3ox.webauthn.'.LoggerInterface::class)->debug($e->getTraceAsString());
|
||||||
Registry::getUtilsView()->addErrorToDisplay($e);
|
Registry::getUtilsView()->addErrorToDisplay($e->getMessage());
|
||||||
d3GetOxidDIC()->get('d3ox.webauthn.'.Utils::class)->redirect('index.php?cl=start');
|
d3GetOxidDIC()->get('d3ox.webauthn.'.Utils::class)->redirect('index.php?cl=start');
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -26,7 +26,6 @@ use D3\Webauthn\Application\Model\Exceptions\WebauthnGetException;
|
|||||||
use D3\Webauthn\Modules\Application\Model\d3_User_Webauthn;
|
use D3\Webauthn\Modules\Application\Model\d3_User_Webauthn;
|
||||||
use Doctrine\DBAL\Driver\Exception as DoctrineDriverException;
|
use Doctrine\DBAL\Driver\Exception as DoctrineDriverException;
|
||||||
use Doctrine\DBAL\Exception as DoctrineException;
|
use Doctrine\DBAL\Exception as DoctrineException;
|
||||||
use Exception;
|
|
||||||
use Nyholm\Psr7\Factory\Psr17Factory;
|
use Nyholm\Psr7\Factory\Psr17Factory;
|
||||||
use Nyholm\Psr7Server\ServerRequestCreator;
|
use Nyholm\Psr7Server\ServerRequestCreator;
|
||||||
use OxidEsales\Eshop\Application\Model\User;
|
use OxidEsales\Eshop\Application\Model\User;
|
||||||
@ -78,6 +77,7 @@ class Webauthn
|
|||||||
* @throws DoctrineDriverException
|
* @throws DoctrineDriverException
|
||||||
* @throws DoctrineException
|
* @throws DoctrineException
|
||||||
* @throws NotFoundExceptionInterface
|
* @throws NotFoundExceptionInterface
|
||||||
|
* @throws InvalidArgumentException
|
||||||
*/
|
*/
|
||||||
public function getCreationOptions(User $user): string
|
public function getCreationOptions(User $user): string
|
||||||
{
|
{
|
||||||
@ -96,9 +96,7 @@ class Webauthn
|
|||||||
|
|
||||||
$json = $this->jsonEncode($publicKeyCredentialCreationOptions);
|
$json = $this->jsonEncode($publicKeyCredentialCreationOptions);
|
||||||
|
|
||||||
if ($json === false) {
|
Assert::that($json)->isJsonString("can't encode request options");
|
||||||
throw oxNew(Exception::class, "can't encode creation options");
|
|
||||||
}
|
|
||||||
|
|
||||||
return $json;
|
return $json;
|
||||||
}
|
}
|
||||||
@ -149,7 +147,7 @@ class Webauthn
|
|||||||
$existingCredentials = $this->getExistingCredentials($userEntity);
|
$existingCredentials = $this->getExistingCredentials($userEntity);
|
||||||
|
|
||||||
d3GetOxidDIC()->get('d3ox.webauthn.'.LoggerInterface::class)->debug(
|
d3GetOxidDIC()->get('d3ox.webauthn.'.LoggerInterface::class)->debug(
|
||||||
'found user credentials: '.count($existingCredentials).' for ID '.$userId)
|
'found user credentials: '.count($existingCredentials).' for ID '.$userId
|
||||||
);
|
);
|
||||||
|
|
||||||
// We generate the set of options.
|
// We generate the set of options.
|
||||||
@ -167,7 +165,7 @@ class Webauthn
|
|||||||
'request options: '.$json
|
'request options: '.$json
|
||||||
);
|
);
|
||||||
|
|
||||||
Assert::that($json)->minLength(1, "can't encode request options");
|
Assert::that($json)->isJsonString("can't encode request options");
|
||||||
|
|
||||||
return $json;
|
return $json;
|
||||||
}
|
}
|
||||||
|
@ -17,6 +17,7 @@ namespace D3\Webauthn\Application\Model;
|
|||||||
|
|
||||||
use D3\TestingTools\Production\IsMockable;
|
use D3\TestingTools\Production\IsMockable;
|
||||||
use OxidEsales\Eshop\Core\Language;
|
use OxidEsales\Eshop\Core\Language;
|
||||||
|
use Psr\Log\LoggerInterface;
|
||||||
|
|
||||||
class WebauthnErrors
|
class WebauthnErrors
|
||||||
{
|
{
|
||||||
|
@ -112,6 +112,7 @@ class WebauthnLogin
|
|||||||
$myUtilsView = d3GetOxidDIC()->get('d3ox.webauthn.'.UtilsView::class);
|
$myUtilsView = d3GetOxidDIC()->get('d3ox.webauthn.'.UtilsView::class);
|
||||||
/** @var d3_User_Webauthn $user */
|
/** @var d3_User_Webauthn $user */
|
||||||
$user = d3GetOxidDIC()->get('d3ox.webauthn.'.User::class);
|
$user = d3GetOxidDIC()->get('d3ox.webauthn.'.User::class);
|
||||||
|
$userId = null;
|
||||||
|
|
||||||
try {
|
try {
|
||||||
$userId = $this->getUserId();
|
$userId = $this->getUserId();
|
||||||
@ -160,6 +161,7 @@ class WebauthnLogin
|
|||||||
$myUtilsView = d3GetOxidDIC()->get('d3ox.webauthn.'.UtilsView::class);
|
$myUtilsView = d3GetOxidDIC()->get('d3ox.webauthn.'.UtilsView::class);
|
||||||
/** @var d3_User_Webauthn $user */
|
/** @var d3_User_Webauthn $user */
|
||||||
$user = d3GetOxidDIC()->get('d3ox.webauthn.'.User::class);
|
$user = d3GetOxidDIC()->get('d3ox.webauthn.'.User::class);
|
||||||
|
$userId = null;
|
||||||
|
|
||||||
try {
|
try {
|
||||||
$userId = $this->getUserId();
|
$userId = $this->getUserId();
|
||||||
|
@ -66,8 +66,7 @@ class d3_webauthn_UserComponent extends d3_webauthn_UserComponent_parent
|
|||||||
$user = d3GetOxidDIC()->get('d3ox.webauthn.'.User::class);
|
$user = d3GetOxidDIC()->get('d3ox.webauthn.'.User::class);
|
||||||
$userId = $user->d3GetLoginUserId($lgn_user);
|
$userId = $user->d3GetLoginUserId($lgn_user);
|
||||||
|
|
||||||
if ($this->d3CanUseWebauthn($lgn_user, $userId)) {
|
if ($this->d3CanUseWebauthn($lgn_user, $userId) && $this->d3HasWebauthnButNotLoggedin($userId)) {
|
||||||
if ($this->d3HasWebauthnButNotLoggedin($userId)) {
|
|
||||||
$session = d3GetOxidDIC()->get('d3ox.webauthn.'.Session::class);
|
$session = d3GetOxidDIC()->get('d3ox.webauthn.'.Session::class);
|
||||||
$session->setVariable(
|
$session->setVariable(
|
||||||
WebauthnConf::WEBAUTHN_SESSION_CURRENTCLASS,
|
WebauthnConf::WEBAUTHN_SESSION_CURRENTCLASS,
|
||||||
@ -90,7 +89,6 @@ class d3_webauthn_UserComponent extends d3_webauthn_UserComponent_parent
|
|||||||
d3GetOxidDIC()->get('d3ox.webauthn.'.Utils::class)->redirect($sUrl);
|
d3GetOxidDIC()->get('d3ox.webauthn.'.Utils::class)->redirect($sUrl);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @param $lgn_user
|
* @param $lgn_user
|
||||||
|
@ -42,6 +42,9 @@ class Actions
|
|||||||
public $seo_en = 'en/key-authentication';
|
public $seo_en = 'en/key-authentication';
|
||||||
public $stdClassName = 'd3_account_webauthn';
|
public $stdClassName = 'd3_account_webauthn';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @throws Exception
|
||||||
|
*/
|
||||||
public function runModuleMigrations()
|
public function runModuleMigrations()
|
||||||
{
|
{
|
||||||
/** @var MigrationsBuilder $migrationsBuilder */
|
/** @var MigrationsBuilder $migrationsBuilder */
|
||||||
@ -52,6 +55,7 @@ class Actions
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* Regenerate views for changed tables
|
* Regenerate views for changed tables
|
||||||
|
* @throws Exception
|
||||||
*/
|
*/
|
||||||
public function regenerateViews()
|
public function regenerateViews()
|
||||||
{
|
{
|
||||||
@ -61,6 +65,7 @@ class Actions
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* clear cache
|
* clear cache
|
||||||
|
* @throws Exception
|
||||||
*/
|
*/
|
||||||
public function clearCache()
|
public function clearCache()
|
||||||
{
|
{
|
||||||
@ -126,6 +131,7 @@ class Actions
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* @return void
|
* @return void
|
||||||
|
* @throws Exception
|
||||||
*/
|
*/
|
||||||
public function seoUrl()
|
public function seoUrl()
|
||||||
{
|
{
|
||||||
@ -142,9 +148,11 @@ class Actions
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* @return bool
|
* @return bool
|
||||||
|
* @throws Exception
|
||||||
*/
|
*/
|
||||||
public function hasSeoUrl(): bool
|
public function hasSeoUrl(): bool
|
||||||
{
|
{
|
||||||
|
/** @var SeoEncoder $seoEncoder */
|
||||||
$seoEncoder = d3GetOxidDIC()->get('d3ox.webauthn.'.SeoEncoder::class);
|
$seoEncoder = d3GetOxidDIC()->get('d3ox.webauthn.'.SeoEncoder::class);
|
||||||
$seoUrl = $seoEncoder->getStaticUrl(
|
$seoUrl = $seoEncoder->getStaticUrl(
|
||||||
d3GetOxidDIC()->get('d3ox.webauthn.'.FrontendController::class)->getViewConfig()->getSelfLink() .
|
d3GetOxidDIC()->get('d3ox.webauthn.'.FrontendController::class)->getViewConfig()->getSelfLink() .
|
||||||
@ -156,6 +164,7 @@ class Actions
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* @return void
|
* @return void
|
||||||
|
* @throws Exception
|
||||||
*/
|
*/
|
||||||
public function createSeoUrl()
|
public function createSeoUrl()
|
||||||
{
|
{
|
||||||
|
@ -13,6 +13,7 @@
|
|||||||
|
|
||||||
namespace D3\Webauthn\tests\unit\Application\Controller\Admin;
|
namespace D3\Webauthn\tests\unit\Application\Controller\Admin;
|
||||||
|
|
||||||
|
use Assert\InvalidArgumentException;
|
||||||
use D3\TestingTools\Development\CanAccessRestricted;
|
use D3\TestingTools\Development\CanAccessRestricted;
|
||||||
use D3\TestingTools\Production\IsMockable;
|
use D3\TestingTools\Production\IsMockable;
|
||||||
use D3\Webauthn\Application\Controller\Admin\d3user_webauthn;
|
use D3\Webauthn\Application\Controller\Admin\d3user_webauthn;
|
||||||
@ -172,7 +173,7 @@ class d3user_webauthnTest extends WAUnitTestCase
|
|||||||
])
|
])
|
||||||
->getMock();
|
->getMock();
|
||||||
$sutMock->expects($this->atLeastOnce())->method('setPageType');
|
$sutMock->expects($this->atLeastOnce())->method('setPageType');
|
||||||
$sutMock->expects($this->atLeastOnce())->method('setAuthnRegister')->willThrowException(oxNew(WebauthnException::class));
|
$sutMock->expects($this->atLeastOnce())->method('setAuthnRegister')->willThrowException(new InvalidArgumentException('msg', 20));
|
||||||
|
|
||||||
$this->callMethod(
|
$this->callMethod(
|
||||||
$sutMock,
|
$sutMock,
|
||||||
|
@ -144,11 +144,15 @@ class d3webauthnadminloginTest extends d3webauthnloginTest
|
|||||||
* @test
|
* @test
|
||||||
* @return void
|
* @return void
|
||||||
* @throws ReflectionException
|
* @throws ReflectionException
|
||||||
|
* @dataProvider \D3\Webauthn\tests\unit\Application\Controller\d3webauthnloginTest::generateCredentialRequestFailedDataProvider()
|
||||||
* @covers \D3\Webauthn\Application\Controller\Admin\d3webauthnadminlogin::generateCredentialRequest
|
* @covers \D3\Webauthn\Application\Controller\Admin\d3webauthnadminlogin::generateCredentialRequest
|
||||||
*/
|
*/
|
||||||
public function generateCredentialRequestFailed($redirectClass = 'login', $userVarName = WebauthnConf::WEBAUTHN_ADMIN_SESSION_CURRENTUSER)
|
public function generateCredentialRequestFailed(
|
||||||
{
|
$exception,
|
||||||
parent::generateCredentialRequestFailed($redirectClass, $userVarName);
|
$redirectClass = 'login',
|
||||||
|
$userVarName = WebauthnConf::WEBAUTHN_ADMIN_SESSION_CURRENTUSER
|
||||||
|
) {
|
||||||
|
parent::generateCredentialRequestFailed($exception, $redirectClass, $userVarName);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -210,9 +210,10 @@ class d3_account_webauthnTest extends WAUnitTestCase
|
|||||||
* @test
|
* @test
|
||||||
* @return void
|
* @return void
|
||||||
* @throws ReflectionException
|
* @throws ReflectionException
|
||||||
|
* @dataProvider canRequestNewCredentialCantGetCreationOptionsDataProvider
|
||||||
* @covers \D3\Webauthn\Application\Controller\d3_account_webauthn::requestNewCredential()
|
* @covers \D3\Webauthn\Application\Controller\d3_account_webauthn::requestNewCredential()
|
||||||
*/
|
*/
|
||||||
public function canRequestNewCredentialCantGetCreationOptions()
|
public function canRequestNewCredentialCantGetCreationOptions($exception)
|
||||||
{
|
{
|
||||||
$oUser = oxNew(User::class);
|
$oUser = oxNew(User::class);
|
||||||
$oUser->setId('foo');
|
$oUser->setId('foo');
|
||||||
@ -233,7 +234,7 @@ class d3_account_webauthnTest extends WAUnitTestCase
|
|||||||
->onlyMethods(['setAuthnRegister', 'setPageType', 'getUser'])
|
->onlyMethods(['setAuthnRegister', 'setPageType', 'getUser'])
|
||||||
->getMock();
|
->getMock();
|
||||||
$oControllerMock->expects($this->atLeastOnce())->method('setAuthnRegister')
|
$oControllerMock->expects($this->atLeastOnce())->method('setAuthnRegister')
|
||||||
->willThrowException(oxNew(WebauthnException::class));
|
->willThrowException($exception);
|
||||||
$oControllerMock->expects($this->never())->method('setPageType');
|
$oControllerMock->expects($this->never())->method('setPageType');
|
||||||
$oControllerMock->method('getUser')->willReturn($oUser);
|
$oControllerMock->method('getUser')->willReturn($oUser);
|
||||||
|
|
||||||
@ -245,6 +246,16 @@ class d3_account_webauthnTest extends WAUnitTestCase
|
|||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return Generator
|
||||||
|
*/
|
||||||
|
public function canRequestNewCredentialCantGetCreationOptionsDataProvider(): Generator
|
||||||
|
{
|
||||||
|
yield 'WebauthnException' => [oxNew(WebauthnException::class)];
|
||||||
|
yield 'InvalidArgumentException' => [oxNew(InvalidArgumentException::class, 'msg', 20)];
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @test
|
* @test
|
||||||
* @param $throwExc
|
* @param $throwExc
|
||||||
|
@ -15,6 +15,7 @@ declare(strict_types=1);
|
|||||||
|
|
||||||
namespace D3\Webauthn\tests\unit\Application\Controller;
|
namespace D3\Webauthn\tests\unit\Application\Controller;
|
||||||
|
|
||||||
|
use Assert\InvalidArgumentException;
|
||||||
use D3\TestingTools\Development\CanAccessRestricted;
|
use D3\TestingTools\Development\CanAccessRestricted;
|
||||||
use D3\Webauthn\Application\Controller\d3webauthnlogin;
|
use D3\Webauthn\Application\Controller\d3webauthnlogin;
|
||||||
use D3\Webauthn\Application\Model\Exceptions\WebauthnException;
|
use D3\Webauthn\Application\Model\Exceptions\WebauthnException;
|
||||||
@ -181,9 +182,14 @@ class d3webauthnloginTest extends WAUnitTestCase
|
|||||||
* @test
|
* @test
|
||||||
* @return void
|
* @return void
|
||||||
* @throws ReflectionException
|
* @throws ReflectionException
|
||||||
|
* @dataProvider generateCredentialRequestFailedDataProvider
|
||||||
* @covers \D3\Webauthn\Application\Controller\d3webauthnlogin::generateCredentialRequest
|
* @covers \D3\Webauthn\Application\Controller\d3webauthnlogin::generateCredentialRequest
|
||||||
*/
|
*/
|
||||||
public function generateCredentialRequestFailed($redirectClass = 'start', $userVarName = WebauthnConf::WEBAUTHN_SESSION_CURRENTUSER)
|
public function generateCredentialRequestFailed(
|
||||||
|
$exception,
|
||||||
|
$redirectClass = 'start',
|
||||||
|
$userVarName = WebauthnConf::WEBAUTHN_SESSION_CURRENTUSER
|
||||||
|
)
|
||||||
{
|
{
|
||||||
$currUserFixture = 'currentUserFixture';
|
$currUserFixture = 'currentUserFixture';
|
||||||
|
|
||||||
@ -209,7 +215,7 @@ class d3webauthnloginTest extends WAUnitTestCase
|
|||||||
->onlyMethods(['getRequestOptions'])
|
->onlyMethods(['getRequestOptions'])
|
||||||
->getMock();
|
->getMock();
|
||||||
$webAuthnMock->expects($this->once())->method('getRequestOptions')->with($currUserFixture)
|
$webAuthnMock->expects($this->once())->method('getRequestOptions')->with($currUserFixture)
|
||||||
->willThrowException(oxNew(WebauthnException::class, 'foobar0'));
|
->willThrowException($exception);
|
||||||
d3GetOxidDIC()->set(Webauthn::class, $webAuthnMock);
|
d3GetOxidDIC()->set(Webauthn::class, $webAuthnMock);
|
||||||
|
|
||||||
/** @var Utils|MockObject $utilsMock */
|
/** @var Utils|MockObject $utilsMock */
|
||||||
@ -233,6 +239,15 @@ class d3webauthnloginTest extends WAUnitTestCase
|
|||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return Generator
|
||||||
|
*/
|
||||||
|
public function generateCredentialRequestFailedDataProvider(): Generator
|
||||||
|
{
|
||||||
|
yield 'WebauthnException' => [oxNew(WebauthnException::class, 'foobar0')];
|
||||||
|
yield 'InvalidArgumentException' => [oxNew(InvalidArgumentException::class, 'foobar0', 20)];
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @test
|
* @test
|
||||||
* @return void
|
* @return void
|
||||||
|
@ -182,7 +182,7 @@ class WebauthnTest extends WAUnitTestCase
|
|||||||
*/
|
*/
|
||||||
public function canGetOptionsDataProvider(): Generator
|
public function canGetOptionsDataProvider(): Generator
|
||||||
{
|
{
|
||||||
yield 'json encoded' => ['jsonstring'];
|
yield 'json encoded' => [json_encode(['jsonstring'])];
|
||||||
yield 'json failed' => [false];
|
yield 'json failed' => [false];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -41,7 +41,7 @@ class Version20230209212939Test extends WAUnitTestCase
|
|||||||
|
|
||||||
public function setUp(): void
|
public function setUp(): void
|
||||||
{
|
{
|
||||||
parent::setUp(); // TODO: Change the autogenerated stub
|
parent::setUp();
|
||||||
|
|
||||||
/** @var AbstractPlatform|MockObject $databasePlatformMock */
|
/** @var AbstractPlatform|MockObject $databasePlatformMock */
|
||||||
$databasePlatformMock = $this->getMockBuilder(MySQL57Platform::class)
|
$databasePlatformMock = $this->getMockBuilder(MySQL57Platform::class)
|
||||||
|
Loading…
Reference in New Issue
Block a user