Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Feature/http client test coverage #55

Open
wants to merge 22 commits into
base: main
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
22 commits
Select commit Hold shift + click to select a range
4882dae
Added a mocking framework to test against the API client responses
gplanchat May 18, 2022
bd3d595
mock the token response to pass the extractor test
clemzarch May 23, 2022
29a6226
raise the minimum MSI to 30%,
clemzarch May 24, 2022
91b6351
check if Akeneo responds with code 201 during an upsert,
clemzarch May 24, 2022
60d66dc
Added Infection logging
gplanchat May 30, 2022
2760869
Upgraded the Akeneo client and removed the withEnterpriseSupport flag
gplanchat May 30, 2022
bd5edc2
raise minimum MSI to 50%,
clemzarch May 31, 2022
307f666
Merge remote-tracking branch 'origin/feature/http-client-test-coverag…
clemzarch May 31, 2022
bf90758
remove last traces of "withEnterpriseSupport" because the new client …
clemzarch May 31, 2022
92397f9
run cs-fixer and force it to avoid re-indenting PhpParser Nodes ("met…
clemzarch May 31, 2022
11490ef
remove a catch that could never be triggered,
clemzarch Jun 1, 2022
5af814d
Merge remote-tracking branch 'origin/main' into feature/http-client-t…
clemzarch Jun 2, 2022
e76e0b2
add a test for the Download capacity
clemzarch Jun 2, 2022
9dce521
rename "assetMediaFiles" to the correct endpoint "assetMediaFile",
clemzarch Jun 2, 2022
ec8d02b
add phpunit-extension to the composer.lock so it can be used in CI
clemzarch Jun 2, 2022
499cb4b
force phpstan to use php 8.1 instead of 8.0
clemzarch Jun 7, 2022
1ace4ef
remove a check in the Lookup that could never be triggered
clemzarch Jun 7, 2022
1dad2dc
test the Lookup capacity by providing the configuration as an array,
clemzarch Jun 8, 2022
3101b4d
Fixed the lookup code building
gplanchat Jun 26, 2023
303db3a
remove requirement for Enterprise Edition of client
clemzarch Aug 11, 2023
78d8dff
Merge remote-tracking branch 'origin/main' into feature/http-client-t…
clemzarch Aug 11, 2023
940910b
raise min MSI,
clemzarch Aug 11, 2023
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Next Next commit
Added a mocking framework to test against the API client responses
  • Loading branch information
gplanchat committed May 18, 2022
commit 4882dae9c289624dedbcae60bdf8ec0c775dcb5b
4 changes: 3 additions & 1 deletion composer.json
Original file line number Diff line number Diff line change
Expand Up @@ -38,7 +38,9 @@
"php-http/message": "^1.11",
"php-http/curl-client": "^2.0",
"mikey179/vfsstream": "^1.6",
"infection/infection": "^0.26.10"
"infection/infection": "^0.26.10",
"php-etl/phpunit-extension": "^0.4",
"fakerphp/faker": "^1.19"
},
"autoload": {
"psr-4": {
Expand Down
179 changes: 178 additions & 1 deletion composer.lock

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

7 changes: 3 additions & 4 deletions src/Builder/AlternativeLookup.php
Original file line number Diff line number Diff line change
Expand Up @@ -10,12 +10,11 @@

final class AlternativeLookup implements Builder
{
private ?Builder $capacity;
private ?Builder $merge;

public function __construct()
{
$this->capacity = null;
public function __construct(
private Builder $capacity,
) {
$this->merge = null;
}

Expand Down
8 changes: 3 additions & 5 deletions src/Builder/Extractor.php
Original file line number Diff line number Diff line change
Expand Up @@ -5,21 +5,19 @@
use Kiboko\Contract\Configurator\StepBuilderInterface;
use PhpParser\Builder;
use PhpParser\Node;
use Symfony\Component\ExpressionLanguage\ExpressionLanguage;

final class Extractor implements StepBuilderInterface
{
private ?Node\Expr $logger;
private bool $withEnterpriseSupport;
private ?Node\Expr $client;
private ?Builder $capacity;

public function __construct()
{
public function __construct(
private Builder $capacity,
) {
$this->logger = null;
$this->withEnterpriseSupport = false;
$this->client = null;
$this->capacity = null;
}

public function withEnterpriseSupport(bool $withEnterpriseSupport): self
Expand Down
8 changes: 3 additions & 5 deletions src/Builder/Loader.php
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,6 @@
namespace Kiboko\Plugin\Akeneo\Builder;

use Kiboko\Contract\Configurator\StepBuilderInterface;
use Kiboko\Plugin\Akeneo;
use PhpParser\Builder;
use PhpParser\Node;

Expand All @@ -12,14 +11,13 @@ final class Loader implements StepBuilderInterface
private ?Node\Expr $logger;
private bool $withEnterpriseSupport;
private ?Node\Expr $client;
private ?Builder $capacity;

public function __construct()
{
public function __construct(
private Builder $capacity,
) {
$this->logger = null;
$this->withEnterpriseSupport = false;
$this->client = null;
$this->capacity = null;
}

public function withEnterpriseSupport(bool $withEnterpriseSupport): self
Expand Down
5 changes: 3 additions & 2 deletions src/Builder/Lookup.php
Original file line number Diff line number Diff line change
Expand Up @@ -13,8 +13,9 @@ final class Lookup implements StepBuilderInterface
private bool $withEnterpriseSupport;
private ?Node\Expr $client;

public function __construct(private AlternativeLookup $alternative)
{
public function __construct(
private AlternativeLookup $alternative,
) {
$this->logger = null;
$this->withEnterpriseSupport = false;
$this->client = null;
Expand Down
4 changes: 1 addition & 3 deletions src/Factory/Extractor.php
Original file line number Diff line number Diff line change
Expand Up @@ -75,10 +75,8 @@ private function findCapacity(array $config): Akeneo\Capacity\CapacityInterface

public function compile(array $config): Repository\Extractor
{
$builder = new Akeneo\Builder\Extractor();

try {
$builder->withCapacity(
$builder = new Akeneo\Builder\Extractor(
$this->findCapacity($config)->getBuilder($config)
);
} catch (NoApplicableCapacityException $exception) {
Expand Down
13 changes: 4 additions & 9 deletions src/Factory/Lookup.php
Original file line number Diff line number Diff line change
Expand Up @@ -98,14 +98,10 @@ public function compile(array $config): Repository\Lookup
{
try {
if (!array_key_exists('conditional', $config)) {
$alternativeBuilder = new Akeneo\Builder\AlternativeLookup();
$builder = new Akeneo\Builder\Lookup($alternativeBuilder);
$repository = new Repository\Lookup($builder);

try {
$alternativeBuilder->withCapacity(
$this->findCapacity($config)->getBuilder($config)
);
$alternativeBuilder = new Akeneo\Builder\AlternativeLookup($this->findCapacity($config)->getBuilder($config));
$builder = new Akeneo\Builder\Lookup($alternativeBuilder);
$repository = new Repository\Lookup($builder);
} catch (NoApplicableCapacityException $exception) {
throw new Configurator\InvalidConfigurationException(
message: 'Your Akeneo API configuration is using some unsupported capacity, check your "type" and "method" properties to a suitable set.',
Expand All @@ -119,10 +115,9 @@ public function compile(array $config): Repository\Lookup
$repository = new Repository\Lookup($builder);

foreach ($config['conditional'] as $alternative) {
$alternativeBuilder = new Akeneo\Builder\AlternativeLookup();

try {
$alternativeBuilder->withCapacity(
$alternativeBuilder = new Akeneo\Builder\AlternativeLookup(
$this->findCapacity($alternative)->getBuilder($alternative)
);
} catch (NoApplicableCapacityException $exception) {
Expand Down
Loading