Skip to content

Commit

Permalink
Merge pull request #49 from commercetools/gen-sdk-updates
Browse files Browse the repository at this point in the history
  • Loading branch information
jenschude authored Sep 1, 2021
2 parents 46e2d7f + d37d505 commit 73122e4
Show file tree
Hide file tree
Showing 146 changed files with 9,599 additions and 73 deletions.
1 change: 0 additions & 1 deletion lib/commercetools-api-tests/gen.properties

This file was deleted.

1 change: 0 additions & 1 deletion lib/commercetools-api/gen.properties

This file was deleted.

1 change: 0 additions & 1 deletion lib/commercetools-base/gen.properties

This file was deleted.

1 change: 0 additions & 1 deletion lib/commercetools-history-tests/gen.properties

This file was deleted.

1 change: 0 additions & 1 deletion lib/commercetools-history/gen.properties

This file was deleted.

1 change: 0 additions & 1 deletion lib/commercetools-import-tests/gen.properties

This file was deleted.

Original file line number Diff line number Diff line change
@@ -0,0 +1,157 @@
<?php

declare(strict_types=1);
/**
* This file has been auto generated
* Do not change it.
*/

namespace Commercetools\Import\Test\Client\Resource;

use Commercetools\Base\JsonObject;
use Commercetools\Client\ApiRequest;
use Commercetools\Exception\ApiClientException;
use Commercetools\Exception\ApiServerException;
use Commercetools\Import\Client\ImportRequestBuilder;
use GuzzleHttp\ClientInterface;
use GuzzleHttp\Exception\ClientException;
use GuzzleHttp\Exception\ServerException;
use GuzzleHttp\Psr7\Response;
use PHPUnit\Framework\TestCase;
use Psr\Http\Message\RequestInterface;

