make cart coupon test more granular

This commit is contained in:
Ron Rennick 2021-01-27 17:15:39 -04:00
parent ed04d3080a
commit d18dc96158
1 changed files with 65 additions and 67 deletions

View File

@ -19,11 +19,36 @@ const {
beforeAll, beforeAll,
} = require( '@jest/globals' ); } = require( '@jest/globals' );
/**
* Apply a coupon code to the cart.
*
* @param couponCode string
* @returns {Promise<void>}
*/
const applyCouponToCart = async ( couponCode ) => {
await expect(page).toClick('a', {text: 'Click here to enter your code'});
await uiUnblocked();
await expect(page).toFill('#coupon_code', couponCode);
await expect(page).toClick('button', {text: 'Apply coupon'});
await uiUnblocked();
};
/**
* Remove one coupon from the cart.
*
* @returns {Promise<void>}
*/
const removeCouponFromCart = async () => {
await expect(page).toClick('.woocommerce-remove-coupon', {text: '[Remove]'});
await uiUnblocked();
await expect(page).toMatchElement('.woocommerce-message', {text: 'Coupon has been removed.'});
}
const runCheckoutApplyCouponsTest = () => { const runCheckoutApplyCouponsTest = () => {
let couponFixedCart;
let couponPercentage;
let couponFixedProduct;
describe('Checkout applying coupons', () => { describe('Checkout applying coupons', () => {
let couponFixedCart;
let couponPercentage;
let couponFixedProduct;
beforeAll(async () => { beforeAll(async () => {
await merchant.login(); await merchant.login();
await createSimpleProduct(); await createSimpleProduct();
@ -31,86 +56,59 @@ const runCheckoutApplyCouponsTest = () => {
couponPercentage = await createCoupon('50', 'Percentage discount'); couponPercentage = await createCoupon('50', 'Percentage discount');
couponFixedProduct = await createCoupon('5', 'Fixed product discount'); couponFixedProduct = await createCoupon('5', 'Fixed product discount');
await merchant.logout(); await merchant.logout();
});
it('allows customer to apply coupons in the checkout', async () => {
await shopper.goToShop(); await shopper.goToShop();
await shopper.addToCartFromShopPage('Simple product'); await shopper.addToCartFromShopPage('Simple product');
await uiUnblocked(); await uiUnblocked();
await shopper.goToCheckout(); await shopper.goToCheckout();
});
// Apply Fixed cart discount coupon it('allows customer to apply fixed cart coupon', async () => {
await expect(page).toClick('a', {text: 'Click here to enter your code'}); await applyCouponToCart( couponFixedCart );
await uiUnblocked(); await expect(page).toMatchElement('.woocommerce-message', {text: 'Coupon code applied successfully.'});
await expect(page).toFill('#coupon_code', couponFixedCart);
await expect(page).toClick('button', {text: 'Apply coupon'});
await uiUnblocked();
await page.waitForSelector('.woocommerce-message', {text: 'Coupon code applied successfully.'});
// Wait for page to expand total calculations to avoid flakyness // Wait for page to expand total calculations to avoid flakyness
await page.waitForSelector('.order-total'); await page.waitForSelector('.order-total');
// Verify discount applied and order total // Verify discount applied and order total
await page.waitForSelector('.cart-discount .amount', {text: '$5.00'}); await expect(page).toMatchElement('.cart-discount .amount', {text: '$5.00'});
await page.waitForSelector('.order-total .amount', {text: '$4.99'}); await expect(page).toMatchElement('.order-total .amount', {text: '$4.99'});
await removeCouponFromCart();
});
// Remove coupon it('allows customer to apply percentage coupon', async () => {
await expect(page).toClick('.woocommerce-remove-coupon', {text: '[Remove]'}); await applyCouponToCart( couponPercentage );
await uiUnblocked(); await expect(page).toMatchElement('.woocommerce-message', {text: 'Coupon code applied successfully.'});
await page.waitForSelector('.woocommerce-message', {text: 'Coupon has been removed.'});
// Apply Percentage discount coupon // Verify discount applied and order total
await expect(page).toClick('a', {text: 'Click here to enter your code'}); await expect(page).toMatchElement('.cart-discount .amount', {text: '$4.99'});
await uiUnblocked(); await expect(page).toMatchElement('.order-total .amount', {text: '$5.00'});
await expect(page).toFill('#coupon_code', couponPercentage); await removeCouponFromCart();
await expect(page).toClick('button', {text: 'Apply coupon'}); });
await uiUnblocked();
await page.waitForSelector('.woocommerce-message', {text: 'Coupon code applied successfully.'});
await page.waitForSelector('.cart-discount .amount', {text: '$4.99'});
await page.waitForSelector('.order-total .amount', {text: '$5.00'});
// Remove coupon it('allows customer to apply fixed product coupon', async () => {
await expect(page).toClick('.woocommerce-remove-coupon', {text: '[Remove]'}); await applyCouponToCart( couponFixedProduct );
await uiUnblocked(); await expect(page).toMatchElement('.woocommerce-message', {text: 'Coupon code applied successfully.'});
await page.waitForSelector('.woocommerce-message', {text: 'Coupon has been removed.'}); await expect(page).toMatchElement('.cart-discount .amount', {text: '$5.00'});
await expect(page).toMatchElement('.order-total .amount', {text: '$4.99'});
await removeCouponFromCart();
});
// Apply Fixed product discount coupon it('prevents customer applying same coupon twice', async () => {
await expect(page).toClick('a', {text: 'Click here to enter your code'}); await applyCouponToCart( couponFixedProduct );
await uiUnblocked(); await applyCouponToCart( couponFixedProduct );
await expect(page).toFill('#coupon_code', couponFixedProduct); await expect(page).toMatchElement('.woocommerce-error', { text: 'Coupon code already applied!' });
await expect(page).toClick('button', {text: 'Apply coupon'}); });
await uiUnblocked();
await page.waitForSelector('.woocommerce-message', {text: 'Coupon code applied successfully.'});
await page.waitForSelector('.cart-discount .amount', {text: '$5.00'});
await page.waitForSelector('.order-total .amount', {text: '$4.99'});
// Try to apply the same coupon it('allows customer to apply multiple coupon', async () => {
await expect(page).toClick('a', {text: 'Click here to enter your code'}); await applyCouponToCart( couponFixedCart );
await uiUnblocked(); await expect(page).toMatchElement('.woocommerce-message', {text: 'Coupon code applied successfully.'});
await expect(page).toFill('#coupon_code', couponFixedProduct); await expect(page).toMatchElement('.order-total .amount', {text: '$0.00'});
await expect(page).toClick('button', {text: 'Apply coupon'}); });
await uiUnblocked();
await page.waitForSelector('.woocommerce-error', { text: 'Coupon code already applied!' });
// Try to apply multiple coupons it('restores cart total when coupons are removed', async () => {
await expect(page).toClick('a', {text: 'Click here to enter your code'}); await removeCouponFromCart();
await uiUnblocked(); await removeCouponFromCart();
await expect(page).toFill('#coupon_code', couponFixedCart); await expect(page).toMatchElement('.order-total .amount', {text: '$9.99'});
await expect(page).toClick('button', {text: 'Apply coupon'});
await uiUnblocked();
await page.waitForSelector('.woocommerce-message', {text: 'Coupon code applied successfully.'});
await page.waitForSelector('.order-total .amount', {text: '$0.00'});
// Remove coupon
await expect(page).toClick('.woocommerce-remove-coupon', {text: '[Remove]'});
await uiUnblocked();
await page.waitForSelector('.woocommerce-message', {text: 'Coupon has been removed.'});
await expect(page).toClick('.woocommerce-remove-coupon', {text: '[Remove]'});
await uiUnblocked();
await page.waitForSelector('.woocommerce-message', {text: 'Coupon has been removed.'});
// Verify the total amount after all coupons removal
await page.waitForSelector('.order-total .amount', {text: '$9.99'});
}); });
}); });
}; };