Update member test
This commit is contained in:
parent
f37c003ffc
commit
326761e88d
|
@ -2,22 +2,19 @@
|
||||||
|
|
||||||
namespace Zoomyboy\LaravelNami\Tests\Unit;
|
namespace Zoomyboy\LaravelNami\Tests\Unit;
|
||||||
|
|
||||||
use Zoomyboy\LaravelNami\Nami;
|
|
||||||
use Zoomyboy\LaravelNami\Tests\TestCase;
|
|
||||||
use Illuminate\Support\Facades\Http;
|
|
||||||
use Illuminate\Support\Facades\Config;
|
|
||||||
use Zoomyboy\LaravelNami\NamiServiceProvider;
|
|
||||||
use Zoomyboy\LaravelNami\LoginException;
|
|
||||||
use Zoomyboy\LaravelNami\Group;
|
|
||||||
use Zoomyboy\LaravelNami\Member;
|
|
||||||
use Illuminate\Database\Eloquent\Model;
|
use Illuminate\Database\Eloquent\Model;
|
||||||
|
use Illuminate\Support\Facades\Config;
|
||||||
|
use Illuminate\Support\Facades\Http;
|
||||||
|
use Zoomyboy\LaravelNami\Group;
|
||||||
|
use Zoomyboy\LaravelNami\LoginException;
|
||||||
|
use Zoomyboy\LaravelNami\Member;
|
||||||
|
use Zoomyboy\LaravelNami\Nami;
|
||||||
|
use Zoomyboy\LaravelNami\NamiServiceProvider;
|
||||||
|
use Zoomyboy\LaravelNami\Tests\TestCase;
|
||||||
|
|
||||||
class PushMemberTest extends TestCase
|
class PushMemberTest extends TestCase
|
||||||
{
|
{
|
||||||
public $groupsResponse = '{"success":true,"data":[{"descriptor":"Group","name":"","representedClass":"de.iconcept.nami.entity.org.Gruppierung","id":103}],"responseType":"OK"}';
|
public array $attributes = [
|
||||||
public $unauthorizedResponse = '{"success":false,"data":null,"responseType":"EXCEPTION","message":"Access denied - no right for requested operation","title":"Exception"}';
|
|
||||||
|
|
||||||
public $attributes = [
|
|
||||||
[
|
[
|
||||||
'firstname' => 'Max',
|
'firstname' => 'Max',
|
||||||
'lastname' => 'Nach1',
|
'lastname' => 'Nach1',
|
||||||
|
@ -39,65 +36,42 @@ class PushMemberTest extends TestCase
|
||||||
]
|
]
|
||||||
];
|
];
|
||||||
|
|
||||||
public function dataProvider() {
|
public function dataProvider(): array {
|
||||||
return [
|
return [
|
||||||
'firstname' => ['vorname', ['Max', 'Jane']],
|
'firstname' => [['firstname' => 'Max'], ['vorname' => 'Max']],
|
||||||
'lastname' => ['nachname', ['Nach1', 'Nach2']],
|
'lastname' => [['lastname' => 'Nach1'], ['nachname' => 'Nach1']],
|
||||||
'nickname' => ['spitzname', ['spitz1', '']],
|
'nickname' => [['nickname' => 'nick'], ['spitzname' => 'nick']],
|
||||||
'gender_id' => ['geschlechtId', [17, 23]],
|
'nicknameEmpty' => [['nickname' => null], ['spitzname' => '']],
|
||||||
'group_id' => ['gruppierungId', [103, 103]],
|
'gender_id' => [['gender_id' => 17], ['geschlechtId' => 17]],
|
||||||
'nami_id' => ['id', [16, 17]],
|
|
||||||
/*
|
|
||||||
'other_country' => ['other_country', ['deutsch', null]],
|
|
||||||
'address' => ['address', ['straße 1', 'straße 2']],
|
|
||||||
'further_address' => ['further_address', ['addrz', null]],
|
|
||||||
'zip' => ['zip', ['12345', '5555']],
|
|
||||||
'location' => ['location', ['SG', 'Köln']],
|
|
||||||
'main_phone' => ['main_phone', ['+49888', '+49668']],
|
|
||||||
'mobile_phone' => ['mobile_phone', ['+49176', '+49172']],
|
|
||||||
'work_phone' => ['work_phone', ['+11111', '+22222']],
|
|
||||||
'fax' => ['fax', ['+55111', '+55222']],
|
|
||||||
'email' => ['email', ['test@example.com', 'test2@example.com']],
|
|
||||||
'email_parents' => ['email_parents', ['testp@example.com', 'test2p@example.com']],
|
|
||||||
'gender_id' => ['gender_id', [19, null]],
|
|
||||||
'nationality_id' => ['nationality_id', [1054, null]],
|
|
||||||
'confession_id' => ['confession_id', [1, null]],
|
|
||||||
'birthday' => ['birthday', ['1991-06-20', '1984-01-17']],
|
|
||||||
'joined_at' => ['joined_at', ['2005-05-01', null]],
|
|
||||||
'group_id' => ['group_id', [103, 103]],
|
|
||||||
*/
|
|
||||||
];
|
];
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @dataProvider dataProvider
|
* @dataProvider dataProvider
|
||||||
*/
|
*/
|
||||||
public function test_push_a_single_member($key, $values) {
|
public function test_push_a_single_member(array $overwrites, array $check): void {
|
||||||
Http::fake(array_merge($this->login(), [
|
Http::fake(array_merge([
|
||||||
'https://nami.dpsg.de/ica/rest/nami/mitglied/filtered-for-navigation/gruppierung/gruppierung/103/16' => Http::response('{"success": true, "data": {"id": 16}}', 200),
|
'https://nami.dpsg.de/ica/rest/nami/mitglied/filtered-for-navigation/gruppierung/gruppierung/103/16' => Http::response('{"success": true, "data": {"id": 16}}', 200),
|
||||||
'https://nami.dpsg.de/ica/rest/nami/mitglied/filtered-for-navigation/gruppierung/gruppierung/103/17' => Http::response('{"success": true, "data": {"id": 17}}', 200),
|
|
||||||
]));
|
]));
|
||||||
|
|
||||||
$this->setCredentials();
|
$res = Nami::putMember(array_merge($this->attributes[0], $overwrites));
|
||||||
Nami::login();
|
$this->assertEquals(16, $res['id']);
|
||||||
|
|
||||||
Nami::putMember($this->attributes[0]);
|
Http::assertSent(function($request) use ($check) {
|
||||||
$res = Nami::putMember($this->attributes[1]);
|
if ($request->url() != 'https://nami.dpsg.de/ica/rest/nami/mitglied/filtered-for-navigation/gruppierung/gruppierung/103/16') {
|
||||||
$this->assertEquals(17, $res['id']);
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
Http::assertSent(function($request) use ($key, $values) {
|
foreach ($check as $key => $value) {
|
||||||
return $request->url() == 'https://nami.dpsg.de/ica/rest/nami/mitglied/filtered-for-navigation/gruppierung/gruppierung/103/16'
|
if ($request[$key] !== $value) {
|
||||||
&& $request[$key] === $values[0]
|
return false;
|
||||||
&& $request->method() == 'PUT';
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return $request->method() === 'PUT';
|
||||||
});
|
});
|
||||||
|
|
||||||
Http::assertSent(function($request) use ($key, $values) {
|
Http::assertSentCount(1);
|
||||||
return $request->url() == 'https://nami.dpsg.de/ica/rest/nami/mitglied/filtered-for-navigation/gruppierung/gruppierung/103/17'
|
|
||||||
&& $request[$key] === $values[1]
|
|
||||||
&& $request->method() == 'PUT';
|
|
||||||
});
|
|
||||||
|
|
||||||
Http::assertSentCount(4);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue