ebed7b15b4
* API endpoints for embedded login flow * unit tests * UI Tweaks * Universal login implementation Signed-off-by: smarcet@gmail.com <smarcet@gmail.com> Change-Id: Ib09f1486f5d9419ee1df64a9d1c41dc7c9a4a65c Depends-on: https://review.opendev.org/c/osf/openstackid/+/791306
127 lines
3.8 KiB
PHP
127 lines
3.8 KiB
PHP
<?php namespace Tests;
|
|
/**
|
|
* 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.
|
|
**/
|
|
use Models\OAuth2\ApiScope;
|
|
use Models\OAuth2\Api;
|
|
use LaravelDoctrine\ORM\Facades\EntityManager;
|
|
use Illuminate\Support\Facades\Config;
|
|
/**
|
|
* Class ApiScopeTest
|
|
*/
|
|
final class ApiScopeTest extends BrowserKitTestCase {
|
|
|
|
private $current_realm;
|
|
|
|
protected function prepareForTests()
|
|
{
|
|
parent::prepareForTests();
|
|
$this->withoutMiddleware();
|
|
$this->current_realm = Config::get('app.url');
|
|
}
|
|
|
|
/**
|
|
* testGetById
|
|
* @covers get scope api by id
|
|
*/
|
|
public function testGetById(){
|
|
|
|
$scope = EntityManager::getRepository(ApiScope::class)->findOneBy(['name' => sprintf('%s/api-scope/read',$this->current_realm)]);
|
|
|
|
$this->assertTrue(!is_null($scope));
|
|
|
|
$response = $this->action("GET", "Api\ApiScopeController@get",
|
|
$parameters = array('id' => $scope->id),
|
|
[],
|
|
[],
|
|
[]);
|
|
|
|
$content = $response->getContent();
|
|
$response_scope = json_decode($content);
|
|
|
|
$this->assertResponseStatus(200);
|
|
$this->assertTrue($response_scope->id === $scope->id);
|
|
}
|
|
|
|
/**
|
|
* testGetByPage
|
|
* @covers get api scopes by list (paginated)
|
|
*/
|
|
public function testGetByPage(){
|
|
$response = $this->action("GET", "Api\ApiScopeController@getAll",
|
|
$parameters = array('page' => 1,'per_page'=>10),
|
|
[],
|
|
[],
|
|
[]);
|
|
|
|
$content = $response->getContent();
|
|
$list = json_decode($content);
|
|
$this->assertTrue(isset($list->total) && intval($list->total)>0);
|
|
$this->assertResponseStatus(200);
|
|
}
|
|
|
|
/**
|
|
* testCreate
|
|
* @covers create a new api scope
|
|
*/
|
|
public function testCreate(){
|
|
|
|
$api = EntityManager::getRepository(Api::class)->findOneBy(['name' => 'api-endpoint']);
|
|
|
|
$this->assertTrue(!is_null($api));
|
|
|
|
$data = array(
|
|
'name' => 'https://test-scope/read.only',
|
|
'description' => 'test scope.',
|
|
'short_description' => 'test scope.',
|
|
'active' => true,
|
|
'system' => true,
|
|
'default' => true,
|
|
'api_id' => $api->id,
|
|
'assigned_by_groups' => false,
|
|
);
|
|
|
|
$response = $this->action("POST", "Api\ApiScopeController@create",
|
|
$data,
|
|
[],
|
|
[],
|
|
[]);
|
|
|
|
$content = $response->getContent();
|
|
$json_response = json_decode($content);
|
|
|
|
$this->assertResponseStatus(201);
|
|
$this->assertTrue(isset($json_response->id) && !empty($json_response->id));
|
|
}
|
|
|
|
/**
|
|
* testDeleteExisting
|
|
* @covers deletes an existing api scope
|
|
*/
|
|
public function testDeleteExisting(){
|
|
|
|
$scope = EntityManager::getRepository(ApiScope::class)->findOneBy(['name' => sprintf('%s/api-scope/read',$this->current_realm)]);
|
|
|
|
$this->assertTrue(!is_null($scope));
|
|
|
|
$id = $scope->id;
|
|
|
|
$response = $this->action("DELETE", "Api\ApiScopeController@delete",$parameters = array('id' => $id),
|
|
[],
|
|
[],
|
|
[]);
|
|
|
|
$this->assertResponseStatus(204);
|
|
|
|
}
|
|
|
|
}
|