Skip to content

Commit

Permalink
bug #316 fix original payment method of refund (AdamKasp)
Browse files Browse the repository at this point in the history
This PR was merged into the 1.0-dev branch.

Discussion
----------



Commits
-------

c00a23a Fix original payment method on refund page
  • Loading branch information
GSadee authored Jun 18, 2021
2 parents e366896 + c00a23a commit bb1b91c
Show file tree
Hide file tree
Showing 8 changed files with 117 additions and 3 deletions.
Original file line number Diff line number Diff line change
@@ -0,0 +1,24 @@
@refunds
Feature: Seeing an original payment method from completed payment on the refund page
In order to choose proper payment method while refunding
As an Administrator
I want to see the original payment method of completed payment

Background:
Given the store operates on a single green channel in "United States"
And the store has a product "Mr. Meeseeks T-Shirt" priced at "$10.00"
And the store allows shipping with "Galaxy Post"
And the store allows paying with "Space money"
And the store also allows paying with "Mars money"
And there is a customer "[email protected]" that placed an order "#00000023"
And the customer bought 2 "Mr. Meeseeks T-Shirt" products
And the customer chose "Galaxy Post" shipping method to "United States" with "Space money" payment
And the payment of order "#00000023" failed
And the customer chose "Mars money" payment method
And this payment has been paid
And I am logged in as an administrator

@ui
Scenario: Seeing original payment method of completed payment
When I want to refund some units of order "#00000023"
Then I should see original payment method "Mars money"
6 changes: 3 additions & 3 deletions src/Resources/views/_paymentMethod.html.twig
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
{% if order.payments.first() %}
{% set original_payment_method = order.payments.first().method %}

{% set completed = constant('Sylius\\Component\\Core\\Model\\PaymentInterface::STATE_COMPLETED') %}
{% set original_payment_method = order.lastPayment(completed).method %}
<div class="ui hidden divider"></div>

<div class="ui stackable grid">
Expand All @@ -15,7 +15,7 @@
</option>
{% endfor %}
</select>
<small>{{ 'sylius.ui.original_payment_method'|trans }}: <strong>{{ original_payment_method }}</strong></small>
<small id="original-payment-method">{{ 'sylius.ui.original_payment_method'|trans }}: <strong>{{ original_payment_method }}</strong></small>
</div>
</div>
<div class="ui form column">
Expand Down
68 changes: 68 additions & 0 deletions tests/Behat/Context/Setup/PaymentContext.php
Original file line number Diff line number Diff line change
@@ -0,0 +1,68 @@
<?php

/*
* This file is part of the Sylius package.
*
* (c) Paweł Jędrzejewski
*
* For the full copyright and license information, please view the LICENSE
* file that was distributed with this source code.
*/

declare(strict_types=1);

namespace Tests\Sylius\RefundPlugin\Behat\Context\Setup;

use Behat\Behat\Context\Context;
use SM\Factory\FactoryInterface as StateMachineFactoryInterface;
use Sylius\Behat\Service\SharedStorageInterface;
use Sylius\Component\Core\Model\OrderInterface;
use Sylius\Component\Core\Model\PaymentInterface;
use Sylius\Component\Core\Model\PaymentMethodInterface;
use Sylius\Component\Payment\PaymentTransitions;

final class PaymentContext implements Context
{
/** @var StateMachineFactoryInterface */
private $stateMachineFactory;

/** @var SharedStorageInterface */
private $sharedStorage;

public function __construct(StateMachineFactoryInterface $stateMachineFactory, SharedStorageInterface $sharedStorage)
{
$this->stateMachineFactory = $stateMachineFactory;
$this->sharedStorage = $sharedStorage;
}

/**
* @Given the payment of order :order failed
*/
public function paymentOfOrderFailed(OrderInterface $order): void
{
$payment = $order->getLastPayment();
$this->stateMachineFactory->get($payment, PaymentTransitions::GRAPH)->apply(PaymentTransitions::TRANSITION_FAIL);
}

/**
* @Given /^the customer chose ("[^"]+" payment) method$/
*/
public function theCustomerChosePaymentMethod(PaymentMethodInterface $paymentMethod): void
{
/** @var OrderInterface $order */
$order = $this->sharedStorage->get('order');

$lastPayment = $order->getLastPayment();
$lastPayment->setMethod($paymentMethod);

$this->sharedStorage->set('payment', $lastPayment);
}

/**
* @Given /^(this payment) has been paid$/
*/
public function andThisPaymentHasBeenPaid(PaymentInterface $payment): void
{
$this->stateMachineFactory->get($payment, PaymentTransitions::GRAPH)->apply(PaymentTransitions::TRANSITION_COMPLETE);
}
}
8 changes: 8 additions & 0 deletions tests/Behat/Context/Ui/RefundingContext.php
Original file line number Diff line number Diff line change
Expand Up @@ -369,6 +369,14 @@ public function emailToWithCreditMemoShouldNotBeSent(string $email): void
}
}

