[TESTS][ENTITY] Raise test coverage for Entity class to 100%

This commit is contained in:
Hugo Sales 2021-07-21 16:44:06 +00:00
parent 3b18853ff1
commit 871422e6b6
Signed by: someonewithpc
GPG Key ID: 7D0C7EAFC9D835A0

67
tests/Core/EntityTest.php Normal file
View File

@ -0,0 +1,67 @@
<?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\Core;
use App\Core\DB\DB;
use App\Entity\LocalUser;
use App\Util\Exception\NotFoundException;
use App\Util\GNUsocialTestCase;
use Jchook\AssertThrows\AssertThrows;
class EntityTest extends GNUsocialTestCase
{
use AssertThrows;
public function testHasMethod()
{
$user = LocalUser::create(['nickname' => 'foo']);
static::assertTrue($user->hasNickname());
static::assertFalse($user->hasPassword());
static::assertThrows(\BadMethodCallException::class, fn () => $user->nonExistantMethod());
}
public function testCreate()
{
$user = LocalUser::create(['nickname' => 'foo']);
static::assertSame('foo', $user->getNickname());
static::assertThrows(\InvalidArgumentException::class, fn () => LocalUser::create(['non_existant_property' => 'bar']));
}
public function testCreateOrUpdate()
{
$user = LocalUser::createOrUpdate(['nickname' => 'taken_user']);
static::assertNotNull($user);
static::assertThrows(NotFoundException::class, fn () => LocalUser::createOrUpdate(['nickname' => 'taken_user', 'outgoing_email' => 'foo@bar']));
$user = LocalUser::createOrUpdate(['nickname' => 'taken_user', 'outgoing_email' => 'foo@bar'], find_by_keys: ['nickname']);
static::assertSame('foo@bar', $user->getOutgoingEmail());
}
public function testGetWithPK()
{
$user = DB::findOneBy('local_user', ['nickname' => 'taken_user']);
$user_with_pk = LocalUser::getWithPK($user->getId());
static::assertSame($user, $user_with_pk);
$user_with_pk = LocalUser::getWithPK(['id' => $user->getId()]);
static::assertSame($user, $user_with_pk);
static::assertNull(LocalUser::getWithPK(0));
}
}