diff --git a/tests/Core/EntityTest.php b/tests/Core/EntityTest.php new file mode 100644 index 0000000000..38bc8ef0a8 --- /dev/null +++ b/tests/Core/EntityTest.php @@ -0,0 +1,67 @@ +. + +// }}} + +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)); + } +}