NoteTest.php 3.2 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071
  1. <?php
  2. declare(strict_types = 1);
  3. // {{{ License
  4. // This file is part of GNU social - https://www.gnu.org/software/social
  5. //
  6. // GNU social is free software: you can redistribute it and/or modify
  7. // it under the terms of the GNU Affero General Public License as published by
  8. // the Free Software Foundation, either version 3 of the License, or
  9. // (at your option) any later version.
  10. //
  11. // GNU social is distributed in the hope that it will be useful,
  12. // but WITHOUT ANY WARRANTY; without even the implied warranty of
  13. // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  14. // GNU Affero General Public License for more details.
  15. //
  16. // You should have received a copy of the GNU Affero General Public License
  17. // along with GNU social. If not, see <http://www.gnu.org/licenses/>.
  18. // }}}
  19. namespace App\Tests\Entity;
  20. use App\Core\DB\DB;
  21. use App\Core\VisibilityScope;
  22. use App\Util\GNUsocialTestCase;
  23. use Functional as F;
  24. use Jchook\AssertThrows\AssertThrows;
  25. class NoteTest extends GNUsocialTestCase
  26. {
  27. use AssertThrows;
  28. // public function testGetReplies()
  29. // {
  30. // $user = DB::findOneBy('local_user', ['nickname' => 'taken_user']);
  31. // $notes = DB::findBy('note', ['actor_id' => $user->getId(), 'content' => 'some content', 'reply_to' => null]);
  32. // dd($notes, F\map($notes, fn ($n) => $n->getReplies()), DB::dql('select n from note n'));
  33. // $note = DB::findOneBy('note', ['actor_id' => $user->getId(), 'content' => 'some content', 'reply_to' => null]);
  34. // $replies = $note->getReplies();
  35. // // dd($note, $replies);
  36. // static::assertSame('some other content', $replies[0]->getContent());
  37. // static::assertSame($user->getId(), $replies[0]->getActorId());
  38. // static::assertSame($note->getId(), $replies[0]->getReplyTo());
  39. // static::assertSame($user->getNickname(), $replies[0]->getReplyToNickname());
  40. // }
  41. public function testIsVisibleTo()
  42. {
  43. $actor1 = DB::findOneBy('actor', ['nickname' => 'taken_user']);
  44. $actor2 = DB::findOneBy('actor', ['nickname' => 'taken_group']);
  45. $actor3 = DB::findOneBy('actor', ['nickname' => 'some_user']);
  46. $note_visible_to_1 = DB::findBy('note', ['actor_id' => $actor1->getId(), 'content' => 'private note', 'scope' => VisibilityScope::COLLECTION->value], limit: 1)[0];
  47. static::assertTrue($note_visible_to_1->isVisibleTo($actor1));
  48. static::assertFalse($note_visible_to_1->isVisibleTo($actor2));
  49. static::assertFalse($note_visible_to_1->isVisibleTo($actor3));
  50. $note_public = DB::findBy('note', ['actor_id' => $actor1->getId(), 'content' => 'some content'], limit: 1)[0];
  51. static::assertTrue($note_public->isVisibleTo($actor1));
  52. static::assertTrue($note_public->isVisibleTo($actor2));
  53. static::assertTrue($note_public->isVisibleTo($actor3));
  54. $group_note = DB::findBy('note', ['actor_id' => $actor1->getId(), 'content' => 'group note', 'scope' => VisibilityScope::GROUP->value], limit: 1)[0];
  55. static::assertTrue($group_note->isVisibleTo($actor3));
  56. static::assertFalse($group_note->isVisibleTo($actor2));
  57. static::assertFalse($group_note->isVisibleTo($actor1));
  58. }
  59. }