adrema/tests/Feature/Initialize/InitializeTest.php

366 lines
12 KiB
PHP
Raw Normal View History

2021-11-17 22:32:52 +01:00
<?php
namespace Tests\Feature\Initialize;
use App\Activity;
use App\Country;
2021-11-19 22:58:27 +01:00
use App\Course\Models\Course;
2021-11-17 22:32:52 +01:00
use App\Gender;
use App\Group;
2021-11-18 01:54:27 +01:00
use App\Member\Member;
2021-11-17 22:32:52 +01:00
use App\Nationality;
2022-01-03 01:17:24 +01:00
use App\Setting\GeneralSettings;
use App\Subactivity;
2021-11-17 22:32:52 +01:00
use Illuminate\Foundation\Testing\RefreshDatabase;
use Illuminate\Foundation\Testing\WithFaker;
2022-01-03 01:17:24 +01:00
use Illuminate\Support\Facades\Artisan;
2021-11-17 22:32:52 +01:00
use Illuminate\Support\Facades\Http;
use Tests\TestCase;
use Zoomyboy\LaravelNami\Backend\FakeBackend;
class InitializeTest extends TestCase
{
use RefreshDatabase;
2021-11-17 23:41:04 +01:00
public function initializeProvider(callable $callback = null): void
2021-11-17 22:32:52 +01:00
{
2021-11-17 23:41:04 +01:00
$backend = app(FakeBackend::class)
2021-11-18 19:55:03 +01:00
->fakeLogin('123')
2021-11-17 22:32:52 +01:00
->addSearch(123, ['entries_vorname' => '::firstname::', 'entries_nachname' => '::lastname::', 'entries_gruppierungId' => 1000])
->fakeNationalities([['name' => 'deutsch', 'id' => 291]])
->fakeFees(1000, [['name' => 'Family', 'id' => 300]])
->fakeConfessions([['name' => 'Konf', 'id' => 301]])
->fakeCountries([['name' => 'Germany', 'id' => 302]])
->fakeGenders([['name' => 'Male', 'id' => 303]])
->fakeRegions([['name' => 'nrw', 'id' => 304]])
2021-11-18 01:54:27 +01:00
->fakeCourses([['name' => '1a', 'id' => 506]])
->fakeActivities(1000, [['name' => '€ leiter', 'id' => 305]]);
2021-11-17 23:41:04 +01:00
if (!$callback) {
$backend->fakeMember([
2021-11-17 22:32:52 +01:00
'vorname' => '::firstname::',
'nachname' => '::lastname::',
'beitragsartId' => 300,
'geburtsDatum' => '2014-07-11 00:00:00',
'gruppierungId' => 1000,
'id' => 411,
'eintrittsdatum' => '2020-11-17 00:00:00',
'geschlechtId' => 303,
'landId' => 302,
'staatsangehoerigkeitId' => 291,
'zeitschriftenversand' => true,
'strasse' => '::street',
'plz' => '12346',
2021-11-17 22:32:52 +01:00
'ort' => '::location::',
2021-11-18 00:09:37 +01:00
'gruppierung' => '::group::',
2021-11-17 22:32:52 +01:00
'version' => 40,
]);
2021-11-17 23:41:04 +01:00
} else {
$callback($backend);
}
$backend->fakeSubactivities([
305 => [['name' => 'wö', 'id' => 306]]
]);
}
2021-11-18 01:54:27 +01:00
public function testItInitializesAll(): void
2021-11-17 23:41:04 +01:00
{
$this->withoutExceptionHandling();
$this->initializeProvider();
2021-11-23 01:02:18 +01:00
$this->login();
2021-11-17 22:32:52 +01:00
$this->post('/initialize');
$this->assertDatabaseHas('regions', [
'name' => 'nrw',
'nami_id' => 304
]);
$this->assertDatabaseHas('genders', [
'name' => 'Male',
'nami_id' => 303
]);
$this->assertDatabaseHas('nationalities', [
'name' => 'deutsch',
'nami_id' => 291
]);
$this->assertDatabaseHas('fees', [
'name' => 'Family',
'nami_id' => 300
]);
$this->assertDatabaseHas('confessions', [
'name' => 'Konf',
'nami_id' => 301
]);
$this->assertDatabaseHas('countries', [
'name' => 'Germany',
'nami_id' => 302
]);
$this->assertDatabaseHas('activities', [
'name' => '€ Leiter',
2021-11-17 22:32:52 +01:00
'nami_id' => 305
]);
2021-11-18 01:54:27 +01:00
$this->assertDatabaseHas('courses', [
'name' => '1a',
'nami_id' => 506
]);
2021-11-18 00:09:37 +01:00
$this->assertDatabaseHas('groups', ['nami_id' => 1000, 'name' => '::group::']);
2021-11-17 22:32:52 +01:00
$this->assertDatabaseHas('members', [
'nami_id' => 411,
'gender_id' => Gender::nami(303)->id,
'country_id' => Country::nami(302)->id,
'nationality_id' => Nationality::nami(291)->id,
'send_newspaper' => 1,
'address' => '::street',
'zip' => '12346',
2021-11-17 22:32:52 +01:00
'location' => '::location::',
'version' => 40,
]);
$this->assertEquals([306], Activity::where('nami_id', 305)->firstOrFail()->subactivities()->pluck('nami_id')->toArray());
2021-11-17 22:32:52 +01:00
Http::assertSentCount(16);
2021-11-18 01:54:27 +01:00
}
2022-01-03 01:17:24 +01:00
public function testItInitializesFromCommandLine(): void
{
$this->withoutExceptionHandling();
$this->initializeProvider();
GeneralSettings::fake(['allowed_nami_accounts' => [123]]);
Artisan::call('nami:initialize', [
'--mglnr' => 90166,
'--password' => 'secret',
'--group_id' => 1000,
]);
$this->assertDatabaseHas('regions', [
'name' => 'nrw',
'nami_id' => 304
]);
}
2021-11-18 01:54:27 +01:00
public function testSyncCoursesOfMember(): void
{
$this->withoutExceptionHandling();
$this->initializeProvider(function($backend) {
$backend->fakeMembers([
2021-11-18 02:16:29 +01:00
$this->member(['courses' => [ ['bausteinId' => 506, 'id' => 788, 'veranstalter' => 'KJA', 'vstgName' => 'eventname', 'vstgTag' => '2021-11-12 00:00:00'] ]])
2021-11-18 01:54:27 +01:00
]);
});
2021-11-23 01:02:18 +01:00
$this->login();
2021-11-18 01:54:27 +01:00
$this->post('/initialize');
2021-11-20 00:48:42 +01:00
$this->assertDatabaseHas('course_members', [
2021-11-18 01:54:27 +01:00
'member_id' => Member::where('firstname', '::firstname::')->firstOrFail()->id,
'course_id' => Course::where('name', '1a')->firstOrFail()->id,
'event_name' => 'eventname',
'completed_at' => '2021-11-12',
'organizer' => 'KJA',
'nami_id' => 788,
]);
2021-11-17 22:32:52 +01:00
}
2021-11-17 23:41:04 +01:00
public function membershipDataProvider() {
return [
'fetch_group_from_backend' => [
[
'gruppierung' => '::newgroup:: 22',
'id' => 1077,
'taetigkeit' => '::newtaetigkeit:: (9001)',
],
function($db) {
$db->assertDatabaseHas('activities', ['name' => '::newtaetigkeit::', 'nami_id' => 4000]);
$db->assertDatabaseHas('groups', ['name' => '::newgroup::', 'nami_id' => 9056]);
$db->assertDatabaseHas('activity_subactivity', [
'activity_id' => Activity::where('nami_id', 4000)->firstOrFail()->id,
'subactivity_id' => Subactivity::where('nami_id', 306)->firstOrFail()->id,
]);
$db->assertDatabaseHas('memberships', [
'activity_id' => Activity::where('nami_id', 4000)->firstOrFail()->id,
'group_id' => Group::where('nami_id', 9056)->firstOrFail()->id,
'nami_id' => 1077,
]);
},
function($backend) {
return $backend->fakeSingleMembership(116, 1077, [
'aktivVon' => '2021-08-22 00:00:00',
'aktivBis' => '',
'gruppierungId' => 9056,
'gruppierung' => '::newgroup::',
'id' => 1077,
'taetigkeit' => '::newtaetigkeit::',
'taetigkeitId' => 4000,
'untergliederungId' => 306,
])
->fakeActivities(9056, [['name' => '::newtaetigkeit::', 'id' => 4000]])
->fakeSubactivities([
4000 => [['name' => 'wö', 'id' => 306]]
]);
}
],
'normal' => [
[
'aktivVon' => '2021-08-22 00:00:00',
'aktivBis' => '',
'gruppierung' => '::group::',
'id' => 1077,
'taetigkeit' => '€ leiter (305)',
'untergliederung' => 'wö',
],
function($db) {
$db->assertDatabaseHas('memberships', [
'member_id' => Member::where('firstname', '::firstname::')->firstOrFail()->id,
'activity_id' => Activity::where('nami_id', 305)->firstOrFail()->id,
'subactivity_id' => Subactivity::where('nami_id', 306)->firstOrFail()->id,
'nami_id' => 1077,
'created_at' => '2021-08-22 00:00:00',
'group_id' => Group::where('name', '::group::')->firstOrFail()->id,
]);
},
],
'new_group' => [
[
'gruppierung' => '::new group:: 5555',
],
function($db) {
$db->assertDatabaseHas('groups', ['name' => '::new group::', 'nami_id' => 5555]);
},
],
'no_subactivity' => [
[
'untergliederung' => '',
],
function($db) {
$db->assertDatabaseHas('memberships', ['subactivity_id' => null]);
},
],
'no_wrong_dates' => [
[
'aktivVon' => '1014-04-01 00:00:00',
],
function($db) {
$db->assertDatabaseCount('memberships', 0);
},
],
'not_inactive' => [
[
'aktivBis' => '2021-08-25 00:00:00',
],
function($db) {
$db->assertDatabaseCount('memberships', 0);
},
],
];
}
/**
* @dataProvider membershipDataProvider
*/
public function testSyncMembershipsOfMember(array $membership, callable $dbcheck, ?callable $backendCallback = null): void
{
if (!$backendCallback) {
$backendCallback = function($backend) { return $backend; };
}
$this->withoutExceptionHandling();
$this->initializeProvider(function($backend) use ($membership, $backendCallback) {
$backend->fakeMembers([
$this->member([
'memberships' => [array_merge([
'aktivVon' => '2021-08-22 00:00:00',
'aktivBis' => '',
'gruppierung' => '::group::',
'id' => 1077,
'taetigkeit' => 'leiter (305)',
'untergliederung' => 'wö',
], $membership)],
])
]);
$backendCallback($backend);
});
$this->login();
$this->post('/initialize');
$dbcheck($this);
}
public function testItDoesntGetMembersWithNoJoinedAtDate(): void
{
$this->withoutExceptionHandling();
$this->initializeProvider(function($backend) {
$backend->fakeMembers([$this->member(['eintrittsdatum' => null])]);
});
2021-11-23 01:02:18 +01:00
$this->login();
$this->post('/initialize');
$this->assertDatabaseCount('members', 0);
}
2021-11-17 23:41:04 +01:00
/**
* @return array<int, array<int, int>>
*/
public function pageProvider(): array
{
return [
[99],
[100],
[101],
[199],
[200],
[201],
];
}
/**
* @dataProvider pageProvider
*/
public function testItInitializesPages(int $num): void
2021-11-17 23:41:04 +01:00
{
$this->withoutExceptionHandling();
$this->initializeProvider(function($backend) use ($num) {
$members = collect([]);
foreach (range(1, $num) as $i) {
$members->push($this->member(['id' => $i]));
2021-11-17 23:41:04 +01:00
}
$backend->fakeMembers($members->toArray());
});
2021-11-23 01:02:18 +01:00
$this->login();
2021-11-17 23:41:04 +01:00
$this->post('/initialize');
$this->assertDatabaseCount('members', $num);
}
/**
* @param array<string, mixed> $overwrites
* @return array<string, mixed>
*/
private function member(array $overwrites): array
{
return array_merge([
'vorname' => '::firstname::',
'nachname' => '::lastname::',
'beitragsartId' => 300,
'geburtsDatum' => '2014-07-11 00:00:00',
'gruppierungId' => 1000,
'geschlechtId' => 303,
'id' => 116,
'eintrittsdatum' => '2020-11-17 00:00:00',
'landId' => 302,
'staatsangehoerigkeitId' => 291,
'zeitschriftenversand' => true,
'strasse' => '::street',
'plz' => '12346',
'ort' => '::location::',
'version' => 40,
'gruppierung' => '::group::',
], $overwrites);
}
2021-11-17 22:32:52 +01:00
}