forked from pierront/mylibrary-template
Compare commits
34 Commits
13f8cab3ed
..
main
| Author | SHA1 | Date | |
|---|---|---|---|
| d0c7514624 | |||
| fd9863097c | |||
| c582b54a42 | |||
| a828b0db95 | |||
| 4511e4e961 | |||
| 889f17d806 | |||
| 8fc037e4b1 | |||
| 0d2a88f4a0 | |||
| a5c26c62e3 | |||
| 1ac8896253 | |||
| 4d7079c585 | |||
| 5b7e413a44 | |||
| f0704e4039 | |||
| 7ba85a0ae8 | |||
| 9bdccbb954 | |||
| 01e92154e7 | |||
| 42b0073297 | |||
| aa40ad0e3b | |||
| 76b60297c1 | |||
| 3ace5810f8 | |||
| 28a923c126 | |||
| a93ea4fc31 | |||
| 45d4016960 | |||
| 7c2eb19e13 | |||
| 49ddb77fb2 | |||
| 3deb17a4c7 | |||
| 655fad8fb2 | |||
| 5adb10101f | |||
| 2c33798c83 | |||
| 9e69e02066 | |||
| b2969260c0 | |||
| 2a6db59950 | |||
| 5d5945b48b | |||
| da19dfcbac |
@@ -19,6 +19,12 @@
|
||||
}
|
||||
},
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
"PasserCommande": {
|
||||
"input": {
|
||||
"clientId": "uuid",
|
||||
@@ -40,6 +46,12 @@
|
||||
"pointsFideliteGagnes": "integer"
|
||||
}
|
||||
},
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
"GererAvis": {
|
||||
"input": {
|
||||
"clientId": "uuid",
|
||||
|
||||
@@ -0,0 +1,3 @@
|
||||
package fr.iut_fbleau.but3.dev62.mylibrary.commande;
|
||||
|
||||
public record AdresseInfo(String rue, String ville, String codePostal, String pays) {}
|
||||
@@ -0,0 +1,23 @@
|
||||
package fr.iut_fbleau.but3.dev62.mylibrary.commande;
|
||||
|
||||
import lombok.Builder;
|
||||
import lombok.Getter;
|
||||
|
||||
import java.util.List;
|
||||
import java.util.UUID;
|
||||
|
||||
@Getter
|
||||
@Builder
|
||||
public class CommandeDTO {
|
||||
private UUID clientId;
|
||||
private List<LigneCommandeInfo> lignesCommande;
|
||||
private String rue;
|
||||
private String ville;
|
||||
private String codePostal;
|
||||
private String pays;
|
||||
private String modePaiement;
|
||||
private UUID commandeId ;
|
||||
private double montantTotal ;
|
||||
private Integer pointsFideliteGagnes ;
|
||||
|
||||
}
|
||||
@@ -0,0 +1,6 @@
|
||||
package fr.iut_fbleau.but3.dev62.mylibrary.commande;
|
||||
|
||||
import java.util.List;
|
||||
|
||||
public record CommandeInfo(List<LigneCommandeInfo> listeLigne , String modePayement) {
|
||||
}
|
||||
@@ -0,0 +1,15 @@
|
||||
package fr.iut_fbleau.but3.dev62.mylibrary.commande;
|
||||
|
||||
|
||||
import lombok.Builder;
|
||||
import lombok.Getter;
|
||||
|
||||
import java.util.UUID;
|
||||
|
||||
@Getter
|
||||
@Builder
|
||||
public class LigneCommandeDTO {
|
||||
|
||||
int quantite;
|
||||
UUID id;
|
||||
}
|
||||
@@ -0,0 +1,6 @@
|
||||
package fr.iut_fbleau.but3.dev62.mylibrary.commande;
|
||||
|
||||
import java.util.UUID;
|
||||
|
||||
public record LigneCommandeInfo(int quantite) {
|
||||
}
|
||||
@@ -0,0 +1,7 @@
|
||||
package fr.iut_fbleau.but3.dev62.mylibrary.commande;
|
||||
|
||||
public enum ModePaiement {
|
||||
CB,
|
||||
PAYPAL,
|
||||
POINTS_FIDELITE,
|
||||
}
|
||||
+59
@@ -0,0 +1,59 @@
|
||||
package fr.iut_fbleau.but3.dev62.mylibrary.commande.converter;
|
||||
|
||||
import fr.iut_fbleau.but3.dev62.mylibrary.commande.AdresseInfo;
|
||||
import fr.iut_fbleau.but3.dev62.mylibrary.commande.CommandeInfo;
|
||||
import fr.iut_fbleau.but3.dev62.mylibrary.commande.CommandeDTO;
|
||||
import fr.iut_fbleau.but3.dev62.mylibrary.commande.entity.Commande;
|
||||
|
||||
public final class CommandeConverter {
|
||||
|
||||
|
||||
public static Commande toDomain(CommandeInfo commandeInfo, AdresseInfo adressInfo, String modePaiement) {
|
||||
return Commande.builder()
|
||||
.lignesCommande(commandeInfo.listeLigne())
|
||||
.rue(adressInfo.rue())
|
||||
.ville(adressInfo.ville())
|
||||
.codePostal(adressInfo.codePostal())
|
||||
.pays(adressInfo.pays())
|
||||
.modePaiement(commandeInfo.modePayement())
|
||||
.build();
|
||||
}
|
||||
|
||||
public static Commande toDomain(CommandeInfo commandeInfo, AdresseInfo adressInfo) {
|
||||
return Commande.builder()
|
||||
.lignesCommande(commandeInfo.listeLigne())
|
||||
.rue(adressInfo.rue())
|
||||
.ville(adressInfo.ville())
|
||||
.codePostal(adressInfo.codePostal())
|
||||
.pays(adressInfo.pays())
|
||||
.modePaiement(commandeInfo.modePayement())
|
||||
.build();
|
||||
}
|
||||
|
||||
public static CommandeDTO toDTO(CommandeInfo commandeInfo, AdresseInfo adressInfo, String modePaiement) {
|
||||
return CommandeDTO.builder()
|
||||
.lignesCommande(commandeInfo.listeLigne())
|
||||
.rue(adressInfo.rue())
|
||||
.ville(adressInfo.ville())
|
||||
.codePostal(adressInfo.codePostal())
|
||||
.pays(adressInfo.pays())
|
||||
.modePaiement(modePaiement)
|
||||
.build();
|
||||
}
|
||||
|
||||
public static CommandeDTO toDTO(Commande commande) {
|
||||
return CommandeDTO.builder()
|
||||
.lignesCommande(commande.getLignesCommande())
|
||||
.rue(commande.getRue())
|
||||
.ville(commande.getVille())
|
||||
.codePostal(commande.getCodePostal())
|
||||
.pays(commande.getPays())
|
||||
.modePaiement(commande.getModePaiement())
|
||||
.commandeId(commande.getCommandeId())
|
||||
.clientId(commande.getClientId())
|
||||
.montantTotal(commande.getMontantTotal())
|
||||
.pointsFideliteGagnes(commande.getPointsFideliteGagnes())
|
||||
.build();
|
||||
}
|
||||
|
||||
}
|
||||
+22
@@ -0,0 +1,22 @@
|
||||
package fr.iut_fbleau.but3.dev62.mylibrary.commande.converter;
|
||||
|
||||
import fr.iut_fbleau.but3.dev62.mylibrary.commande.LigneCommandeDTO;
|
||||
import fr.iut_fbleau.but3.dev62.mylibrary.commande.LigneCommandeInfo;
|
||||
import fr.iut_fbleau.but3.dev62.mylibrary.commande.entity.Commande;
|
||||
import fr.iut_fbleau.but3.dev62.mylibrary.commande.entity.LigneCommande;
|
||||
|
||||
public final class LigneCommandeConverter {
|
||||
|
||||
public static LigneCommande toDomain(LigneCommandeInfo ligneCommandeInfo) {
|
||||
return LigneCommande.builder()
|
||||
.quantite(ligneCommandeInfo.quantite())
|
||||
.build();
|
||||
}
|
||||
|
||||
public static LigneCommandeDTO toDTO(LigneCommandeInfo ligneCommandeInfo) {
|
||||
return LigneCommandeDTO.builder()
|
||||
.quantite(ligneCommandeInfo.quantite())
|
||||
.build();
|
||||
}
|
||||
|
||||
}
|
||||
@@ -0,0 +1,44 @@
|
||||
package fr.iut_fbleau.but3.dev62.mylibrary.commande.entity;
|
||||
|
||||
import fr.iut_fbleau.but3.dev62.mylibrary.commande.LigneCommandeInfo;
|
||||
import fr.iut_fbleau.but3.dev62.mylibrary.commande.ModePaiement;
|
||||
import lombok.Builder;
|
||||
import lombok.Getter;
|
||||
|
||||
import java.util.List;
|
||||
import java.util.UUID;
|
||||
|
||||
@Getter
|
||||
@Builder
|
||||
public class Commande {
|
||||
private UUID clientId;
|
||||
private List<LigneCommandeInfo> lignesCommande;
|
||||
private String rue;
|
||||
private String ville;
|
||||
private String codePostal;
|
||||
private String pays;
|
||||
private String modePaiement;
|
||||
|
||||
private UUID commandeId ;
|
||||
private double montantTotal ;
|
||||
private Integer pointsFideliteGagnes ;
|
||||
|
||||
public void setRandomUUID() {
|
||||
this.clientId = UUID.randomUUID();
|
||||
}
|
||||
|
||||
public void setRandomUUIDCommande() {
|
||||
this.commandeId = UUID.randomUUID();
|
||||
}
|
||||
|
||||
public int convertPointsFidelite(){
|
||||
if (this.montantTotal==0|| this.montantTotal<=0){
|
||||
return 0;
|
||||
}
|
||||
return (int) Math.ceil(this.getMontantTotal());
|
||||
}
|
||||
|
||||
|
||||
// conversion point de fidéliter
|
||||
|
||||
}
|
||||
@@ -0,0 +1,20 @@
|
||||
package fr.iut_fbleau.but3.dev62.mylibrary.commande.entity;
|
||||
|
||||
|
||||
import lombok.Builder;
|
||||
import lombok.Getter;
|
||||
|
||||
import java.util.UUID;
|
||||
|
||||
@Getter
|
||||
@Builder
|
||||
public class LigneCommande {
|
||||
|
||||
int quantite;
|
||||
UUID livreId;
|
||||
|
||||
public void setRandomUUID() {
|
||||
this.livreId = UUID.randomUUID();
|
||||
}
|
||||
|
||||
}
|
||||
+13
@@ -0,0 +1,13 @@
|
||||
package fr.iut_fbleau.but3.dev62.mylibrary.commande.exception;
|
||||
|
||||
import java.text.MessageFormat;
|
||||
import java.util.UUID;
|
||||
|
||||
public class CommandeNotFoundException extends RuntimeException {
|
||||
|
||||
public static final String THE_COMMANDE_WITH_ID_DOES_NOT_EXIST_MESSAGE = "The commande with id {0} does not exist";
|
||||
|
||||
public CommandeNotFoundException(UUID uuid) {
|
||||
super(MessageFormat.format(THE_COMMANDE_WITH_ID_DOES_NOT_EXIST_MESSAGE, uuid));
|
||||
}
|
||||
}
|
||||
+7
@@ -0,0 +1,7 @@
|
||||
package fr.iut_fbleau.but3.dev62.mylibrary.commande.exception;
|
||||
|
||||
public class NotValidAdressException extends RuntimeException {
|
||||
public NotValidAdressException(String message) {
|
||||
super(message);
|
||||
}
|
||||
}
|
||||
+7
@@ -0,0 +1,7 @@
|
||||
package fr.iut_fbleau.but3.dev62.mylibrary.commande.exception;
|
||||
|
||||
public class NotValidCommandeException extends RuntimeException {
|
||||
public NotValidCommandeException(String message) {
|
||||
super(message);
|
||||
}
|
||||
}
|
||||
+7
@@ -0,0 +1,7 @@
|
||||
package fr.iut_fbleau.but3.dev62.mylibrary.commande.exception;
|
||||
|
||||
public class NotValidLigneCommandeException extends RuntimeException {
|
||||
public NotValidLigneCommandeException(String message) {
|
||||
super(message);
|
||||
}
|
||||
}
|
||||
+47
@@ -0,0 +1,47 @@
|
||||
package fr.iut_fbleau.but3.dev62.mylibrary.commande.repository;
|
||||
|
||||
import fr.iut_fbleau.but3.dev62.mylibrary.commande.entity.Commande;
|
||||
|
||||
import java.util.ArrayList;
|
||||
import java.util.List;
|
||||
import java.util.Optional;
|
||||
import java.util.UUID;
|
||||
|
||||
public class CommandeRepository {
|
||||
|
||||
private final List<Commande> commande = new ArrayList<>();
|
||||
|
||||
public List<Commande> findAll(){return commande;}
|
||||
|
||||
|
||||
public void deleteAll() {
|
||||
commande.clear();
|
||||
}
|
||||
|
||||
public Commande save(Commande newCommande){
|
||||
Optional<Commande> optionalCommandeWithSameIsbn = this.findById(newCommande.getCommandeId());
|
||||
optionalCommandeWithSameIsbn.ifPresent(commande::remove);
|
||||
this.commande.add(newCommande);
|
||||
return newCommande;
|
||||
}
|
||||
|
||||
public Optional<Commande> findById(UUID uuid){
|
||||
return this.commande.stream()
|
||||
.filter(customer -> customer.getCommandeId().equals(uuid))
|
||||
.findFirst();
|
||||
}
|
||||
|
||||
public boolean existsById(UUID uuid) {
|
||||
return this.commande.stream()
|
||||
.anyMatch(customer -> customer.getCommandeId().equals(uuid));
|
||||
}
|
||||
|
||||
public void delete(Commande commande) {
|
||||
this.commande.remove(commande);
|
||||
}
|
||||
|
||||
|
||||
public void deleteById(UUID uuid) {
|
||||
this.commande.removeIf(commande -> commande.getClientId().equals(uuid));
|
||||
}
|
||||
}
|
||||
+73
@@ -0,0 +1,73 @@
|
||||
package fr.iut_fbleau.but3.dev62.mylibrary.commande.usecase;
|
||||
|
||||
import fr.iut_fbleau.but3.dev62.mylibrary.commande.AdresseInfo;
|
||||
import fr.iut_fbleau.but3.dev62.mylibrary.commande.CommandeDTO;
|
||||
import fr.iut_fbleau.but3.dev62.mylibrary.commande.CommandeInfo;
|
||||
import fr.iut_fbleau.but3.dev62.mylibrary.commande.converter.CommandeConverter;
|
||||
import fr.iut_fbleau.but3.dev62.mylibrary.commande.entity.Commande;
|
||||
import fr.iut_fbleau.but3.dev62.mylibrary.commande.exception.CommandeNotFoundException;
|
||||
import fr.iut_fbleau.but3.dev62.mylibrary.commande.exception.NotValidCommandeException;
|
||||
import fr.iut_fbleau.but3.dev62.mylibrary.commande.repository.CommandeRepository;
|
||||
import fr.iut_fbleau.but3.dev62.mylibrary.commande.validator.CommandeValidator;
|
||||
|
||||
import java.util.Optional;
|
||||
import java.util.UUID;
|
||||
|
||||
public class CommandeUseCase {
|
||||
|
||||
private final CommandeRepository commandeRepository;
|
||||
|
||||
public CommandeUseCase(CommandeRepository commandeRepository) {
|
||||
this.commandeRepository = commandeRepository;
|
||||
}
|
||||
|
||||
|
||||
public UUID registerCommande(CommandeInfo validCommandeInfo, AdresseInfo validAdresseInfo){
|
||||
CommandeValidator.validate(validCommandeInfo);
|
||||
CommandeValidator.validate(validAdresseInfo);
|
||||
|
||||
Commande commandeToRegister = CommandeConverter.toDomain(validCommandeInfo,validAdresseInfo);
|
||||
Commande commandeToRegistered = commandeRepository.save(commandeToRegister) ;
|
||||
return commandeToRegistered.getCommandeId();
|
||||
|
||||
}
|
||||
|
||||
public Optional<CommandeDTO> findCommandByUUID(UUID uuid) {
|
||||
Optional<Commande> optionalCommande = commandeRepository.findById(uuid);
|
||||
return optionalCommande.map(CommandeConverter::toDTO);
|
||||
}
|
||||
|
||||
public CommandeDTO updateCommande(UUID uuid, CommandeInfo commandeInfo, AdresseInfo adresseInfo)
|
||||
throws CommandeNotFoundException, NotValidCommandeException {
|
||||
CommandeValidator.validate(commandeInfo);
|
||||
CommandeValidator.validate(adresseInfo);
|
||||
Commande commandeByUUID = getCommandeIfDoesNotExistThrowCommandeNotFoundException(
|
||||
uuid);
|
||||
Commande commande = Commande.builder()
|
||||
.clientId(commandeByUUID.getClientId())
|
||||
.lignesCommande(commandeInfo.listeLigne())
|
||||
.rue(adresseInfo.rue())
|
||||
.ville(adresseInfo.ville())
|
||||
.codePostal(adresseInfo.codePostal())
|
||||
.pays(adresseInfo.pays())
|
||||
.modePaiement(commandeInfo.modePayement())
|
||||
.commandeId(uuid)
|
||||
.build();
|
||||
Commande updatedCommande = commandeRepository.save(commande);
|
||||
return CommandeConverter.toDTO(updatedCommande);
|
||||
}
|
||||
|
||||
public void deleteCommande(UUID uuid) throws CommandeNotFoundException {
|
||||
Commande commandeToDelete = getCommandeIfDoesNotExistThrowCommandeNotFoundException(uuid);
|
||||
this.commandeRepository.delete(commandeToDelete);
|
||||
}
|
||||
|
||||
private Commande getCommandeIfDoesNotExistThrowCommandeNotFoundException(UUID uuid)
|
||||
throws CommandeNotFoundException {
|
||||
Optional<Commande> optionalCommandeById = commandeRepository.findById(uuid);
|
||||
if (optionalCommandeById.isEmpty()) {
|
||||
throw new CommandeNotFoundException(uuid);
|
||||
}
|
||||
return optionalCommandeById.get();
|
||||
}
|
||||
}
|
||||
+87
@@ -0,0 +1,87 @@
|
||||
package fr.iut_fbleau.but3.dev62.mylibrary.commande.validator;
|
||||
|
||||
import fr.iut_fbleau.but3.dev62.mylibrary.commande.AdresseInfo;
|
||||
import fr.iut_fbleau.but3.dev62.mylibrary.commande.CommandeInfo;
|
||||
import fr.iut_fbleau.but3.dev62.mylibrary.commande.LigneCommandeInfo;
|
||||
import fr.iut_fbleau.but3.dev62.mylibrary.commande.exception.NotValidAdressException;
|
||||
import fr.iut_fbleau.but3.dev62.mylibrary.commande.exception.NotValidCommandeException;
|
||||
import fr.iut_fbleau.but3.dev62.mylibrary.commande.exception.NotValidLigneCommandeException;
|
||||
|
||||
import java.util.Objects;
|
||||
|
||||
public final class CommandeValidator {
|
||||
|
||||
public static final String LIGNE_COMMANDE_IS_NOT_VALIDE = "Ligne commande is not valide";
|
||||
public static final String MODE_PAIEMENT_IS_NOT_VALIDE = "Mode Paiement is not valide";
|
||||
public static final String LIST_LIGNE_COMANDE_IS_NOT_VALIDE = "List ligne commande is not valide";
|
||||
public static final String STREET_IS_NOT_VALIDE = "rue is not valide";
|
||||
|
||||
public static final String CITY_IS_NOT_VALIDE = "city is not valide";
|
||||
public static final String CODE_POSTAL_IS_NOT_VALIDE = "code postal is not valide";
|
||||
public static final String COUNTRY_IS_NOT_VALIDE = "Country is not valide";
|
||||
|
||||
|
||||
public static void validate(LigneCommandeInfo ligneCommandeInfo) {
|
||||
if (ligneCommandeInfo.quantite()<=0){
|
||||
throw new NotValidLigneCommandeException(LIGNE_COMMANDE_IS_NOT_VALIDE);
|
||||
}
|
||||
}
|
||||
|
||||
public static void validate(CommandeInfo commandeInfo) {
|
||||
|
||||
validateModePaiement(commandeInfo);
|
||||
validateListLigneCommande(commandeInfo);
|
||||
}
|
||||
|
||||
public static void validate(AdresseInfo adresseInfo) {
|
||||
validateStreet(adresseInfo);
|
||||
validateCity(adresseInfo);
|
||||
validateCodePostal(adresseInfo);
|
||||
validateCountry(adresseInfo);
|
||||
}
|
||||
|
||||
|
||||
|
||||
private static void validateModePaiement(CommandeInfo commandeInfo) {
|
||||
if(commandeInfo.modePayement()!="CB"&& commandeInfo.modePayement()!="PAYPAL"&& commandeInfo.modePayement()!="POINTS_FIDELITE"){
|
||||
throw new NotValidCommandeException(MODE_PAIEMENT_IS_NOT_VALIDE);
|
||||
}
|
||||
}
|
||||
|
||||
private static void validateListLigneCommande(CommandeInfo commandeInfo) {
|
||||
if (commandeInfo.listeLigne() == null
|
||||
|| commandeInfo.listeLigne().isEmpty()
|
||||
|| commandeInfo.listeLigne().stream().anyMatch(Objects::isNull)){
|
||||
throw new NotValidCommandeException(LIST_LIGNE_COMANDE_IS_NOT_VALIDE);
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
private static void validateStreet(AdresseInfo adresseInfo) {
|
||||
if (adresseInfo.rue() == null || adresseInfo.rue().isBlank()){
|
||||
throw new NotValidAdressException(STREET_IS_NOT_VALIDE);
|
||||
}
|
||||
}
|
||||
private static void validateCity(AdresseInfo adresseInfo) {
|
||||
if (adresseInfo.ville() == null || adresseInfo.ville().isBlank()){
|
||||
throw new NotValidAdressException(CITY_IS_NOT_VALIDE);
|
||||
}
|
||||
}
|
||||
|
||||
private static void validateCodePostal(AdresseInfo adresseInfo) {
|
||||
if (adresseInfo.codePostal() == null || adresseInfo.codePostal().isBlank()){
|
||||
throw new NotValidAdressException(CODE_POSTAL_IS_NOT_VALIDE);
|
||||
}
|
||||
}
|
||||
|
||||
private static void validateCountry(AdresseInfo adresseInfo) {
|
||||
if (adresseInfo.pays() == null || adresseInfo.pays().isBlank()){
|
||||
throw new NotValidAdressException(COUNTRY_IS_NOT_VALIDE);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
}
|
||||
+17
@@ -0,0 +1,17 @@
|
||||
package fr.iut_fbleau.but3.dev62.mylibrary.subscription;
|
||||
|
||||
public enum DesiredSubscriptionDuration {
|
||||
THREE(3),
|
||||
SIX(6),
|
||||
TWELVE(12);
|
||||
|
||||
private final Integer value;
|
||||
|
||||
DesiredSubscriptionDuration(Integer value) {
|
||||
this.value = value;
|
||||
}
|
||||
|
||||
public Integer getValue() {
|
||||
return value;
|
||||
}
|
||||
}
|
||||
@@ -0,0 +1,4 @@
|
||||
package fr.iut_fbleau.but3.dev62.mylibrary.subscription;
|
||||
|
||||
public record PaymentMethodInfo(String paymentType, Object details) {
|
||||
}
|
||||
@@ -0,0 +1,6 @@
|
||||
package fr.iut_fbleau.but3.dev62.mylibrary.subscription;
|
||||
|
||||
public enum PaymentType {
|
||||
CB,
|
||||
PAYPAL;
|
||||
}
|
||||
@@ -0,0 +1,22 @@
|
||||
package fr.iut_fbleau.but3.dev62.mylibrary.subscription;
|
||||
|
||||
import fr.iut_fbleau.but3.dev62.mylibrary.subscription.entity.PaymentMethod;
|
||||
import lombok.Builder;
|
||||
import lombok.Getter;
|
||||
|
||||
import java.time.LocalDate;
|
||||
import java.util.UUID;
|
||||
|
||||
@Builder
|
||||
@Getter
|
||||
public class SubscriptionDTO {
|
||||
|
||||
private UUID subscriptionId;
|
||||
private UUID customerId;
|
||||
private Integer desiredSubscriptionDuration;
|
||||
private PaymentMethod paymentMethod;
|
||||
private LocalDate desiredStartDate;
|
||||
private LocalDate startDate;
|
||||
private LocalDate endDate;
|
||||
private double monthlyAmount;
|
||||
}
|
||||
@@ -0,0 +1,6 @@
|
||||
package fr.iut_fbleau.but3.dev62.mylibrary.subscription;
|
||||
|
||||
import java.time.LocalDate;
|
||||
|
||||
public record SubscriptionInfo(Integer desiredSubscriptionDuration, LocalDate desiredStartDate) {
|
||||
}
|
||||
+43
@@ -0,0 +1,43 @@
|
||||
package fr.iut_fbleau.but3.dev62.mylibrary.subscription.converter;
|
||||
|
||||
import fr.iut_fbleau.but3.dev62.mylibrary.customer.CustomerDTO;
|
||||
import fr.iut_fbleau.but3.dev62.mylibrary.subscription.PaymentMethodInfo;
|
||||
import fr.iut_fbleau.but3.dev62.mylibrary.subscription.SubscriptionDTO;
|
||||
import fr.iut_fbleau.but3.dev62.mylibrary.subscription.SubscriptionInfo;
|
||||
import fr.iut_fbleau.but3.dev62.mylibrary.subscription.entity.PaymentMethod;
|
||||
import fr.iut_fbleau.but3.dev62.mylibrary.subscription.entity.Subscription;
|
||||
|
||||
public class SubscriptionConverter {
|
||||
|
||||
private SubscriptionConverter(){
|
||||
|
||||
}
|
||||
|
||||
public static Subscription toDomain(SubscriptionInfo newSubscription, PaymentMethodInfo newPaymentMethod) {
|
||||
PaymentMethod paymentMethod = PaymentMethod.builder()
|
||||
.paymentType(newPaymentMethod.paymentType())
|
||||
.details(newPaymentMethod.details())
|
||||
.build();
|
||||
return Subscription.builder()
|
||||
.desiredSubscriptionDuration(newSubscription.desiredSubscriptionDuration())
|
||||
.paymentMethod(paymentMethod)
|
||||
.desiredStartDate(newSubscription.desiredStartDate())
|
||||
.startDate(newSubscription.desiredStartDate())
|
||||
.endDate(newSubscription.desiredStartDate().plusMonths(newSubscription.desiredSubscriptionDuration()))
|
||||
.monthlyAmount(0)
|
||||
.build();
|
||||
}
|
||||
|
||||
public static SubscriptionDTO toDTO(Subscription subscription) {
|
||||
return SubscriptionDTO.builder()
|
||||
.subscriptionId(subscription.getSubscriptionId())
|
||||
.customerId(subscription.getCustomerId())
|
||||
.desiredSubscriptionDuration(subscription.getDesiredSubscriptionDuration())
|
||||
.paymentMethod(subscription.getPaymentMethod())
|
||||
.desiredStartDate(subscription.getDesiredStartDate())
|
||||
.startDate(subscription.getStartDate())
|
||||
.endDate(subscription.getEndDate())
|
||||
.monthlyAmount(subscription.getMonthlyAmount())
|
||||
.build();
|
||||
}
|
||||
}
|
||||
+12
@@ -0,0 +1,12 @@
|
||||
package fr.iut_fbleau.but3.dev62.mylibrary.subscription.entity;
|
||||
|
||||
import lombok.Builder;
|
||||
import lombok.Getter;
|
||||
|
||||
@Builder
|
||||
@Getter
|
||||
public class PaymentMethod {
|
||||
|
||||
private String paymentType;
|
||||
private Object details;
|
||||
}
|
||||
+44
@@ -0,0 +1,44 @@
|
||||
package fr.iut_fbleau.but3.dev62.mylibrary.subscription.entity;
|
||||
|
||||
import lombok.Builder;
|
||||
import lombok.Getter;
|
||||
|
||||
import java.time.LocalDate;
|
||||
import java.util.UUID;
|
||||
|
||||
@Builder
|
||||
@Getter
|
||||
public class Subscription {
|
||||
|
||||
private UUID subscriptionId;
|
||||
private UUID customerId;
|
||||
private Integer desiredSubscriptionDuration;
|
||||
private PaymentMethod paymentMethod;
|
||||
private LocalDate desiredStartDate;
|
||||
private LocalDate startDate;
|
||||
private LocalDate endDate;
|
||||
private double monthlyAmount;
|
||||
|
||||
public void setRandomSubscriptionUUID() {
|
||||
|
||||
this.subscriptionId = UUID.randomUUID();
|
||||
}
|
||||
|
||||
public void setRandomCustomerUUID() {
|
||||
|
||||
this.customerId = UUID.randomUUID();
|
||||
}
|
||||
|
||||
public void setStartDate(){
|
||||
this.startDate = this.desiredStartDate;
|
||||
}
|
||||
|
||||
public void setEndDate(){
|
||||
this.endDate = this.desiredStartDate.plusMonths(this.desiredSubscriptionDuration);
|
||||
}
|
||||
|
||||
public void setDateSubscription(){
|
||||
setStartDate();
|
||||
setEndDate();
|
||||
}
|
||||
}
|
||||
+8
@@ -0,0 +1,8 @@
|
||||
package fr.iut_fbleau.but3.dev62.mylibrary.subscription.exception;
|
||||
|
||||
public class NotValidPaymentMethodException extends RuntimeException {
|
||||
|
||||
public NotValidPaymentMethodException(String message) {
|
||||
super(message);
|
||||
}
|
||||
}
|
||||
+8
@@ -0,0 +1,8 @@
|
||||
package fr.iut_fbleau.but3.dev62.mylibrary.subscription.exception;
|
||||
|
||||
public class NotValidSubscriptionException extends RuntimeException {
|
||||
|
||||
public NotValidSubscriptionException(String message) {
|
||||
super(message);
|
||||
}
|
||||
}
|
||||
+21
@@ -0,0 +1,21 @@
|
||||
package fr.iut_fbleau.but3.dev62.mylibrary.subscription.exception;
|
||||
|
||||
import java.text.MessageFormat;
|
||||
import java.util.Optional;
|
||||
import java.util.UUID;
|
||||
|
||||
public class SubscriptionNotFoundException extends RuntimeException {
|
||||
public static final String THE_SUBSCRIPTION_WITH_CUSTOMER_ID_DOES_NOT_EXIST_MESSAGE = "The subscriptions with the customer id {0} does not exists";
|
||||
public static final String THE_SUBSCRIPTION_WITH_SUBSCRIPTION_ID_DOES_NOT_EXIST_MESSAGE = "The subscription with subscription id {0} does not exists";
|
||||
|
||||
public SubscriptionNotFoundException(Optional<UUID> customerUUID, Optional<UUID> subscriptionUUID) {
|
||||
super(buildMessage(customerUUID, subscriptionUUID));
|
||||
}
|
||||
|
||||
private static String buildMessage(Optional<UUID> customerUUID, Optional<UUID> subscriptionUUID) {
|
||||
if (customerUUID.isPresent()) {
|
||||
return MessageFormat.format(THE_SUBSCRIPTION_WITH_CUSTOMER_ID_DOES_NOT_EXIST_MESSAGE, customerUUID.get());
|
||||
}
|
||||
return MessageFormat.format(THE_SUBSCRIPTION_WITH_SUBSCRIPTION_ID_DOES_NOT_EXIST_MESSAGE, subscriptionUUID.get());
|
||||
}
|
||||
}
|
||||
+62
@@ -0,0 +1,62 @@
|
||||
package fr.iut_fbleau.but3.dev62.mylibrary.subscription.repository;
|
||||
|
||||
import fr.iut_fbleau.but3.dev62.mylibrary.subscription.entity.Subscription;
|
||||
|
||||
import java.util.ArrayList;
|
||||
import java.util.List;
|
||||
import java.util.Optional;
|
||||
import java.util.UUID;
|
||||
|
||||
public class SubscriptionRepository {
|
||||
|
||||
private final List<Subscription> subscriptions = new ArrayList<>();
|
||||
|
||||
public List<Subscription> findAll() {
|
||||
|
||||
return subscriptions;
|
||||
}
|
||||
|
||||
public void deleteAll() {
|
||||
|
||||
subscriptions.clear();
|
||||
}
|
||||
|
||||
public Subscription save(Subscription newSubscription) {
|
||||
Optional<Subscription> optionalSubscriptionWithSameSubscriptionId = this.findBySubscriptionId(newSubscription.getSubscriptionId());
|
||||
optionalSubscriptionWithSameSubscriptionId.ifPresent(subscriptions::remove);
|
||||
this.subscriptions.add(newSubscription);
|
||||
return newSubscription;
|
||||
}
|
||||
|
||||
public List<Subscription> FindByCustomerId(UUID customerUUID) {
|
||||
return this.subscriptions.stream()
|
||||
.filter(subscription -> subscription.getCustomerId().equals(customerUUID))
|
||||
.toList();
|
||||
}
|
||||
|
||||
public Optional<Subscription> findBySubscriptionId(UUID subscriptionUUID) {
|
||||
return this.subscriptions.stream()
|
||||
.filter(subscription -> subscription.getSubscriptionId().equals(subscriptionUUID))
|
||||
.findFirst();
|
||||
}
|
||||
|
||||
public boolean existsByCustomerId(UUID customerUUID) {
|
||||
return this.subscriptions.stream()
|
||||
.anyMatch(review -> review.getCustomerId().equals(customerUUID));
|
||||
}
|
||||
|
||||
public boolean existsBySubscriptionId(UUID subscriptionUUID) {
|
||||
return this.subscriptions.stream()
|
||||
.anyMatch(subscription -> subscription.getSubscriptionId().equals(subscriptionUUID));
|
||||
}
|
||||
|
||||
public void deleteByCustomerId(UUID customerUUID) {
|
||||
|
||||
this.subscriptions.removeIf(subscription -> subscription.getCustomerId().equals(customerUUID));
|
||||
}
|
||||
|
||||
public void delete(Subscription subscription) {
|
||||
|
||||
this.subscriptions.remove(subscription);
|
||||
}
|
||||
}
|
||||
+110
@@ -0,0 +1,110 @@
|
||||
package fr.iut_fbleau.but3.dev62.mylibrary.subscription.usecase;
|
||||
|
||||
import fr.iut_fbleau.but3.dev62.mylibrary.subscription.PaymentMethodInfo;
|
||||
import fr.iut_fbleau.but3.dev62.mylibrary.subscription.SubscriptionDTO;
|
||||
import fr.iut_fbleau.but3.dev62.mylibrary.subscription.SubscriptionInfo;
|
||||
import fr.iut_fbleau.but3.dev62.mylibrary.subscription.converter.SubscriptionConverter;
|
||||
import fr.iut_fbleau.but3.dev62.mylibrary.subscription.entity.PaymentMethod;
|
||||
import fr.iut_fbleau.but3.dev62.mylibrary.subscription.entity.Subscription;
|
||||
import fr.iut_fbleau.but3.dev62.mylibrary.subscription.exception.NotValidSubscriptionException;
|
||||
import fr.iut_fbleau.but3.dev62.mylibrary.subscription.exception.SubscriptionNotFoundException;
|
||||
import fr.iut_fbleau.but3.dev62.mylibrary.subscription.repository.SubscriptionRepository;
|
||||
import fr.iut_fbleau.but3.dev62.mylibrary.subscription.validator.PaymentMethodValidator;
|
||||
import fr.iut_fbleau.but3.dev62.mylibrary.subscription.validator.SubscriptionValidator;
|
||||
|
||||
import java.util.*;
|
||||
|
||||
public class SubscriptionUseCase {
|
||||
|
||||
private final SubscriptionRepository subscriptionRepository;
|
||||
|
||||
public SubscriptionUseCase(SubscriptionRepository subscriptionRepository) {
|
||||
|
||||
this.subscriptionRepository = subscriptionRepository;
|
||||
}
|
||||
|
||||
private Map<String, Object> Output(Subscription subscription){
|
||||
Map<String, Object> result = new HashMap<>();
|
||||
|
||||
result.put("subscriptionId", subscription.getSubscriptionId());
|
||||
result.put("startDate", subscription.getStartDate());
|
||||
result.put("endDate", subscription.getEndDate());
|
||||
result.put("monthlyAmount", subscription.getMonthlyAmount());
|
||||
|
||||
return result;
|
||||
}
|
||||
|
||||
public Map<String, Object> registerSubscription(SubscriptionInfo newSubscription, PaymentMethodInfo newPaymentMethod)
|
||||
throws NotValidSubscriptionException {
|
||||
SubscriptionValidator.validate(newSubscription);
|
||||
PaymentMethodValidator.validate(newPaymentMethod);
|
||||
Subscription subscriptionToRegister = SubscriptionConverter.toDomain(newSubscription, newPaymentMethod);
|
||||
Subscription subscriptionToRegistered = subscriptionRepository.save(subscriptionToRegister);
|
||||
return Output(subscriptionToRegistered);
|
||||
}
|
||||
|
||||
public List<SubscriptionDTO> findSubscriptionByCustomerId(UUID customerId) {
|
||||
List<Subscription> optionalSubscriptions = subscriptionRepository.FindByCustomerId(customerId);
|
||||
return optionalSubscriptions.stream()
|
||||
.map(SubscriptionConverter::toDTO)
|
||||
.toList();
|
||||
}
|
||||
|
||||
public Optional<SubscriptionDTO> findSubscriptionBySubscriptionId(UUID subscriptionId) {
|
||||
Optional<Subscription> optionalSubscription = subscriptionRepository.findBySubscriptionId(subscriptionId);
|
||||
return optionalSubscription.map(SubscriptionConverter::toDTO);
|
||||
}
|
||||
|
||||
public SubscriptionDTO updateSubscription(UUID SubscriptionUUID, SubscriptionInfo subscriptionInfo, PaymentMethodInfo paymentMethodInfo)
|
||||
throws SubscriptionNotFoundException, NotValidSubscriptionException {
|
||||
SubscriptionValidator.validate(subscriptionInfo);
|
||||
PaymentMethodValidator.validate(paymentMethodInfo);
|
||||
Subscription subscriptionBySubscriptionUUID = getSubscriptionIfDoesNotExistThrowSubscriptionNotFoundException(
|
||||
SubscriptionUUID);
|
||||
PaymentMethod paymentMethod = PaymentMethod.builder()
|
||||
.paymentType(paymentMethodInfo.paymentType())
|
||||
.details(paymentMethodInfo.details())
|
||||
.build();
|
||||
Subscription subscription = Subscription.builder()
|
||||
.subscriptionId(SubscriptionUUID)
|
||||
.customerId(subscriptionBySubscriptionUUID.getCustomerId())
|
||||
.desiredSubscriptionDuration(subscriptionInfo.desiredSubscriptionDuration())
|
||||
.paymentMethod(paymentMethod)
|
||||
.desiredStartDate(subscriptionInfo.desiredStartDate())
|
||||
.monthlyAmount(subscriptionBySubscriptionUUID.getMonthlyAmount())
|
||||
.build();
|
||||
subscription.setDateSubscription();
|
||||
Subscription updatedSubscription = subscriptionRepository.save(subscription);
|
||||
return SubscriptionConverter.toDTO(updatedSubscription);
|
||||
}
|
||||
|
||||
public void deleteSubscription(UUID subscriptionUUID) throws SubscriptionNotFoundException {
|
||||
Subscription subscriptionToDelete = getSubscriptionIfDoesNotExistThrowSubscriptionNotFoundException(subscriptionUUID);
|
||||
this.subscriptionRepository.delete(subscriptionToDelete);
|
||||
}
|
||||
|
||||
public void deleteSubscriptionsOfACustomer(UUID customerUUID) throws SubscriptionNotFoundException {
|
||||
List<Subscription> subscriptionsToDelete = getSubscriptionByCustomerIdIfDoesNotExistThrowSubscriptionNotFoundException(customerUUID);
|
||||
for (Subscription subscription : subscriptionsToDelete) {
|
||||
subscriptionRepository.delete(subscription);
|
||||
}
|
||||
}
|
||||
|
||||
private Subscription getSubscriptionIfDoesNotExistThrowSubscriptionNotFoundException(UUID subscriptionUUID)
|
||||
throws SubscriptionNotFoundException {
|
||||
Optional<Subscription> optionalSubscriptionBySubscriptionId = subscriptionRepository.findBySubscriptionId(subscriptionUUID);
|
||||
if (optionalSubscriptionBySubscriptionId.isEmpty()) {
|
||||
throw new SubscriptionNotFoundException(Optional.empty(),Optional.of(subscriptionUUID));
|
||||
}
|
||||
return optionalSubscriptionBySubscriptionId.get();
|
||||
}
|
||||
|
||||
private List<Subscription> getSubscriptionByCustomerIdIfDoesNotExistThrowSubscriptionNotFoundException(UUID customerUUID)
|
||||
throws SubscriptionNotFoundException {
|
||||
List<Subscription> optionalSubscriptionBySubscriptionId = subscriptionRepository.FindByCustomerId(customerUUID);
|
||||
if (optionalSubscriptionBySubscriptionId.isEmpty()) {
|
||||
throw new SubscriptionNotFoundException(Optional.of(customerUUID),Optional.empty());
|
||||
}
|
||||
return optionalSubscriptionBySubscriptionId;
|
||||
}
|
||||
}
|
||||
+27
@@ -0,0 +1,27 @@
|
||||
package fr.iut_fbleau.but3.dev62.mylibrary.subscription.validator;
|
||||
|
||||
import fr.iut_fbleau.but3.dev62.mylibrary.subscription.PaymentMethodInfo;
|
||||
import fr.iut_fbleau.but3.dev62.mylibrary.subscription.exception.NotValidPaymentMethodException;
|
||||
|
||||
import java.util.Set;
|
||||
|
||||
public class PaymentMethodValidator {
|
||||
|
||||
public static final String MODE_PAIEMENT_IS_NOT_VALID = "paymentType is not valid";
|
||||
|
||||
private PaymentMethodValidator() {
|
||||
|
||||
}
|
||||
|
||||
public static void validate(PaymentMethodInfo newPaymentMethod)
|
||||
throws NotValidPaymentMethodException {
|
||||
validatePaymentType(newPaymentMethod);
|
||||
}
|
||||
|
||||
private static void validatePaymentType(PaymentMethodInfo newPaymentMethod)
|
||||
throws NotValidPaymentMethodException {
|
||||
Set<String> Valid_Payment_Type = Set.of("CB", "PAYPAL");
|
||||
if (!Valid_Payment_Type.contains(newPaymentMethod.paymentType())) {
|
||||
throw new NotValidPaymentMethodException(MODE_PAIEMENT_IS_NOT_VALID);}
|
||||
}
|
||||
}
|
||||
+36
@@ -0,0 +1,36 @@
|
||||
package fr.iut_fbleau.but3.dev62.mylibrary.subscription.validator;
|
||||
|
||||
import fr.iut_fbleau.but3.dev62.mylibrary.subscription.SubscriptionInfo;
|
||||
import fr.iut_fbleau.but3.dev62.mylibrary.subscription.exception.NotValidSubscriptionException;
|
||||
|
||||
import java.time.LocalDate;
|
||||
import java.util.Set;
|
||||
|
||||
public class SubscriptionValidator {
|
||||
|
||||
public static final String SUBSCRIPTION_DURATION_DESIRED_IS_NOT_VALID = "desiredSubscriptionDuration will be 3, 6 or 12 by the ENUM file SubscriptionDurationDesired";
|
||||
public static final String DESIRED_START_DATE_CANNOT_BE_BEFORE_TODAY = "desiredStartDate cannot be before today";
|
||||
|
||||
private SubscriptionValidator() {
|
||||
|
||||
}
|
||||
|
||||
public static void validate(SubscriptionInfo newSubscription) throws NotValidSubscriptionException {
|
||||
validateDesiredStartDate(newSubscription);
|
||||
validateSubscriptionDurationDesired(newSubscription);
|
||||
}
|
||||
|
||||
private static void validateSubscriptionDurationDesired(SubscriptionInfo newSubscription)
|
||||
throws NotValidSubscriptionException {
|
||||
Set<Integer> VALID_DURATIONS = Set.of(3, 6, 12);
|
||||
if (!VALID_DURATIONS.contains(newSubscription.desiredSubscriptionDuration())) {
|
||||
throw new NotValidSubscriptionException(SUBSCRIPTION_DURATION_DESIRED_IS_NOT_VALID);}
|
||||
}
|
||||
|
||||
private static void validateDesiredStartDate(SubscriptionInfo newSubscription)
|
||||
throws NotValidSubscriptionException {
|
||||
if (newSubscription.desiredStartDate().isBefore(LocalDate.now())) {
|
||||
throw new NotValidSubscriptionException(DESIRED_START_DATE_CANNOT_BE_BEFORE_TODAY);
|
||||
}
|
||||
}
|
||||
}
|
||||
+65
@@ -0,0 +1,65 @@
|
||||
package fr.iut_fbleau.but3.dev62.mylibrary.commande.converter;
|
||||
|
||||
import fr.iut_fbleau.but3.dev62.mylibrary.commande.*;
|
||||
import fr.iut_fbleau.but3.dev62.mylibrary.commande.entity.Commande;
|
||||
import org.junit.jupiter.api.Test;
|
||||
|
||||
import java.util.ArrayList;
|
||||
import java.util.List;
|
||||
|
||||
import static org.junit.jupiter.api.Assertions.assertEquals;
|
||||
import static org.junit.jupiter.api.Assertions.assertNotNull;
|
||||
|
||||
public class CommandeConverterTest {
|
||||
|
||||
|
||||
@Test
|
||||
void TestConvertCommandeToDomain(){
|
||||
String modePaiement = ModePaiement.CB.name();
|
||||
List<LigneCommandeInfo> listLigne = new ArrayList<>();
|
||||
LigneCommandeInfo ligne = new LigneCommandeInfo(12);
|
||||
LigneCommandeInfo ligne2 = new LigneCommandeInfo(14);
|
||||
listLigne.add(ligne);
|
||||
listLigne.add(ligne2);
|
||||
CommandeInfo commandeInfo = new CommandeInfo(listLigne,modePaiement);
|
||||
AdresseInfo adressInfo = new AdresseInfo("rue du cheval","La Rochette","77000","France");
|
||||
|
||||
|
||||
Commande result = CommandeConverter.toDomain(commandeInfo,adressInfo,modePaiement);
|
||||
|
||||
|
||||
assertNotNull(result);
|
||||
assertEquals(commandeInfo.listeLigne(), result.getLignesCommande());
|
||||
assertEquals(adressInfo.rue() , result.getRue());
|
||||
assertEquals(adressInfo.ville() , result.getVille());
|
||||
assertEquals(adressInfo.codePostal() , result.getCodePostal());
|
||||
assertEquals(adressInfo.pays() , result.getPays());
|
||||
assertEquals( modePaiement,result.getModePaiement());
|
||||
}
|
||||
|
||||
@Test
|
||||
void TestConvertCommandeToDTO(){
|
||||
String modePaiement = ModePaiement.CB.name();
|
||||
List<LigneCommandeInfo> listLigne = new ArrayList<>();
|
||||
LigneCommandeInfo ligne = new LigneCommandeInfo(12);
|
||||
LigneCommandeInfo ligne2 = new LigneCommandeInfo(14);
|
||||
listLigne.add(ligne);
|
||||
listLigne.add(ligne2);
|
||||
CommandeInfo commandeInfo = new CommandeInfo(listLigne,modePaiement);
|
||||
AdresseInfo adressInfo = new AdresseInfo("rue du cheval","La Rochette","77000","France");
|
||||
|
||||
|
||||
CommandeDTO result = CommandeConverter.toDTO(commandeInfo,adressInfo,modePaiement);
|
||||
|
||||
|
||||
assertNotNull(result);
|
||||
assertEquals(commandeInfo.listeLigne(), result.getLignesCommande());
|
||||
assertEquals(adressInfo.rue() , result.getRue());
|
||||
assertEquals(adressInfo.ville() , result.getVille());
|
||||
assertEquals(adressInfo.codePostal() , result.getCodePostal());
|
||||
assertEquals(adressInfo.pays() , result.getPays());
|
||||
assertEquals( modePaiement,result.getModePaiement());
|
||||
}
|
||||
|
||||
|
||||
}
|
||||
+35
@@ -0,0 +1,35 @@
|
||||
package fr.iut_fbleau.but3.dev62.mylibrary.commande.converter;
|
||||
|
||||
import fr.iut_fbleau.but3.dev62.mylibrary.commande.LigneCommandeDTO;
|
||||
import fr.iut_fbleau.but3.dev62.mylibrary.commande.LigneCommandeInfo;
|
||||
import fr.iut_fbleau.but3.dev62.mylibrary.commande.entity.LigneCommande;
|
||||
import org.junit.jupiter.api.Test;
|
||||
|
||||
import static org.junit.jupiter.api.Assertions.assertEquals;
|
||||
|
||||
public class LigneCommandeConverterTest {
|
||||
|
||||
|
||||
@Test
|
||||
void TestConvertLigneCommandeToDomain(){
|
||||
LigneCommandeInfo ligne = new LigneCommandeInfo(12);
|
||||
|
||||
LigneCommande result = LigneCommandeConverter.toDomain(ligne);
|
||||
|
||||
|
||||
assertEquals(ligne.quantite(),result.getQuantite());
|
||||
|
||||
}
|
||||
|
||||
@Test
|
||||
void TestConvertLigneCommandeToDTO(){
|
||||
LigneCommandeInfo ligne = new LigneCommandeInfo(12);
|
||||
|
||||
LigneCommandeDTO result = LigneCommandeConverter.toDTO(ligne);
|
||||
|
||||
|
||||
assertEquals(ligne.quantite(),result.getQuantite());
|
||||
|
||||
}
|
||||
|
||||
}
|
||||
@@ -0,0 +1,104 @@
|
||||
package fr.iut_fbleau.but3.dev62.mylibrary.commande.entity;
|
||||
|
||||
import fr.iut_fbleau.but3.dev62.mylibrary.commande.LigneCommandeInfo;
|
||||
import fr.iut_fbleau.but3.dev62.mylibrary.commande.ModePaiement;
|
||||
import org.junit.jupiter.api.DisplayName;
|
||||
import org.junit.jupiter.api.Test;
|
||||
import org.junit.jupiter.params.ParameterizedTest;
|
||||
import org.junit.jupiter.params.provider.ValueSource;
|
||||
|
||||
import java.util.ArrayList;
|
||||
import java.util.List;
|
||||
import java.util.UUID;
|
||||
|
||||
import static org.junit.jupiter.api.Assertions.*;
|
||||
|
||||
public class CommandeTest {
|
||||
@Test
|
||||
public void commandeTest(){
|
||||
|
||||
UUID clientId = UUID.randomUUID();
|
||||
List<LigneCommandeInfo> lignesCommande = new ArrayList<>();
|
||||
LigneCommandeInfo commande1 = new LigneCommandeInfo(12);
|
||||
LigneCommandeInfo commande2 = new LigneCommandeInfo(13);
|
||||
lignesCommande.add(commande1);
|
||||
lignesCommande.add(commande2);
|
||||
String rue = "rue du chien" ;
|
||||
String ville = "LKa Rochette" ;
|
||||
String codePostal = "7700" ;
|
||||
String pays = "France" ;
|
||||
String modePayement = ModePaiement.CB.name() ;
|
||||
|
||||
Commande commande = Commande.builder()
|
||||
.clientId(clientId)
|
||||
.lignesCommande(lignesCommande)
|
||||
.rue(rue)
|
||||
.ville(ville)
|
||||
.codePostal(codePostal)
|
||||
.pays(pays)
|
||||
.modePaiement(modePayement)
|
||||
.build();
|
||||
|
||||
assertEquals(clientId, commande.getClientId());
|
||||
assertEquals(lignesCommande, commande.getLignesCommande());
|
||||
assertEquals(rue, commande.getRue());
|
||||
assertEquals(ville, commande.getVille());
|
||||
assertEquals(codePostal, commande.getCodePostal());
|
||||
assertEquals(pays, commande.getPays());
|
||||
assertEquals(modePayement, commande.getModePaiement());
|
||||
}
|
||||
|
||||
|
||||
|
||||
@Test
|
||||
@DisplayName("setRandomUUID should change the ID to a new random UUID")
|
||||
void testSetRandomUUID() {
|
||||
Commande commande = Commande.builder().build();
|
||||
UUID originalId = commande.getClientId();
|
||||
|
||||
commande.setRandomUUID();
|
||||
|
||||
assertNotNull(commande.getClientId());
|
||||
assertNotEquals(originalId, commande.getClientId());
|
||||
}
|
||||
|
||||
@Test
|
||||
@DisplayName("setRandomUUID should change the ID to a new random UUID")
|
||||
void testSetRandomUUIDForCommande() {
|
||||
Commande commande = Commande.builder().build();
|
||||
UUID originalId = commande.getCommandeId();
|
||||
|
||||
commande.setRandomUUIDCommande();
|
||||
|
||||
assertNotNull(commande.getCommandeId());
|
||||
assertNotEquals(originalId, commande.getCommandeId());
|
||||
}
|
||||
|
||||
|
||||
@Test
|
||||
void testConvertPointsFideliteGagnes(){
|
||||
Commande commande = Commande.builder()
|
||||
.montantTotal(14.34)
|
||||
.build();
|
||||
Integer point = commande.convertPointsFidelite();
|
||||
|
||||
assertEquals(point,(int) Math.ceil(commande.getMontantTotal()));
|
||||
}
|
||||
|
||||
@ParameterizedTest
|
||||
@ValueSource(doubles = {-1.9,0.0})
|
||||
void testConvertPointsFideliteGagnesWhenMontantTotalIsNotGood(){
|
||||
Commande commande = Commande.builder()
|
||||
.montantTotal(14.34)
|
||||
.build();
|
||||
Integer point = commande.convertPointsFidelite();
|
||||
|
||||
assertEquals(point,(int) Math.ceil(commande.getMontantTotal()));
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
}
|
||||
+41
@@ -0,0 +1,41 @@
|
||||
package fr.iut_fbleau.but3.dev62.mylibrary.commande.entity;
|
||||
|
||||
import fr.iut_fbleau.but3.dev62.mylibrary.customer.entity.Customer;
|
||||
import org.junit.jupiter.api.DisplayName;
|
||||
import org.junit.jupiter.api.Test;
|
||||
|
||||
import java.util.UUID;
|
||||
|
||||
import static org.junit.jupiter.api.Assertions.*;
|
||||
|
||||
public class LigneCommandeTest {
|
||||
|
||||
@Test
|
||||
@DisplayName("Builder should create a valid LigneCommande instance")
|
||||
void TestLigneCommande() {
|
||||
UUID id = UUID.randomUUID();
|
||||
int quantite = 12;
|
||||
|
||||
|
||||
LigneCommande ligneCommande = LigneCommande.builder()
|
||||
.livreId(id)
|
||||
.quantite(quantite)
|
||||
.build();
|
||||
|
||||
assertEquals(id, ligneCommande.getLivreId());
|
||||
assertEquals(quantite, ligneCommande.getQuantite());
|
||||
|
||||
}
|
||||
|
||||
@Test
|
||||
@DisplayName("setRandomUUID should change the ID to a new random UUID")
|
||||
void testSetRandomUUID() {
|
||||
LigneCommande ligneCommande = LigneCommande.builder().build();
|
||||
UUID originalId = ligneCommande.getLivreId();
|
||||
|
||||
ligneCommande.setRandomUUID();
|
||||
|
||||
assertNotNull(ligneCommande.getLivreId());
|
||||
assertNotEquals(originalId, ligneCommande.getLivreId());
|
||||
}
|
||||
}
|
||||
+50
@@ -0,0 +1,50 @@
|
||||
package fr.iut_fbleau.but3.dev62.mylibrary.commande.exception.valid;
|
||||
|
||||
import fr.iut_fbleau.but3.dev62.mylibrary.commande.exception.CommandeNotFoundException;
|
||||
import org.junit.jupiter.api.DisplayName;
|
||||
import org.junit.jupiter.api.Test;
|
||||
|
||||
import java.util.UUID;
|
||||
|
||||
import static org.junit.jupiter.api.Assertions.assertEquals;
|
||||
import static org.junit.jupiter.api.Assertions.assertTrue;
|
||||
|
||||
public class CommandeNotFoundEsceptionTest {
|
||||
|
||||
@Test
|
||||
@DisplayName("Exception message should contain the UUID provided")
|
||||
void testExceptionMessageContainsUUID() {
|
||||
UUID uuid = UUID.randomUUID();
|
||||
|
||||
CommandeNotFoundException exception = new CommandeNotFoundException(uuid);
|
||||
|
||||
String expectedMessage = String.format("The commande with id %s does not exist", uuid);
|
||||
assertEquals(expectedMessage, exception.getMessage());
|
||||
}
|
||||
|
||||
@Test
|
||||
@DisplayName("Exception should use the correct constant message format")
|
||||
void testExceptionUsesConstantMessageFormat() {
|
||||
UUID uuid = UUID.randomUUID();
|
||||
|
||||
CommandeNotFoundException exception = new CommandeNotFoundException(uuid);
|
||||
|
||||
String expectedFormatWithPlaceholder = "The commande with id {0} does not exist";
|
||||
assertEquals(CommandeNotFoundException.THE_COMMANDE_WITH_ID_DOES_NOT_EXIST_MESSAGE,
|
||||
expectedFormatWithPlaceholder);
|
||||
assertTrue(exception.getMessage().contains(uuid.toString()));
|
||||
}
|
||||
|
||||
@Test
|
||||
@DisplayName("Exception should be properly thrown and caught")
|
||||
void testExceptionCanBeThrownAndCaught() {
|
||||
UUID uuid = UUID.randomUUID();
|
||||
|
||||
try {
|
||||
throw new CommandeNotFoundException(uuid);
|
||||
} catch (CommandeNotFoundException e) {
|
||||
String expectedMessage = String.format("The commande with id %s does not exist", uuid);
|
||||
assertEquals(expectedMessage, e.getMessage());
|
||||
}
|
||||
}
|
||||
}
|
||||
+67
@@ -0,0 +1,67 @@
|
||||
package fr.iut_fbleau.but3.dev62.mylibrary.commande.exception.valid;
|
||||
|
||||
import fr.iut_fbleau.but3.dev62.mylibrary.commande.exception.NotValidAdressException;
|
||||
import org.junit.jupiter.api.DisplayName;
|
||||
import org.junit.jupiter.api.Test;
|
||||
import org.junit.jupiter.params.ParameterizedTest;
|
||||
import org.junit.jupiter.params.provider.ValueSource;
|
||||
|
||||
import static org.junit.jupiter.api.Assertions.assertEquals;
|
||||
import static org.junit.jupiter.api.Assertions.assertThrows;
|
||||
|
||||
public class NotValidAdressExceptionTest {
|
||||
|
||||
@Test
|
||||
@DisplayName("Exception should be created with the provided message")
|
||||
void testExceptionCreation() {
|
||||
String errorMessage = "Adresse is not valid";
|
||||
|
||||
NotValidAdressException exception = new NotValidAdressException(errorMessage);
|
||||
|
||||
assertEquals(errorMessage, exception.getMessage());
|
||||
}
|
||||
|
||||
@ParameterizedTest
|
||||
@ValueSource(strings = {
|
||||
"rue is not valide",
|
||||
"city is not valide",
|
||||
"code postal is not valide",
|
||||
"Country is not valide"
|
||||
})
|
||||
@DisplayName("Exception should handle different validation messages")
|
||||
void testExceptionWithDifferentMessages(String errorMessage) {
|
||||
NotValidAdressException exception = new NotValidAdressException(errorMessage);
|
||||
|
||||
assertEquals(errorMessage, exception.getMessage());
|
||||
}
|
||||
|
||||
@Test
|
||||
@DisplayName("Exception should be properly thrown and caught")
|
||||
void testExceptionCanBeThrownAndCaught() {
|
||||
String errorMessage = "Required field is missing";
|
||||
|
||||
Exception exception = assertThrows(NotValidAdressException.class, () -> {
|
||||
throw new NotValidAdressException(errorMessage);
|
||||
});
|
||||
|
||||
assertEquals(errorMessage, exception.getMessage());
|
||||
}
|
||||
|
||||
@Test
|
||||
@DisplayName("Exception should be catchable as a general Exception")
|
||||
void testExceptionInheritance() {
|
||||
String errorMessage = "Invalid Adresse ";
|
||||
|
||||
try {
|
||||
throw new NotValidAdressException(errorMessage);
|
||||
} catch (Exception e) {
|
||||
assertEquals(NotValidAdressException.class, e.getClass());
|
||||
assertEquals(errorMessage, e.getMessage());
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
}
|
||||
+61
@@ -0,0 +1,61 @@
|
||||
package fr.iut_fbleau.but3.dev62.mylibrary.commande.exception.valid;
|
||||
|
||||
import fr.iut_fbleau.but3.dev62.mylibrary.commande.exception.NotValidCommandeException;
|
||||
import org.junit.jupiter.api.DisplayName;
|
||||
import org.junit.jupiter.api.Test;
|
||||
import org.junit.jupiter.params.ParameterizedTest;
|
||||
import org.junit.jupiter.params.provider.ValueSource;
|
||||
|
||||
import static org.junit.jupiter.api.Assertions.assertEquals;
|
||||
import static org.junit.jupiter.api.Assertions.assertThrows;
|
||||
|
||||
public class NotValidCommandeExceptionTest {
|
||||
|
||||
@Test
|
||||
@DisplayName("Exception should be created with the provided message")
|
||||
void testExceptionCreation() {
|
||||
String errorMessage = "Commande is not valid";
|
||||
|
||||
NotValidCommandeException exception = new NotValidCommandeException(errorMessage);
|
||||
|
||||
assertEquals(errorMessage, exception.getMessage());
|
||||
}
|
||||
|
||||
@ParameterizedTest
|
||||
@ValueSource(strings = {
|
||||
"Mode Paiement is not valide",
|
||||
"List ligne commande is not valide"
|
||||
})
|
||||
@DisplayName("Exception should handle different validation messages")
|
||||
void testExceptionWithDifferentMessages(String errorMessage) {
|
||||
NotValidCommandeException exception = new NotValidCommandeException(errorMessage);
|
||||
|
||||
assertEquals(errorMessage, exception.getMessage());
|
||||
}
|
||||
|
||||
@Test
|
||||
@DisplayName("Exception should be properly thrown and caught")
|
||||
void testExceptionCanBeThrownAndCaught() {
|
||||
String errorMessage = "Required field is missing";
|
||||
|
||||
Exception exception = assertThrows(NotValidCommandeException.class, () -> {
|
||||
throw new NotValidCommandeException(errorMessage);
|
||||
});
|
||||
|
||||
assertEquals(errorMessage, exception.getMessage());
|
||||
}
|
||||
|
||||
@Test
|
||||
@DisplayName("Exception should be catchable as a general Exception")
|
||||
void testExceptionInheritance() {
|
||||
String errorMessage = "Invalid Commande ";
|
||||
|
||||
try {
|
||||
throw new NotValidCommandeException(errorMessage);
|
||||
} catch (Exception e) {
|
||||
assertEquals(NotValidCommandeException.class, e.getClass());
|
||||
assertEquals(errorMessage, e.getMessage());
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
+47
@@ -0,0 +1,47 @@
|
||||
package fr.iut_fbleau.but3.dev62.mylibrary.commande.exception.valid;
|
||||
|
||||
import fr.iut_fbleau.but3.dev62.mylibrary.commande.exception.NotValidLigneCommandeException;
|
||||
import org.junit.jupiter.api.DisplayName;
|
||||
import org.junit.jupiter.api.Test;
|
||||
|
||||
import static org.junit.jupiter.api.Assertions.assertEquals;
|
||||
import static org.junit.jupiter.api.Assertions.assertThrows;
|
||||
|
||||
public class NotValidLigneCommandeExceptionTest {
|
||||
|
||||
@Test
|
||||
@DisplayName("Exception should handle different validation messages")
|
||||
void testExceptionCreation() {
|
||||
String errorMessage = "Ligne commande is not valide";
|
||||
NotValidLigneCommandeException exception = new NotValidLigneCommandeException(errorMessage);
|
||||
|
||||
assertEquals(errorMessage, exception.getMessage());
|
||||
}
|
||||
|
||||
@Test
|
||||
@DisplayName("Exception should be properly thrown and caught")
|
||||
void testExceptionCanBeThrownAndCaught() {
|
||||
String errorMessage = "Required field is missing";
|
||||
|
||||
Exception exception = assertThrows(NotValidLigneCommandeException.class, () -> {
|
||||
throw new NotValidLigneCommandeException(errorMessage);
|
||||
});
|
||||
|
||||
assertEquals(errorMessage, exception.getMessage());
|
||||
}
|
||||
|
||||
@Test
|
||||
@DisplayName("Exception should be catchable as a general Exception")
|
||||
void testExceptionInheritance() {
|
||||
String errorMessage = "Invalid Commande ";
|
||||
|
||||
try {
|
||||
throw new NotValidLigneCommandeException(errorMessage);
|
||||
} catch (Exception e) {
|
||||
assertEquals(NotValidLigneCommandeException.class, e.getClass());
|
||||
assertEquals(errorMessage, e.getMessage());
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
}
|
||||
+349
@@ -0,0 +1,349 @@
|
||||
package fr.iut_fbleau.but3.dev62.mylibrary.commande.repository;
|
||||
|
||||
import fr.iut_fbleau.but3.dev62.mylibrary.commande.LigneCommandeInfo;
|
||||
import fr.iut_fbleau.but3.dev62.mylibrary.commande.ModePaiement;
|
||||
import fr.iut_fbleau.but3.dev62.mylibrary.commande.entity.Commande;
|
||||
import org.junit.jupiter.api.BeforeEach;
|
||||
import org.junit.jupiter.api.DisplayName;
|
||||
import org.junit.jupiter.api.Nested;
|
||||
import org.junit.jupiter.api.Test;
|
||||
|
||||
import java.util.ArrayList;
|
||||
import java.util.List;
|
||||
import java.util.Optional;
|
||||
import java.util.UUID;
|
||||
|
||||
import static org.junit.jupiter.api.Assertions.*;
|
||||
|
||||
public class CommandeRepositoryTest {
|
||||
|
||||
private CommandeRepository repository;
|
||||
private Commande commandeN1;
|
||||
private Commande commandeN2;
|
||||
private Commande commandeN3;
|
||||
|
||||
@BeforeEach
|
||||
void setUp() {
|
||||
repository = new CommandeRepository();
|
||||
|
||||
UUID clientId = UUID.randomUUID();
|
||||
List<LigneCommandeInfo> lignesCommande = new ArrayList<>();
|
||||
LigneCommandeInfo commande1 = new LigneCommandeInfo(12);
|
||||
LigneCommandeInfo commande2 = new LigneCommandeInfo(13);
|
||||
lignesCommande.add(commande1);
|
||||
lignesCommande.add(commande2);
|
||||
String rue = "rue du chien";
|
||||
String ville = "LKa Rochette";
|
||||
String codePostal = "7700";
|
||||
String pays = "France";
|
||||
String modePayement = ModePaiement.CB.name();
|
||||
|
||||
commandeN1 = Commande.builder()
|
||||
.clientId(clientId)
|
||||
.lignesCommande(lignesCommande)
|
||||
.rue(rue)
|
||||
.ville(ville)
|
||||
.codePostal(codePostal)
|
||||
.pays(pays)
|
||||
.modePaiement(modePayement)
|
||||
.build();
|
||||
commandeN1.setRandomUUIDCommande();
|
||||
|
||||
|
||||
List<LigneCommandeInfo> lignesCommande2 = new ArrayList<>();
|
||||
LigneCommandeInfo commande3 = new LigneCommandeInfo(43);
|
||||
LigneCommandeInfo commande4 = new LigneCommandeInfo(1);
|
||||
lignesCommande2.add(commande3);
|
||||
lignesCommande2.add(commande4);
|
||||
|
||||
commandeN2 = Commande.builder()
|
||||
.clientId(clientId)
|
||||
.lignesCommande(lignesCommande2)
|
||||
.rue(rue)
|
||||
.ville(ville)
|
||||
.codePostal(codePostal)
|
||||
.pays(pays)
|
||||
.modePaiement(modePayement)
|
||||
.build();
|
||||
commandeN2.setRandomUUIDCommande();
|
||||
|
||||
List<LigneCommandeInfo> lignesCommande3 = new ArrayList<>();
|
||||
LigneCommandeInfo commande6 = new LigneCommandeInfo(12);
|
||||
LigneCommandeInfo commande7 = new LigneCommandeInfo(13);
|
||||
lignesCommande3.add(commande6);
|
||||
lignesCommande3.add(commande7);
|
||||
String rue2 = "rue du chevre chaud ";
|
||||
String ville2 = "jsp";
|
||||
String codePostal2 = "77";
|
||||
String pays2 = "Lune ";
|
||||
String modePayement2 = ModePaiement.PAYPAL.name();
|
||||
|
||||
commandeN3 = Commande.builder()
|
||||
.lignesCommande(lignesCommande3)
|
||||
.rue(rue2)
|
||||
.ville(ville2)
|
||||
.codePostal(codePostal2)
|
||||
.pays(pays2)
|
||||
.modePaiement(modePayement2)
|
||||
.build();
|
||||
commandeN3.setRandomUUID();
|
||||
commandeN3.setRandomUUIDCommande();
|
||||
|
||||
}
|
||||
|
||||
@Test
|
||||
@DisplayName("New repository should be empty")
|
||||
void testNewRepositoryIsEmpty() {
|
||||
List<Commande> commande = repository.findAll();
|
||||
|
||||
assertTrue(commande.isEmpty());
|
||||
assertEquals(0, commande.size());
|
||||
}
|
||||
|
||||
|
||||
@Nested
|
||||
@DisplayName("Save operations")
|
||||
class SaveOperations {
|
||||
@Test
|
||||
@DisplayName("Save should add a new comande")
|
||||
void testSaveNewCommande() {
|
||||
Commande savedCommande = repository.save(commandeN1);
|
||||
|
||||
assertEquals(1, repository.findAll().size());
|
||||
assertEquals(commandeN1.getCommandeId(), savedCommande.getCommandeId());
|
||||
assertEquals(commandeN1.getClientId(), savedCommande.getClientId());
|
||||
}
|
||||
|
||||
|
||||
@Test
|
||||
@DisplayName("Save should update existing commande with same ID")
|
||||
void testSaveUpdatesExistingCommande() {
|
||||
repository.save(commandeN1);
|
||||
|
||||
|
||||
List<LigneCommandeInfo> lignesCommande2 = new ArrayList<>();
|
||||
LigneCommandeInfo commande3 = new LigneCommandeInfo(43);
|
||||
LigneCommandeInfo commande4 = new LigneCommandeInfo(1);
|
||||
lignesCommande2.add(commande3);
|
||||
lignesCommande2.add(commande4);
|
||||
|
||||
|
||||
UUID id = commandeN1.getCommandeId();
|
||||
Commande updatedCommande = Commande.builder()
|
||||
.commandeId(id)
|
||||
.lignesCommande(lignesCommande2)
|
||||
.rue("rue")
|
||||
.ville("moi")
|
||||
.codePostal("1")
|
||||
.pays("Russie")
|
||||
.modePaiement(ModePaiement.POINTS_FIDELITE.name())
|
||||
.build();
|
||||
|
||||
Commande savedCommande = repository.save(updatedCommande);
|
||||
|
||||
assertEquals(1, repository.findAll().size());
|
||||
assertEquals(id, savedCommande.getCommandeId());
|
||||
assertEquals("rue", savedCommande.getRue());
|
||||
assertEquals("moi", savedCommande.getVille());
|
||||
assertEquals("1", savedCommande.getCodePostal());
|
||||
assertEquals("Russie", savedCommande.getPays());
|
||||
assertEquals(ModePaiement.POINTS_FIDELITE.name(), savedCommande.getModePaiement());
|
||||
}
|
||||
|
||||
@Test
|
||||
@DisplayName("Save multiple customers should add all of them")
|
||||
void testSaveMultipleCommande() {
|
||||
repository.save(commandeN1);
|
||||
repository.save(commandeN2);
|
||||
|
||||
List<Commande> commande = repository.findAll();
|
||||
|
||||
assertEquals(2, commande.size());
|
||||
assertTrue(commande.contains(commandeN1));
|
||||
assertTrue(commande.contains(commandeN2));
|
||||
}
|
||||
}
|
||||
|
||||
@Nested
|
||||
@DisplayName("Find operations")
|
||||
class FindOperations {
|
||||
|
||||
@BeforeEach
|
||||
void setUpCommande() {
|
||||
repository.save(commandeN1);
|
||||
repository.save(commandeN2);
|
||||
}
|
||||
|
||||
@Test
|
||||
@DisplayName("FindAll should return all commande")
|
||||
void testFindAll() {
|
||||
List<Commande> commande = repository.findAll();
|
||||
|
||||
assertEquals(2, commande.size());
|
||||
assertTrue(commande.contains(commandeN1));
|
||||
assertTrue(commande.contains(commandeN2));
|
||||
}
|
||||
|
||||
@Test
|
||||
@DisplayName("FindById should return commande with matching ID")
|
||||
void testFindById() {
|
||||
Optional<Commande> foundCommande = repository.findById(commandeN1.getCommandeId());
|
||||
|
||||
assertTrue(foundCommande.isPresent());
|
||||
assertEquals(commandeN1.getCommandeId(), foundCommande.get().getCommandeId());
|
||||
assertEquals(commandeN1.getClientId(), foundCommande.get().getClientId());
|
||||
}
|
||||
|
||||
@Test
|
||||
void testFindByIdNotFound(){
|
||||
UUID nonExistentId = UUID.randomUUID();
|
||||
Optional<Commande> foundCommande = repository.findById(nonExistentId);
|
||||
|
||||
assertTrue(foundCommande.isEmpty());
|
||||
}
|
||||
|
||||
|
||||
@Test
|
||||
void testExistsByIdExists(){
|
||||
boolean exists = repository.existsById(commandeN1.getCommandeId());
|
||||
|
||||
assertTrue(exists);
|
||||
|
||||
}
|
||||
|
||||
@Test
|
||||
void testExistsByIdNotExists(){
|
||||
UUID nonExistentId = UUID.randomUUID();
|
||||
boolean exists = repository.existsById(nonExistentId);
|
||||
|
||||
assertFalse(exists);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
||||
@Nested
|
||||
@DisplayName("Delete operations")
|
||||
class DeleteOperations {
|
||||
|
||||
|
||||
@BeforeEach
|
||||
void setUpCustomers() {
|
||||
repository.save(commandeN1);
|
||||
repository.save(commandeN2);
|
||||
repository.save(commandeN3);
|
||||
}
|
||||
|
||||
|
||||
@Test
|
||||
@DisplayName("Delete should remove the specified customer")
|
||||
void testDelete() {
|
||||
repository.delete(commandeN1);
|
||||
|
||||
List<Commande> commande = repository.findAll();
|
||||
|
||||
assertEquals(2, commande.size());
|
||||
assertFalse(commande.contains(commandeN1));
|
||||
assertTrue(commande.contains(commandeN2));
|
||||
assertTrue(commande.contains(commandeN3));
|
||||
}
|
||||
|
||||
@Test
|
||||
@DisplayName("DeleteAll should remove all customers")
|
||||
void testDeleteAll() {
|
||||
repository.deleteAll();
|
||||
|
||||
List<Commande> commande = repository.findAll();
|
||||
|
||||
assertTrue(commande.isEmpty());
|
||||
assertEquals(0, commande.size());
|
||||
}
|
||||
|
||||
@Test
|
||||
@DisplayName("Delete should not throw exception when customer doesn't exist")
|
||||
void testDeleteNonExistentCustomer() {
|
||||
|
||||
List<LigneCommandeInfo> lignesCommande = new ArrayList<>();
|
||||
LigneCommandeInfo commande1 = new LigneCommandeInfo(321);
|
||||
LigneCommandeInfo commande2 = new LigneCommandeInfo(3);
|
||||
lignesCommande.add(commande1);
|
||||
lignesCommande.add(commande2);
|
||||
|
||||
|
||||
Commande nonExistentCommande = Commande.builder()
|
||||
.lignesCommande(lignesCommande)
|
||||
.rue("non")
|
||||
.ville("non")
|
||||
.codePostal("Existent")
|
||||
.pays("0000")
|
||||
.modePaiement(ModePaiement.PAYPAL.name())
|
||||
.build();
|
||||
nonExistentCommande.setRandomUUIDCommande();
|
||||
|
||||
assertDoesNotThrow(() -> repository.delete(nonExistentCommande));
|
||||
|
||||
assertEquals(3, repository.findAll().size());
|
||||
}
|
||||
|
||||
|
||||
@Test
|
||||
void TestDeleteAllCommandeByCustomerID() {
|
||||
System.out.println(commandeN1.getClientId());
|
||||
System.out.println(commandeN2.getClientId());
|
||||
System.out.println(commandeN3.getClientId());
|
||||
repository.deleteById(commandeN1.getClientId());
|
||||
|
||||
|
||||
List<Commande> commande = repository.findAll();
|
||||
|
||||
assertEquals(1, commande.size());
|
||||
assertFalse(commande.contains(commandeN1));
|
||||
assertFalse(commande.contains(commandeN2));
|
||||
assertTrue(commande.contains(commandeN3));
|
||||
|
||||
|
||||
}
|
||||
|
||||
|
||||
@Test
|
||||
void TestDeleteAllCommandeByNonExistentCustomerID() {
|
||||
|
||||
|
||||
List<LigneCommandeInfo> lignesCommande = new ArrayList<>();
|
||||
LigneCommandeInfo commande1 = new LigneCommandeInfo(321);
|
||||
LigneCommandeInfo commande2 = new LigneCommandeInfo(3);
|
||||
lignesCommande.add(commande1);
|
||||
lignesCommande.add(commande2);
|
||||
|
||||
|
||||
Commande nonExistentCommande = Commande.builder()
|
||||
.lignesCommande(lignesCommande)
|
||||
.rue("non")
|
||||
.ville("non")
|
||||
.codePostal("Existent")
|
||||
.pays("0000")
|
||||
.modePaiement(ModePaiement.PAYPAL.name())
|
||||
.build();
|
||||
nonExistentCommande.setRandomUUIDCommande();
|
||||
|
||||
|
||||
repository.deleteById(nonExistentCommande.getClientId());
|
||||
|
||||
|
||||
assertDoesNotThrow(() -> repository.findAll());
|
||||
|
||||
assertEquals(3, repository.findAll().size());
|
||||
|
||||
|
||||
}
|
||||
|
||||
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
||||
}
|
||||
|
||||
|
||||
+249
@@ -0,0 +1,249 @@
|
||||
package fr.iut_fbleau.but3.dev62.mylibrary.commande.usecase;
|
||||
|
||||
import fr.iut_fbleau.but3.dev62.mylibrary.commande.*;
|
||||
import fr.iut_fbleau.but3.dev62.mylibrary.commande.entity.Commande;
|
||||
import fr.iut_fbleau.but3.dev62.mylibrary.commande.exception.CommandeNotFoundException;
|
||||
import fr.iut_fbleau.but3.dev62.mylibrary.commande.exception.NotValidCommandeException;
|
||||
import fr.iut_fbleau.but3.dev62.mylibrary.commande.repository.CommandeRepository;
|
||||
import org.junit.jupiter.api.BeforeEach;
|
||||
import org.junit.jupiter.api.DisplayName;
|
||||
import org.junit.jupiter.api.Nested;
|
||||
import org.junit.jupiter.api.Test;
|
||||
import org.junit.jupiter.api.extension.ExtendWith;
|
||||
import org.mockito.InjectMocks;
|
||||
import org.mockito.Mock;
|
||||
import org.mockito.junit.jupiter.MockitoExtension;
|
||||
|
||||
import java.util.ArrayList;
|
||||
import java.util.List;
|
||||
import java.util.Optional;
|
||||
import java.util.UUID;
|
||||
|
||||
import static org.junit.jupiter.api.Assertions.*;
|
||||
import static org.mockito.ArgumentMatchers.any;
|
||||
import static org.mockito.Mockito.*;
|
||||
|
||||
|
||||
|
||||
@ExtendWith(MockitoExtension.class)
|
||||
public class TestCommandeUseCase {
|
||||
|
||||
@Mock
|
||||
private CommandeRepository commandeRepository;
|
||||
|
||||
|
||||
@InjectMocks
|
||||
private CommandeUseCase commandeUseCase;
|
||||
|
||||
private UUID commandeId;
|
||||
private UUID clientId;
|
||||
private Commande testCommande;
|
||||
private CommandeInfo validCommandeInfo;
|
||||
private LigneCommandeInfo validLigneCommandeInfo;
|
||||
private AdresseInfo validAdresseInfo;
|
||||
private List<LigneCommandeInfo> lignesCommande;
|
||||
private LigneCommandeInfo commande1;
|
||||
private LigneCommandeInfo commande2;
|
||||
private String rue;
|
||||
private String ville;
|
||||
private String codePostal;
|
||||
private String pays;
|
||||
private String modePayement;
|
||||
|
||||
@BeforeEach
|
||||
void setUp() {
|
||||
|
||||
clientId = UUID.randomUUID();
|
||||
commandeId = UUID.randomUUID();
|
||||
lignesCommande = new ArrayList<>();
|
||||
commande1 = new LigneCommandeInfo(12);
|
||||
commande2 = new LigneCommandeInfo(13);
|
||||
lignesCommande.add(commande1);
|
||||
lignesCommande.add(commande2);
|
||||
rue = "rue du chien";
|
||||
ville = "LKa Rochette";
|
||||
codePostal = "7700";
|
||||
pays = "France";
|
||||
modePayement = ModePaiement.CB.name();
|
||||
|
||||
testCommande = Commande.builder()
|
||||
.clientId(clientId)
|
||||
.lignesCommande(lignesCommande)
|
||||
.rue(rue)
|
||||
.ville(ville)
|
||||
.codePostal(codePostal)
|
||||
.pays(pays)
|
||||
.modePaiement(modePayement)
|
||||
.commandeId(commandeId)
|
||||
.build();
|
||||
|
||||
|
||||
validCommandeInfo = new CommandeInfo(lignesCommande,ModePaiement.CB.name());
|
||||
validLigneCommandeInfo= new LigneCommandeInfo(12);
|
||||
validAdresseInfo = new AdresseInfo("rue du chien","LKa Rochette","7700","France");
|
||||
}
|
||||
|
||||
|
||||
@Nested
|
||||
class RegisterCommandeTest{
|
||||
|
||||
|
||||
@Test
|
||||
void testRegisterCommandeWhitValidData(){
|
||||
when(commandeRepository.save(any(Commande.class))).thenReturn(testCommande);
|
||||
|
||||
UUID registeredIsbn = commandeUseCase.registerCommande(validCommandeInfo,validAdresseInfo);
|
||||
|
||||
assertNotNull(registeredIsbn);
|
||||
assertEquals(commandeId, registeredIsbn);
|
||||
verify(commandeRepository, times(1)).save(any(Commande.class));
|
||||
}
|
||||
|
||||
@Test
|
||||
void testRegisterCommandeWhitInvalidData(){
|
||||
CommandeInfo invalidCommandeInfo = new CommandeInfo(new ArrayList<LigneCommandeInfo>(),"pas bon ");
|
||||
AdresseInfo invalidAdressInfo = new AdresseInfo(""," "," ","");
|
||||
|
||||
assertThrows(NotValidCommandeException.class,
|
||||
()->commandeUseCase.registerCommande(invalidCommandeInfo,invalidAdressInfo));
|
||||
verify(commandeRepository, never()).save(any(Commande.class));
|
||||
}
|
||||
|
||||
|
||||
|
||||
}
|
||||
|
||||
|
||||
@Nested
|
||||
class FindCommandeTests {
|
||||
@Test
|
||||
@DisplayName("Should return book when isbn exists")
|
||||
void testFindCommandByUUID() {
|
||||
when(commandeRepository.findById(testCommande.getCommandeId())).thenReturn(Optional.of(testCommande));
|
||||
|
||||
Optional<CommandeDTO> foundCommande = commandeUseCase.findCommandByUUID(testCommande.getCommandeId());
|
||||
|
||||
assertTrue(foundCommande.isPresent());
|
||||
assertEquals(testCommande.getCommandeId(), foundCommande.get().getCommandeId());
|
||||
verify(commandeRepository, times(1)).findById(testCommande.getCommandeId());
|
||||
}
|
||||
|
||||
@Test
|
||||
@DisplayName("Should return empty Optional when isbn doesn't exist")
|
||||
void testFindCommandByUUIDNotFound() {
|
||||
UUID uuid = UUID.randomUUID();
|
||||
when(commandeRepository.findById(uuid)).thenReturn(Optional.empty());
|
||||
|
||||
Optional<CommandeDTO> foundCommande = commandeUseCase.findCommandByUUID(uuid);
|
||||
|
||||
assertTrue(foundCommande.isEmpty());
|
||||
verify(commandeRepository, times(1)).findById(uuid);
|
||||
}
|
||||
}
|
||||
|
||||
@Nested
|
||||
class UpdateCommandeTests {
|
||||
@Test
|
||||
@DisplayName("Should update commande when valid data is provided")
|
||||
void testUpdateCommandeWithValidData() throws CommandeNotFoundException, NotValidCommandeException {
|
||||
when(commandeRepository.findById(commandeId)).thenReturn(Optional.of(testCommande));
|
||||
|
||||
Commande updatedCommande = Commande.builder()
|
||||
.clientId(clientId)
|
||||
.lignesCommande(lignesCommande)
|
||||
.rue(rue)
|
||||
.ville("Fontainebleau")
|
||||
.codePostal("77300")
|
||||
.pays(pays)
|
||||
.modePaiement(modePayement)
|
||||
.commandeId(commandeId)
|
||||
.build();
|
||||
|
||||
when(commandeRepository.save(any(Commande.class))).thenReturn(updatedCommande);
|
||||
|
||||
List<LigneCommandeInfo> updatelignesCommande = new ArrayList<>();
|
||||
LigneCommandeInfo updateLigneCommandeInfo= new LigneCommandeInfo(12);
|
||||
updatelignesCommande.add(updateLigneCommandeInfo);
|
||||
CommandeInfo updateInfo = new CommandeInfo(updatelignesCommande,ModePaiement.CB.name());
|
||||
AdresseInfo updateAdresseInfo = new AdresseInfo("rue du chien","Fontainebleau","77300","France");
|
||||
|
||||
CommandeDTO result = commandeUseCase.updateCommande(commandeId, updateInfo, updateAdresseInfo);
|
||||
|
||||
assertNotNull(result);
|
||||
assertEquals(commandeId, result.getCommandeId());
|
||||
assertEquals("Fontainebleau", result.getVille());
|
||||
assertEquals("77300", result.getCodePostal());
|
||||
verify(commandeRepository, times(1)).findById(commandeId);
|
||||
verify(commandeRepository, times(1)).save(any(Commande.class));
|
||||
}
|
||||
|
||||
@Test
|
||||
@DisplayName("Should throw exception when commande ID doesn't exist")
|
||||
void testUpdateCommandeNotFound() {
|
||||
UUID nonExistentId = UUID.randomUUID();
|
||||
when(commandeRepository.findById(nonExistentId)).thenReturn(Optional.empty());
|
||||
|
||||
List<LigneCommandeInfo> updatelignesCommande = new ArrayList<>();
|
||||
LigneCommandeInfo updateLigneCommandeInfo= new LigneCommandeInfo(12);
|
||||
updatelignesCommande.add(updateLigneCommandeInfo);
|
||||
CommandeInfo updateInfo = new CommandeInfo(updatelignesCommande,ModePaiement.CB.name());
|
||||
AdresseInfo updateAdresseInfo = new AdresseInfo("rue du chien","Fontainebleau","77300","France");
|
||||
|
||||
assertThrows(CommandeNotFoundException.class,
|
||||
() -> commandeUseCase.updateCommande(nonExistentId, updateInfo, updateAdresseInfo));
|
||||
|
||||
verify(commandeRepository, times(1)).findById(nonExistentId);
|
||||
verify(commandeRepository, never()).save(any(Commande.class));
|
||||
}
|
||||
|
||||
@Test
|
||||
@DisplayName("Should throw exception when update data is not valid")
|
||||
void testUpdateCommandeWithInvalidData() {
|
||||
List<LigneCommandeInfo> updatelignesCommande = new ArrayList<>();
|
||||
LigneCommandeInfo updateLigneCommandeInfo= new LigneCommandeInfo(12);
|
||||
updatelignesCommande.add(updateLigneCommandeInfo);
|
||||
CommandeInfo invalidUpdateInfo = new CommandeInfo(updatelignesCommande, "CARTE");
|
||||
AdresseInfo updateAdresseInfo = new AdresseInfo("rue du chien","Fontainebleau","77300","France");
|
||||
|
||||
assertThrows(NotValidCommandeException.class,
|
||||
() -> commandeUseCase.updateCommande(commandeId, invalidUpdateInfo, updateAdresseInfo));
|
||||
|
||||
verify(commandeRepository, never()).findById(any(UUID.class));
|
||||
verify(commandeRepository, never()).save(any(Commande.class));
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
@Nested
|
||||
class DeleteCommandeTests {
|
||||
@Test
|
||||
@DisplayName("Should delete commande when ID exists")
|
||||
void testDeleteCommande() throws CommandeNotFoundException {
|
||||
when(commandeRepository.findById(commandeId)).thenReturn(Optional.of(testCommande));
|
||||
doNothing().when(commandeRepository).delete(testCommande);
|
||||
|
||||
commandeUseCase.deleteCommande(commandeId);
|
||||
|
||||
verify(commandeRepository, times(1)).findById(commandeId);
|
||||
verify(commandeRepository, times(1)).delete(testCommande);
|
||||
}
|
||||
|
||||
@Test
|
||||
@DisplayName("Should throw exception when commande ID doesn't exist")
|
||||
void testDeleteCustomerNotFound() {
|
||||
UUID nonExistentId = UUID.randomUUID();
|
||||
when(commandeRepository.findById(nonExistentId)).thenReturn(Optional.empty());
|
||||
|
||||
assertThrows(CommandeNotFoundException.class,
|
||||
() -> commandeUseCase.deleteCommande(nonExistentId));
|
||||
|
||||
verify(commandeRepository, times(1)).findById(nonExistentId);
|
||||
verify(commandeRepository, never()).delete(any(Commande.class));
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
}
|
||||
+165
@@ -0,0 +1,165 @@
|
||||
package fr.iut_fbleau.but3.dev62.mylibrary.commande.validator;
|
||||
|
||||
import fr.iut_fbleau.but3.dev62.mylibrary.commande.AdresseInfo;
|
||||
import fr.iut_fbleau.but3.dev62.mylibrary.commande.CommandeInfo;
|
||||
import fr.iut_fbleau.but3.dev62.mylibrary.commande.LigneCommandeInfo;
|
||||
import fr.iut_fbleau.but3.dev62.mylibrary.commande.ModePaiement;
|
||||
import fr.iut_fbleau.but3.dev62.mylibrary.commande.exception.NotValidAdressException;
|
||||
import fr.iut_fbleau.but3.dev62.mylibrary.commande.exception.NotValidCommandeException;
|
||||
import fr.iut_fbleau.but3.dev62.mylibrary.commande.exception.NotValidLigneCommandeException;
|
||||
import org.junit.jupiter.api.Nested;
|
||||
import org.junit.jupiter.api.Test;
|
||||
import org.junit.jupiter.params.ParameterizedTest;
|
||||
import org.junit.jupiter.params.provider.*;
|
||||
|
||||
import java.util.*;
|
||||
import java.util.stream.Stream;
|
||||
|
||||
import static org.junit.jupiter.api.Assertions.*;
|
||||
|
||||
public class CommandeValidatorTest {
|
||||
|
||||
|
||||
@Test
|
||||
void testValidateValideLigneCommande () {
|
||||
LigneCommandeInfo ligneCommandeValide = new LigneCommandeInfo(5);
|
||||
|
||||
|
||||
assertDoesNotThrow(() -> CommandeValidator.validate(ligneCommandeValide));
|
||||
}
|
||||
@ParameterizedTest
|
||||
@ValueSource(ints = {-5,0 })
|
||||
void testValidateNotValideLigneCommande (int notValiteQuantite) {
|
||||
LigneCommandeInfo ligneCommandeNotValide = new LigneCommandeInfo(notValiteQuantite);
|
||||
NotValidLigneCommandeException exception = assertThrows(
|
||||
NotValidLigneCommandeException.class,
|
||||
() -> CommandeValidator.validate(ligneCommandeNotValide)
|
||||
);
|
||||
|
||||
assertEquals(CommandeValidator.LIGNE_COMMANDE_IS_NOT_VALIDE, exception.getMessage());
|
||||
}
|
||||
|
||||
|
||||
@ParameterizedTest
|
||||
@EnumSource(value = ModePaiement.class, names = {"CB", "PAYPAL", "POINTS_FIDELITE"})
|
||||
void testValidateValideCommande(ModePaiement modePaiement) {
|
||||
LigneCommandeInfo ligneCommandeValide = new LigneCommandeInfo(5);
|
||||
List<LigneCommandeInfo> listeLigne = new ArrayList<>();
|
||||
listeLigne.add(ligneCommandeValide);
|
||||
String modePaiementValide = modePaiement.toString();
|
||||
CommandeInfo commandeValid = new CommandeInfo(listeLigne, modePaiementValide);
|
||||
|
||||
assertDoesNotThrow(() -> CommandeValidator.validate(commandeValid));
|
||||
}
|
||||
|
||||
@ParameterizedTest
|
||||
@ValueSource(strings = {"jambon", " ", ""})
|
||||
void testValidateNotValideModePaiement(String modePaiementError) {
|
||||
LigneCommandeInfo ligneCommandeValide = new LigneCommandeInfo(5);
|
||||
List<LigneCommandeInfo> listeLigne = new ArrayList<>();
|
||||
listeLigne.add(ligneCommandeValide);
|
||||
String modePaiementValide = modePaiementError;
|
||||
CommandeInfo commandeValid = new CommandeInfo(listeLigne, modePaiementValide);
|
||||
|
||||
NotValidCommandeException exception = assertThrows(
|
||||
NotValidCommandeException.class,
|
||||
() -> CommandeValidator.validate(commandeValid)
|
||||
);
|
||||
assertEquals(CommandeValidator.MODE_PAIEMENT_IS_NOT_VALIDE, exception.getMessage());
|
||||
}
|
||||
|
||||
@ParameterizedTest
|
||||
@MethodSource("provideInvalidOrderLists")
|
||||
void testValidateNotValideListLigneCommande(List<LigneCommandeInfo> listeLigne) {
|
||||
String modePaiementValide = ModePaiement.CB.toString();
|
||||
CommandeInfo commandeValid = new CommandeInfo(listeLigne, modePaiementValide);
|
||||
NotValidCommandeException exception = assertThrows(
|
||||
NotValidCommandeException.class,
|
||||
() -> CommandeValidator.validate(commandeValid)
|
||||
);
|
||||
assertEquals(CommandeValidator.LIST_LIGNE_COMANDE_IS_NOT_VALIDE, exception.getMessage());
|
||||
|
||||
}
|
||||
static Stream<Arguments> provideInvalidOrderLists() {
|
||||
return Stream.of(
|
||||
Arguments.of(Collections.emptyList()),
|
||||
Arguments.of(Arrays.asList(new LigneCommandeInfo(5), null, null, new LigneCommandeInfo(12))),
|
||||
Arguments.of((List<LigneCommandeInfo>) null)
|
||||
);
|
||||
}
|
||||
|
||||
@Nested
|
||||
class TestAdress{
|
||||
|
||||
|
||||
@Test
|
||||
void testValidateValideLigneCommande () {
|
||||
AdresseInfo adress = new AdresseInfo("rue du chien","La Rochette","7700","France");
|
||||
|
||||
assertDoesNotThrow(() -> CommandeValidator.validate(adress));
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
||||
@ParameterizedTest
|
||||
@NullSource
|
||||
@ValueSource(strings = {" ", " ", "\t", "\n"})
|
||||
void testValidateNotValideStreet(String notvalideStreet) {
|
||||
AdresseInfo adress = new AdresseInfo(notvalideStreet,"La Rochette","7700","France");
|
||||
NotValidAdressException exception = assertThrows(
|
||||
NotValidAdressException.class,
|
||||
() -> CommandeValidator.validate(adress)
|
||||
);
|
||||
assertEquals(CommandeValidator.STREET_IS_NOT_VALIDE, exception.getMessage());
|
||||
}
|
||||
|
||||
@ParameterizedTest
|
||||
@NullSource
|
||||
@ValueSource(strings = {" ", " ", "\t", "\n"})
|
||||
void testValidateNotValideCity(String notvalideCity) {
|
||||
AdresseInfo adress = new AdresseInfo("rue du chien",notvalideCity,"7700","France");
|
||||
NotValidAdressException exception = assertThrows(
|
||||
NotValidAdressException.class,
|
||||
() -> CommandeValidator.validate(adress)
|
||||
);
|
||||
assertEquals(CommandeValidator.CITY_IS_NOT_VALIDE, exception.getMessage());
|
||||
}
|
||||
|
||||
@ParameterizedTest
|
||||
@NullSource
|
||||
@ValueSource(strings = {" ", " ", "\t", "\n"})
|
||||
void testValidateNotValideCodePostal(String notvalideCodePostal) {
|
||||
AdresseInfo adress = new AdresseInfo("rue du chien","La Rochette",notvalideCodePostal,"France");
|
||||
NotValidAdressException exception = assertThrows(
|
||||
NotValidAdressException.class,
|
||||
() -> CommandeValidator.validate(adress)
|
||||
);
|
||||
assertEquals(CommandeValidator.CODE_POSTAL_IS_NOT_VALIDE, exception.getMessage());
|
||||
}
|
||||
|
||||
@ParameterizedTest
|
||||
@NullSource
|
||||
@ValueSource(strings = {" ", " ", "\t", "\n"})
|
||||
void testValidateNotValideCountry(String notvalideCountry) {
|
||||
AdresseInfo adress = new AdresseInfo("rue du chien","La Rochette","7700",notvalideCountry);
|
||||
NotValidAdressException exception = assertThrows(
|
||||
NotValidAdressException.class,
|
||||
() -> CommandeValidator.validate(adress)
|
||||
);
|
||||
assertEquals(CommandeValidator.COUNTRY_IS_NOT_VALIDE, exception.getMessage());
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
}
|
||||
+125
@@ -0,0 +1,125 @@
|
||||
package fr.iut_fbleau.but3.dev62.mylibrary.subscription.converter;
|
||||
|
||||
import fr.iut_fbleau.but3.dev62.mylibrary.subscription.*;
|
||||
import fr.iut_fbleau.but3.dev62.mylibrary.subscription.entity.PaymentMethod;
|
||||
import fr.iut_fbleau.but3.dev62.mylibrary.subscription.entity.Subscription;
|
||||
import org.junit.jupiter.api.DisplayName;
|
||||
import org.junit.jupiter.api.Nested;
|
||||
import org.junit.jupiter.api.Test;
|
||||
|
||||
import java.time.LocalDate;
|
||||
import java.util.UUID;
|
||||
|
||||
import static org.junit.jupiter.api.Assertions.*;
|
||||
import static org.junit.jupiter.api.Assertions.assertEquals;
|
||||
import static org.junit.jupiter.api.Assertions.assertNull;
|
||||
|
||||
public class SubscriptionConverterTest {
|
||||
|
||||
@Nested
|
||||
@DisplayName("toDomain() method tests")
|
||||
class ToDomainTests {
|
||||
|
||||
@Test
|
||||
@DisplayName("Should convert SubscriptionInfo to Subscription domain object with monthly amount initialized to 0")
|
||||
void shouldConvertSubscriptionInfoToDomain() {
|
||||
// Given
|
||||
PaymentMethodInfo paymentMethodInfo = new PaymentMethodInfo(PaymentType.CB.name(), "Maxime Lebreton");
|
||||
LocalDate desiredStartDate = LocalDate.of(2026, 6, 24);
|
||||
SubscriptionInfo subscriptionInfo = new SubscriptionInfo(DesiredSubscriptionDuration.THREE.getValue(), desiredStartDate);
|
||||
LocalDate estimateEndDate = LocalDate.of(2026, 9, 24);
|
||||
|
||||
// When
|
||||
Subscription result = SubscriptionConverter.toDomain(subscriptionInfo, paymentMethodInfo);
|
||||
|
||||
// Then
|
||||
assertNotNull(result);
|
||||
assertEquals(subscriptionInfo.desiredSubscriptionDuration(), result.getDesiredSubscriptionDuration());
|
||||
assertEquals(paymentMethodInfo.paymentType(), result.getPaymentMethod().getPaymentType());
|
||||
assertEquals(paymentMethodInfo.details(), result.getPaymentMethod().getDetails());
|
||||
assertEquals(subscriptionInfo.desiredStartDate(), result.getDesiredStartDate());
|
||||
assertEquals(subscriptionInfo.desiredStartDate(), result.getStartDate());
|
||||
assertEquals(estimateEndDate, result.getEndDate());
|
||||
assertEquals(0, result.getMonthlyAmount());
|
||||
}
|
||||
}
|
||||
|
||||
@Nested
|
||||
@DisplayName("toDTO() method tests")
|
||||
class ToDTOTests {
|
||||
|
||||
@Test
|
||||
@DisplayName("Should convert Subscription domain object to SubscriptionDTO with all fields mapped correctly")
|
||||
void shouldConvertSubscriptionToDTO() {
|
||||
PaymentMethod paymentMethod = PaymentMethod.builder()
|
||||
.paymentType(PaymentType.CB.name())
|
||||
.details("Maxime Lebreton")
|
||||
.build();
|
||||
LocalDate desiredStartDate = LocalDate.of(2026, 6, 24);
|
||||
LocalDate estimateEndDate = LocalDate.of(2026, 9, 24);
|
||||
Subscription subscription = Subscription.builder()
|
||||
.subscriptionId(UUID.randomUUID())
|
||||
.customerId(UUID.randomUUID())
|
||||
.desiredSubscriptionDuration(DesiredSubscriptionDuration.THREE.getValue())
|
||||
.paymentMethod(paymentMethod)
|
||||
.desiredStartDate(desiredStartDate)
|
||||
.startDate(desiredStartDate)
|
||||
.endDate(estimateEndDate)
|
||||
.monthlyAmount(12.03)
|
||||
.build();
|
||||
|
||||
SubscriptionDTO result = SubscriptionConverter.toDTO(subscription);
|
||||
|
||||
assertNotNull(result);
|
||||
assertEquals(subscription.getSubscriptionId(), result.getSubscriptionId());
|
||||
assertEquals(subscription.getCustomerId(), result.getCustomerId());
|
||||
assertEquals(subscription.getDesiredSubscriptionDuration(), result.getDesiredSubscriptionDuration());
|
||||
assertEquals(subscription.getPaymentMethod().getPaymentType(), result.getPaymentMethod().getPaymentType());
|
||||
assertEquals(subscription.getPaymentMethod().getDetails(), result.getPaymentMethod().getDetails());
|
||||
assertEquals(subscription.getDesiredStartDate(), result.getDesiredStartDate());
|
||||
assertEquals(subscription.getStartDate(), result.getStartDate());
|
||||
assertEquals(subscription.getEndDate(), result.getEndDate());
|
||||
assertEquals(12.03, result.getMonthlyAmount());
|
||||
}
|
||||
}
|
||||
|
||||
@Test
|
||||
@DisplayName("Should handle null values properly when converting between objects")
|
||||
void shouldHandleNullValuesGracefully() {
|
||||
PaymentMethod paymentMethod = PaymentMethod.builder()
|
||||
.paymentType(PaymentType.CB.name())
|
||||
.details(null)
|
||||
.build();
|
||||
LocalDate desiredStartDate = LocalDate.of(2026, 6, 24);
|
||||
LocalDate estimateEndDate = LocalDate.of(2026, 9, 24);
|
||||
Subscription subscription = Subscription.builder()
|
||||
.subscriptionId(UUID.randomUUID())
|
||||
.customerId(UUID.randomUUID())
|
||||
.desiredSubscriptionDuration(DesiredSubscriptionDuration.THREE.getValue())
|
||||
.paymentMethod(paymentMethod)
|
||||
.desiredStartDate(desiredStartDate)
|
||||
.startDate(desiredStartDate)
|
||||
.endDate(estimateEndDate)
|
||||
.monthlyAmount(12.03)
|
||||
.build();
|
||||
|
||||
SubscriptionDTO result = SubscriptionConverter.toDTO(subscription);
|
||||
|
||||
assertNotNull(result);
|
||||
assertNull(result.getPaymentMethod().getDetails());
|
||||
assertEquals(desiredStartDate, result.getDesiredStartDate());
|
||||
}
|
||||
|
||||
@Test
|
||||
@DisplayName("Should preserve empty string values during conversion")
|
||||
void shouldPreserveEmptyStrings() {
|
||||
PaymentMethodInfo paymentMethodInfo = new PaymentMethodInfo(PaymentType.CB.name(), "");
|
||||
LocalDate desiredStartDate = LocalDate.of(2026, 6, 24);
|
||||
SubscriptionInfo subscriptionInfo = new SubscriptionInfo(DesiredSubscriptionDuration.THREE.getValue(), desiredStartDate);
|
||||
|
||||
Subscription domainResult = SubscriptionConverter.toDomain(subscriptionInfo, paymentMethodInfo);
|
||||
SubscriptionDTO dtoResult = SubscriptionConverter.toDTO(domainResult);
|
||||
|
||||
assertEquals("", dtoResult.getPaymentMethod().getDetails());
|
||||
}
|
||||
}
|
||||
+58
@@ -0,0 +1,58 @@
|
||||
package fr.iut_fbleau.but3.dev62.mylibrary.subscription.entity;
|
||||
|
||||
import fr.iut_fbleau.but3.dev62.mylibrary.subscription.PaymentType;
|
||||
import org.junit.jupiter.api.DisplayName;
|
||||
import org.junit.jupiter.api.Test;
|
||||
|
||||
import static org.junit.jupiter.api.Assertions.assertEquals;
|
||||
|
||||
public class PaymentMethodTest {
|
||||
|
||||
@Test
|
||||
@DisplayName("Builder should create a valid PaymentMethod instance")
|
||||
void testPaymentMethodBuilder() {
|
||||
String paymentType = PaymentType.CB.name();
|
||||
Object details = new Object();
|
||||
details = "Maxime Lebreton";
|
||||
|
||||
PaymentMethod paymentMethod = PaymentMethod.builder()
|
||||
.paymentType(paymentType)
|
||||
.details(details)
|
||||
.build();
|
||||
|
||||
assertEquals(paymentType, paymentMethod.getPaymentType());
|
||||
assertEquals(details, paymentMethod.getDetails());
|
||||
}
|
||||
|
||||
@Test
|
||||
@DisplayName("Builder should create a valid PaymentMethod instance with details as an Integer")
|
||||
void testPaymentMethodDetailsInteger() {
|
||||
String paymentType = PaymentType.CB.name();
|
||||
Object details = new Object();
|
||||
details = 10;
|
||||
|
||||
PaymentMethod paymentMethod = PaymentMethod.builder()
|
||||
.paymentType(paymentType)
|
||||
.details(details)
|
||||
.build();
|
||||
|
||||
assertEquals(paymentType, paymentMethod.getPaymentType());
|
||||
assertEquals(details, paymentMethod.getDetails());
|
||||
}
|
||||
|
||||
@Test
|
||||
@DisplayName("Builder should create a valid PaymentMethod instance with details as an boolean")
|
||||
void testPaymentMethodDetailsBoolean() {
|
||||
String paymentType = PaymentType.CB.name();
|
||||
Object details = new Object();
|
||||
details = true;
|
||||
|
||||
PaymentMethod paymentMethod = PaymentMethod.builder()
|
||||
.paymentType(paymentType)
|
||||
.details(details)
|
||||
.build();
|
||||
|
||||
assertEquals(paymentType, paymentMethod.getPaymentType());
|
||||
assertEquals(details, paymentMethod.getDetails());
|
||||
}
|
||||
}
|
||||
+125
@@ -0,0 +1,125 @@
|
||||
package fr.iut_fbleau.but3.dev62.mylibrary.subscription.entity;
|
||||
|
||||
import fr.iut_fbleau.but3.dev62.mylibrary.subscription.PaymentType;
|
||||
import fr.iut_fbleau.but3.dev62.mylibrary.subscription.DesiredSubscriptionDuration;
|
||||
import org.junit.jupiter.api.DisplayName;
|
||||
import org.junit.jupiter.api.Test;
|
||||
|
||||
import java.time.LocalDate;
|
||||
import java.util.UUID;
|
||||
|
||||
import static org.junit.jupiter.api.Assertions.*;
|
||||
import static org.junit.jupiter.api.Assertions.assertEquals;
|
||||
|
||||
public class SubscriptionTest {
|
||||
|
||||
@Test
|
||||
@DisplayName("Builder should create a valid Subscription instance")
|
||||
void testSubscriptionBuilder() {
|
||||
UUID subscriptionId = UUID.randomUUID();
|
||||
UUID customerId = UUID.randomUUID();
|
||||
Integer desiredSubscriptionDuration = DesiredSubscriptionDuration.THREE.getValue();
|
||||
String paymentType = PaymentType.CB.name();
|
||||
Object details = new Object();
|
||||
details = "Maxime Lebreton";
|
||||
LocalDate desiredStartDate = LocalDate.of(2026, 6, 24);
|
||||
LocalDate startDate = desiredStartDate;
|
||||
LocalDate estimateEndDate = LocalDate.of(2026, 9, 24);
|
||||
double monthlyAmount = 17.99;
|
||||
|
||||
PaymentMethod paymentMethod = PaymentMethod.builder()
|
||||
.paymentType(paymentType)
|
||||
.details(details)
|
||||
.build();
|
||||
Subscription subscription = Subscription.builder()
|
||||
.subscriptionId(subscriptionId)
|
||||
.customerId(customerId)
|
||||
.desiredSubscriptionDuration(desiredSubscriptionDuration)
|
||||
.paymentMethod(paymentMethod)
|
||||
.desiredStartDate(desiredStartDate)
|
||||
.startDate(startDate)
|
||||
.endDate(estimateEndDate)
|
||||
.monthlyAmount(monthlyAmount)
|
||||
.build();
|
||||
|
||||
assertEquals(subscriptionId, subscription.getSubscriptionId());
|
||||
assertEquals(customerId, subscription.getCustomerId());
|
||||
assertEquals(desiredSubscriptionDuration, subscription.getDesiredSubscriptionDuration());
|
||||
assertEquals(paymentType, paymentMethod.getPaymentType());
|
||||
assertEquals(details, paymentMethod.getDetails());
|
||||
assertEquals(desiredStartDate, subscription.getDesiredStartDate());
|
||||
assertEquals(startDate, subscription.getStartDate());
|
||||
assertEquals(estimateEndDate, subscription.getEndDate());
|
||||
assertEquals(monthlyAmount, subscription.getMonthlyAmount());
|
||||
}
|
||||
|
||||
@Test
|
||||
@DisplayName("setRandomSubscriptionUUID should change the ID to a new random UUID")
|
||||
void testSetRandomSubscriptionUUID() {
|
||||
Subscription subscription = Subscription.builder().build();
|
||||
UUID originalId = subscription.getSubscriptionId();
|
||||
|
||||
subscription.setRandomSubscriptionUUID();
|
||||
|
||||
assertNotNull(subscription.getSubscriptionId());
|
||||
assertNotEquals(originalId, subscription.getSubscriptionId());
|
||||
}
|
||||
|
||||
@Test
|
||||
@DisplayName("setRandomCustomerUUID should change the ID to a new random UUID")
|
||||
void testSetRandomCustomerUUID() {
|
||||
Subscription subscription = Subscription.builder().build();
|
||||
UUID originalId = subscription.getCustomerId();
|
||||
|
||||
subscription.setRandomCustomerUUID();
|
||||
|
||||
assertNotNull(subscription.getCustomerId());
|
||||
assertNotEquals(originalId, subscription.getCustomerId());
|
||||
}
|
||||
|
||||
@Test
|
||||
@DisplayName("setStartDate should instantiate StartDate as the same value as the variable desiredStartDate")
|
||||
void testSetStartDate() {
|
||||
LocalDate desiredStartDate = LocalDate.of(2026, 6, 24);
|
||||
Subscription subscription = Subscription.builder()
|
||||
.desiredStartDate(desiredStartDate)
|
||||
.build();
|
||||
|
||||
subscription.setStartDate();
|
||||
|
||||
assertNotNull(subscription.getStartDate());
|
||||
assertEquals(desiredStartDate, subscription.getStartDate());
|
||||
}
|
||||
|
||||
@Test
|
||||
@DisplayName("setEndDate should instantiate EndDate as the same value as the variable desiredStartDate + desiredSubscriptionDuration")
|
||||
void testSetEndDate() {
|
||||
LocalDate desiredStartDate = LocalDate.of(2026, 6, 24);
|
||||
LocalDate estimateEndDate = LocalDate.of(2026, 9, 24);
|
||||
Subscription subscription = Subscription.builder()
|
||||
.desiredSubscriptionDuration(DesiredSubscriptionDuration.THREE.getValue())
|
||||
.desiredStartDate(desiredStartDate)
|
||||
.build();
|
||||
|
||||
subscription.setEndDate();
|
||||
|
||||
assertNotNull(subscription.getEndDate());
|
||||
assertEquals(estimateEndDate, subscription.getEndDate());
|
||||
}
|
||||
|
||||
@Test
|
||||
@DisplayName("setDateSubscription should instantiate StartDate and EndDate ")
|
||||
void testSetDateSubscription() {
|
||||
LocalDate desiredStartDate = LocalDate.of(2026, 6, 24);
|
||||
LocalDate estimateEndDate = LocalDate.of(2026, 9, 24);
|
||||
Subscription subscription = Subscription.builder()
|
||||
.desiredSubscriptionDuration(DesiredSubscriptionDuration.THREE.getValue())
|
||||
.desiredStartDate(desiredStartDate)
|
||||
.build();
|
||||
|
||||
subscription.setDateSubscription();
|
||||
|
||||
assertNotNull(subscription.getEndDate());
|
||||
assertEquals(estimateEndDate, subscription.getEndDate());
|
||||
}
|
||||
}
|
||||
+58
@@ -0,0 +1,58 @@
|
||||
package fr.iut_fbleau.but3.dev62.mylibrary.subscription.exception;
|
||||
|
||||
import org.junit.jupiter.api.DisplayName;
|
||||
import org.junit.jupiter.api.Test;
|
||||
import org.junit.jupiter.params.ParameterizedTest;
|
||||
import org.junit.jupiter.params.provider.ValueSource;
|
||||
|
||||
import static org.junit.jupiter.api.Assertions.assertEquals;
|
||||
import static org.junit.jupiter.api.Assertions.assertThrows;
|
||||
|
||||
public class NotValidPaymentMethodEsceptionTest {
|
||||
|
||||
@Test
|
||||
@DisplayName("Exception should be created with the provided message")
|
||||
void testExceptionCreation() {
|
||||
String errorMessage = "PaymentMethod data is not valid";
|
||||
|
||||
NotValidPaymentMethodException exception = new NotValidPaymentMethodException(errorMessage);
|
||||
|
||||
assertEquals(errorMessage, exception.getMessage());
|
||||
}
|
||||
|
||||
@ParameterizedTest
|
||||
@ValueSource(strings = {
|
||||
"paymentType is not valid"
|
||||
})
|
||||
@DisplayName("Exception should handle different validation messages")
|
||||
void testExceptionWithDifferentMessages(String errorMessage) {
|
||||
NotValidPaymentMethodException exception = new NotValidPaymentMethodException(errorMessage);
|
||||
|
||||
assertEquals(errorMessage, exception.getMessage());
|
||||
}
|
||||
|
||||
@Test
|
||||
@DisplayName("Exception should be properly thrown and caught")
|
||||
void testExceptionCanBeThrownAndCaught() {
|
||||
String errorMessage = "paymentType is not valid";
|
||||
|
||||
Exception exception = assertThrows(NotValidPaymentMethodException.class, () -> {
|
||||
throw new NotValidPaymentMethodException(errorMessage);
|
||||
});
|
||||
|
||||
assertEquals(errorMessage, exception.getMessage());
|
||||
}
|
||||
|
||||
@Test
|
||||
@DisplayName("Exception should be catchable as a general Exception")
|
||||
void testExceptionInheritance() {
|
||||
String errorMessage = "Invalid paymentMethod data";
|
||||
|
||||
try {
|
||||
throw new NotValidPaymentMethodException(errorMessage);
|
||||
} catch (Exception e) {
|
||||
assertEquals(NotValidPaymentMethodException.class, e.getClass());
|
||||
assertEquals(errorMessage, e.getMessage());
|
||||
}
|
||||
}
|
||||
}
|
||||
+60
@@ -0,0 +1,60 @@
|
||||
package fr.iut_fbleau.but3.dev62.mylibrary.subscription.exception;
|
||||
|
||||
import fr.iut_fbleau.but3.dev62.mylibrary.customer.exception.NotValidCustomerException;
|
||||
import org.junit.jupiter.api.DisplayName;
|
||||
import org.junit.jupiter.api.Test;
|
||||
import org.junit.jupiter.params.ParameterizedTest;
|
||||
import org.junit.jupiter.params.provider.ValueSource;
|
||||
|
||||
import static org.junit.jupiter.api.Assertions.assertEquals;
|
||||
import static org.junit.jupiter.api.Assertions.assertThrows;
|
||||
|
||||
public class NotValidSubscriptionExceptionTest {
|
||||
|
||||
@Test
|
||||
@DisplayName("Exception should be created with the provided message")
|
||||
void testExceptionCreation() {
|
||||
String errorMessage = "Subscription data is not valid";
|
||||
|
||||
NotValidSubscriptionException exception = new NotValidSubscriptionException(errorMessage);
|
||||
|
||||
assertEquals(errorMessage, exception.getMessage());
|
||||
}
|
||||
|
||||
@ParameterizedTest
|
||||
@ValueSource(strings = {
|
||||
"desiredSubscriptionDuration will be 3, 6 or 12 by the ENUM file SubscriptionDurationDesired",
|
||||
"desiredStartDate cannot be before today"
|
||||
})
|
||||
@DisplayName("Exception should handle different validation messages")
|
||||
void testExceptionWithDifferentMessages(String errorMessage) {
|
||||
NotValidSubscriptionException exception = new NotValidSubscriptionException(errorMessage);
|
||||
|
||||
assertEquals(errorMessage, exception.getMessage());
|
||||
}
|
||||
|
||||
@Test
|
||||
@DisplayName("Exception should be properly thrown and caught")
|
||||
void testExceptionCanBeThrownAndCaught() {
|
||||
String errorMessage = "desiredStartDate cannot be before today";
|
||||
|
||||
Exception exception = assertThrows(NotValidSubscriptionException.class, () -> {
|
||||
throw new NotValidSubscriptionException(errorMessage);
|
||||
});
|
||||
|
||||
assertEquals(errorMessage, exception.getMessage());
|
||||
}
|
||||
|
||||
@Test
|
||||
@DisplayName("Exception should be catchable as a general Exception")
|
||||
void testExceptionInheritance() {
|
||||
String errorMessage = "Invalid subscription data";
|
||||
|
||||
try {
|
||||
throw new NotValidSubscriptionException(errorMessage);
|
||||
} catch (Exception e) {
|
||||
assertEquals(NotValidSubscriptionException.class, e.getClass());
|
||||
assertEquals(errorMessage, e.getMessage());
|
||||
}
|
||||
}
|
||||
}
|
||||
+74
@@ -0,0 +1,74 @@
|
||||
package fr.iut_fbleau.but3.dev62.mylibrary.subscription.exception;
|
||||
|
||||
import org.junit.jupiter.api.DisplayName;
|
||||
import org.junit.jupiter.api.Test;
|
||||
|
||||
import java.util.Optional;
|
||||
import java.util.UUID;
|
||||
|
||||
import static org.junit.jupiter.api.Assertions.assertEquals;
|
||||
import static org.junit.jupiter.api.Assertions.assertTrue;
|
||||
|
||||
public class SubscriptionNotFoundExceptionTest {
|
||||
|
||||
@Test
|
||||
@DisplayName("Exception message should contain the UUID provided for customer")
|
||||
void testExceptionMessageContainsUUIDForCustomer() {
|
||||
UUID customerUUID = UUID.randomUUID();
|
||||
|
||||
SubscriptionNotFoundException exception = new SubscriptionNotFoundException(Optional.of(customerUUID), Optional.empty());
|
||||
|
||||
String expectedMessage = String.format("The subscriptions with the customer id %s does not exists", customerUUID);
|
||||
assertEquals(expectedMessage, exception.getMessage());
|
||||
}
|
||||
|
||||
@Test
|
||||
@DisplayName("Exception message should contain the UUID provided for subscription")
|
||||
void testExceptionMessageContainsUUIDForSubscription() {
|
||||
UUID subscriptionUUID = UUID.randomUUID();
|
||||
|
||||
SubscriptionNotFoundException exception = new SubscriptionNotFoundException(Optional.empty(), Optional.of(subscriptionUUID));
|
||||
|
||||
String expectedMessage = String.format("The subscription with subscription id %s does not exists", subscriptionUUID);
|
||||
assertEquals(expectedMessage, exception.getMessage());
|
||||
}
|
||||
|
||||
@Test
|
||||
@DisplayName("Exception should use the correct constant message format for customer")
|
||||
void testExceptionUsesConstantMessageCustomerFormat() {
|
||||
UUID customerUUID = UUID.randomUUID();
|
||||
|
||||
SubscriptionNotFoundException exception = new SubscriptionNotFoundException(Optional.of(customerUUID), Optional.empty());
|
||||
|
||||
String expectedFormatWithPlaceholder = "The subscriptions with the customer id {0} does not exists";
|
||||
assertEquals(SubscriptionNotFoundException.THE_SUBSCRIPTION_WITH_CUSTOMER_ID_DOES_NOT_EXIST_MESSAGE,
|
||||
expectedFormatWithPlaceholder);
|
||||
assertTrue(exception.getMessage().contains(customerUUID.toString()));
|
||||
}
|
||||
|
||||
@Test
|
||||
@DisplayName("Exception should use the correct constant message format for subscription")
|
||||
void testExceptionUsesConstantMessageSubscriptionFormat() {
|
||||
UUID subscriptionUUID = UUID.randomUUID();
|
||||
|
||||
SubscriptionNotFoundException exception = new SubscriptionNotFoundException(Optional.empty(), Optional.of(subscriptionUUID));
|
||||
|
||||
String expectedFormatWithPlaceholder = "The subscription with subscription id {0} does not exists";
|
||||
assertEquals(SubscriptionNotFoundException.THE_SUBSCRIPTION_WITH_SUBSCRIPTION_ID_DOES_NOT_EXIST_MESSAGE,
|
||||
expectedFormatWithPlaceholder);
|
||||
assertTrue(exception.getMessage().contains(subscriptionUUID.toString()));
|
||||
}
|
||||
|
||||
@Test
|
||||
@DisplayName("Exception should be properly thrown and caught")
|
||||
void testExceptionCanBeThrownAndCaught() {
|
||||
UUID subscriptionUUID = UUID.randomUUID();
|
||||
|
||||
try {
|
||||
throw new SubscriptionNotFoundException(Optional.empty(), Optional.of(subscriptionUUID));
|
||||
} catch (SubscriptionNotFoundException e) {
|
||||
String expectedMessage = String.format("The subscription with subscription id %s does not exists", subscriptionUUID);
|
||||
assertEquals(expectedMessage, e.getMessage());
|
||||
}
|
||||
}
|
||||
}
|
||||
Some files were not shown because too many files have changed in this diff Show More
Reference in New Issue
Block a user