Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
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
2 changes: 1 addition & 1 deletion pom.xml
Original file line number Diff line number Diff line change
Expand Up @@ -50,7 +50,7 @@
<dependency>
<groupId>com.github.Podzilla</groupId>
<artifactId>podzilla-utils-lib</artifactId>
<version>1.1.11</version>
<version>v1.1.13</version>

</dependency>

Expand Down
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
package com.podzilla.cart.controller;

import com.podzilla.auth.annotations.AllowedRoles;
import com.podzilla.cart.model.PromoCode;
import com.podzilla.cart.service.PromoCodeService;
import io.swagger.v3.oas.annotations.Operation;
Expand All @@ -22,6 +23,7 @@

@RestController
@RequestMapping("/admin/promocodes")
@AllowedRoles({"ROLE_ADMIN"})
@RequiredArgsConstructor
@Tag(name = "PromoCode Admin", description = "Manage promotional codes (Requires Admin Role)")
@Slf4j
Expand Down
2 changes: 1 addition & 1 deletion src/main/java/com/podzilla/cart/service/CartService.java
Original file line number Diff line number Diff line change
Expand Up @@ -294,7 +294,7 @@ public Cart checkoutCart(final String customerId, final ConfirmationType confirm
+ " Discount={}, Total={}, ConfirmationType={}",
cart.getId(), cart.getSubTotal(), cart.getDiscountAmount(),
cart.getTotalPrice(), confirmationType);
eventPublisher.publishEvent(EventsConstants.ORDER_PLACED, checkoutEvent);
eventPublisher.publishEvent(EventsConstants.CART_CHECKEDOUT, checkoutEvent);

log.info("Checkout event published successfully for cartId: {}. Clearing cart.", cart.getId());
cart.getItems().clear();
Expand Down
12 changes: 6 additions & 6 deletions src/test/java/service/CartServiceTest.java
Original file line number Diff line number Diff line change
Expand Up @@ -343,12 +343,12 @@ void checkoutCart_validCartWithPromo_publishesEventAndClearsCart() {
PromoCode promo = createTestPromoCode("SAVE10", PromoCode.DiscountType.PERCENTAGE, new BigDecimal("10"), null, null, true);
when(promoCodeService.getActivePromoCode("SAVE10")).thenReturn(Optional.of(promo));

doNothing().when(eventPublisher).publishEvent(eq(EventsConstants.ORDER_PLACED), any(CartCheckedoutEvent.class));
doNothing().when(eventPublisher).publishEvent(eq(EventsConstants.CART_CHECKEDOUT), any(CartCheckedoutEvent.class));

Cart result = cartService.checkoutCart(customerId, ConfirmationType.OTP, "", latitude, longitude, address);

ArgumentCaptor<CartCheckedoutEvent> eventCaptor = ArgumentCaptor.forClass(CartCheckedoutEvent.class);
verify(eventPublisher).publishEvent(eq(EventsConstants.ORDER_PLACED), eventCaptor.capture());
verify(eventPublisher).publishEvent(eq(EventsConstants.CART_CHECKEDOUT), eventCaptor.capture());
CartCheckedoutEvent publishedEvent = eventCaptor.getValue();

assertEquals(customerId, publishedEvent.getCustomerId());
Expand Down Expand Up @@ -377,7 +377,7 @@ void checkoutCart_withSignature_publishesEventWithSignature() {
Cart result = cartService.checkoutCart(customerId, ConfirmationType.SIGNATURE, signature, latitude, longitude, address);

ArgumentCaptor<CartCheckedoutEvent> eventCaptor = ArgumentCaptor.forClass(CartCheckedoutEvent.class);
verify(eventPublisher).publishEvent(eq(EventsConstants.ORDER_PLACED), eventCaptor.capture());
verify(eventPublisher).publishEvent(eq(EventsConstants.CART_CHECKEDOUT), eventCaptor.capture());
CartCheckedoutEvent publishedEvent = eventCaptor.getValue();

assertEquals(ConfirmationType.SIGNATURE, publishedEvent.getConfirmationType());
Expand All @@ -393,7 +393,7 @@ void checkoutCart_signatureTypeWithoutSignature_throwsException() {

assertEquals(HttpStatus.BAD_REQUEST, ex.getStatus());
assertEquals("Signature is required for SIGNATURE confirmation type", ex.getMessage());
verify(eventPublisher, never()).publishEvent(eq(EventsConstants.ORDER_PLACED), any(CartCheckedoutEvent.class));
verify(eventPublisher, never()).publishEvent(eq(EventsConstants.CART_CHECKEDOUT), any(CartCheckedoutEvent.class));
}

@Test
Expand All @@ -405,7 +405,7 @@ void checkoutCart_emptyCart_throwsGlobalHandlerException() {

assertEquals(HttpStatus.BAD_REQUEST, ex.getStatus());
assertEquals("Cannot checkout an empty cart.", ex.getMessage());
verify(eventPublisher, never()).publishEvent(eq(EventsConstants.ORDER_PLACED), any(CartCheckedoutEvent.class));
verify(eventPublisher, never()).publishEvent(eq(EventsConstants.CART_CHECKEDOUT), any(CartCheckedoutEvent.class));
}

@Test
Expand All @@ -421,7 +421,7 @@ void checkoutCart_rabbitMqFails_throwsRuntimeExceptionAndCartNotCleared() {
cart.setDiscountAmount(new BigDecimal(formattedBigZero));

doThrow(new RuntimeException("Event publish error")).when(eventPublisher)
.publishEvent(eq(EventsConstants.ORDER_PLACED), any(CartCheckedoutEvent.class));
.publishEvent(eq(EventsConstants.CART_CHECKEDOUT), any(CartCheckedoutEvent.class));

RuntimeException ex = assertThrows(RuntimeException.class,
() -> cartService.checkoutCart(customerId, ConfirmationType.QR_CODE, null, latitude, longitude, address));
Expand Down