Compare commits

..

No commits in common. "5a48c983cd691ecee8d1df40533f066cee0ab0ba" and "37c9021e762bb9f6ca15e049ca49f2b0746fc420" have entirely different histories.

10 changed files with 459 additions and 486 deletions

View File

@ -84,9 +84,6 @@ class MemberRequest extends FormRequest
'salutation' => '', 'salutation' => '',
'comment' => '', 'comment' => '',
'keepdata' => 'boolean', 'keepdata' => 'boolean',
'bank_account' => 'array|exclude',
'bank_account.iban' => 'nullable|string|max:255',
'bank_account.bic' => 'nullable|string|max:255',
]; ];
} }
@ -97,7 +94,6 @@ class MemberRequest extends FormRequest
'group_id' => Group::where('nami_id', $settings->default_group_id)->firstOrFail()->id, 'group_id' => Group::where('nami_id', $settings->default_group_id)->firstOrFail()->id,
]); ]);
$member->updatePhoneNumbers()->save(); $member->updatePhoneNumbers()->save();
$member->bankAccount->update($this->input('bank_account'));
if ($this->input('has_nami')) { if ($this->input('has_nami')) {
$this->storeFreshMemberInNami($member); $this->storeFreshMemberInNami($member);
@ -121,7 +117,6 @@ class MemberRequest extends FormRequest
$namiSync = $member->isDirty(Member::$namiFields); $namiSync = $member->isDirty(Member::$namiFields);
$member->save(); $member->save();
$member->bankAccount->update($this->input('bank_account'));
if ($this->input('has_nami') && null === $member->nami_id) { if ($this->input('has_nami') && null === $member->nami_id) {
$this->storeFreshMemberInNami($member); $this->storeFreshMemberInNami($member);

View File

@ -1,7 +1,7 @@
#!/bin/bash #!/bin/bash
echo "drop database adrema;" | sudo mysql echo "drop database scoutrobot;" | sudo mysql
echo "create database adrema;" | sudo mysql echo "create database scoutrobot;" | sudo mysql
ssh -l stamm-silva zoomyboy.de "cd /usr/share/webapps/adrema_silva && docker compose exec db mysqldump -udb -p$SCOUTROBOT_DB_PASSWORD db" > db.tmp ssh -l stamm-silva zoomyboy.de "cd /usr/share/webapps/adrema_silva && docker compose exec db mysqldump -udb -p$SCOUTROBOT_DB_PASSWORD db" > db.tmp
sudo mysql adrema < db.tmp sudo mysql adrema < db.tmp

View File

@ -93,11 +93,6 @@ class MemberFactory extends Factory
return $this->state(['nami_id' => $namiId]); return $this->state(['nami_id' => $namiId]);
} }
public function notInNami(): self
{
return $this->state(['nami_id' => null]);
}
public function withBankAccount(BankAccountFactory $factory): self public function withBankAccount(BankAccountFactory $factory): self
{ {
return $this->afterCreating(function ($member) use ($factory) { return $this->afterCreating(function ($member) use ($factory) {

View File

@ -1,6 +1,5 @@
<?php <?php
use App\Member\Member;
use Illuminate\Database\Migrations\Migration; use Illuminate\Database\Migrations\Migration;
use Illuminate\Database\Schema\Blueprint; use Illuminate\Database\Schema\Blueprint;
use Illuminate\Support\Facades\Schema; use Illuminate\Support\Facades\Schema;
@ -23,10 +22,6 @@ return new class extends Migration
$table->string('account_number')->nullable(); $table->string('account_number')->nullable();
$table->timestamps(); $table->timestamps();
}); });
foreach (Member::get() as $member) {
$member->bankAccount()->create([]);
}
} }
/** /**

@ -1 +1 @@
Subproject commit c20cf930f2037ddda4400dd7d35bf9ef707356eb Subproject commit f905c316ee7913cbf85c386021fbaa28b4b2a158

View File

@ -17,242 +17,277 @@ use App\Region;
use App\Subactivity; use App\Subactivity;
use Illuminate\Foundation\Testing\DatabaseTransactions; use Illuminate\Foundation\Testing\DatabaseTransactions;
use Tests\Lib\MergesAttributes; use Tests\Lib\MergesAttributes;
use Tests\RequestFactories\MemberStoreRequestFactory;
use Tests\TestCase; use Tests\TestCase;
use Zoomyboy\LaravelNami\Fakes\MemberFake; use Zoomyboy\LaravelNami\Fakes\MemberFake;
uses(DatabaseTransactions::class); class StoreTest extends TestCase
{
use DatabaseTransactions;
use MergesAttributes;
beforeEach(function () { public function testItCanStoreAMember(): void
Confession::factory()->create(['is_null' => true]); {
PullMemberAction::shouldRun(); app(MemberFake::class)->stores(55, 103);
PullMembershipsAction::shouldRun(); Fee::factory()->create();
}); $this->withoutExceptionHandling()->login()->loginNami();
$country = Country::factory()->create();
$gender = Gender::factory()->create();
$region = Region::factory()->create();
$nationality = Nationality::factory()->create();
$activity = Activity::factory()->inNami(89)->create();
$subactivity = Subactivity::factory()->inNami(90)->create();
$subscription = Subscription::factory()->forFee()->create();
$confesstion = Confession::factory()->create(['is_null' => true]);
PullMemberAction::shouldRun();
PullMembershipsAction::shouldRun();
it('can store a member', function () { $response = $this
app(MemberFake::class)->stores(55, 103); ->from('/member/create')
Fee::factory()->create(); ->post('/member', $this->attributes([
$this->withoutExceptionHandling()->login()->loginNami(); 'country_id' => $country->id,
$country = Country::factory()->create(); 'gender_id' => $gender->id,
$gender = Gender::factory()->create(); 'region_id' => $region->id,
$region = Region::factory()->create(); 'nationality_id' => $nationality->id,
$nationality = Nationality::factory()->create(); 'first_activity_id' => $activity->id,
$activity = Activity::factory()->inNami(89)->create(); 'first_subactivity_id' => $subactivity->id,
$subactivity = Subactivity::factory()->inNami(90)->create(); 'subscription_id' => $subscription->id,
$subscription = Subscription::factory()->forFee()->create(); 'bill_kind' => 'Post',
'salutation' => 'Doktor',
'comment' => 'Lorem bla',
]))->assertSessionHasNoErrors();
$response = $this $response->assertRedirect('/member')->assertSessionHasNoErrors();
->from('/member/create') $member = Member::firstWhere('firstname', 'Joe');
->post('/member', MemberStoreRequestFactory::new()->create([ $this->assertDatabaseHas('members', [
'country_id' => $country->id, 'address' => 'Bavert 50',
'gender_id' => $gender->id,
'region_id' => $region->id,
'nationality_id' => $nationality->id,
'first_activity_id' => $activity->id,
'first_subactivity_id' => $subactivity->id,
'subscription_id' => $subscription->id,
'bill_kind' => 'Post', 'bill_kind' => 'Post',
'birthday' => '2013-02-19',
'children_phone' => '+49 176 70512778',
'country_id' => $country->id,
'email_parents' => 'osloot@aol.com',
'firstname' => 'Joe',
'gender_id' => $gender->id,
'joined_at' => '2022-08-12',
'lastname' => 'Muster',
'letter_address' => null,
'location' => 'Solingen',
'main_phone' => '+49 212 337056',
'mobile_phone' => '+49 176 70512774',
'nationality_id' => $nationality->id,
'region_id' => $region->id,
'send_newspaper' => '1',
'subscription_id' => $subscription->id,
'zip' => '42719',
'fax' => '+49 212 4732223',
'salutation' => 'Doktor', 'salutation' => 'Doktor',
'comment' => 'Lorem bla', 'comment' => 'Lorem bla',
]))->assertSessionHasNoErrors(); ]);
$response->assertRedirect('/member')->assertSessionHasNoErrors(); app(MemberFake::class)->assertStored(55, [
$this->assertDatabaseHas('members', [ 'ersteTaetigkeitId' => 89,
'address' => 'Bavert 50', 'ersteUntergliederungId' => 90,
'bill_kind' => 'Post', ]);
'birthday' => '2013-02-19', }
'children_phone' => '+49 176 70512778',
'country_id' => $country->id,
'email_parents' => 'osloot@aol.com',
'firstname' => 'Joe',
'gender_id' => $gender->id,
'joined_at' => '2022-08-12',
'lastname' => 'Muster',
'letter_address' => null,
'location' => 'Solingen',
'main_phone' => '+49 212 337056',
'mobile_phone' => '+49 176 70512774',
'nationality_id' => $nationality->id,
'region_id' => $region->id,
'send_newspaper' => '1',
'subscription_id' => $subscription->id,
'zip' => '42719',
'fax' => '+49 212 4732223',
'salutation' => 'Doktor',
'comment' => 'Lorem bla',
]);
app(MemberFake::class)->assertStored(55, [ public function testItStoresWiederverwendenFlag(): void
'ersteTaetigkeitId' => 89, {
'ersteUntergliederungId' => 90, app(MemberFake::class)->stores(55, 103);
]); Fee::factory()->create();
}); $this->withoutExceptionHandling()->login()->loginNami();
$activity = Activity::factory()->inNami(89)->create();
$subactivity = Subactivity::factory()->inNami(90)->create();
$subscription = Subscription::factory()->forFee()->create();
$confesstion = Confession::factory()->create(['is_null' => true]);
PullMemberAction::shouldRun();
PullMembershipsAction::shouldRun();
it('can store iban and bic', function () { $this
app(MemberFake::class)->stores(55, 103); ->from('/member/create')
Fee::factory()->create(); ->post('/member', $this->attributes([
$this->withoutExceptionHandling()->login()->loginNami(); 'first_activity_id' => $activity->id,
'first_subactivity_id' => $subactivity->id,
'subscription_id' => $subscription->id,
'keepdata' => true,
]))->assertSessionHasNoErrors();
$this->post('/member', MemberStoreRequestFactory::new()->create([ $this->assertDatabaseHas('members', [
'bank_account.iban' => '666',
'bank_account.bic' => 'SOLSDE',
]))->assertSessionHasNoErrors();
$this->assertDatabaseHas('bank_accounts', [
'iban' => '666',
'bic' => 'SOLSDE',
'member_id' => Member::first()->id,
]);
app(MemberFake::class)->assertStored(55, function ($payload) {
$bank = json_decode($payload['kontoverbindung'], true);
return $bank['iban'] === '666' && $bank['bic'] === 'SOLSDE';
});
});
it('testItStoresWiederverwendenFlag', function () {
app(MemberFake::class)->stores(55, 103);
Fee::factory()->create();
$this->withoutExceptionHandling()->login()->loginNami();
$activity = Activity::factory()->inNami(89)->create();
$subactivity = Subactivity::factory()->inNami(90)->create();
$subscription = Subscription::factory()->forFee()->create();
$this
->from('/member/create')
->post('/member', MemberStoreRequestFactory::new()->create([
'first_activity_id' => $activity->id,
'first_subactivity_id' => $subactivity->id,
'subscription_id' => $subscription->id,
'keepdata' => true, 'keepdata' => true,
]))->assertSessionHasNoErrors(); ]);
app(MemberFake::class)->assertStored(55, [
'wiederverwendenFlag' => true,
]);
}
$this->assertDatabaseHas('members', [ public function testItCanStoreAMemberWithoutNami(): void
'keepdata' => true, {
]); $this->withoutExceptionHandling()->login()->loginNami();
app(MemberFake::class)->assertStored(55, [ $activity = Activity::factory()->create();
'wiederverwendenFlag' => true, $subactivity = Subactivity::factory()->create();
]);
});
it('testItCanStoreAMemberWithoutNami', function () { $response = $this
$this->withoutExceptionHandling()->login()->loginNami(); ->from('/member/create')
$activity = Activity::factory()->create(); ->post('/member', $this->attributes([
$subactivity = Subactivity::factory()->create(); 'first_activity_id' => $activity->id,
'first_subactivity_id' => $subactivity->id,
'has_nami' => false,
]));
$response = $this $response->assertSessionHasNoErrors();
->from('/member/create') $this->assertDatabaseHas('members', [
->post('/member', MemberStoreRequestFactory::new()->create([ 'nami_id' => null,
'first_activity_id' => $activity->id, ]);
'first_subactivity_id' => $subactivity->id, NamiPutMemberAction::spy()->shouldNotHaveReceived('handle');
}
public function testItUpdatesPhoneNumber(): void
{
$this->withoutExceptionHandling()->login()->loginNami();
$this->post('/member', $this->attributes([
'has_nami' => false, 'has_nami' => false,
'main_phone' => '02103 4455129',
'fax' => '02103 4455130',
'children_phone' => '02103 4455130',
])); ]));
$response->assertSessionHasNoErrors(); $this->assertDatabaseHas('members', [
$this->assertDatabaseHas('members', [ 'main_phone' => '+49 2103 4455129',
'nami_id' => null, 'fax' => '+49 2103 4455130',
]); 'children_phone' => '+49 2103 4455130',
NamiPutMemberAction::spy()->shouldNotHaveReceived('handle'); ]);
}); }
it('testItUpdatesPhoneNumber', function () { public function testItHasErrorWhenPhoneNumberIsInvalid(): void
$this->withoutExceptionHandling()->login()->loginNami(); {
$this->login()->loginNami();
$this->post('/member', MemberStoreRequestFactory::new()->create([ $response = $this->post('/member', $this->attributes([
'has_nami' => false, 'has_nami' => false,
'main_phone' => '02103 4455129', 'main_phone' => '1111111111111111',
'fax' => '02103 4455130', 'mobile_phone' => '1111111111111111',
'children_phone' => '02103 4455130', 'fax' => '1111111111111111',
])); 'children_phone' => '1111111111111111',
]));
$this->assertDatabaseHas('members', [ $response->assertSessionHasErrors([
'main_phone' => '+49 2103 4455129', 'main_phone' => 'Telefon (Eltern) ist keine valide Nummer.',
'fax' => '+49 2103 4455130', 'mobile_phone' => 'Handy (Eltern) ist keine valide Nummer.',
'children_phone' => '+49 2103 4455130', 'children_phone' => 'Telefon (Kind) ist keine valide Nummer.',
]); 'fax' => 'Fax ist keine valide Nummer.',
}); ]);
}
it('testItHasErrorWhenPhoneNumberIsInvalid', function () { public function testItDoesntRequireBirthdayWhenNotInNami(): void
$this->login()->loginNami(); {
$this->login()->loginNami();
$response = $this->post('/member', MemberStoreRequestFactory::new()->create([ $this
'has_nami' => false, ->post('/member', $this->attributes([
'main_phone' => '1111111111111111', 'nationality_id' => null,
'mobile_phone' => '1111111111111111', 'birthday' => null,
'fax' => '1111111111111111', 'has_nami' => false,
'children_phone' => '1111111111111111', 'address' => null,
])); 'zip' => null,
'location' => null,
$response->assertSessionHasErrors([ 'joined_at' => null,
'main_phone' => 'Telefon (Eltern) ist keine valide Nummer.', ]))->assertSessionDoesntHaveErrors();
'mobile_phone' => 'Handy (Eltern) ist keine valide Nummer.', $this->assertDatabaseHas('members', [
'children_phone' => 'Telefon (Kind) ist keine valide Nummer.',
'fax' => 'Fax ist keine valide Nummer.',
]);
});
it('testItDoesntRequireBirthdayWhenNotInNami', function () {
$this->login()->loginNami();
$this
->post('/member', MemberStoreRequestFactory::new()->create([
'nationality_id' => null, 'nationality_id' => null,
'birthday' => null, 'birthday' => null,
'has_nami' => false,
'address' => null, 'address' => null,
'zip' => null, 'zip' => null,
'location' => null, 'location' => null,
'joined_at' => null, 'joined_at' => null,
]))->assertSessionDoesntHaveErrors(); ]);
$this->assertDatabaseHas('members', [ }
'nationality_id' => null,
'birthday' => null,
'address' => null,
'zip' => null,
'location' => null,
'joined_at' => null,
]);
});
it('testItDoesntNeedSubscription', function () { public function testItDoesntNeedSubscription(): void
$this->login()->loginNami(); {
$this->login()->loginNami();
$this $this
->post('/member', MemberStoreRequestFactory::new()->create([ ->post('/member', $this->attributes([
'has_nami' => false, 'has_nami' => false,
'subscription_id' => null,
]))->assertSessionDoesntHaveErrors();
$this->assertDatabaseHas('members', [
'subscription_id' => null, 'subscription_id' => null,
]))->assertSessionDoesntHaveErrors(); ]);
$this->assertDatabaseHas('members', [ }
'subscription_id' => null,
]);
});
it('testItRequiresFields', function () { public function testItRequiresFields(): void
$this->login()->loginNami(); {
$this->login()->loginNami();
$this $this
->post('/member', MemberStoreRequestFactory::new()->create([ ->post('/member', $this->attributes([
'nationality_id' => null, 'nationality_id' => null,
'birthday' => '', 'birthday' => '',
'address' => '', 'address' => '',
'zip' => '', 'zip' => '',
'location' => '', 'location' => '',
'joined_at' => '', 'joined_at' => '',
])) ]))
->assertSessionHasErrors(['nationality_id', 'birthday', 'address', 'zip', 'location', 'joined_at']); ->assertSessionHasErrors(['nationality_id', 'birthday', 'address', 'zip', 'location', 'joined_at']);
}); }
it('testSubscriptionIsRequiredIfFirstActivityIsPaid', function () { public function testSubscriptionIsRequiredIfFirstActivityIsPaid(): void
$this->login()->loginNami(); {
$activity = Activity::factory()->name('€ Mitglied')->create(); $this->login()->loginNami();
$subactivity = Subactivity::factory()->create(); $activity = Activity::factory()->name('€ Mitglied')->create();
$subactivity = Subactivity::factory()->create();
$this $this
->from('/member/create') ->from('/member/create')
->post('/member', MemberStoreRequestFactory::new()->create([ ->post('/member', $this->attributes([
'first_activity_id' => $activity->id, 'first_activity_id' => $activity->id,
'first_subactivity_id' => $subactivity->id, 'first_subactivity_id' => $subactivity->id,
'subscription_id' => null, 'subscription_id' => null,
])) ]))
->assertSessionHasErrors(['subscription_id' => 'Beitragsart ist erforderlich.']); ->assertSessionHasErrors(['subscription_id' => 'Beitragsart ist erforderlich.']);
}); }
/**
* @return array<string, mixed>
*/
public function defaults(): array
{
$country = Country::factory()->create();
$nationality = Nationality::factory()->create();
$subscription = Subscription::factory()->forFee()->create();
return [
'address' => 'Bavert 50',
'birthday' => '2013-02-19',
'children_phone' => '+49 176 70512778',
'efz' => '',
'email' => '',
'email_parents' => 'osloot@aol.com',
'fax' => '+49 212 4732223',
'firstname' => 'Joe',
'further_address' => '',
'has_nami' => true,
'has_svk' => false,
'has_vk' => false,
'joined_at' => '2022-08-12',
'lastname' => 'Muster',
'letter_address' => '',
'location' => 'Solingen',
'main_phone' => '+49 212 337056',
'mobile_phone' => '+49 176 70512774',
'more_ps_at' => '',
'multiply_more_pv' => false,
'multiply_pv' => false,
'other_country' => '',
'ps_at' => '',
'send_newspaper' => true,
'without_education_at' => '',
'without_efz_at' => '',
'work_phone' => '',
'zip' => '42719',
'country_id' => $country->id,
'nationality_id' => $nationality->id,
'subscription_id' => $subscription->id,
];
}
}

View File

@ -6,239 +6,238 @@ use App\Actions\PullMemberAction;
use App\Actions\PullMembershipsAction; use App\Actions\PullMembershipsAction;
use App\Activity; use App\Activity;
use App\Confession; use App\Confession;
use App\Country;
use App\Fee;
use App\Group; use App\Group;
use App\Member\Actions\NamiPutMemberAction; use App\Member\Actions\NamiPutMemberAction;
use App\Member\Member; use App\Member\Member;
use App\Nationality;
use App\Payment\Subscription;
use App\Subactivity; use App\Subactivity;
use Illuminate\Foundation\Testing\DatabaseTransactions; use Illuminate\Foundation\Testing\DatabaseTransactions;
use Illuminate\Support\Facades\Http; use Illuminate\Support\Facades\Http;
use Tests\RequestFactories\MemberUpdateRequestFactory; use Tests\TestCase;
use Zoomyboy\LaravelNami\Fakes\MemberFake; use Zoomyboy\LaravelNami\Fakes\MemberFake;
uses(DatabaseTransactions::class); class UpdateTest extends TestCase
function singleMemberUrl(int $gruppierungId, int $memberId): string
{ {
return "https://nami.dpsg.de/ica/rest/nami/mitglied/filtered-for-navigation/gruppierung/gruppierung/{$gruppierungId}/{$memberId}"; use DatabaseTransactions;
}
beforeEach(function () { public function testItRedirectsToMemberOverview(): void
Confession::factory()->create(['is_null' => true]); {
}); $this->withoutExceptionHandling()->login()->loginNami();
$member = $this->member();
$this->fakeRequest();
NamiPutMemberAction::allowToRun();
function fakeRequest(): void $response = $this
{ ->from("/member/{$member->id}")
Http::fake(function ($request) { ->patch("/member/{$member->id}", array_merge($member->getAttributes(), ['has_nami' => true]));
if ($request->url() === singleMemberUrl(10, 135) && 'GET' === $request->method()) {
return Http::response('{ "success": true, "data": {"missingkey": "missingvalue", "kontoverbindung": {"a": "b"} } }', 200);
}
if ($request->url() === singleMemberUrl(10, 135) && 'PUT' === $request->method() && 43 === $request['version']) { $response->assertRedirect('/member');
return Http::response('{ "success": false, "message": "Update nicht möglich. Der Datensatz wurde zwischenzeitlich verändert." }', 200); NamiPutMemberAction::spy()->shouldHaveReceived('handle')->withArgs(
} fn (Member $memberParam, ?Activity $activityParam, ?Subactivity $subactivityParam) => $memberParam->is($member)
&& null === $activityParam
&& null === $subactivityParam
)->once();
}
if ($request->url() === singleMemberUrl(10, 135) && 'PUT' === $request->method()) { public function testItChecksVersion(): void
return Http::response('{ "success": true, "data": { "version": 44 } }', 200); {
} $this->login()->loginNami()->withoutExceptionHandling();
}); $member = $this->member();
} $member->update(['version' => 43]);
$this->fakeRequest();
function factory() $response = $this
{ ->from("/member/{$member->id}")
return Member::factory() ->patch("/member/{$member->id}", array_merge($member->getAttributes(), ['has_nami' => true, 'firstname' => '::firstname::']));
->defaults()
->for(Group::factory()->state(['nami_id' => 10]))
->state(['nami_id' => 135]);
}
it('calls put action', function () { $response->assertRedirect("/member/{$member->id}/edit?conflict=1");
$this->withoutExceptionHandling()->login()->loginNami(); }
$member = factory()->create();
fakeRequest();
NamiPutMemberAction::allowToRun();
$this->patch("/member/{$member->id}", MemberUpdateRequestFactory::new()->create()); public function testItUpdatesPhoneNumber(): void
{
$this->withoutExceptionHandling()->login()->loginNami();
$member = $this->member();
$this->fakeRequest();
NamiPutMemberAction::allowToRun();
NamiPutMemberAction::spy()->shouldHaveReceived('handle')->withArgs( $this->patch("/member/{$member->id}", array_merge($member->getAttributes(), [
fn (Member $memberParam, ?Activity $activityParam, ?Subactivity $subactivityParam) => $memberParam->is($member) 'main_phone' => '02103 4455129',
&& null === $activityParam 'fax' => '02103 4455130',
&& null === $subactivityParam 'children_phone' => '02103 4455130',
)->once(); 'has_nami' => true,
});
it('redirects to member overview', function () {
$this->withoutExceptionHandling()->login()->loginNami();
$member = factory()->create();
fakeRequest();
NamiPutMemberAction::allowToRun();
$this->patch("/member/{$member->id}", MemberUpdateRequestFactory::new()->create())
->assertRedirect('/member');
});
it('testItChecksVersion', function () {
$this->login()->loginNami()->withoutExceptionHandling();
$member = tap(factory()->create(), fn ($member) => $member->update(['version' => 43]));
fakeRequest();
$this->patch("/member/{$member->id}", array_merge($member->getAttributes(), MemberUpdateRequestFactory::new()->create()))
->assertRedirect("/member/{$member->id}/edit?conflict=1");
});
it('testItUpdatesPhoneNumber', function () {
$this->withoutExceptionHandling()->login()->loginNami();
$member = factory()->create();
fakeRequest();
NamiPutMemberAction::allowToRun();
$this->patch("/member/{$member->id}", MemberUpdateRequestFactory::new()->create([
'main_phone' => '02103 4455129',
'fax' => '02103 4455130',
'children_phone' => '02103 4455130',
]));
$this->assertDatabaseHas('members', [
'main_phone' => '+49 2103 4455129',
'fax' => '+49 2103 4455130',
'children_phone' => '+49 2103 4455130',
]);
});
it('testItUpdatesBankAccount', function () {
$this->withoutExceptionHandling()->login()->loginNami();
$member = factory()->create();
fakeRequest();
NamiPutMemberAction::allowToRun();
$this->patch("/member/{$member->id}", MemberUpdateRequestFactory::new()->create([
'bank_account' => [
'iban' => 'DE1122',
'bic' => 'SOLSDE',
'person' => 'Max'
]
]));
$this->assertDatabaseHas('bank_accounts', [
'iban' => 'DE1122',
'bic' => 'SOLSDE',
'person' => 'Max',
'member_id' => $member->id,
]);
});
it('testItUpdatesWiederverwendenFlag', function () {
$this->withoutExceptionHandling()->login()->loginNami();
$member = factory()->create();
fakeRequest();
NamiPutMemberAction::allowToRun();
$this->patch("/member/{$member->id}", MemberUpdateRequestFactory::new()->create([
'keepdata' => true,
]));
$this->assertDatabaseHas('members', [
'keepdata' => true,
]);
});
it('testItSetsLocationToNull', function () {
$this->withoutExceptionHandling()->login()->loginNami();
$member = factory()->notInNami()->create(['location' => 'Hilden']);
fakeRequest();
NamiPutMemberAction::allowToRun();
$this->patch("/member/{$member->id}", MemberUpdateRequestFactory::new()->noNami()->create([
'location' => null,
'bank_account' => []
]));
$this->assertDatabaseHas('members', [
'location' => null,
]);
});
it('testItUpdatesContact', function () {
$this->withoutExceptionHandling()->login()->loginNami();
$member = factory()->notInNami()->create();
fakeRequest();
$this->patch("/member/{$member->id}", MemberUpdateRequestFactory::new()->noNami()->create([
'other_country' => 'englisch',
'bank_account' => []
]));
$this->assertEquals('englisch', $member->fresh()->other_country);
});
it('testItCreatesMemberWithFirstActivityId', function () {
$this->login()->loginNami()->withoutExceptionHandling();
$member = factory()->new()->defaults()->create();
app(MemberFake::class)->stores($member->group->nami_id, 103);
$activity = Activity::factory()->inNami(89)->create();
$subactivity = Subactivity::factory()->inNami(90)->create();
Confession::factory()->create(['is_null' => true]);
PullMemberAction::shouldRun();
PullMembershipsAction::shouldRun();
$this->patch("/member/{$member->id}", MemberUpdateRequestFactory::new()->create([
'first_activity_id' => $activity->id,
'first_subactivity_id' => $subactivity->id,
]))->assertSessionHasNoErrors();
app(MemberFake::class)->assertStored($member->group->nami_id, [
'ersteTaetigkeitId' => 89,
'ersteUntergliederungId' => 90,
]);
});
it('testItRequiresFirstActivityId', function () {
$this->login()->loginNami();
$member = factory()->new()->defaults()->create();
app(MemberFake::class)->stores($member->group->nami_id, 103);
Confession::factory()->create(['is_null' => true]);
PullMemberAction::shouldRun();
PullMembershipsAction::shouldRun();
$this->patch("/member/{$member->id}", MemberUpdateRequestFactory::new()->create([
'first_activity_id' => null,
'first_subactivity_id' => null,
]))->assertSessionHasErrors([
'first_activity_id' => 'Erste Tätigkeit ist erforderlich.',
'first_subactivity_id' => 'Erste Untergliederung ist erforderlich.',
]);
});
it('testItUpdatesCriminalRecord', function () {
$this->withoutExceptionHandling()->login()->loginNami();
$member = factory()->notInNami()->create();
fakeRequest();
$this
->patch("/member/{$member->id}", MemberUpdateRequestFactory::new()->noNami()->create([
'ps_at' => '2021-02-01',
'more_ps_at' => '2021-02-02',
'has_svk' => true,
'has_vk' => true,
'efz' => '2021-02-03',
'without_education_at' => '2021-02-04',
'without_efz_at' => '2021-02-05',
'recertified_at' => '2021-02-08',
'has_nami' => false,
'multiply_pv' => true,
'multiply_more_pv' => true,
'salutation' => 'Doktor',
'bank_account' => []
])); ]));
$this->assertEquals('2021-02-01', $member->fresh()->ps_at->format('Y-m-d')); $this->assertDatabaseHas('members', [
$this->assertEquals('2021-02-02', $member->fresh()->more_ps_at->format('Y-m-d')); 'main_phone' => '+49 2103 4455129',
$this->assertTrue($member->fresh()->has_svk); 'fax' => '+49 2103 4455130',
$this->assertTrue($member->fresh()->has_vk); 'children_phone' => '+49 2103 4455130',
$this->assertTrue($member->fresh()->multiply_pv); ]);
$this->assertTrue($member->fresh()->multiply_more_pv); }
$this->assertEquals('2021-02-03', $member->fresh()->efz->format('Y-m-d'));
$this->assertEquals('2021-02-04', $member->fresh()->without_education_at->format('Y-m-d')); public function testItUpdatesWiederverwendenFlag(): void
$this->assertEquals('2021-02-05', $member->fresh()->without_efz_at->format('Y-m-d')); {
$this->assertEquals('2021-02-08', $member->fresh()->recertified_at->format('Y-m-d')); $this->withoutExceptionHandling()->login()->loginNami();
$this->assertEquals('Doktor', $member->fresh()->salutation); $member = $this->member();
}); $this->fakeRequest();
NamiPutMemberAction::allowToRun();
$this->patch("/member/{$member->id}", array_merge($member->getAttributes(), [
'keepdata' => true,
'has_nami' => true,
]));
$this->assertDatabaseHas('members', [
'keepdata' => true,
]);
}
public function testItSetsLocationToNull(): void
{
$this->withoutExceptionHandling()->login()->loginNami();
$member = $this->member(['location' => 'Hilden', 'nami_id' => null]);
$this->fakeRequest();
NamiPutMemberAction::allowToRun();
$this->patch("/member/{$member->id}", array_merge($member->getAttributes(), [
'location' => null,
]));
$this->assertDatabaseHas('members', [
'location' => null,
]);
}
public function testItUpdatesContact(): void
{
$this->withoutExceptionHandling()->login()->loginNami();
$member = $this->member(['nami_id' => null]);
$this->fakeRequest();
$response = $this
->from("/member/{$member->id}")
->patch("/member/{$member->id}", array_merge($member->getAttributes(), [
'other_country' => 'englisch',
]));
$this->assertEquals('englisch', $member->fresh()->other_country);
}
public function testItCreatesMemberWithFirstActivityId(): void
{
$this->login()->loginNami()->withoutExceptionHandling();
$member = Member::factory()->defaults()->create();
app(MemberFake::class)->stores($member->group->nami_id, 103);
$activity = Activity::factory()->inNami(89)->create();
$subactivity = Subactivity::factory()->inNami(90)->create();
Confession::factory()->create(['is_null' => true]);
PullMemberAction::shouldRun();
PullMembershipsAction::shouldRun();
$this->patch("/member/{$member->id}", [
...$member->getAttributes(),
'has_nami' => true,
'first_activity_id' => $activity->id,
'first_subactivity_id' => $subactivity->id,
])->assertSessionHasNoErrors();
app(MemberFake::class)->assertStored($member->group->nami_id, [
'ersteTaetigkeitId' => 89,
'ersteUntergliederungId' => 90,
]);
}
public function testItRequiresFirstActivityId(): void
{
$this->login()->loginNami();
$member = Member::factory()->defaults()->create();
app(MemberFake::class)->stores($member->group->nami_id, 103);
Confession::factory()->create(['is_null' => true]);
PullMemberAction::shouldRun();
PullMembershipsAction::shouldRun();
$this->patch("/member/{$member->id}", [
...$member->getAttributes(),
'has_nami' => true,
'first_activity_id' => null,
'first_subactivity_id' => null,
])->assertSessionHasErrors([
'first_activity_id' => 'Erste Tätigkeit ist erforderlich.',
'first_subactivity_id' => 'Erste Untergliederung ist erforderlich.',
]);
}
public function testItUpdatesCriminalRecord(): void
{
$this->withoutExceptionHandling()->login()->loginNami();
$member = $this->member(['nami_id' => null]);
$this->fakeRequest();
$response = $this
->from("/member/{$member->id}")
->patch("/member/{$member->id}", array_merge($member->getAttributes(), [
'ps_at' => '2021-02-01',
'more_ps_at' => '2021-02-02',
'has_svk' => true,
'has_vk' => true,
'efz' => '2021-02-03',
'without_education_at' => '2021-02-04',
'without_efz_at' => '2021-02-05',
'recertified_at' => '2021-02-08',
'has_nami' => false,
'multiply_pv' => true,
'multiply_more_pv' => true,
'salutation' => 'Doktor',
]));
$this->assertEquals('2021-02-01', $member->fresh()->ps_at->format('Y-m-d'));
$this->assertEquals('2021-02-02', $member->fresh()->more_ps_at->format('Y-m-d'));
$this->assertTrue($member->fresh()->has_svk);
$this->assertTrue($member->fresh()->has_vk);
$this->assertTrue($member->fresh()->multiply_pv);
$this->assertTrue($member->fresh()->multiply_more_pv);
$this->assertEquals('2021-02-03', $member->fresh()->efz->format('Y-m-d'));
$this->assertEquals('2021-02-04', $member->fresh()->without_education_at->format('Y-m-d'));
$this->assertEquals('2021-02-05', $member->fresh()->without_efz_at->format('Y-m-d'));
$this->assertEquals('2021-02-08', $member->fresh()->recertified_at->format('Y-m-d'));
$this->assertEquals('Doktor', $member->fresh()->salutation);
}
/**
* @param array<string, string|Activity|null> $overwrites
*/
private function member(array $overwrites = []): Member
{
return Member::factory()
->for(Group::factory()->state(['nami_id' => 10]))
->for(Confession::factory())
->for(Nationality::factory())
->for(Subscription::factory()->forFee())
->for(Country::factory())
->create(['nami_id' => 135, ...$overwrites]);
}
private function fakeRequest(): void
{
Http::fake(function ($request) {
if ($request->url() === $this->singleMemberUrl(10, 135) && 'GET' === $request->method()) {
return Http::response('{ "success": true, "data": {"missingkey": "missingvalue", "kontoverbindung": {"a": "b"} } }', 200);
}
if ($request->url() === $this->singleMemberUrl(10, 135) && 'PUT' === $request->method() && 43 === $request['version']) {
return Http::response('{ "success": false, "message": "Update nicht möglich. Der Datensatz wurde zwischenzeitlich verändert." }', 200);
}
if ($request->url() === $this->singleMemberUrl(10, 135) && 'PUT' === $request->method()) {
return Http::response('{ "success": true, "data": { "version": 44 } }', 200);
}
});
}
private function singleMemberUrl(int $gruppierungId, int $memberId): string
{
return "https://nami.dpsg.de/ica/rest/nami/mitglied/filtered-for-navigation/gruppierung/gruppierung/{$gruppierungId}/{$memberId}";
}
}

View File

@ -2,9 +2,6 @@
namespace Tests\RequestFactories; namespace Tests\RequestFactories;
use App\Country;
use App\Nationality;
use App\Payment\Subscription;
use Worksome\RequestFactories\RequestFactory; use Worksome\RequestFactories\RequestFactory;
class MemberRequestFactory extends RequestFactory class MemberRequestFactory extends RequestFactory
@ -14,18 +11,14 @@ class MemberRequestFactory extends RequestFactory
*/ */
public function definition(): array public function definition(): array
{ {
$country = Country::factory()->create();
$nationality = Nationality::factory()->create();
$subscription = Subscription::factory()->forFee()->create();
return [ return [
'address' => 'Bavert 50', 'address' => 'Bavert 50',
'birthday' => '2013-02-19', 'birthday' => '2013-02-19',
'children_phone' => '+49 176 70512778', 'children_phone' => '+49 123 44444',
'efz' => '', 'efz' => '',
'email' => '', 'email' => '',
'email_parents' => 'osloot@aol.com', 'email_parents' => 'osloot@aol.com',
'fax' => '+49 212 4732223', 'fax' => '+49 666',
'firstname' => 'Joe', 'firstname' => 'Joe',
'further_address' => '', 'further_address' => '',
'has_nami' => true, 'has_nami' => true,
@ -35,8 +28,8 @@ class MemberRequestFactory extends RequestFactory
'lastname' => 'Muster', 'lastname' => 'Muster',
'letter_address' => '', 'letter_address' => '',
'location' => 'Solingen', 'location' => 'Solingen',
'main_phone' => '+49 212 337056', 'main_phone' => '+49 212 2334322',
'mobile_phone' => '+49 176 70512774', 'mobile_phone' => '+49 157 53180451',
'more_ps_at' => '', 'more_ps_at' => '',
'multiply_more_pv' => false, 'multiply_more_pv' => false,
'multiply_pv' => false, 'multiply_pv' => false,
@ -47,13 +40,6 @@ class MemberRequestFactory extends RequestFactory
'without_efz_at' => '', 'without_efz_at' => '',
'work_phone' => '', 'work_phone' => '',
'zip' => '42719', 'zip' => '42719',
'bank_account' => [
'iban' => '',
'bic' => '',
],
'country_id' => $country->id,
'nationality_id' => $nationality->id,
'subscription_id' => $subscription->id,
]; ];
} }
} }

View File

@ -1,21 +0,0 @@
<?php
namespace Tests\RequestFactories;
use App\Activity;
use App\Subactivity;
class MemberStoreRequestFactory extends MemberRequestFactory
{
public function definition(): array
{
$activity = Activity::factory()->inNami(89)->create();
$subactivity = Subactivity::factory()->inNami(90)->create();
return [
...parent::definition(),
'first_activity_id' => $activity->id,
'first_subactivity_id' => $subactivity->id,
];
}
}

View File

@ -1,11 +0,0 @@
<?php
namespace Tests\RequestFactories;
class MemberUpdateRequestFactory extends MemberRequestFactory
{
public function noNami(): self
{
return $this->state(['has_nami' => false]);
}
}