[TESTS][DataFixtures] Add user, self follows, group member and group scope note
This commit is contained in:
parent
365afb7ba8
commit
e392a9c90c
@ -3,7 +3,9 @@
|
|||||||
namespace App\DataFixtures;
|
namespace App\DataFixtures;
|
||||||
|
|
||||||
use App\Core\VisibilityScope;
|
use App\Core\VisibilityScope;
|
||||||
|
use App\Entity\Follow;
|
||||||
use App\Entity\GroupInbox;
|
use App\Entity\GroupInbox;
|
||||||
|
use App\Entity\GroupMember;
|
||||||
use App\Entity\GSActor;
|
use App\Entity\GSActor;
|
||||||
use App\Entity\LocalGroup;
|
use App\Entity\LocalGroup;
|
||||||
use App\Entity\LocalUser;
|
use App\Entity\LocalUser;
|
||||||
@ -17,17 +19,21 @@ class CoreFixtures extends Fixture
|
|||||||
{
|
{
|
||||||
$actors = [];
|
$actors = [];
|
||||||
$local_entities = [];
|
$local_entities = [];
|
||||||
foreach (['taken_user' => [LocalUser::class, 'setId', ['password' => LocalUser::hashPassword('foobar'), 'outgoing_email' => 'email@provider']],
|
foreach ([
|
||||||
|
'taken_user' => [LocalUser::class, 'setId', ['password' => LocalUser::hashPassword('foobar'), 'outgoing_email' => 'email@provider']],
|
||||||
|
'some_user' => [LocalUser::class, 'setId', []],
|
||||||
'form_personal_info_test_user' => [LocalUser::class, 'setId', []],
|
'form_personal_info_test_user' => [LocalUser::class, 'setId', []],
|
||||||
'form_account_test_user' => [LocalUser::class, 'setId', ['password' => LocalUser::hashPassword('some password')]],
|
'form_account_test_user' => [LocalUser::class, 'setId', ['password' => LocalUser::hashPassword('some password')]],
|
||||||
'taken_group' => [LocalGroup::class, 'setGroupId', []], ]
|
'taken_group' => [LocalGroup::class, 'setGroupId', []],
|
||||||
as $nick => [$entity, $method, $extra_create]) {
|
] as $nick => [$entity, $method, $extra_create]) {
|
||||||
$actor = GSActor::create(['nickname' => $nick]);
|
$actor = GSActor::create(['nickname' => $nick]);
|
||||||
$manager->persist($actor);
|
$manager->persist($actor);
|
||||||
$ent = $entity::create(array_merge(['nickname' => $nick], $extra_create)); // cannot use array spread for arrays with string keys
|
$ent = $entity::create(array_merge(['nickname' => $nick], $extra_create)); // cannot use array spread for arrays with string keys
|
||||||
$ent->{$method}($actor->getId());
|
$ent->{$method}($actor->getId());
|
||||||
$local_entities[$nick] = $ent;
|
$local_entities[$nick] = $ent;
|
||||||
$manager->persist($ent);
|
$manager->persist($ent);
|
||||||
|
// Add self follows
|
||||||
|
$manager->persist(Follow::create(['follower' => $actor->getId(), 'followed' => $actor->getId()]));
|
||||||
$actors[$nick] = $actor;
|
$actors[$nick] = $actor;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -35,11 +41,13 @@ class CoreFixtures extends Fixture
|
|||||||
$manager->persist($n);
|
$manager->persist($n);
|
||||||
$notes[] = Note::create(['gsactor_id' => $actors['taken_user']->getId(), 'content' => 'some other content', 'reply_to' => $n->getId()]);
|
$notes[] = Note::create(['gsactor_id' => $actors['taken_user']->getId(), 'content' => 'some other content', 'reply_to' => $n->getId()]);
|
||||||
$notes[] = Note::create(['gsactor_id' => $actors['taken_user']->getId(), 'content' => 'private note', 'scope' => VisibilityScope::FOLLOWER]);
|
$notes[] = Note::create(['gsactor_id' => $actors['taken_user']->getId(), 'content' => 'private note', 'scope' => VisibilityScope::FOLLOWER]);
|
||||||
|
$notes[] = $group_note = Note::create(['gsactor_id' => $actors['taken_user']->getId(), 'content' => 'group note', 'scope' => VisibilityScope::GROUP]);
|
||||||
foreach ($notes as $note) {
|
foreach ($notes as $note) {
|
||||||
$manager->persist($note);
|
$manager->persist($note);
|
||||||
}
|
}
|
||||||
|
|
||||||
$manager->persist(GroupInbox::create(['group_id' => $local_entities['taken_group']->getGroupId(), 'activity_id' => $note->getId()]));
|
$manager->persist(GroupMember::create(['group_id' => $local_entities['taken_group']->getGroupId(), 'gsactor_id' => $actors['some_user']->getId()]));
|
||||||
|
$manager->persist(GroupInbox::create(['group_id' => $local_entities['taken_group']->getGroupId(), 'activity_id' => $group_note->getId()]));
|
||||||
$manager->flush();
|
$manager->flush();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user