openstackid-resources/tests/OAuth2MembersApiTest.php
smarcet 434da847b5 Updated member serializer
Added track_chairs collection

Change-Id: I4c1c1abc15bdf4909525acdcea205af1f2fa4632
Signed-off-by: smarcet <smarcet@gmail.com>
2021-03-01 14:25:20 -03:00

474 lines
13 KiB
PHP

<?php
use App\Models\Foundation\Main\IGroup;
/**
* Copyright 2016 OpenStack Foundation
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
* http://www.apache.org/licenses/LICENSE-2.0
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
**/
final class OAuth2MembersApiTest extends ProtectedApiTest
{
use InsertSummitTestData;
protected function setUp()
{
$this->setCurrentGroup(IGroup::TrackChairs);
parent::setUp();
self::insertTestData();
self::$summit_permission_group->addMember(self::$member);
self::$em->persist(self::$summit);
self::$em->persist(self::$summit_permission_group);
self::$em->flush();
self::$summit->addTrackChair(self::$member, [ self::$defaultTrack ] );
self::$em->persist(self::$summit);
self::$em->flush();
}
public function tearDown()
{
self::clearTestData();
Mockery::close();
}
public function testGetMembers()
{
$params = [
//AND FILTER
'filter' => ['first_name=@Seba', 'last_name=@Marcet'],
'order' => '+first_name,-last_name'
];
$headers = array("HTTP_Authorization" => " Bearer " . $this->access_token);
$response = $this->action(
"GET",
"OAuth2MembersApiController@getAll",
$params,
array(),
array(),
array(),
$headers
);
$content = $response->getContent();
$members = json_decode($content);
$this->assertTrue(!is_null($members));
$this->assertResponseStatus(200);
}
public function testGetMemberByFullName()
{
$params = [
//AND FILTER
'filter' => ['full_name=@Seba'],
'order' => '+first_name,-last_name'
];
$headers = array("HTTP_Authorization" => " Bearer " . $this->access_token);
$response = $this->action(
"GET",
"OAuth2MembersApiController@getAll",
$params,
array(),
array(),
array(),
$headers
);
$content = $response->getContent();
$members = json_decode($content);
$this->assertTrue(!is_null($members));
$this->assertResponseStatus(200);
}
public function testGetMembersEmpty()
{
$params = [
'filter' => ['first_name=@', 'last_name=@'],
//AND FILTER
'order' => '+first_name,-last_name'
];
$headers = ["HTTP_Authorization" => " Bearer " . $this->access_token];
$response = $this->action(
"GET",
"OAuth2MembersApiController@getAll",
$params,
[],
[],
[],
$headers
);
$content = $response->getContent();
$this->assertResponseStatus(412);
}
public function testGetMembersByEmail()
{
$params = [
'filter' => 'email=@sebastian@tipit.net',
'order' => '+first_name,-last_name',
'expand' => 'groups'
];
$headers = array("HTTP_Authorization" => " Bearer " . $this->access_token);
$response = $this->action(
"GET",
"OAuth2MembersApiController@getAll",
$params,
array(),
array(),
array(),
$headers
);
$content = $response->getContent();
$members = json_decode($content);
$this->assertTrue(!is_null($members));
$this->assertResponseStatus(200);
}
public function testGetMembersByEmail2()
{
$params = [
'filter' => ['email==sean.mcginnis@gmail.com', "email_verified==0"],
];
$headers = array("HTTP_Authorization" => " Bearer " . $this->access_token);
$response = $this->action(
"GET",
"OAuth2MembersApiController@getAll",
$params,
array(),
array(),
array(),
$headers
);
$content = $response->getContent();
$members = json_decode($content);
$this->assertTrue(!is_null($members));
$this->assertResponseStatus(200);
}
public function testGetMyMember()
{
$params = [
'expand' => 'groups,track_chairs'
];
$headers = array("HTTP_Authorization" => " Bearer " . $this->access_token);
$response = $this->action(
"GET",
"OAuth2MembersApiController@getMyMember",
$params,
array(),
array(),
array(),
$headers
);
$content = $response->getContent();
$member = json_decode($content);
$this->assertTrue(!is_null($member));
$this->assertResponseStatus(200);
}
public function testGetMembersByGitHubUser()
{
$params = [
'filter' => 'github_user=@smarcet',
'order' => '+first_name,-last_name',
'expand' => 'groups, ccla_teams'
];
$headers = ["HTTP_Authorization" => " Bearer " . $this->access_token];
$response = $this->action(
"GET",
"OAuth2MembersApiController@getAll",
$params,
array(),
array(),
array(),
$headers
);
$content = $response->getContent();
$members = json_decode($content);
$this->assertTrue(!is_null($members));
$this->assertResponseStatus(200);
}
public function testAddMemberAffiliation($member_id = 11624){
$params = [
'member_id' => $member_id,
];
$start_datetime = new DateTime( "2018-11-10 00:00:00");
$start_datetime_unix = $start_datetime->getTimestamp();
$data = [
'is_current' => true,
'start_date' => $start_datetime_unix,
'job_title' => 'test affiliation',
'end_date' => null,
'organization_id' => 1
];
$headers = [
"HTTP_Authorization" => " Bearer " . $this->access_token,
"CONTENT_TYPE" => "application/json"
];
$response = $this->action(
"POST",
"OAuth2MembersApiController@addAffiliation",
$params,
[],
[],
[],
$headers,
json_encode($data)
);
$content = $response->getContent();
$this->assertResponseStatus(201);
$affiliation = json_decode($content);
$this->assertTrue(!is_null($affiliation));
return $affiliation;
}
public function testAddMyMemberAffiliation(){
$params = [
];
$start_datetime = new DateTime( "2018-11-10 00:00:00");
$start_datetime_unix = $start_datetime->getTimestamp();
$data = [
'is_current' => true,
'start_date' => $start_datetime_unix,
'job_title' => 'test affiliation',
'end_date' => null,
'organization_name' => 'test new organization'
];
$headers = [
"HTTP_Authorization" => " Bearer " . $this->access_token,
"CONTENT_TYPE" => "application/json"
];
$response = $this->action(
"POST",
"OAuth2MembersApiController@addMyAffiliation",
$params,
[],
[],
[],
$headers,
json_encode($data)
);
$content = $response->getContent();
$this->assertResponseStatus(201);
$affiliation = json_decode($content);
$this->assertTrue(!is_null($affiliation));
return $affiliation;
}
public function testUpdateMemberAffiliation($member_id = 11624){
$new_affiliation = $this->testAddMemberAffiliation($member_id);
$params = [
'member_id' => $member_id,
'affiliation_id' => $new_affiliation->id,
];
$data = [
'job_title' => 'job title update'
];
$headers = [
"HTTP_Authorization" => " Bearer " . $this->access_token,
"CONTENT_TYPE" => "application/json"
];
$response = $this->action(
"PUT",
"OAuth2MembersApiController@updateAffiliation",
$params,
[],
[],
[],
$headers,
json_encode($data)
);
$content = $response->getContent();
$this->assertResponseStatus(201);
$affiliation = json_decode($content);
$this->assertTrue(!is_null($affiliation));
return $affiliation;
}
public function testDeleteMemberAffiliation($member_id = 11624){
$new_affiliation = $this->testAddMemberAffiliation($member_id);
$params = [
'member_id' => $member_id,
'affiliation_id' => $new_affiliation->id,
];
$headers = [
"HTTP_Authorization" => " Bearer " . $this->access_token,
"CONTENT_TYPE" => "application/json"
];
$response = $this->action(
"DELETE",
"OAuth2MembersApiController@deleteAffiliation",
$params,
[],
[],
[],
$headers
);
$content = $response->getContent();
$this->assertResponseStatus(204);
}
public function testGetMemberAffiliation($member_id = 11624)
{
$params = [
//AND FILTER
'member_id' => $member_id
];
$headers = ["HTTP_Authorization" => " Bearer " . $this->access_token];
$response = $this->action(
"GET",
"OAuth2MembersApiController@getMemberAffiliations",
$params,
[],
[],
[],
$headers
);
$content = $response->getContent();
$affiliations = json_decode($content);
$this->assertTrue(!is_null($affiliations));
$this->assertResponseStatus(200);
}
public function testGetAllSummitPermissions(){
self::$member2->addSummitEditPermission(self::$summit);
self::$member2->addSummitEditPermission(self::$summit2);
$params = [
'order' => '-id'
];
$headers = ["HTTP_Authorization" => " Bearer " . $this->access_token];
$response = $this->action(
"GET",
"OAuth2MembersApiController@getAllSummitEditPermissions",
$params,
[],
[],
[],
$headers
);
$content = $response->getContent();
$pemissions = json_decode($content);
$this->assertTrue(!is_null($pemissions));
$this->assertResponseStatus(200);
}
public function testSignFoundationMembership(){
$params = [
'member_id' => 'me',
];
$headers = [
"HTTP_Authorization" => " Bearer " . $this->access_token,
"CONTENT_TYPE" => "application/json"
];
$response = $this->action(
"PUT",
"OAuth2MembersApiController@signFoundationMembership",
$params,
[],
[],
[],
$headers,
""
);
$content = $response->getContent();
$this->assertResponseStatus(201);
$member = json_decode($content);
$this->assertTrue(!is_null($member));
return $member;
}
public function testSignResignFoundationMembership(){
$params = [
'member_id' => 'me',
];
$headers = [
"HTTP_Authorization" => " Bearer " . $this->access_token,
"CONTENT_TYPE" => "application/json"
];
$response = $this->action(
"PUT",
"OAuth2MembersApiController@signFoundationMembership",
$params,
[],
[],
[],
$headers,
""
);
$content = $response->getContent();
$this->assertResponseStatus(201);
$member = json_decode($content);
$this->assertTrue(!is_null($member));
$response = $this->action(
"PUT",
"OAuth2MembersApiController@resignFoundationMembership",
$params,
[],
[],
[],
$headers,
""
);
$content = $response->getContent();
$this->assertResponseStatus(201);
$member = json_decode($content);
$this->assertTrue(!is_null($member));
return $member;
}
}