[TESTS] Raise test coverage of LocalUser to 100%

This commit is contained in:
Hugo Sales 2021-08-18 17:33:41 +01:00
parent 152beb5798
commit 2ba6f66b7f
Signed by untrusted user: someonewithpc
GPG Key ID: 7D0C7EAFC9D835A0

View File

@ -0,0 +1,54 @@
<?php
// {{{ License
// This file is part of GNU social - https://www.gnu.org/software/social
//
// GNU social is free software: you can redistribute it and/or modify
// it under the terms of the GNU Affero General Public License as published by
// the Free Software Foundation, either version 3 of the License, or
// (at your option) any later version.
//
// GNU social is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU Affero General Public License for more details.
//
// You should have received a copy of the GNU Affero General Public License
// along with GNU social. If not, see <http://www.gnu.org/licenses/>.
// }}}
namespace App\Tests\Entity;
use App\Entity\LocalUser;
use App\Util\GNUsocialTestCase;
use Jchook\AssertThrows\AssertThrows;
class LocalUserTest extends GNUsocialTestCase
{
use AssertThrows;
public function testAlgoNameToConstant()
{
$if_exists = function ($name, $constant) {
if (defined($constant)) {
static::assertSame(constant($constant), LocalUser::algoNameToConstant($name));
} else {
static::assertThrows(\Exception::class, fn () => LocalUser::algoNameToConstant($name));
}
};
$if_exists('bcrypt', 'PASSWORD_BCRYPT');
$if_exists('argon2', 'PASSWORD_ARGON2');
$if_exists('argon2i', 'PASSWORD_ARGON2I');
$if_exists('argon2d', 'PASSWORD_ARGON2D');
$if_exists('argon2id', 'PASSWORD_ARGON2ID');
static::assertSame(\PASSWORD_ARGON2ID, LocalUser::algoNameToConstant('argon2id'));
}
public function testChangePassword()
{
$user = LocalUser::findByNicknameOrEmail('form_personal_info_test_user', 'some@email');
static::assertTrue($user->changePassword(old_password_plain_text: '', new_password_plain_text: 'password', override: true));
static::assertTrue($user->changePassword(old_password_plain_text: 'password', new_password_plain_text: 'new_password', override: false));
static::assertFalse($user->changePassword(old_password_plain_text: 'wrong_password', new_password_plain_text: 'new_password', override: false));
}
}