/**
* @Then I should see original payment method :paymentMethodName
*/
public function iShouldSeeOriginalPaymentMethod(string $paymentMethodName): void
{
Assert::same($this->orderRefundsPage->getOriginalPaymentMethodName(), sprintf('Original Payment Method: %s', $paymentMethodName));
}

private function provideLongComment(): string
{
return 'Tu ne quaesieris scire nefas, quem mihi quem tibi finem di dederint, Leuconoe, nec Babylonios temptaris numeros. Ut melius quidquid erit pati. Seu plures hiemes sue tribuit Iuppiter ultimam. Qae nunc oppositis debilitat pumicibus mare Tyrrenum: sapias vina liques et spatio brevi. Spem longam resecens. Dum loquimur fugerit invida Aetas: CARPE DIEM, quam minimum credula postero.';
Expand Down
6 changes: 6 additions & 0 deletions tests/Behat/Page/Admin/OrderRefundsPage.php
Original file line number Diff line number Diff line change
Expand Up @@ -154,9 +154,15 @@ public function isPaymentMethodSelected(string $paymentMethodName): bool
return true;
}

public function getOriginalPaymentMethodName(): string
{
return $this->getTextFromElement($this->getElement('original_payment_method'));
}

protected function getDefinedElements(): array
{
return [
'original_payment_method' => '#original-payment-method',
'payment_methods' => '#payment-methods',
'refunded_total' => '#refunded-total',
];
Expand Down
2 changes: 2 additions & 0 deletions tests/Behat/Page/Admin/OrderRefundsPageInterface.php
Original file line number Diff line number Diff line change
Expand Up @@ -41,4 +41,6 @@ public function hasBackButton(): bool;
public function canChoosePaymentMethod(): bool;

public function isPaymentMethodVisible(string $paymentMethodName): bool;

public function getOriginalPaymentMethodName(): string;
}
5 changes: 5 additions & 0 deletions tests/Behat/Resources/services.xml
Original file line number Diff line number Diff line change
Expand Up @@ -85,6 +85,11 @@
<argument type="service" id="doctrine.orm.entity_manager" />
</service>

<service id="Tests\Sylius\RefundPlugin\Behat\Context\Setup\PaymentContext">
<argument type="service" id="SM\Factory\Factory" />
<argument type="service" id="sylius.behat.shared_storage" />
</service>

<service id="Tests\Sylius\RefundPlugin\Behat\Context\Transform\OrderContext">
<argument type="service" id="sylius.repository.order" />
</service>
Expand Down
1 change: 1 addition & 0 deletions tests/Behat/Resources/suites.yml
Original file line number Diff line number Diff line change
Expand Up @@ -41,6 +41,7 @@ default:
- sylius.behat.context.ui.admin.managing_orders

- Tests\Sylius\RefundPlugin\Behat\Context\Application\EmailsContext
- Tests\Sylius\RefundPlugin\Behat\Context\Setup\PaymentContext
- Tests\Sylius\RefundPlugin\Behat\Context\Ui\CreditMemoContext
- Tests\Sylius\RefundPlugin\Behat\Context\Ui\ManagingOrdersContext
- Tests\Sylius\RefundPlugin\Behat\Context\Ui\RefundingContext
Expand Down

0 comments on commit bb1b91c

Please sign in to comment.