21 use Slim\Psr7\Factory\StreamFactory;
22 use Slim\Psr7\Headers;
23 use Slim\Psr7\Request;
25 use Symfony\Component\Yaml\Parser;
37 const YAML_LOC = __DIR__ .
'/../../../ui/api/documentation/openapi.yaml';
61 protected function setUp() : void
64 $container = M::mock(
'ContainerBuilder');
65 $this->dbHelper = M::mock(DbHelper::class);
66 $this->restHelper = M::mock(RestHelper::class);
68 $this->restHelper->shouldReceive(
'getDbHelper')->andReturn($this->dbHelper);
70 $container->shouldReceive(
'get')->withArgs(array(
71 'helper.restHelper'))->andReturn($this->restHelper);
73 $this->assertCountBefore = \Hamcrest\MatcherAssert::getCount();
82 $this->addToAssertionCount(
83 \Hamcrest\MatcherAssert::getCount() - $this->assertCountBefore);
95 $response->getBody()->seek(0);
96 return json_decode($response->getBody()->getContents(),
true);
99 public function testGetInfoV1()
103 public function testGetInfoV2()
113 $yaml =
new Parser();
114 $yamlDocArray = $yaml->parseFile(self::YAML_LOC);
115 $apiTitle = $yamlDocArray[
"info"][
"title"];
116 $apiDescription = $yamlDocArray[
"info"][
"description"];
117 $apiVersion = $yamlDocArray[
"info"][
"version"];
118 $apiContact = $yamlDocArray[
"info"][
"contact"][
"email"];
119 $apiLicense = $yamlDocArray[
"info"][
"license"];
121 foreach ($yamlDocArray[
"security"] as $secMethod) {
122 $security[] = key($secMethod);
124 $GLOBALS[
"SysConf"] = [
126 "VERSION" =>
"1.0.0",
128 "COMMIT_HASH" =>
"deadbeef",
129 "COMMIT_DATE" =>
"2022/01/01 00:01 +05:30",
130 "BUILD_DATE" =>
"2022/01/01 00:02 +05:30"
134 "version" =>
"1.0.0",
135 "branchName" =>
"tree",
136 "commitHash" =>
"deadbeef",
137 "commitDate" =>
"2021-12-31T18:31:00+00:00",
138 "buildDate" =>
"2021-12-31T18:32:00+00:00"
142 "description" => $apiDescription,
143 "version" => $version == APiVersion::V1 ? $apiVersion :
"2.0.0",
144 "security" => $security,
145 "contact" => $apiContact,
147 "name" => $apiLicense[
"name"],
148 "url" => $apiLicense[
"url"]
150 "fossology" => $fossInfo
152 $request =
new Request(
"POST",
new Uri(
"HTTP",
"localhost"),
new Headers(),
153 [], [], (
new StreamFactory())->createStream());
154 $request = $request->withAttribute(ApiVersion::ATTRIBUTE_NAME,$version);
155 $actualResponse = $this->infoController->getInfo($request,
157 $this->assertEquals($expectedResponse->getStatusCode(),
158 $actualResponse->getStatusCode());
163 public function testGetOpenApiJson()
165 $requestHeadersJson =
new Headers();
166 $requestHeadersJson->setHeader(
'Accept',
"application/vnd.oai.openapi+json");
167 $body = (
new StreamFactory())->createStream();
168 $requestJson =
new Request(
"GET",
new Uri(
"HTTP",
"localhost"),
169 $requestHeadersJson, [], [], $body);
170 $yaml =
new Parser();
171 $yamlDocArray = $yaml->parseFile(self::YAML_LOC);
173 ->withJson($yamlDocArray, 200)
174 ->withHeader(
"Content-Disposition",
"inline; filename=\"openapi.json\"");
175 $actualResponseJson = $this->infoController->getOpenApi($requestJson,
177 $this->assertEquals($expectedResponseJson->getStatusCode(),
178 $actualResponseJson->getStatusCode());
181 $this->assertEquals([
"application/json"],
182 $actualResponseJson->getHeader(
"Content-Type"));
185 public function testGetOpenApiYaml()
187 $requestHeadersYaml =
new Headers();
188 $requestHeadersYaml->setHeader(
'Accept',
"application/vnd.oai.openapi");
189 $body = (
new StreamFactory())->createStream();
190 $requestJson =
new Request(
"GET",
new Uri(
"HTTP",
"localhost"),
191 $requestHeadersYaml, [], [], $body);
193 ->withHeader(
"Content-Type",
"application/vnd.oai.openapi;charset=utf-8")
194 ->withHeader(
"Content-Disposition",
"inline; filename=\"openapi.yaml\"")
196 $expectedResponseYaml->getBody()->write(file_get_contents(self::YAML_LOC));
197 $actualResponseYaml = $this->infoController->getOpenApi($requestJson,
199 $this->assertEquals($expectedResponseYaml->getStatusCode(),
200 $actualResponseYaml->getStatusCode());
201 $this->assertEquals($expectedResponseYaml->getBody()->getContents(),
202 $actualResponseYaml->getBody()->getContents());
203 $this->assertEquals([
"application/vnd.oai.openapi;charset=utf-8"],
204 $actualResponseYaml->getHeader(
"Content-Type"));
Controller for REST API version.
Provides helper methods to access database for REST api.
Override Slim response for withJson function.
Provides various DAO helper functions for REST api.
Test cases for InfoController.
setUp()
Setup test objects.
tearDown()
Remove test objects.
getResponseJson($response)
testGetInfo($version=ApiVersion::V2)