Fixed: Sync subgroups of subgroups
continuous-integration/drone/push Build is passing Details

This commit is contained in:
philipp lang 2022-03-15 10:24:04 +01:00
parent d719ebca23
commit c17334d9a6
3 changed files with 46 additions and 9 deletions

View File

@ -19,9 +19,15 @@ class InitializeGroups
$this->api->groups()->each(function ($group) { $this->api->groups()->each(function ($group) {
$parent = Group::updateOrCreate(['nami_id' => $group->id], ['nami_id' => $group->id, 'name' => $group->name]); $parent = Group::updateOrCreate(['nami_id' => $group->id], ['nami_id' => $group->id, 'name' => $group->name]);
$this->api->subgroupsOf($group->id)->each(function ($subgroup) use ($parent) { $this->syncChildren($group->id, $parent);
Group::updateOrCreate(['nami_id' => $subgroup->id], ['nami_id' => $subgroup->id, 'name' => $subgroup->name, 'parent_id' => $parent->id]); });
}); }
private function syncChildren(int $groupId, Group $parent): void
{
$this->api->subgroupsOf($groupId)->each(function ($subgroup) use ($parent) {
$newParent = Group::updateOrCreate(['nami_id' => $subgroup->id], ['nami_id' => $subgroup->id, 'name' => $subgroup->name, 'parent_id' => $parent->id]);
$this->syncChildren($subgroup->id, $newParent);
}); });
} }
} }

View File

@ -8,6 +8,7 @@ class Initializer
{ {
public NamiSettings $settings; public NamiSettings $settings;
public array $initializers = [ public array $initializers = [
InitializeGroups::class,
InitializeNationalities::class, InitializeNationalities::class,
InitializeFees::class, InitializeFees::class,
InitializeConfessions::class, InitializeConfessions::class,

View File

@ -73,9 +73,13 @@ class InitializeGroupsTest extends TestCase
$this->api->method('groups')->willReturn( $this->api->method('groups')->willReturn(
collect([(new Group())->setParentId(null)->setId(150)->setName('lorem')]) collect([(new Group())->setParentId(null)->setId(150)->setName('lorem')])
); );
$this->api->method('subgroupsOf')->willReturn( $this->api->method('subgroupsOf')->willReturnCallback(function ($groupId) {
collect([(new Group())->setParentId(150)->setId(200)->setName('subgroup')]) if (150 === $groupId) {
); return collect([(new Group())->setParentId(150)->setId(200)->setName('subgroup')]);
}
return collect([]);
});
(new InitializeGroups($this->api))->handle(); (new InitializeGroups($this->api))->handle();
@ -85,15 +89,41 @@ class InitializeGroupsTest extends TestCase
$this->assertEquals(150, $subgroup->parent->nami_id); $this->assertEquals(150, $subgroup->parent->nami_id);
} }
public function testItSynchsSubgroupsOfSubgroups(): void
{
GroupModel::factory()->create(['nami_id' => 150]);
$this->api->method('groups')->willReturn(
collect([(new Group())->setParentId(null)->setId(150)->setName('lorem')])
);
$this->api->method('subgroupsOf')->willReturnCallback(function ($groupId) {
if (150 === $groupId) {
return collect([(new Group())->setParentId(150)->setId(200)->setName('subgroup')]);
}
if (200 === $groupId) {
return collect([(new Group())->setParentId(200)->setId(201)->setName('subsubgroup')]);
}
return collect([]);
});
(new InitializeGroups($this->api))->handle();
$this->assertDatabaseCount('groups', 3);
}
public function testItAssignsIdAndParentToAnExistingSubgroup(): void public function testItAssignsIdAndParentToAnExistingSubgroup(): void
{ {
GroupModel::factory()->create(['nami_id' => 200]); GroupModel::factory()->create(['nami_id' => 200]);
$this->api->method('groups')->willReturn( $this->api->method('groups')->willReturn(
collect([(new Group())->setParentId(null)->setId(150)->setName('root')]) collect([(new Group())->setParentId(null)->setId(150)->setName('root')])
); );
$this->api->method('subgroupsOf')->willReturn( $this->api->method('subgroupsOf')->willReturnCallback(function ($groupId) {
collect([(new Group())->setParentId(150)->setId(200)->setName('child')]) if (150 === $groupId) {
); return collect([(new Group())->setParentId(150)->setId(200)->setName('child')]);
}
return collect([]);
});
(new InitializeGroups($this->api))->handle(); (new InitializeGroups($this->api))->handle();