/**
* @covers \Commercetools\Import\Client\Resource\ByProjectKeyCategoriesImportContainersByImportContainerKeyPost
* @covers \Commercetools\Import\Client\Resource\ResourceByProjectKeyCategoriesImportContainersByImportContainerKey
*/
class ResourceByProjectKeyCategoriesImportContainersByImportContainerKeyTest extends TestCase
{
/**
* @dataProvider getRequests()
*/
public function testBuilder(callable $builderFunction, string $method, string $relativeUri, string $body = null)
{
$builder = new ImportRequestBuilder();
$request = $builderFunction($builder);
$this->assertSame(strtolower($method), strtolower($request->getMethod()));
$this->assertSame($relativeUri, (string) $request->getUri());
if (!is_null($body)) {
$this->assertJsonStringEqualsJsonString($body, (string) $request->getBody());
} else {
$this->assertSame("", (string) $request->getBody());
}
}



/**
* @dataProvider getRequestBuilderResponses()
*/
public function testMapFromResponse(callable $builderFunction, $statusCode)
{
$builder = new ImportRequestBuilder();
$request = $builderFunction($builder);
$this->assertInstanceOf(ApiRequest::class, $request);

$response = new Response($statusCode, [], "{}");
$this->assertInstanceOf(JsonObject::class, $request->mapFromResponse($response));
}

/**
* @dataProvider getRequestBuilders()
*/
public function testExecuteClientException(callable $builderFunction)
{
$client = $this->createMock(ClientInterface::class);

$builder = new ImportRequestBuilder($client);
$request = $builderFunction($builder);
$client->method("send")->willThrowException(new ClientException("Oops!", $request, new Response(400)));

$this->expectException(ApiClientException::class);
$request->execute();
}

/**
* @dataProvider getRequestBuilders()
*/
public function testExecuteServerException(callable $builderFunction)
{
$client = $this->createMock(ClientInterface::class);

$builder = new ImportRequestBuilder($client);
$request = $builderFunction($builder);
$client->method("send")->willThrowException(new ServerException("Oops!", $request, new Response(500)));

$this->expectException(ApiServerException::class);
$request->execute();
}

public function getRequests()
{
return [
'ByProjectKeyCategoriesImportContainersByImportContainerKeyPost' => [
function (ImportRequestBuilder $builder): RequestInterface {
return $builder
->withProjectKeyValue("test_projectKey")
->categories()
->importContainers()
->withImportContainerKeyValue("test_importContainerKey")
->post(null);
},
'post',
'test_projectKey/categories/import-containers/test_importContainerKey',
]
];
}

public function getResources()
{
return [
];
}

public function getRequestBuilders()
{
return [
'ByProjectKeyCategoriesImportContainersByImportContainerKeyPost' => [
function (ImportRequestBuilder $builder): RequestInterface {
return $builder
->withProjectKeyValue("projectKey")
->categories()
->importContainers()
->withImportContainerKeyValue("importContainerKey")
->post(null);
}
]
];
}

public function getRequestBuilderResponses()
{
return [
'ByProjectKeyCategoriesImportContainersByImportContainerKeyPost_201' => [
function (ImportRequestBuilder $builder): RequestInterface {
return $builder
->withProjectKeyValue("projectKey")
->categories()
->importContainers()
->withImportContainerKeyValue("importContainerKey")
->post(null);
},
201
],
'ByProjectKeyCategoriesImportContainersByImportContainerKeyPost_599' => [
function (ImportRequestBuilder $builder): RequestInterface {
return $builder
->withProjectKeyValue("projectKey")
->categories()
->importContainers()
->withImportContainerKeyValue("importContainerKey")
->post(null);
},
599
]
];
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,81 @@
<?php

declare(strict_types=1);
/**
* This file has been auto generated
* Do not change it.
*/

namespace Commercetools\Import\Test\Client\Resource;

use Commercetools\Base\JsonObject;
use Commercetools\Client\ApiRequest;
use Commercetools\Exception\ApiClientException;
use Commercetools\Exception\ApiServerException;
use Commercetools\Import\Client\ImportRequestBuilder;
use Commercetools\Import\Client\Resource\ResourceByProjectKeyCategoriesImportContainersByImportContainerKey;
use GuzzleHttp\ClientInterface;
use GuzzleHttp\Exception\ClientException;
use GuzzleHttp\Exception\ServerException;
use GuzzleHttp\Psr7\Response;
use PHPUnit\Framework\TestCase;
use Psr\Http\Message\RequestInterface;

/**
* @covers \Commercetools\Import\Client\Resource\ResourceByProjectKeyCategoriesImportContainers
*/
class ResourceByProjectKeyCategoriesImportContainersTest extends TestCase
{
/**
* @dataProvider getResources()
*/
public function testResources(callable $builderFunction, string $class, array $expectedArgs)
{
$builder = new ImportRequestBuilder();
$resource = $builderFunction($builder);
$this->assertInstanceOf($class, $resource);
$this->assertEquals($expectedArgs, $resource->getArgs());
}







public function getRequests()
{
return [
];
}

public function getResources()
{
return [
'ResourceByProjectKeyCategoriesImportContainersByImportContainerKey' => [
function (ImportRequestBuilder $builder): ResourceByProjectKeyCategoriesImportContainersByImportContainerKey {
return $builder
->withProjectKeyValue("test_projectKey")
->categories()
->importContainers()
->withImportContainerKeyValue("test_importContainerKey");
},
ResourceByProjectKeyCategoriesImportContainersByImportContainerKey::class,
['projectKey' => 'test_projectKey', 'importContainerKey' => 'test_importContainerKey'],
'/{projectKey}/categories/import-containers/{importContainerKey}'
]
];
}

public function getRequestBuilders()
{
return [
];
}

public function getRequestBuilderResponses()
{
return [
];
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -13,6 +13,7 @@
use Commercetools\Exception\ApiClientException;
use Commercetools\Exception\ApiServerException;
use Commercetools\Import\Client\ImportRequestBuilder;
use Commercetools\Import\Client\Resource\ResourceByProjectKeyCategoriesImportContainers;
use Commercetools\Import\Client\Resource\ResourceByProjectKeyCategoriesImportSinkKeyByImportSinkKey;
use GuzzleHttp\ClientInterface;
use GuzzleHttp\Exception\ClientException;
Expand Down Expand Up @@ -52,6 +53,17 @@ public function getRequests()
public function getResources()
{
return [
'ResourceByProjectKeyCategoriesImportContainers' => [
function (ImportRequestBuilder $builder): ResourceByProjectKeyCategoriesImportContainers {
return $builder
->withProjectKeyValue("test_projectKey")
->categories()
->importContainers();
},
ResourceByProjectKeyCategoriesImportContainers::class,
['projectKey' => 'test_projectKey'],
'/{projectKey}/categories/import-containers'
],
'ResourceByProjectKeyCategoriesImportSinkKeyByImportSinkKey' => [
function (ImportRequestBuilder $builder): ResourceByProjectKeyCategoriesImportSinkKeyByImportSinkKey {
return $builder
Expand Down
Loading

0 comments on commit 73122e4

Please sign in to comment.