forked from pierront/mylibrary-template
🎉
This commit is contained in:
commit
1f82178d1c
.gitignorepom.xml
src
main/java/fr/iut_fbleau/but3/dev62/mylibrary/customer
test
java/fr/iut_fbleau/but3/dev62/mylibrary
customer
converter
entity
exception
CustomerNotFoundExceptionTest.javaIllegalCustomerPointExceptionTest.javaNotValidCustomerExceptionTest.java
repository
usecase
validator
features
resources/features
38
.gitignore
vendored
Normal file
38
.gitignore
vendored
Normal file
@ -0,0 +1,38 @@
|
|||||||
|
target/
|
||||||
|
!.mvn/wrapper/maven-wrapper.jar
|
||||||
|
!**/src/main/**/target/
|
||||||
|
!**/src/test/**/target/
|
||||||
|
|
||||||
|
### IntelliJ IDEA ###
|
||||||
|
.idea/modules.xml
|
||||||
|
.idea/jarRepositories.xml
|
||||||
|
.idea/compiler.xml
|
||||||
|
.idea/libraries/
|
||||||
|
*.iws
|
||||||
|
*.iml
|
||||||
|
*.ipr
|
||||||
|
|
||||||
|
### Eclipse ###
|
||||||
|
.apt_generated
|
||||||
|
.classpath
|
||||||
|
.factorypath
|
||||||
|
.project
|
||||||
|
.settings
|
||||||
|
.springBeans
|
||||||
|
.sts4-cache
|
||||||
|
|
||||||
|
### NetBeans ###
|
||||||
|
/nbproject/private/
|
||||||
|
/nbbuild/
|
||||||
|
/dist/
|
||||||
|
/nbdist/
|
||||||
|
/.nb-gradle/
|
||||||
|
build/
|
||||||
|
!**/src/main/**/build/
|
||||||
|
!**/src/test/**/build/
|
||||||
|
|
||||||
|
### VS Code ###
|
||||||
|
.vscode/
|
||||||
|
|
||||||
|
### Mac OS ###
|
||||||
|
.DS_Store
|
151
pom.xml
Normal file
151
pom.xml
Normal file
@ -0,0 +1,151 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<project xmlns="http://maven.apache.org/POM/4.0.0"
|
||||||
|
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
|
||||||
|
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
|
||||||
|
<modelVersion>4.0.0</modelVersion>
|
||||||
|
|
||||||
|
<groupId>fr.iut_fbleau.but3.dev62</groupId>
|
||||||
|
<artifactId>mylibrary</artifactId>
|
||||||
|
<version>1.0-SNAPSHOT</version>
|
||||||
|
|
||||||
|
<properties>
|
||||||
|
<!-- Your java version-->
|
||||||
|
<maven.compiler.source>21</maven.compiler.source>
|
||||||
|
<maven.compiler.target>21</maven.compiler.target>
|
||||||
|
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
|
||||||
|
|
||||||
|
<!-- Main dependencies -->
|
||||||
|
<lombok.version>1.18.36</lombok.version>
|
||||||
|
|
||||||
|
<!-- Test Verisons-->
|
||||||
|
<junit.version>5.11.4</junit.version>
|
||||||
|
<junit.platform.version>1.11.4</junit.platform.version>
|
||||||
|
<cucumber.version>7.21.1</cucumber.version>
|
||||||
|
<mockito.version>5.16.0</mockito.version>
|
||||||
|
|
||||||
|
<!-- Maven build version -->
|
||||||
|
<maven.compiler.version>3.13.0</maven.compiler.version>
|
||||||
|
<maven.surefire.version>3.5.2</maven.surefire.version>
|
||||||
|
</properties>
|
||||||
|
|
||||||
|
<dependencyManagement>
|
||||||
|
<dependencies>
|
||||||
|
<dependency>
|
||||||
|
<groupId>io.cucumber</groupId>
|
||||||
|
<artifactId>cucumber-bom</artifactId>
|
||||||
|
<version>${cucumber.version}</version>
|
||||||
|
<type>pom</type>
|
||||||
|
<scope>import</scope>
|
||||||
|
</dependency>
|
||||||
|
<dependency>
|
||||||
|
<groupId>org.junit</groupId>
|
||||||
|
<artifactId>junit-bom</artifactId>
|
||||||
|
<version>${junit.version}</version>
|
||||||
|
<type>pom</type>
|
||||||
|
<scope>import</scope>
|
||||||
|
</dependency>
|
||||||
|
</dependencies>
|
||||||
|
</dependencyManagement>
|
||||||
|
|
||||||
|
<dependencies>
|
||||||
|
<dependency>
|
||||||
|
<groupId>org.projectlombok</groupId>
|
||||||
|
<artifactId>lombok</artifactId>
|
||||||
|
<version>${lombok.version}</version>
|
||||||
|
<scope>provided</scope>
|
||||||
|
</dependency>
|
||||||
|
|
||||||
|
<dependency>
|
||||||
|
<groupId>io.cucumber</groupId>
|
||||||
|
<artifactId>cucumber-java</artifactId>
|
||||||
|
<scope>test</scope>
|
||||||
|
</dependency>
|
||||||
|
|
||||||
|
<dependency>
|
||||||
|
<groupId>io.cucumber</groupId>
|
||||||
|
<artifactId>cucumber-junit-platform-engine</artifactId>
|
||||||
|
<scope>test</scope>
|
||||||
|
</dependency>
|
||||||
|
|
||||||
|
<dependency>
|
||||||
|
<groupId>org.junit.platform</groupId>
|
||||||
|
<artifactId>junit-platform-suite</artifactId>
|
||||||
|
<version>${junit.platform.version}</version>
|
||||||
|
<scope>test</scope>
|
||||||
|
</dependency>
|
||||||
|
<dependency>
|
||||||
|
<groupId>org.junit.platform</groupId>
|
||||||
|
<artifactId>junit-platform-engine</artifactId>
|
||||||
|
<version>${junit.platform.version}</version>
|
||||||
|
<scope>test</scope>
|
||||||
|
</dependency>
|
||||||
|
|
||||||
|
<dependency>
|
||||||
|
<groupId>org.junit.jupiter</groupId>
|
||||||
|
<artifactId>junit-jupiter-api</artifactId>
|
||||||
|
<version>${junit.version}</version>
|
||||||
|
<scope>test</scope>
|
||||||
|
</dependency>
|
||||||
|
<dependency>
|
||||||
|
<groupId>org.junit.jupiter</groupId>
|
||||||
|
<artifactId>junit-jupiter-params</artifactId>
|
||||||
|
<version>${junit.version}</version>
|
||||||
|
<scope>test</scope>
|
||||||
|
</dependency>
|
||||||
|
<dependency>
|
||||||
|
<groupId>org.junit.jupiter</groupId>
|
||||||
|
<artifactId>junit-jupiter-engine</artifactId>
|
||||||
|
<version>${junit.version}</version>
|
||||||
|
<scope>test</scope>
|
||||||
|
</dependency>
|
||||||
|
<dependency>
|
||||||
|
<groupId>org.junit.platform</groupId>
|
||||||
|
<artifactId>junit-platform-launcher</artifactId>
|
||||||
|
<version>${junit.platform.version}</version>
|
||||||
|
<scope>test</scope>
|
||||||
|
</dependency>
|
||||||
|
|
||||||
|
<dependency>
|
||||||
|
<groupId>org.mockito</groupId>
|
||||||
|
<artifactId>mockito-core</artifactId>
|
||||||
|
<version>${mockito.version}</version>
|
||||||
|
<scope>test</scope>
|
||||||
|
</dependency>
|
||||||
|
<dependency>
|
||||||
|
<groupId>org.mockito</groupId>
|
||||||
|
<artifactId>mockito-junit-jupiter</artifactId>
|
||||||
|
<version>${mockito.version}</version>
|
||||||
|
<scope>test</scope>
|
||||||
|
</dependency>
|
||||||
|
</dependencies>
|
||||||
|
|
||||||
|
<build>
|
||||||
|
<plugins>
|
||||||
|
<plugin>
|
||||||
|
<groupId>org.apache.maven.plugins</groupId>
|
||||||
|
<artifactId>maven-compiler-plugin</artifactId>
|
||||||
|
<version>${maven.compiler.version}</version>
|
||||||
|
<configuration>
|
||||||
|
<encoding>${project.build.sourceEncoding}</encoding>
|
||||||
|
<source>${maven.compiler.source}</source>
|
||||||
|
<target>${maven.compiler.target}</target>
|
||||||
|
</configuration>
|
||||||
|
</plugin>
|
||||||
|
<plugin>
|
||||||
|
<groupId>org.apache.maven.plugins</groupId>
|
||||||
|
<artifactId>maven-surefire-plugin</artifactId>
|
||||||
|
<version>${maven.surefire.version}</version>
|
||||||
|
<configuration>
|
||||||
|
<properties>
|
||||||
|
<!-- Work around. Surefire does not include enough
|
||||||
|
information to disambiguate between different
|
||||||
|
examples and scenarios. -->
|
||||||
|
<configurationParameters>
|
||||||
|
cucumber.junit-platform.naming-strategy=long
|
||||||
|
</configurationParameters>
|
||||||
|
</properties>
|
||||||
|
</configuration>
|
||||||
|
</plugin>
|
||||||
|
</plugins>
|
||||||
|
</build>
|
||||||
|
</project>
|
@ -0,0 +1,15 @@
|
|||||||
|
package fr.iut_fbleau.but3.dev62.mylibrary.customer;
|
||||||
|
|
||||||
|
import java.util.UUID;
|
||||||
|
import lombok.Builder;
|
||||||
|
import lombok.Getter;
|
||||||
|
|
||||||
|
@Builder
|
||||||
|
@Getter
|
||||||
|
public class CustomerDTO {
|
||||||
|
private final UUID id;
|
||||||
|
private final String firstName;
|
||||||
|
private final String lastName;
|
||||||
|
private final String phoneNumber;
|
||||||
|
private final int loyaltyPoints;
|
||||||
|
}
|
@ -0,0 +1,4 @@
|
|||||||
|
package fr.iut_fbleau.but3.dev62.mylibrary.customer;
|
||||||
|
|
||||||
|
public record CustomerInfo(String firstName, String lastName, String phoneNumber) {
|
||||||
|
}
|
30
src/main/java/fr/iut_fbleau/but3/dev62/mylibrary/customer/converter/CustomerConverter.java
Normal file
30
src/main/java/fr/iut_fbleau/but3/dev62/mylibrary/customer/converter/CustomerConverter.java
Normal file
@ -0,0 +1,30 @@
|
|||||||
|
package fr.iut_fbleau.but3.dev62.mylibrary.customer.converter;
|
||||||
|
|
||||||
|
import fr.iut_fbleau.but3.dev62.mylibrary.customer.CustomerDTO;
|
||||||
|
import fr.iut_fbleau.but3.dev62.mylibrary.customer.CustomerInfo;
|
||||||
|
import fr.iut_fbleau.but3.dev62.mylibrary.customer.entity.Customer;
|
||||||
|
|
||||||
|
public final class CustomerConverter {
|
||||||
|
private CustomerConverter(){
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
public static Customer toDomain(CustomerInfo newCustomer) {
|
||||||
|
return Customer.builder()
|
||||||
|
.firstName(newCustomer.firstName())
|
||||||
|
.lastName(newCustomer.lastName())
|
||||||
|
.phoneNumber(newCustomer.phoneNumber())
|
||||||
|
.loyaltyPoints(0)
|
||||||
|
.build();
|
||||||
|
}
|
||||||
|
|
||||||
|
public static CustomerDTO toDTO(Customer customer) {
|
||||||
|
return CustomerDTO.builder()
|
||||||
|
.id(customer.getId())
|
||||||
|
.firstName(customer.getFirstName())
|
||||||
|
.lastName(customer.getLastName())
|
||||||
|
.phoneNumber(customer.getPhoneNumber())
|
||||||
|
.loyaltyPoints(customer.getLoyaltyPoints())
|
||||||
|
.build();
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,30 @@
|
|||||||
|
package fr.iut_fbleau.but3.dev62.mylibrary.customer.entity;
|
||||||
|
|
||||||
|
|
||||||
|
import fr.iut_fbleau.but3.dev62.mylibrary.customer.exception.IllegalCustomerPointException;
|
||||||
|
import java.util.UUID;
|
||||||
|
import lombok.Builder;
|
||||||
|
import lombok.Getter;
|
||||||
|
|
||||||
|
@Builder
|
||||||
|
@Getter
|
||||||
|
public class Customer {
|
||||||
|
private UUID id;
|
||||||
|
private String firstName;
|
||||||
|
private String lastName;
|
||||||
|
private String phoneNumber;
|
||||||
|
private int loyaltyPoints;
|
||||||
|
|
||||||
|
public void setRandomUUID() {
|
||||||
|
this.id = UUID.randomUUID();
|
||||||
|
}
|
||||||
|
|
||||||
|
public void addLoyaltyPoints(int loyaltyPointToAdd) {
|
||||||
|
this.loyaltyPoints += loyaltyPointToAdd;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void removeLoyaltyPoints(int loyaltyPointToRemove) throws IllegalCustomerPointException {
|
||||||
|
if (loyaltyPointToRemove > this.loyaltyPoints) throw new IllegalCustomerPointException(loyaltyPointToRemove, this.loyaltyPoints);
|
||||||
|
this.loyaltyPoints -= loyaltyPointToRemove;
|
||||||
|
}
|
||||||
|
}
|
13
src/main/java/fr/iut_fbleau/but3/dev62/mylibrary/customer/exception/CustomerNotFoundException.java
Normal file
13
src/main/java/fr/iut_fbleau/but3/dev62/mylibrary/customer/exception/CustomerNotFoundException.java
Normal file
@ -0,0 +1,13 @@
|
|||||||
|
package fr.iut_fbleau.but3.dev62.mylibrary.customer.exception;
|
||||||
|
|
||||||
|
import java.text.MessageFormat;
|
||||||
|
import java.util.UUID;
|
||||||
|
|
||||||
|
public class CustomerNotFoundException extends Exception {
|
||||||
|
|
||||||
|
public static final String THE_CUSTOMER_WITH_ID_DOES_NOT_EXIST_MESSAGE = "The customer with id {0} does not exist";
|
||||||
|
|
||||||
|
public CustomerNotFoundException(UUID uuid) {
|
||||||
|
super(MessageFormat.format(THE_CUSTOMER_WITH_ID_DOES_NOT_EXIST_MESSAGE, uuid));
|
||||||
|
}
|
||||||
|
}
|
13
src/main/java/fr/iut_fbleau/but3/dev62/mylibrary/customer/exception/IllegalCustomerPointException.java
Normal file
13
src/main/java/fr/iut_fbleau/but3/dev62/mylibrary/customer/exception/IllegalCustomerPointException.java
Normal file
@ -0,0 +1,13 @@
|
|||||||
|
package fr.iut_fbleau.but3.dev62.mylibrary.customer.exception;
|
||||||
|
|
||||||
|
import java.text.MessageFormat;
|
||||||
|
|
||||||
|
public class IllegalCustomerPointException extends Exception {
|
||||||
|
|
||||||
|
public static final String CANNOT_REMOVE_LOYALTY_POINTS = "Cannot remove {0} points from {1} points";
|
||||||
|
|
||||||
|
public IllegalCustomerPointException(int needed, int actual) {
|
||||||
|
super(MessageFormat.format(CANNOT_REMOVE_LOYALTY_POINTS, needed,
|
||||||
|
actual));
|
||||||
|
}
|
||||||
|
}
|
8
src/main/java/fr/iut_fbleau/but3/dev62/mylibrary/customer/exception/NotValidCustomerException.java
Normal file
8
src/main/java/fr/iut_fbleau/but3/dev62/mylibrary/customer/exception/NotValidCustomerException.java
Normal file
@ -0,0 +1,8 @@
|
|||||||
|
package fr.iut_fbleau.but3.dev62.mylibrary.customer.exception;
|
||||||
|
|
||||||
|
public class NotValidCustomerException extends Exception {
|
||||||
|
|
||||||
|
public NotValidCustomerException(String message) {
|
||||||
|
super(message);
|
||||||
|
}
|
||||||
|
}
|
49
src/main/java/fr/iut_fbleau/but3/dev62/mylibrary/customer/repository/CustomerRepository.java
Normal file
49
src/main/java/fr/iut_fbleau/but3/dev62/mylibrary/customer/repository/CustomerRepository.java
Normal file
@ -0,0 +1,49 @@
|
|||||||
|
package fr.iut_fbleau.but3.dev62.mylibrary.customer.repository;
|
||||||
|
|
||||||
|
import fr.iut_fbleau.but3.dev62.mylibrary.customer.entity.Customer;
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Optional;
|
||||||
|
import java.util.UUID;
|
||||||
|
import lombok.NoArgsConstructor;
|
||||||
|
|
||||||
|
@NoArgsConstructor
|
||||||
|
public final class CustomerRepository {
|
||||||
|
private final List<Customer> customers = new ArrayList<>();
|
||||||
|
|
||||||
|
public List<Customer> findAll() {
|
||||||
|
return customers;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void deleteAll() {
|
||||||
|
customers.clear();
|
||||||
|
}
|
||||||
|
|
||||||
|
public Customer save(Customer newCustomer) {
|
||||||
|
Optional<Customer> optionalCustomerWithSameId = this.findById(newCustomer.getId());
|
||||||
|
optionalCustomerWithSameId.ifPresentOrElse(customers::remove, newCustomer::setRandomUUID);
|
||||||
|
this.customers.add(newCustomer);
|
||||||
|
return newCustomer;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Optional<Customer> findById(UUID uuid) {
|
||||||
|
return this.customers.stream()
|
||||||
|
.filter(customer -> customer.getId().equals(uuid))
|
||||||
|
.findFirst();
|
||||||
|
}
|
||||||
|
|
||||||
|
public boolean existsById(UUID uuid) {
|
||||||
|
return this.customers.stream()
|
||||||
|
.anyMatch(customer -> customer.getId().equals(uuid));
|
||||||
|
}
|
||||||
|
|
||||||
|
public Optional<Customer> findByPhoneNumber(String phoneNumber) {
|
||||||
|
return this.customers.stream()
|
||||||
|
.filter(customer -> customer.getPhoneNumber().equals(phoneNumber))
|
||||||
|
.findFirst();
|
||||||
|
}
|
||||||
|
|
||||||
|
public void delete(Customer customer) {
|
||||||
|
this.customers.remove(customer);
|
||||||
|
}
|
||||||
|
}
|
81
src/main/java/fr/iut_fbleau/but3/dev62/mylibrary/customer/usecase/CustomerUseCase.java
Normal file
81
src/main/java/fr/iut_fbleau/but3/dev62/mylibrary/customer/usecase/CustomerUseCase.java
Normal file
@ -0,0 +1,81 @@
|
|||||||
|
package fr.iut_fbleau.but3.dev62.mylibrary.customer.usecase;
|
||||||
|
|
||||||
|
import fr.iut_fbleau.but3.dev62.mylibrary.customer.CustomerDTO;
|
||||||
|
import fr.iut_fbleau.but3.dev62.mylibrary.customer.CustomerInfo;
|
||||||
|
import fr.iut_fbleau.but3.dev62.mylibrary.customer.converter.CustomerConverter;
|
||||||
|
import fr.iut_fbleau.but3.dev62.mylibrary.customer.entity.Customer;
|
||||||
|
import fr.iut_fbleau.but3.dev62.mylibrary.customer.exception.CustomerNotFoundException;
|
||||||
|
import fr.iut_fbleau.but3.dev62.mylibrary.customer.exception.IllegalCustomerPointException;
|
||||||
|
import fr.iut_fbleau.but3.dev62.mylibrary.customer.exception.NotValidCustomerException;
|
||||||
|
import fr.iut_fbleau.but3.dev62.mylibrary.customer.repository.CustomerRepository;
|
||||||
|
import fr.iut_fbleau.but3.dev62.mylibrary.customer.validator.CustomerValidator;
|
||||||
|
import java.util.Optional;
|
||||||
|
import java.util.UUID;
|
||||||
|
|
||||||
|
public final class CustomerUseCase {
|
||||||
|
|
||||||
|
private final CustomerRepository customerRepository;
|
||||||
|
|
||||||
|
public CustomerUseCase(CustomerRepository customerRepository) {
|
||||||
|
this.customerRepository = customerRepository;
|
||||||
|
}
|
||||||
|
|
||||||
|
public UUID registerCustomer(CustomerInfo newCustomer) throws NotValidCustomerException {
|
||||||
|
CustomerValidator.validate(newCustomer);
|
||||||
|
Customer customerToRegister = CustomerConverter.toDomain(newCustomer);
|
||||||
|
Customer customerToRegistered = customerRepository.save(customerToRegister);
|
||||||
|
return customerToRegistered.getId();
|
||||||
|
}
|
||||||
|
|
||||||
|
public Optional<CustomerDTO> findCustomerByPhoneNumber(String phoneNumber) {
|
||||||
|
Optional<Customer> optionalCustomer = customerRepository.findByPhoneNumber(phoneNumber);
|
||||||
|
return optionalCustomer.map(CustomerConverter::toDTO);
|
||||||
|
}
|
||||||
|
|
||||||
|
public CustomerDTO updateCustomer(UUID uuid, CustomerInfo customerInfo)
|
||||||
|
throws CustomerNotFoundException, NotValidCustomerException {
|
||||||
|
CustomerValidator.validate(customerInfo);
|
||||||
|
Customer customerByUUID = getCustomerIfDoesNotExistThrowCustomerNotFoundException(
|
||||||
|
uuid);
|
||||||
|
Customer customer = Customer.builder()
|
||||||
|
.id(uuid)
|
||||||
|
.firstName(customerInfo.firstName())
|
||||||
|
.lastName(customerInfo.lastName())
|
||||||
|
.phoneNumber(customerInfo.phoneNumber())
|
||||||
|
.loyaltyPoints(customerByUUID.getLoyaltyPoints())
|
||||||
|
.build();
|
||||||
|
Customer updatedCustomer = customerRepository.save(customer);
|
||||||
|
return CustomerConverter.toDTO(updatedCustomer);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void deleteCustomer(UUID uuid) throws CustomerNotFoundException {
|
||||||
|
Customer customerToDelete = getCustomerIfDoesNotExistThrowCustomerNotFoundException(uuid);
|
||||||
|
this.customerRepository.delete(customerToDelete);
|
||||||
|
}
|
||||||
|
|
||||||
|
public int addLoyaltyPoints(UUID uuid, int loyaltyPointToAdd) throws CustomerNotFoundException {
|
||||||
|
Customer customerToAddLoyaltyPoints = getCustomerIfDoesNotExistThrowCustomerNotFoundException(
|
||||||
|
uuid);
|
||||||
|
customerToAddLoyaltyPoints.addLoyaltyPoints(loyaltyPointToAdd);
|
||||||
|
customerRepository.save(customerToAddLoyaltyPoints);
|
||||||
|
return customerToAddLoyaltyPoints.getLoyaltyPoints();
|
||||||
|
}
|
||||||
|
|
||||||
|
public int subtractLoyaltyPoints(UUID uuid, int loyaltyPointToRemove)
|
||||||
|
throws CustomerNotFoundException, IllegalCustomerPointException {
|
||||||
|
Customer customerToSubtractLoyaltyPoints = getCustomerIfDoesNotExistThrowCustomerNotFoundException(
|
||||||
|
uuid);
|
||||||
|
customerToSubtractLoyaltyPoints.removeLoyaltyPoints(loyaltyPointToRemove);
|
||||||
|
customerRepository.save(customerToSubtractLoyaltyPoints);
|
||||||
|
return customerToSubtractLoyaltyPoints.getLoyaltyPoints();
|
||||||
|
}
|
||||||
|
|
||||||
|
private Customer getCustomerIfDoesNotExistThrowCustomerNotFoundException(UUID uuid)
|
||||||
|
throws CustomerNotFoundException {
|
||||||
|
Optional<Customer> optionalCustomerById = customerRepository.findById(uuid);
|
||||||
|
if (optionalCustomerById.isEmpty()) {
|
||||||
|
throw new CustomerNotFoundException(uuid);
|
||||||
|
}
|
||||||
|
return optionalCustomerById.get();
|
||||||
|
}
|
||||||
|
}
|
44
src/main/java/fr/iut_fbleau/but3/dev62/mylibrary/customer/validator/CustomerValidator.java
Normal file
44
src/main/java/fr/iut_fbleau/but3/dev62/mylibrary/customer/validator/CustomerValidator.java
Normal file
@ -0,0 +1,44 @@
|
|||||||
|
package fr.iut_fbleau.but3.dev62.mylibrary.customer.validator;
|
||||||
|
|
||||||
|
import fr.iut_fbleau.but3.dev62.mylibrary.customer.CustomerInfo;
|
||||||
|
import fr.iut_fbleau.but3.dev62.mylibrary.customer.exception.NotValidCustomerException;
|
||||||
|
|
||||||
|
public final class CustomerValidator {
|
||||||
|
|
||||||
|
public static final String PHONE_NUMBER_IS_NOT_VALID = "Phone number is not valid";
|
||||||
|
public static final String LAST_NAME_CANNOT_BE_BLANK = "Last name cannot be blank";
|
||||||
|
public static final String FIRST_NAME_CANNOT_BE_BLANK = "First name cannot be blank";
|
||||||
|
public static final String PHONE_NUMBER_REGEX = "0([67])\\d{8}";
|
||||||
|
|
||||||
|
private CustomerValidator() {
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void validate(CustomerInfo newCustomer) throws NotValidCustomerException {
|
||||||
|
validateFirstName(newCustomer);
|
||||||
|
validateLastName(newCustomer);
|
||||||
|
validatePhoneNumber(newCustomer);
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void validatePhoneNumber(CustomerInfo newCustomer)
|
||||||
|
throws NotValidCustomerException {
|
||||||
|
if (newCustomer.phoneNumber().isBlank()) {
|
||||||
|
throw new NotValidCustomerException("Phone number cannot be blank");
|
||||||
|
}
|
||||||
|
if (!newCustomer.phoneNumber().matches(PHONE_NUMBER_REGEX)) {
|
||||||
|
throw new NotValidCustomerException(PHONE_NUMBER_IS_NOT_VALID);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void validateLastName(CustomerInfo newCustomer) throws NotValidCustomerException {
|
||||||
|
if (newCustomer.lastName().isBlank()) {
|
||||||
|
throw new NotValidCustomerException(LAST_NAME_CANNOT_BE_BLANK);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void validateFirstName(CustomerInfo newCustomer) throws NotValidCustomerException {
|
||||||
|
if (newCustomer.firstName().isBlank()) {
|
||||||
|
throw new NotValidCustomerException(FIRST_NAME_CANNOT_BE_BLANK);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
97
src/test/java/fr/iut_fbleau/but3/dev62/mylibrary/customer/converter/CustomerConverterTest.java
Normal file
97
src/test/java/fr/iut_fbleau/but3/dev62/mylibrary/customer/converter/CustomerConverterTest.java
Normal file
@ -0,0 +1,97 @@
|
|||||||
|
package fr.iut_fbleau.but3.dev62.mylibrary.customer.converter;
|
||||||
|
|
||||||
|
import fr.iut_fbleau.but3.dev62.mylibrary.customer.CustomerDTO;
|
||||||
|
import fr.iut_fbleau.but3.dev62.mylibrary.customer.CustomerInfo;
|
||||||
|
import fr.iut_fbleau.but3.dev62.mylibrary.customer.entity.Customer;
|
||||||
|
import java.util.UUID;
|
||||||
|
import org.junit.jupiter.api.DisplayName;
|
||||||
|
import org.junit.jupiter.api.Nested;
|
||||||
|
import org.junit.jupiter.api.Test;
|
||||||
|
|
||||||
|
import static org.junit.jupiter.api.Assertions.assertEquals;
|
||||||
|
import static org.junit.jupiter.api.Assertions.assertNotNull;
|
||||||
|
import static org.junit.jupiter.api.Assertions.assertNull;
|
||||||
|
|
||||||
|
@DisplayName("CustomerConverter Unit Tests")
|
||||||
|
class CustomerConverterTest {
|
||||||
|
|
||||||
|
@Nested
|
||||||
|
@DisplayName("toDomain() method tests")
|
||||||
|
class ToDomainTests {
|
||||||
|
|
||||||
|
@Test
|
||||||
|
@DisplayName("Should convert CustomerInfo to Customer domain object with loyalty points initialized to 0")
|
||||||
|
void shouldConvertCustomerInfoToDomain() {
|
||||||
|
// Given
|
||||||
|
CustomerInfo customerInfo = new CustomerInfo("John", "Doe", "0123456789");
|
||||||
|
|
||||||
|
// When
|
||||||
|
Customer result = CustomerConverter.toDomain(customerInfo);
|
||||||
|
|
||||||
|
// Then
|
||||||
|
assertNotNull(result);
|
||||||
|
assertEquals(customerInfo.firstName(), result.getFirstName());
|
||||||
|
assertEquals(customerInfo.lastName(), result.getLastName());
|
||||||
|
assertEquals(customerInfo.phoneNumber(), result.getPhoneNumber());
|
||||||
|
assertEquals(0, result.getLoyaltyPoints());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Nested
|
||||||
|
@DisplayName("toDTO() method tests")
|
||||||
|
class ToDTOTests {
|
||||||
|
|
||||||
|
@Test
|
||||||
|
@DisplayName("Should convert Customer domain object to CustomerDTO with all fields mapped correctly")
|
||||||
|
void shouldConvertCustomerToDTO() {
|
||||||
|
Customer customer = Customer.builder()
|
||||||
|
.id(UUID.randomUUID())
|
||||||
|
.firstName("Jane")
|
||||||
|
.lastName("Smith")
|
||||||
|
.phoneNumber("9876543210")
|
||||||
|
.loyaltyPoints(100)
|
||||||
|
.build();
|
||||||
|
|
||||||
|
CustomerDTO result = CustomerConverter.toDTO(customer);
|
||||||
|
|
||||||
|
assertNotNull(result);
|
||||||
|
assertEquals(customer.getId(), result.getId());
|
||||||
|
assertEquals(customer.getFirstName(), result.getFirstName());
|
||||||
|
assertEquals(customer.getLastName(), result.getLastName());
|
||||||
|
assertEquals(customer.getPhoneNumber(), result.getPhoneNumber());
|
||||||
|
assertEquals(customer.getLoyaltyPoints(), result.getLoyaltyPoints());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
@DisplayName("Should handle null values properly when converting between objects")
|
||||||
|
void shouldHandleNullValuesGracefully() {
|
||||||
|
Customer customer = Customer.builder()
|
||||||
|
.id(UUID.randomUUID())
|
||||||
|
.firstName(null)
|
||||||
|
.lastName("NullTest")
|
||||||
|
.phoneNumber(null)
|
||||||
|
.loyaltyPoints(50)
|
||||||
|
.build();
|
||||||
|
|
||||||
|
CustomerDTO result = CustomerConverter.toDTO(customer);
|
||||||
|
|
||||||
|
assertNotNull(result);
|
||||||
|
assertNull(result.getFirstName());
|
||||||
|
assertEquals("NullTest", result.getLastName());
|
||||||
|
assertNull(result.getPhoneNumber());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
@DisplayName("Should preserve empty string values during conversion")
|
||||||
|
void shouldPreserveEmptyStrings() {
|
||||||
|
CustomerInfo customerInfo = new CustomerInfo("", "", "");
|
||||||
|
|
||||||
|
Customer domainResult = CustomerConverter.toDomain(customerInfo);
|
||||||
|
CustomerDTO dtoResult = CustomerConverter.toDTO(domainResult);
|
||||||
|
|
||||||
|
assertEquals("", dtoResult.getFirstName());
|
||||||
|
assertEquals("", dtoResult.getLastName());
|
||||||
|
assertEquals("", dtoResult.getPhoneNumber());
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,136 @@
|
|||||||
|
package fr.iut_fbleau.but3.dev62.mylibrary.customer.entity;
|
||||||
|
|
||||||
|
import fr.iut_fbleau.but3.dev62.mylibrary.customer.exception.IllegalCustomerPointException;
|
||||||
|
import org.junit.jupiter.api.Test;
|
||||||
|
import org.junit.jupiter.api.DisplayName;
|
||||||
|
import org.junit.jupiter.api.Nested;
|
||||||
|
import static org.junit.jupiter.api.Assertions.*;
|
||||||
|
|
||||||
|
import java.util.UUID;
|
||||||
|
|
||||||
|
class CustomerTest {
|
||||||
|
|
||||||
|
@Test
|
||||||
|
@DisplayName("Builder should create a valid Customer instance")
|
||||||
|
void testCustomerBuilder() {
|
||||||
|
UUID id = UUID.randomUUID();
|
||||||
|
String firstName = "John";
|
||||||
|
String lastName = "Doe";
|
||||||
|
String phoneNumber = "0123456789";
|
||||||
|
int loyaltyPoints = 100;
|
||||||
|
|
||||||
|
Customer customer = Customer.builder()
|
||||||
|
.id(id)
|
||||||
|
.firstName(firstName)
|
||||||
|
.lastName(lastName)
|
||||||
|
.phoneNumber(phoneNumber)
|
||||||
|
.loyaltyPoints(loyaltyPoints)
|
||||||
|
.build();
|
||||||
|
|
||||||
|
assertEquals(id, customer.getId());
|
||||||
|
assertEquals(firstName, customer.getFirstName());
|
||||||
|
assertEquals(lastName, customer.getLastName());
|
||||||
|
assertEquals(phoneNumber, customer.getPhoneNumber());
|
||||||
|
assertEquals(loyaltyPoints, customer.getLoyaltyPoints());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
@DisplayName("setRandomUUID should change the ID to a new random UUID")
|
||||||
|
void testSetRandomUUID() {
|
||||||
|
Customer customer = Customer.builder().build();
|
||||||
|
UUID originalId = customer.getId();
|
||||||
|
|
||||||
|
customer.setRandomUUID();
|
||||||
|
|
||||||
|
assertNotNull(customer.getId());
|
||||||
|
assertNotEquals(originalId, customer.getId());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Nested
|
||||||
|
@DisplayName("Loyalty Points Tests")
|
||||||
|
class LoyaltyPointsTests {
|
||||||
|
|
||||||
|
@Test
|
||||||
|
@DisplayName("addLoyaltyPoints should correctly increment loyalty points")
|
||||||
|
void testAddLoyaltyPoints() {
|
||||||
|
Customer customer = Customer.builder()
|
||||||
|
.loyaltyPoints(50)
|
||||||
|
.build();
|
||||||
|
int pointsToAdd = 25;
|
||||||
|
int expectedPoints = 75;
|
||||||
|
|
||||||
|
customer.addLoyaltyPoints(pointsToAdd);
|
||||||
|
|
||||||
|
assertEquals(expectedPoints, customer.getLoyaltyPoints());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
@DisplayName("addLoyaltyPoints should handle zero points correctly")
|
||||||
|
void testAddZeroLoyaltyPoints() {
|
||||||
|
Customer customer = Customer.builder()
|
||||||
|
.loyaltyPoints(50)
|
||||||
|
.build();
|
||||||
|
|
||||||
|
customer.addLoyaltyPoints(0);
|
||||||
|
|
||||||
|
assertEquals(50, customer.getLoyaltyPoints());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
@DisplayName("removeLoyaltyPoints should correctly decrement loyalty points")
|
||||||
|
void testRemoveLoyaltyPoints() throws IllegalCustomerPointException {
|
||||||
|
Customer customer = Customer.builder()
|
||||||
|
.loyaltyPoints(50)
|
||||||
|
.build();
|
||||||
|
int pointsToRemove = 20;
|
||||||
|
int expectedPoints = 30;
|
||||||
|
|
||||||
|
customer.removeLoyaltyPoints(pointsToRemove);
|
||||||
|
|
||||||
|
assertEquals(expectedPoints, customer.getLoyaltyPoints());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
@DisplayName("removeLoyaltyPoints should handle removing exactly all points")
|
||||||
|
void testRemoveAllLoyaltyPoints() throws IllegalCustomerPointException {
|
||||||
|
Customer customer = Customer.builder()
|
||||||
|
.loyaltyPoints(50)
|
||||||
|
.build();
|
||||||
|
|
||||||
|
customer.removeLoyaltyPoints(50);
|
||||||
|
|
||||||
|
assertEquals(0, customer.getLoyaltyPoints());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
@DisplayName("removeLoyaltyPoints should throw exception when trying to remove more points than available")
|
||||||
|
void testRemoveTooManyLoyaltyPoints() {
|
||||||
|
Customer customer = Customer.builder()
|
||||||
|
.loyaltyPoints(50)
|
||||||
|
.build();
|
||||||
|
int pointsToRemove = 75;
|
||||||
|
|
||||||
|
IllegalCustomerPointException exception = assertThrows(
|
||||||
|
IllegalCustomerPointException.class,
|
||||||
|
() -> customer.removeLoyaltyPoints(pointsToRemove)
|
||||||
|
);
|
||||||
|
|
||||||
|
assertEquals(50, customer.getLoyaltyPoints());
|
||||||
|
|
||||||
|
assertTrue(exception.getMessage().contains(String.valueOf(pointsToRemove)));
|
||||||
|
assertTrue(exception.getMessage().contains(String.valueOf(customer.getLoyaltyPoints())));
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
@DisplayName("removeLoyaltyPoints should handle removing zero points correctly")
|
||||||
|
void testRemoveZeroLoyaltyPoints() throws IllegalCustomerPointException {
|
||||||
|
Customer customer = Customer.builder()
|
||||||
|
.loyaltyPoints(50)
|
||||||
|
.build();
|
||||||
|
|
||||||
|
customer.removeLoyaltyPoints(0);
|
||||||
|
|
||||||
|
assertEquals(50, customer.getLoyaltyPoints());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
49
src/test/java/fr/iut_fbleau/but3/dev62/mylibrary/customer/exception/CustomerNotFoundExceptionTest.java
Normal file
49
src/test/java/fr/iut_fbleau/but3/dev62/mylibrary/customer/exception/CustomerNotFoundExceptionTest.java
Normal file
@ -0,0 +1,49 @@
|
|||||||
|
package fr.iut_fbleau.but3.dev62.mylibrary.customer.exception;
|
||||||
|
|
||||||
|
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;
|
||||||
|
|
||||||
|
class CustomerNotFoundExceptionTest {
|
||||||
|
|
||||||
|
@Test
|
||||||
|
@DisplayName("Exception message should contain the UUID provided")
|
||||||
|
void testExceptionMessageContainsUUID() {
|
||||||
|
UUID uuid = UUID.randomUUID();
|
||||||
|
|
||||||
|
CustomerNotFoundException exception = new CustomerNotFoundException(uuid);
|
||||||
|
|
||||||
|
String expectedMessage = String.format("The customer 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();
|
||||||
|
|
||||||
|
CustomerNotFoundException exception = new CustomerNotFoundException(uuid);
|
||||||
|
|
||||||
|
String expectedFormatWithPlaceholder = "The customer with id {0} does not exist";
|
||||||
|
assertEquals(CustomerNotFoundException.THE_CUSTOMER_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 CustomerNotFoundException(uuid);
|
||||||
|
} catch (CustomerNotFoundException e) {
|
||||||
|
String expectedMessage = String.format("The customer with id %s does not exist", uuid);
|
||||||
|
assertEquals(expectedMessage, e.getMessage());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
69
src/test/java/fr/iut_fbleau/but3/dev62/mylibrary/customer/exception/IllegalCustomerPointExceptionTest.java
Normal file
69
src/test/java/fr/iut_fbleau/but3/dev62/mylibrary/customer/exception/IllegalCustomerPointExceptionTest.java
Normal file
@ -0,0 +1,69 @@
|
|||||||
|
package fr.iut_fbleau.but3.dev62.mylibrary.customer.exception;
|
||||||
|
|
||||||
|
import java.text.MessageFormat;
|
||||||
|
import org.junit.jupiter.api.DisplayName;
|
||||||
|
import org.junit.jupiter.api.Test;
|
||||||
|
import org.junit.jupiter.params.ParameterizedTest;
|
||||||
|
import org.junit.jupiter.params.provider.CsvSource;
|
||||||
|
|
||||||
|
import static org.junit.jupiter.api.Assertions.assertEquals;
|
||||||
|
import static org.junit.jupiter.api.Assertions.assertTrue;
|
||||||
|
|
||||||
|
class IllegalCustomerPointExceptionTest {
|
||||||
|
|
||||||
|
@Test
|
||||||
|
@DisplayName("Exception message should contain the needed and actual points")
|
||||||
|
void testExceptionMessageContainsPoints() {
|
||||||
|
int neededPoints = 100;
|
||||||
|
int actualPoints = 50;
|
||||||
|
|
||||||
|
IllegalCustomerPointException exception = new IllegalCustomerPointException(neededPoints, actualPoints);
|
||||||
|
|
||||||
|
String expectedMessage = "Cannot remove 100 points from 50 points";
|
||||||
|
assertEquals(expectedMessage, exception.getMessage());
|
||||||
|
}
|
||||||
|
|
||||||
|
@ParameterizedTest
|
||||||
|
@CsvSource({
|
||||||
|
"100, 50",
|
||||||
|
"75, 25",
|
||||||
|
"200, 150",
|
||||||
|
"1000, 750"
|
||||||
|
})
|
||||||
|
@DisplayName("Exception message should be formatted correctly for different point values")
|
||||||
|
void testExceptionMessageForDifferentPointValues(int neededPoints, int actualPoints) {
|
||||||
|
IllegalCustomerPointException exception = new IllegalCustomerPointException(neededPoints, actualPoints);
|
||||||
|
|
||||||
|
String expectedMessage = MessageFormat.format(IllegalCustomerPointException.CANNOT_REMOVE_LOYALTY_POINTS, neededPoints, actualPoints);
|
||||||
|
assertEquals(expectedMessage, exception.getMessage());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
@DisplayName("Exception should use the correct constant message format")
|
||||||
|
void testExceptionUsesConstantMessageFormat() {
|
||||||
|
int neededPoints = 100;
|
||||||
|
int actualPoints = 50;
|
||||||
|
|
||||||
|
IllegalCustomerPointException exception = new IllegalCustomerPointException(neededPoints, actualPoints);
|
||||||
|
|
||||||
|
String expectedFormatWithPlaceholder = "Cannot remove {0} points from {1} points";
|
||||||
|
assertEquals(IllegalCustomerPointException.CANNOT_REMOVE_LOYALTY_POINTS,
|
||||||
|
expectedFormatWithPlaceholder);
|
||||||
|
assertTrue(exception.getMessage().contains(String.valueOf(neededPoints)));
|
||||||
|
assertTrue(exception.getMessage().contains(String.valueOf(actualPoints)));
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
@DisplayName("Exception should be properly thrown and caught")
|
||||||
|
void testExceptionCanBeThrownAndCaught() {
|
||||||
|
int neededPoints = 100;
|
||||||
|
int actualPoints = 50;
|
||||||
|
|
||||||
|
try {
|
||||||
|
throw new IllegalCustomerPointException(neededPoints, actualPoints);
|
||||||
|
} catch (IllegalCustomerPointException e) {
|
||||||
|
String expectedMessage = String.format("Cannot remove %d points from %d points", neededPoints, actualPoints);
|
||||||
|
assertEquals(expectedMessage, e.getMessage());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
61
src/test/java/fr/iut_fbleau/but3/dev62/mylibrary/customer/exception/NotValidCustomerExceptionTest.java
Normal file
61
src/test/java/fr/iut_fbleau/but3/dev62/mylibrary/customer/exception/NotValidCustomerExceptionTest.java
Normal file
@ -0,0 +1,61 @@
|
|||||||
|
package fr.iut_fbleau.but3.dev62.mylibrary.customer.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;
|
||||||
|
|
||||||
|
class NotValidCustomerExceptionTest {
|
||||||
|
|
||||||
|
@Test
|
||||||
|
@DisplayName("Exception should be created with the provided message")
|
||||||
|
void testExceptionCreation() {
|
||||||
|
String errorMessage = "Customer data is not valid";
|
||||||
|
|
||||||
|
NotValidCustomerException exception = new NotValidCustomerException(errorMessage);
|
||||||
|
|
||||||
|
assertEquals(errorMessage, exception.getMessage());
|
||||||
|
}
|
||||||
|
|
||||||
|
@ParameterizedTest
|
||||||
|
@ValueSource(strings = {
|
||||||
|
"First name is required",
|
||||||
|
"Last name cannot be empty",
|
||||||
|
"Phone number format is invalid",
|
||||||
|
"Customer age must be above 18"
|
||||||
|
})
|
||||||
|
@DisplayName("Exception should handle different validation messages")
|
||||||
|
void testExceptionWithDifferentMessages(String errorMessage) {
|
||||||
|
NotValidCustomerException exception = new NotValidCustomerException(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(NotValidCustomerException.class, () -> {
|
||||||
|
throw new NotValidCustomerException(errorMessage);
|
||||||
|
});
|
||||||
|
|
||||||
|
assertEquals(errorMessage, exception.getMessage());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
@DisplayName("Exception should be catchable as a general Exception")
|
||||||
|
void testExceptionInheritance() {
|
||||||
|
String errorMessage = "Invalid customer data";
|
||||||
|
|
||||||
|
try {
|
||||||
|
throw new NotValidCustomerException(errorMessage);
|
||||||
|
} catch (Exception e) {
|
||||||
|
assertEquals(NotValidCustomerException.class, e.getClass());
|
||||||
|
assertEquals(errorMessage, e.getMessage());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
227
src/test/java/fr/iut_fbleau/but3/dev62/mylibrary/customer/repository/CustomerRepositoryTest.java
Normal file
227
src/test/java/fr/iut_fbleau/but3/dev62/mylibrary/customer/repository/CustomerRepositoryTest.java
Normal file
@ -0,0 +1,227 @@
|
|||||||
|
package fr.iut_fbleau.but3.dev62.mylibrary.customer.repository;
|
||||||
|
|
||||||
|
import fr.iut_fbleau.but3.dev62.mylibrary.customer.entity.Customer;
|
||||||
|
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.List;
|
||||||
|
import java.util.Optional;
|
||||||
|
import java.util.UUID;
|
||||||
|
|
||||||
|
import static org.junit.jupiter.api.Assertions.*;
|
||||||
|
|
||||||
|
class CustomerRepositoryTest {
|
||||||
|
|
||||||
|
private CustomerRepository repository;
|
||||||
|
private Customer customer1;
|
||||||
|
private Customer customer2;
|
||||||
|
|
||||||
|
@BeforeEach
|
||||||
|
void setUp() {
|
||||||
|
repository = new CustomerRepository();
|
||||||
|
|
||||||
|
customer1 = Customer.builder()
|
||||||
|
.firstName("John")
|
||||||
|
.lastName("Doe")
|
||||||
|
.phoneNumber("0123456789")
|
||||||
|
.loyaltyPoints(100)
|
||||||
|
.build();
|
||||||
|
customer1.setRandomUUID();
|
||||||
|
|
||||||
|
customer2 = Customer.builder()
|
||||||
|
.firstName("Jane")
|
||||||
|
.lastName("Smith")
|
||||||
|
.phoneNumber("9876543210")
|
||||||
|
.loyaltyPoints(200)
|
||||||
|
.build();
|
||||||
|
customer2.setRandomUUID();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
@DisplayName("New repository should be empty")
|
||||||
|
void testNewRepositoryIsEmpty() {
|
||||||
|
List<Customer> customers = repository.findAll();
|
||||||
|
|
||||||
|
assertTrue(customers.isEmpty());
|
||||||
|
assertEquals(0, customers.size());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Nested
|
||||||
|
@DisplayName("Save operations")
|
||||||
|
class SaveOperations {
|
||||||
|
|
||||||
|
@Test
|
||||||
|
@DisplayName("Save should add a new customer")
|
||||||
|
void testSaveNewCustomer() {
|
||||||
|
Customer savedCustomer = repository.save(customer1);
|
||||||
|
|
||||||
|
assertEquals(1, repository.findAll().size());
|
||||||
|
assertEquals(customer1.getId(), savedCustomer.getId());
|
||||||
|
assertEquals(customer1.getFirstName(), savedCustomer.getFirstName());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
@DisplayName("Save should update existing customer with same ID")
|
||||||
|
void testSaveUpdatesExistingCustomer() {
|
||||||
|
repository.save(customer1);
|
||||||
|
|
||||||
|
UUID id = customer1.getId();
|
||||||
|
Customer updatedCustomer = Customer.builder()
|
||||||
|
.id(id)
|
||||||
|
.firstName("John")
|
||||||
|
.lastName("Updated")
|
||||||
|
.phoneNumber("1111111111")
|
||||||
|
.loyaltyPoints(150)
|
||||||
|
.build();
|
||||||
|
|
||||||
|
Customer savedCustomer = repository.save(updatedCustomer);
|
||||||
|
|
||||||
|
assertEquals(1, repository.findAll().size());
|
||||||
|
assertEquals(id, savedCustomer.getId());
|
||||||
|
assertEquals("Updated", savedCustomer.getLastName());
|
||||||
|
assertEquals("1111111111", savedCustomer.getPhoneNumber());
|
||||||
|
assertEquals(150, savedCustomer.getLoyaltyPoints());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
@DisplayName("Save multiple customers should add all of them")
|
||||||
|
void testSaveMultipleCustomers() {
|
||||||
|
repository.save(customer1);
|
||||||
|
repository.save(customer2);
|
||||||
|
|
||||||
|
List<Customer> customers = repository.findAll();
|
||||||
|
|
||||||
|
assertEquals(2, customers.size());
|
||||||
|
assertTrue(customers.contains(customer1));
|
||||||
|
assertTrue(customers.contains(customer2));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Nested
|
||||||
|
@DisplayName("Find operations")
|
||||||
|
class FindOperations {
|
||||||
|
|
||||||
|
@BeforeEach
|
||||||
|
void setUpCustomers() {
|
||||||
|
repository.save(customer1);
|
||||||
|
repository.save(customer2);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
@DisplayName("FindAll should return all customers")
|
||||||
|
void testFindAll() {
|
||||||
|
List<Customer> customers = repository.findAll();
|
||||||
|
|
||||||
|
assertEquals(2, customers.size());
|
||||||
|
assertTrue(customers.contains(customer1));
|
||||||
|
assertTrue(customers.contains(customer2));
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
@DisplayName("FindById should return customer with matching ID")
|
||||||
|
void testFindById() {
|
||||||
|
Optional<Customer> foundCustomer = repository.findById(customer1.getId());
|
||||||
|
|
||||||
|
assertTrue(foundCustomer.isPresent());
|
||||||
|
assertEquals(customer1.getFirstName(), foundCustomer.get().getFirstName());
|
||||||
|
assertEquals(customer1.getLastName(), foundCustomer.get().getLastName());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
@DisplayName("FindById should return empty Optional when ID doesn't exist")
|
||||||
|
void testFindByIdNotFound() {
|
||||||
|
UUID nonExistentId = UUID.randomUUID();
|
||||||
|
|
||||||
|
Optional<Customer> foundCustomer = repository.findById(nonExistentId);
|
||||||
|
|
||||||
|
assertTrue(foundCustomer.isEmpty());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
@DisplayName("FindByPhoneNumber should return customer with matching phone number")
|
||||||
|
void testFindByPhoneNumber() {
|
||||||
|
Optional<Customer> foundCustomer = repository.findByPhoneNumber("0123456789");
|
||||||
|
|
||||||
|
assertTrue(foundCustomer.isPresent());
|
||||||
|
assertEquals(customer1.getId(), foundCustomer.get().getId());
|
||||||
|
assertEquals(customer1.getFirstName(), foundCustomer.get().getFirstName());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
@DisplayName("FindByPhoneNumber should return empty Optional when phone number doesn't exist")
|
||||||
|
void testFindByPhoneNumberNotFound() {
|
||||||
|
Optional<Customer> foundCustomer = repository.findByPhoneNumber("0000000000");
|
||||||
|
|
||||||
|
assertTrue(foundCustomer.isEmpty());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
@DisplayName("ExistsById should return true when ID exists")
|
||||||
|
void testExistsByIdExists() {
|
||||||
|
boolean exists = repository.existsById(customer1.getId());
|
||||||
|
|
||||||
|
assertTrue(exists);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
@DisplayName("ExistsById should return false when ID doesn't exist")
|
||||||
|
void testExistsByIdNotExists() {
|
||||||
|
UUID nonExistentId = UUID.randomUUID();
|
||||||
|
|
||||||
|
boolean exists = repository.existsById(nonExistentId);
|
||||||
|
|
||||||
|
assertFalse(exists);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Nested
|
||||||
|
@DisplayName("Delete operations")
|
||||||
|
class DeleteOperations {
|
||||||
|
|
||||||
|
@BeforeEach
|
||||||
|
void setUpCustomers() {
|
||||||
|
repository.save(customer1);
|
||||||
|
repository.save(customer2);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
@DisplayName("Delete should remove the specified customer")
|
||||||
|
void testDelete() {
|
||||||
|
repository.delete(customer1);
|
||||||
|
|
||||||
|
List<Customer> customers = repository.findAll();
|
||||||
|
|
||||||
|
assertEquals(1, customers.size());
|
||||||
|
assertFalse(customers.contains(customer1));
|
||||||
|
assertTrue(customers.contains(customer2));
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
@DisplayName("DeleteAll should remove all customers")
|
||||||
|
void testDeleteAll() {
|
||||||
|
repository.deleteAll();
|
||||||
|
|
||||||
|
List<Customer> customers = repository.findAll();
|
||||||
|
|
||||||
|
assertTrue(customers.isEmpty());
|
||||||
|
assertEquals(0, customers.size());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
@DisplayName("Delete should not throw exception when customer doesn't exist")
|
||||||
|
void testDeleteNonExistentCustomer() {
|
||||||
|
Customer nonExistentCustomer = Customer.builder()
|
||||||
|
.firstName("Non")
|
||||||
|
.lastName("Existent")
|
||||||
|
.phoneNumber("0000000000")
|
||||||
|
.build();
|
||||||
|
nonExistentCustomer.setRandomUUID();
|
||||||
|
|
||||||
|
assertDoesNotThrow(() -> repository.delete(nonExistentCustomer));
|
||||||
|
|
||||||
|
assertEquals(2, repository.findAll().size());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
279
src/test/java/fr/iut_fbleau/but3/dev62/mylibrary/customer/usecase/CustomerUseCaseTest.java
Normal file
279
src/test/java/fr/iut_fbleau/but3/dev62/mylibrary/customer/usecase/CustomerUseCaseTest.java
Normal file
@ -0,0 +1,279 @@
|
|||||||
|
package fr.iut_fbleau.but3.dev62.mylibrary.customer.usecase;
|
||||||
|
|
||||||
|
import fr.iut_fbleau.but3.dev62.mylibrary.customer.CustomerDTO;
|
||||||
|
import fr.iut_fbleau.but3.dev62.mylibrary.customer.CustomerInfo;
|
||||||
|
import fr.iut_fbleau.but3.dev62.mylibrary.customer.entity.Customer;
|
||||||
|
import fr.iut_fbleau.but3.dev62.mylibrary.customer.exception.CustomerNotFoundException;
|
||||||
|
import fr.iut_fbleau.but3.dev62.mylibrary.customer.exception.IllegalCustomerPointException;
|
||||||
|
import fr.iut_fbleau.but3.dev62.mylibrary.customer.exception.NotValidCustomerException;
|
||||||
|
import fr.iut_fbleau.but3.dev62.mylibrary.customer.repository.CustomerRepository;
|
||||||
|
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.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)
|
||||||
|
class CustomerUseCaseTest {
|
||||||
|
|
||||||
|
@Mock
|
||||||
|
private CustomerRepository customerRepository;
|
||||||
|
|
||||||
|
@InjectMocks
|
||||||
|
private CustomerUseCase customerUseCase;
|
||||||
|
|
||||||
|
private UUID customerId;
|
||||||
|
private Customer testCustomer;
|
||||||
|
private CustomerInfo validCustomerInfo;
|
||||||
|
|
||||||
|
@BeforeEach
|
||||||
|
void setUp() {
|
||||||
|
customerId = UUID.randomUUID();
|
||||||
|
testCustomer = Customer.builder()
|
||||||
|
.id(customerId)
|
||||||
|
.firstName("John")
|
||||||
|
.lastName("Doe")
|
||||||
|
.phoneNumber("0612345678")
|
||||||
|
.loyaltyPoints(100)
|
||||||
|
.build();
|
||||||
|
|
||||||
|
validCustomerInfo = new CustomerInfo("John", "Doe", "0612345678");
|
||||||
|
}
|
||||||
|
|
||||||
|
@Nested
|
||||||
|
@DisplayName("Register customer tests")
|
||||||
|
class RegisterCustomerTests {
|
||||||
|
|
||||||
|
@Test
|
||||||
|
@DisplayName("Should register customer when valid data is provided")
|
||||||
|
void testRegisterCustomerWithValidData() throws NotValidCustomerException {
|
||||||
|
when(customerRepository.save(any(Customer.class))).thenReturn(testCustomer);
|
||||||
|
|
||||||
|
UUID registeredId = customerUseCase.registerCustomer(validCustomerInfo);
|
||||||
|
|
||||||
|
assertNotNull(registeredId);
|
||||||
|
assertEquals(customerId, registeredId);
|
||||||
|
verify(customerRepository, times(1)).save(any(Customer.class));
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
@DisplayName("Should throw exception when customer data is not valid")
|
||||||
|
void testRegisterCustomerWithInvalidData() {
|
||||||
|
CustomerInfo invalidCustomerInfo = new CustomerInfo("", "", "");
|
||||||
|
|
||||||
|
assertThrows(NotValidCustomerException.class,
|
||||||
|
() -> customerUseCase.registerCustomer(invalidCustomerInfo));
|
||||||
|
|
||||||
|
verify(customerRepository, never()).save(any(Customer.class));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Nested
|
||||||
|
@DisplayName("Find customer tests")
|
||||||
|
class FindCustomerTests {
|
||||||
|
|
||||||
|
@Test
|
||||||
|
@DisplayName("Should return customer when phone number exists")
|
||||||
|
void testFindCustomerByPhoneNumber() {
|
||||||
|
when(customerRepository.findByPhoneNumber("0612345678")).thenReturn(Optional.of(testCustomer));
|
||||||
|
|
||||||
|
Optional<CustomerDTO> foundCustomer = customerUseCase.findCustomerByPhoneNumber("0612345678");
|
||||||
|
|
||||||
|
assertTrue(foundCustomer.isPresent());
|
||||||
|
assertEquals(testCustomer.getId(), foundCustomer.get().getId());
|
||||||
|
assertEquals(testCustomer.getFirstName(), foundCustomer.get().getFirstName());
|
||||||
|
verify(customerRepository, times(1)).findByPhoneNumber("0612345678");
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
@DisplayName("Should return empty Optional when phone number doesn't exist")
|
||||||
|
void testFindCustomerByPhoneNumberNotFound() {
|
||||||
|
when(customerRepository.findByPhoneNumber("0799999999")).thenReturn(Optional.empty());
|
||||||
|
|
||||||
|
Optional<CustomerDTO> foundCustomer = customerUseCase.findCustomerByPhoneNumber("0799999999");
|
||||||
|
|
||||||
|
assertTrue(foundCustomer.isEmpty());
|
||||||
|
verify(customerRepository, times(1)).findByPhoneNumber("0799999999");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Nested
|
||||||
|
@DisplayName("Update customer tests")
|
||||||
|
class UpdateCustomerTests {
|
||||||
|
|
||||||
|
@Test
|
||||||
|
@DisplayName("Should update customer when valid data is provided")
|
||||||
|
void testUpdateCustomerWithValidData() throws CustomerNotFoundException, NotValidCustomerException {
|
||||||
|
when(customerRepository.findById(customerId)).thenReturn(Optional.of(testCustomer));
|
||||||
|
|
||||||
|
Customer updatedCustomer = Customer.builder()
|
||||||
|
.id(customerId)
|
||||||
|
.firstName("John")
|
||||||
|
.lastName("Updated")
|
||||||
|
.phoneNumber("0712345678")
|
||||||
|
.loyaltyPoints(100)
|
||||||
|
.build();
|
||||||
|
|
||||||
|
when(customerRepository.save(any(Customer.class))).thenReturn(updatedCustomer);
|
||||||
|
|
||||||
|
CustomerInfo updateInfo = new CustomerInfo("John", "Updated", "0712345678");
|
||||||
|
|
||||||
|
CustomerDTO result = customerUseCase.updateCustomer(customerId, updateInfo);
|
||||||
|
|
||||||
|
assertNotNull(result);
|
||||||
|
assertEquals(customerId, result.getId());
|
||||||
|
assertEquals("Updated", result.getLastName());
|
||||||
|
assertEquals("0712345678", result.getPhoneNumber());
|
||||||
|
verify(customerRepository, times(1)).findById(customerId);
|
||||||
|
verify(customerRepository, times(1)).save(any(Customer.class));
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
@DisplayName("Should throw exception when customer ID doesn't exist")
|
||||||
|
void testUpdateCustomerNotFound() {
|
||||||
|
UUID nonExistentId = UUID.randomUUID();
|
||||||
|
when(customerRepository.findById(nonExistentId)).thenReturn(Optional.empty());
|
||||||
|
|
||||||
|
CustomerInfo updateInfo = new CustomerInfo("John", "Updated", "0712345678");
|
||||||
|
|
||||||
|
assertThrows(CustomerNotFoundException.class,
|
||||||
|
() -> customerUseCase.updateCustomer(nonExistentId, updateInfo));
|
||||||
|
|
||||||
|
verify(customerRepository, times(1)).findById(nonExistentId);
|
||||||
|
verify(customerRepository, never()).save(any(Customer.class));
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
@DisplayName("Should throw exception when update data is not valid")
|
||||||
|
void testUpdateCustomerWithInvalidData() {
|
||||||
|
CustomerInfo invalidUpdateInfo = new CustomerInfo("", "", "");
|
||||||
|
|
||||||
|
assertThrows(NotValidCustomerException.class,
|
||||||
|
() -> customerUseCase.updateCustomer(customerId, invalidUpdateInfo));
|
||||||
|
|
||||||
|
verify(customerRepository, never()).findById(any(UUID.class));
|
||||||
|
verify(customerRepository, never()).save(any(Customer.class));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Nested
|
||||||
|
@DisplayName("Delete customer tests")
|
||||||
|
class DeleteCustomerTests {
|
||||||
|
|
||||||
|
@Test
|
||||||
|
@DisplayName("Should delete customer when ID exists")
|
||||||
|
void testDeleteCustomer() throws CustomerNotFoundException {
|
||||||
|
when(customerRepository.findById(customerId)).thenReturn(Optional.of(testCustomer));
|
||||||
|
doNothing().when(customerRepository).delete(testCustomer);
|
||||||
|
|
||||||
|
customerUseCase.deleteCustomer(customerId);
|
||||||
|
|
||||||
|
verify(customerRepository, times(1)).findById(customerId);
|
||||||
|
verify(customerRepository, times(1)).delete(testCustomer);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
@DisplayName("Should throw exception when customer ID doesn't exist")
|
||||||
|
void testDeleteCustomerNotFound() {
|
||||||
|
UUID nonExistentId = UUID.randomUUID();
|
||||||
|
when(customerRepository.findById(nonExistentId)).thenReturn(Optional.empty());
|
||||||
|
|
||||||
|
assertThrows(CustomerNotFoundException.class,
|
||||||
|
() -> customerUseCase.deleteCustomer(nonExistentId));
|
||||||
|
|
||||||
|
verify(customerRepository, times(1)).findById(nonExistentId);
|
||||||
|
verify(customerRepository, never()).delete(any(Customer.class));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Nested
|
||||||
|
@DisplayName("Loyalty points tests")
|
||||||
|
class LoyaltyPointsTests {
|
||||||
|
|
||||||
|
@Test
|
||||||
|
@DisplayName("Should add loyalty points to customer")
|
||||||
|
void testAddLoyaltyPoints() throws CustomerNotFoundException {
|
||||||
|
when(customerRepository.findById(customerId)).thenReturn(Optional.of(testCustomer));
|
||||||
|
when(customerRepository.save(testCustomer)).thenReturn(testCustomer);
|
||||||
|
|
||||||
|
int initialPoints = testCustomer.getLoyaltyPoints();
|
||||||
|
int pointsToAdd = 50;
|
||||||
|
int expectedPoints = initialPoints + pointsToAdd;
|
||||||
|
|
||||||
|
int newPoints = customerUseCase.addLoyaltyPoints(customerId, pointsToAdd);
|
||||||
|
|
||||||
|
assertEquals(expectedPoints, newPoints);
|
||||||
|
assertEquals(expectedPoints, testCustomer.getLoyaltyPoints());
|
||||||
|
verify(customerRepository, times(1)).findById(customerId);
|
||||||
|
verify(customerRepository, times(1)).save(testCustomer);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
@DisplayName("Should throw exception when adding points to non-existent customer")
|
||||||
|
void testAddLoyaltyPointsToNonExistentCustomer() {
|
||||||
|
UUID nonExistentId = UUID.randomUUID();
|
||||||
|
when(customerRepository.findById(nonExistentId)).thenReturn(Optional.empty());
|
||||||
|
|
||||||
|
assertThrows(CustomerNotFoundException.class,
|
||||||
|
() -> customerUseCase.addLoyaltyPoints(nonExistentId, 50));
|
||||||
|
|
||||||
|
verify(customerRepository, times(1)).findById(nonExistentId);
|
||||||
|
verify(customerRepository, never()).save(any(Customer.class));
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
@DisplayName("Should subtract loyalty points from customer")
|
||||||
|
void testSubtractLoyaltyPoints() throws CustomerNotFoundException, IllegalCustomerPointException {
|
||||||
|
when(customerRepository.findById(customerId)).thenReturn(Optional.of(testCustomer));
|
||||||
|
when(customerRepository.save(testCustomer)).thenReturn(testCustomer);
|
||||||
|
|
||||||
|
int initialPoints = testCustomer.getLoyaltyPoints();
|
||||||
|
int pointsToRemove = 30;
|
||||||
|
int expectedPoints = initialPoints - pointsToRemove;
|
||||||
|
|
||||||
|
int newPoints = customerUseCase.subtractLoyaltyPoints(customerId, pointsToRemove);
|
||||||
|
|
||||||
|
assertEquals(expectedPoints, newPoints);
|
||||||
|
assertEquals(expectedPoints, testCustomer.getLoyaltyPoints());
|
||||||
|
verify(customerRepository, times(1)).findById(customerId);
|
||||||
|
verify(customerRepository, times(1)).save(testCustomer);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
@DisplayName("Should throw exception when trying to remove more points than available")
|
||||||
|
void testSubtractTooManyLoyaltyPoints() {
|
||||||
|
when(customerRepository.findById(customerId)).thenReturn(Optional.of(testCustomer));
|
||||||
|
|
||||||
|
int pointsToRemove = 200;
|
||||||
|
|
||||||
|
assertThrows(IllegalCustomerPointException.class,
|
||||||
|
() -> customerUseCase.subtractLoyaltyPoints(customerId, pointsToRemove));
|
||||||
|
|
||||||
|
verify(customerRepository, times(1)).findById(customerId);
|
||||||
|
verify(customerRepository, never()).save(any(Customer.class));
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
@DisplayName("Should throw exception when subtracting points from non-existent customer")
|
||||||
|
void testSubtractLoyaltyPointsFromNonExistentCustomer() {
|
||||||
|
UUID nonExistentId = UUID.randomUUID();
|
||||||
|
when(customerRepository.findById(nonExistentId)).thenReturn(Optional.empty());
|
||||||
|
|
||||||
|
assertThrows(CustomerNotFoundException.class,
|
||||||
|
() -> customerUseCase.subtractLoyaltyPoints(nonExistentId, 50));
|
||||||
|
|
||||||
|
verify(customerRepository, times(1)).findById(nonExistentId);
|
||||||
|
verify(customerRepository, never()).save(any(Customer.class));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
155
src/test/java/fr/iut_fbleau/but3/dev62/mylibrary/customer/validator/CustomerValidatorTest.java
Normal file
155
src/test/java/fr/iut_fbleau/but3/dev62/mylibrary/customer/validator/CustomerValidatorTest.java
Normal file
@ -0,0 +1,155 @@
|
|||||||
|
package fr.iut_fbleau.but3.dev62.mylibrary.customer.validator;
|
||||||
|
|
||||||
|
import fr.iut_fbleau.but3.dev62.mylibrary.customer.CustomerInfo;
|
||||||
|
import fr.iut_fbleau.but3.dev62.mylibrary.customer.exception.NotValidCustomerException;
|
||||||
|
import org.junit.jupiter.api.DisplayName;
|
||||||
|
import org.junit.jupiter.api.Nested;
|
||||||
|
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.*;
|
||||||
|
|
||||||
|
class CustomerValidatorTest {
|
||||||
|
|
||||||
|
@Test
|
||||||
|
@DisplayName("Should validate customer with valid data")
|
||||||
|
void testValidateValidCustomer() {
|
||||||
|
CustomerInfo validCustomer = new CustomerInfo("John", "Doe", "0612345678");
|
||||||
|
|
||||||
|
assertDoesNotThrow(() -> CustomerValidator.validate(validCustomer));
|
||||||
|
}
|
||||||
|
|
||||||
|
@Nested
|
||||||
|
@DisplayName("First name validation tests")
|
||||||
|
class FirstNameValidationTests {
|
||||||
|
|
||||||
|
@Test
|
||||||
|
@DisplayName("Should throw exception when first name is blank")
|
||||||
|
void testValidateBlankFirstName() {
|
||||||
|
CustomerInfo customerWithBlankFirstName = new CustomerInfo("", "Doe", "0612345678");
|
||||||
|
|
||||||
|
NotValidCustomerException exception = assertThrows(
|
||||||
|
NotValidCustomerException.class,
|
||||||
|
() -> CustomerValidator.validate(customerWithBlankFirstName)
|
||||||
|
);
|
||||||
|
|
||||||
|
assertEquals(CustomerValidator.FIRST_NAME_CANNOT_BE_BLANK, exception.getMessage());
|
||||||
|
}
|
||||||
|
|
||||||
|
@ParameterizedTest
|
||||||
|
@ValueSource(strings = {" ", " ", "\t", "\n"})
|
||||||
|
@DisplayName("Should throw exception when first name contains only whitespace")
|
||||||
|
void testValidateWhitespaceFirstName(String whitespace) {
|
||||||
|
CustomerInfo customerWithWhitespaceFirstName = new CustomerInfo(whitespace, "Doe", "0612345678");
|
||||||
|
|
||||||
|
NotValidCustomerException exception = assertThrows(
|
||||||
|
NotValidCustomerException.class,
|
||||||
|
() -> CustomerValidator.validate(customerWithWhitespaceFirstName)
|
||||||
|
);
|
||||||
|
|
||||||
|
assertEquals(CustomerValidator.FIRST_NAME_CANNOT_BE_BLANK, exception.getMessage());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Nested
|
||||||
|
@DisplayName("Last name validation tests")
|
||||||
|
class LastNameValidationTests {
|
||||||
|
|
||||||
|
@Test
|
||||||
|
@DisplayName("Should throw exception when last name is blank")
|
||||||
|
void testValidateBlankLastName() {
|
||||||
|
CustomerInfo customerWithBlankLastName = new CustomerInfo("John", "", "0612345678");
|
||||||
|
|
||||||
|
NotValidCustomerException exception = assertThrows(
|
||||||
|
NotValidCustomerException.class,
|
||||||
|
() -> CustomerValidator.validate(customerWithBlankLastName)
|
||||||
|
);
|
||||||
|
|
||||||
|
assertEquals(CustomerValidator.LAST_NAME_CANNOT_BE_BLANK, exception.getMessage());
|
||||||
|
}
|
||||||
|
|
||||||
|
@ParameterizedTest
|
||||||
|
@ValueSource(strings = {" ", " ", "\t", "\n"})
|
||||||
|
@DisplayName("Should throw exception when last name contains only whitespace")
|
||||||
|
void testValidateWhitespaceLastName(String whitespace) {
|
||||||
|
CustomerInfo customerWithWhitespaceLastName = new CustomerInfo("John", whitespace, "0612345678");
|
||||||
|
|
||||||
|
NotValidCustomerException exception = assertThrows(
|
||||||
|
NotValidCustomerException.class,
|
||||||
|
() -> CustomerValidator.validate(customerWithWhitespaceLastName)
|
||||||
|
);
|
||||||
|
|
||||||
|
assertEquals(CustomerValidator.LAST_NAME_CANNOT_BE_BLANK, exception.getMessage());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Nested
|
||||||
|
@DisplayName("Phone number validation tests")
|
||||||
|
class PhoneNumberValidationTests {
|
||||||
|
|
||||||
|
@Test
|
||||||
|
@DisplayName("Should throw exception when phone number is blank")
|
||||||
|
void testValidateBlankPhoneNumber() {
|
||||||
|
CustomerInfo customerWithBlankPhoneNumber = new CustomerInfo("John", "Doe", "");
|
||||||
|
|
||||||
|
NotValidCustomerException exception = assertThrows(
|
||||||
|
NotValidCustomerException.class,
|
||||||
|
() -> CustomerValidator.validate(customerWithBlankPhoneNumber)
|
||||||
|
);
|
||||||
|
|
||||||
|
assertEquals("Phone number cannot be blank", exception.getMessage());
|
||||||
|
}
|
||||||
|
|
||||||
|
@ParameterizedTest
|
||||||
|
@ValueSource(strings = {" ", " ", "\t", "\n"})
|
||||||
|
@DisplayName("Should throw exception when phone number contains only whitespace")
|
||||||
|
void testValidateWhitespacePhoneNumber(String whitespace) {
|
||||||
|
CustomerInfo customerWithWhitespacePhoneNumber = new CustomerInfo("John", "Doe", whitespace);
|
||||||
|
|
||||||
|
NotValidCustomerException exception = assertThrows(
|
||||||
|
NotValidCustomerException.class,
|
||||||
|
() -> CustomerValidator.validate(customerWithWhitespacePhoneNumber)
|
||||||
|
);
|
||||||
|
|
||||||
|
assertEquals("Phone number cannot be blank", exception.getMessage());
|
||||||
|
}
|
||||||
|
|
||||||
|
@ParameterizedTest
|
||||||
|
@ValueSource(strings = {
|
||||||
|
"0512345678", // Invalid prefix (not 06 or 07)
|
||||||
|
"0812345678", // Invalid prefix (not 06 or 07)
|
||||||
|
"061234567", // Too short (missing one digit)
|
||||||
|
"06123456789", // Too long (one extra digit)
|
||||||
|
"6123456789", // Missing leading 0
|
||||||
|
"O612345678", // Letter O instead of zero
|
||||||
|
"+33612345678", // International format not supported
|
||||||
|
"06 12 34 56 78" // Contains spaces
|
||||||
|
})
|
||||||
|
@DisplayName("Should throw exception when phone number format is invalid")
|
||||||
|
void testValidateInvalidPhoneNumberFormat(String invalidPhoneNumber) {
|
||||||
|
CustomerInfo customerWithInvalidPhoneNumber = new CustomerInfo("John", "Doe", invalidPhoneNumber);
|
||||||
|
|
||||||
|
NotValidCustomerException exception = assertThrows(
|
||||||
|
NotValidCustomerException.class,
|
||||||
|
() -> CustomerValidator.validate(customerWithInvalidPhoneNumber)
|
||||||
|
);
|
||||||
|
|
||||||
|
assertEquals(CustomerValidator.PHONE_NUMBER_IS_NOT_VALID, exception.getMessage());
|
||||||
|
}
|
||||||
|
|
||||||
|
@ParameterizedTest
|
||||||
|
@ValueSource(strings = {
|
||||||
|
"0612345678", // Valid 06 number
|
||||||
|
"0712345678", // Valid 07 number
|
||||||
|
"0699999999", // Valid 06 number with all 9s
|
||||||
|
"0700000000" // Valid 07 number with all 0s
|
||||||
|
})
|
||||||
|
@DisplayName("Should validate when phone number format is valid")
|
||||||
|
void testValidateValidPhoneNumberFormat(String validPhoneNumber) {
|
||||||
|
CustomerInfo customerWithValidPhoneNumber = new CustomerInfo("John", "Doe", validPhoneNumber);
|
||||||
|
|
||||||
|
assertDoesNotThrow(() -> CustomerValidator.validate(customerWithValidPhoneNumber));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,14 @@
|
|||||||
|
package fr.iut_fbleau.but3.dev62.mylibrary.features;
|
||||||
|
|
||||||
|
import org.junit.platform.suite.api.*;
|
||||||
|
|
||||||
|
import static io.cucumber.junit.platform.engine.Constants.GLUE_PROPERTY_NAME;
|
||||||
|
import static io.cucumber.junit.platform.engine.Constants.PLUGIN_PROPERTY_NAME;
|
||||||
|
|
||||||
|
@Suite
|
||||||
|
@IncludeEngines("cucumber")
|
||||||
|
@SelectClasspathResource("features")
|
||||||
|
@ConfigurationParameter(key = PLUGIN_PROPERTY_NAME, value = "pretty")
|
||||||
|
@ConfigurationParameter(key = GLUE_PROPERTY_NAME, value = "fr.iut_fbleau.but3.dev62.mylibrary.features")
|
||||||
|
public class RunCucumberTest {
|
||||||
|
}
|
@ -0,0 +1,223 @@
|
|||||||
|
package fr.iut_fbleau.but3.dev62.mylibrary.features.client;
|
||||||
|
|
||||||
|
import static org.junit.jupiter.api.Assertions.assertEquals;
|
||||||
|
import static org.junit.jupiter.api.Assertions.assertFalse;
|
||||||
|
import static org.junit.jupiter.api.Assertions.assertNotNull;
|
||||||
|
import static org.junit.jupiter.api.Assertions.assertThrows;
|
||||||
|
import static org.junit.jupiter.api.Assertions.assertTrue;
|
||||||
|
|
||||||
|
import fr.iut_fbleau.but3.dev62.mylibrary.customer.CustomerDTO;
|
||||||
|
import fr.iut_fbleau.but3.dev62.mylibrary.customer.CustomerInfo;
|
||||||
|
import fr.iut_fbleau.but3.dev62.mylibrary.customer.entity.Customer;
|
||||||
|
import fr.iut_fbleau.but3.dev62.mylibrary.customer.exception.CustomerNotFoundException;
|
||||||
|
import fr.iut_fbleau.but3.dev62.mylibrary.customer.exception.IllegalCustomerPointException;
|
||||||
|
import fr.iut_fbleau.but3.dev62.mylibrary.customer.exception.NotValidCustomerException;
|
||||||
|
import fr.iut_fbleau.but3.dev62.mylibrary.customer.repository.CustomerRepository;
|
||||||
|
import fr.iut_fbleau.but3.dev62.mylibrary.customer.usecase.CustomerUseCase;
|
||||||
|
import io.cucumber.datatable.DataTable;
|
||||||
|
import io.cucumber.java.en.And;
|
||||||
|
import io.cucumber.java.en.Given;
|
||||||
|
import io.cucumber.java.en.Then;
|
||||||
|
import io.cucumber.java.en.When;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Map;
|
||||||
|
import java.util.Optional;
|
||||||
|
import java.util.UUID;
|
||||||
|
|
||||||
|
public class CustomerSteps {
|
||||||
|
|
||||||
|
private final CustomerRepository customerRepository = new CustomerRepository();
|
||||||
|
private final CustomerUseCase customerUseCase = new CustomerUseCase(customerRepository);
|
||||||
|
|
||||||
|
private final Map<String, UUID> customerPhoneUUID = new HashMap<>();
|
||||||
|
private UUID customerRegistration;
|
||||||
|
private Optional<CustomerDTO> customerByPhoneNumber;
|
||||||
|
private Customer updatedCustomer;
|
||||||
|
private IllegalCustomerPointException illegalCustomerPointException;
|
||||||
|
private NotValidCustomerException notValidCustomerException;
|
||||||
|
|
||||||
|
@Given("the system has the following customers:")
|
||||||
|
public void theSystemHasTheFollowingCustomers(DataTable dataTable) {
|
||||||
|
int size = customerRepository.findAll().size();
|
||||||
|
|
||||||
|
if (size > 0) {
|
||||||
|
customerRepository.deleteAll();
|
||||||
|
}
|
||||||
|
|
||||||
|
List<Map<String, String>> customers = dataTable.asMaps(String.class, String.class);
|
||||||
|
|
||||||
|
for (Map<String, String> customer : customers) {
|
||||||
|
String numeroTelephone = customer.get("numeroTelephone");
|
||||||
|
Customer newCustomer = Customer.builder()
|
||||||
|
.firstName(customer.get("prenom"))
|
||||||
|
.lastName(customer.get("nom"))
|
||||||
|
.phoneNumber(numeroTelephone)
|
||||||
|
.loyaltyPoints(Integer.parseInt(customer.get("pointsFidelite")))
|
||||||
|
.build();
|
||||||
|
Customer save = customerRepository.save(newCustomer);
|
||||||
|
customerPhoneUUID.put(numeroTelephone, save.getId());
|
||||||
|
}
|
||||||
|
|
||||||
|
assertEquals(customers.size(), customerRepository.findAll().size());
|
||||||
|
}
|
||||||
|
|
||||||
|
@When("I create a new customer with the following information:")
|
||||||
|
public void iCreateANewCustomerWithTheFollowingInformation(DataTable dataTable) throws NotValidCustomerException {
|
||||||
|
List<Map<String, String>> rows = dataTable.asMaps(String.class, String.class);
|
||||||
|
|
||||||
|
Map<String, String> customerInfo = rows.getFirst();
|
||||||
|
|
||||||
|
CustomerInfo newCustomer = new CustomerInfo(
|
||||||
|
customerInfo.get("prenom"),
|
||||||
|
customerInfo.get("nom"),
|
||||||
|
customerInfo.get("numeroTelephone")
|
||||||
|
);
|
||||||
|
|
||||||
|
customerRegistration = customerUseCase.registerCustomer(newCustomer);
|
||||||
|
}
|
||||||
|
|
||||||
|
@And("the system now has {int} customers")
|
||||||
|
public void theSystemNowHasCustomers(int numberOfCustomers) {
|
||||||
|
assertEquals(numberOfCustomers, customerRepository.findAll().size());
|
||||||
|
}
|
||||||
|
|
||||||
|
@And("the customer has {int} loyalty points")
|
||||||
|
public void theCustomerHasLoyaltyPoints(int loyaltyPoints) {
|
||||||
|
Customer customer = customerRepository.findById(customerRegistration).orElseThrow();
|
||||||
|
assertEquals(loyaltyPoints, customer.getLoyaltyPoints());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Then("a new customer is created")
|
||||||
|
public void aNewCustomerIsCreated() {
|
||||||
|
assertNotNull(customerRegistration);
|
||||||
|
}
|
||||||
|
|
||||||
|
@When("I request the customer with phone number {string}")
|
||||||
|
public void iRequestTheCustomerWithPhoneNumber(String phoneNumber) {
|
||||||
|
customerByPhoneNumber = customerUseCase.findCustomerByPhoneNumber(phoneNumber);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Then("I receive the following customer information:")
|
||||||
|
public void iReceiveTheFollowingCustomerInformation(DataTable dataTable) {
|
||||||
|
List<Map<String, String>> customers = dataTable.asMaps(String.class, String.class);
|
||||||
|
Map<String, String> customerInfo = customers.getFirst();
|
||||||
|
assertTrue(customerByPhoneNumber.isPresent());
|
||||||
|
CustomerDTO customerDTO = customerByPhoneNumber.get();
|
||||||
|
assertEquals(customerInfo.get("prenom"), customerDTO.getFirstName());
|
||||||
|
assertEquals(customerInfo.get("nom"), customerDTO.getLastName());
|
||||||
|
assertEquals(customerInfo.get("numeroTelephone"), customerDTO.getPhoneNumber());
|
||||||
|
}
|
||||||
|
|
||||||
|
@When("I update customer {string} with the following information:")
|
||||||
|
public void iUpdateCustomerWithTheFollowingInformation(String phoneNumber, DataTable dataTable)
|
||||||
|
throws CustomerNotFoundException, NotValidCustomerException {
|
||||||
|
List<Map<String, String>> rows = dataTable.asMaps(String.class, String.class);
|
||||||
|
|
||||||
|
Map<String, String> customerData = rows.getFirst();
|
||||||
|
CustomerInfo customerInfo = new CustomerInfo(
|
||||||
|
customerData.get("prenom"),
|
||||||
|
customerData.get("nom"),
|
||||||
|
customerData.get("numeroTelephone")
|
||||||
|
);
|
||||||
|
UUID uuid = customerPhoneUUID.get(phoneNumber);
|
||||||
|
customerUseCase.updateCustomer(uuid, customerInfo);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Then("the customer {string} has the following updated information:")
|
||||||
|
public void theCustomerHasTheFollowingUpdatedInformation(String phoneNumber, DataTable dataTable) {
|
||||||
|
List<Map<String, String>> rows = dataTable.asMaps(String.class, String.class);
|
||||||
|
|
||||||
|
Map<String, String> updatedDate = rows.getFirst();
|
||||||
|
|
||||||
|
UUID uuid = customerPhoneUUID.get(phoneNumber);
|
||||||
|
updatedCustomer = customerRepository.findById(uuid).orElseThrow();
|
||||||
|
assertEquals(updatedDate.get("numeroTelephone"), updatedCustomer.getPhoneNumber());
|
||||||
|
assertEquals(updatedDate.get("prenom"), updatedCustomer.getFirstName());
|
||||||
|
assertEquals(updatedDate.get("nom"), updatedCustomer.getLastName());
|
||||||
|
}
|
||||||
|
|
||||||
|
@And("the loyalty points remain unchanged at {int}")
|
||||||
|
public void theLoyaltyPointsRemainUnchangedAt(int expectedLoyaltyPoint) {
|
||||||
|
assertEquals(expectedLoyaltyPoint, updatedCustomer.getLoyaltyPoints());
|
||||||
|
}
|
||||||
|
|
||||||
|
@When("I delete the customer with phone number {string}")
|
||||||
|
public void iDeleteTheCustomerWithPhoneNumber(String phoneNumber) throws CustomerNotFoundException {
|
||||||
|
UUID uuid = customerPhoneUUID.get(phoneNumber);
|
||||||
|
customerUseCase.deleteCustomer(uuid);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Then("the customer {string} is removed from the system")
|
||||||
|
public void theCustomerIsRemovedFromTheSystem(String phoneNumber) {
|
||||||
|
UUID uuid = customerPhoneUUID.get(phoneNumber);
|
||||||
|
assertFalse(customerRepository.existsById(uuid));
|
||||||
|
}
|
||||||
|
|
||||||
|
@When("I add {int} loyalty points to customer {string}")
|
||||||
|
public void iAddLoyaltyPointsToCustomer(int loyaltyPointToAdd, String phoneNumber) throws CustomerNotFoundException {
|
||||||
|
UUID uuid = customerPhoneUUID.get(phoneNumber);
|
||||||
|
customerUseCase.addLoyaltyPoints(uuid, loyaltyPointToAdd);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Then("customer {string} now has {int} loyalty points")
|
||||||
|
public void customerNowHasLoyaltyPoints(String phoneNumber, int expectedLoyaltyPoints) {
|
||||||
|
UUID uuid = customerPhoneUUID.get(phoneNumber);
|
||||||
|
Customer customer = customerRepository.findById(uuid).orElseThrow();
|
||||||
|
assertEquals(expectedLoyaltyPoints, customer.getLoyaltyPoints());
|
||||||
|
}
|
||||||
|
|
||||||
|
@When("I deduct {int} loyalty points from customer {string} for a purchase")
|
||||||
|
public void iDeductLoyaltyPointsFromCustomerForAPurchase(int pointsToRemove, String phoneNumber) throws CustomerNotFoundException, IllegalCustomerPointException {
|
||||||
|
UUID uuid = customerPhoneUUID.get(phoneNumber);
|
||||||
|
customerUseCase.subtractLoyaltyPoints(uuid, pointsToRemove);
|
||||||
|
}
|
||||||
|
|
||||||
|
@When("I try to create a new customer with the following information:")
|
||||||
|
public void iTryToCreateANewCustomerWithTheFollowingInformation(DataTable ddataTable) {
|
||||||
|
List<Map<String, String>> rows = ddataTable.asMaps(String.class, String.class);
|
||||||
|
|
||||||
|
Map<String, String> customerInfo = rows.getFirst();
|
||||||
|
|
||||||
|
CustomerInfo newCustomer = new CustomerInfo(
|
||||||
|
customerInfo.get("prenom"),
|
||||||
|
customerInfo.get("nom"),
|
||||||
|
customerInfo.get("numeroTelephone")
|
||||||
|
);
|
||||||
|
|
||||||
|
notValidCustomerException = assertThrows(NotValidCustomerException.class, () -> customerUseCase.registerCustomer(newCustomer));
|
||||||
|
}
|
||||||
|
|
||||||
|
@Then("the creation fails")
|
||||||
|
public void theCreationFails() {
|
||||||
|
assertNotNull(notValidCustomerException);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@And("I receive an error for validation customer message containing {string}")
|
||||||
|
public void iReceiveAnErrorMessageContaining(String errorMessage) {
|
||||||
|
assertEquals(errorMessage, notValidCustomerException.getMessage());
|
||||||
|
}
|
||||||
|
|
||||||
|
@And("the system still has {int} customers")
|
||||||
|
public void theSystemStillHasCustomers(int expectedNumberOfUser) {
|
||||||
|
assertEquals(expectedNumberOfUser, customerRepository.findAll().size());
|
||||||
|
}
|
||||||
|
|
||||||
|
@When("I try to deduct {int} loyalty points from customer {string} for a purchase")
|
||||||
|
public void iTryToDeductLoyaltyPointsFromCustomerForAPurchase(int points, String phoneNumber) {
|
||||||
|
UUID uuid = customerPhoneUUID.get(phoneNumber);
|
||||||
|
illegalCustomerPointException = assertThrows(IllegalCustomerPointException.class, () -> customerUseCase.subtractLoyaltyPoints(uuid, points));
|
||||||
|
}
|
||||||
|
|
||||||
|
@Then("the deduction fails")
|
||||||
|
public void theDeductionFails() {
|
||||||
|
assertNotNull(illegalCustomerPointException);
|
||||||
|
}
|
||||||
|
|
||||||
|
@And("I receive an error for illegal customer exception message containing {string}")
|
||||||
|
public void iReceiveAnErrorForIllegalCustomerExceptionMessageContaining(String errorMessage) {
|
||||||
|
assertEquals(errorMessage, illegalCustomerPointException.getMessage());
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
60
src/test/resources/features/client.feature
Normal file
60
src/test/resources/features/client.feature
Normal file
@ -0,0 +1,60 @@
|
|||||||
|
# language: en
|
||||||
|
|
||||||
|
Feature: Manage customer accounts
|
||||||
|
|
||||||
|
Background:
|
||||||
|
Given the system has the following customers:
|
||||||
|
| prenom | nom | numeroTelephone | pointsFidelite |
|
||||||
|
| Marie | Dupont | 0612345678 | 100 |
|
||||||
|
| Jean | Martin | 0687654321 | 50 |
|
||||||
|
| Sophie | Dubois | 0698765432 | 0 |
|
||||||
|
|
||||||
|
Scenario: Create a new customer account
|
||||||
|
When I create a new customer with the following information:
|
||||||
|
| prenom | nom | numeroTelephone |
|
||||||
|
| Pierre | Lambert | 0611223344 |
|
||||||
|
Then a new customer is created
|
||||||
|
And the customer has 0 loyalty points
|
||||||
|
And the system now has 4 customers
|
||||||
|
|
||||||
|
Scenario: Retrieve a customer by ID
|
||||||
|
When I request the customer with phone number "0612345678"
|
||||||
|
Then I receive the following customer information:
|
||||||
|
| prenom | nom | numeroTelephone | pointsFidelite |
|
||||||
|
| Marie | Dupont | 0612345678 | 100 |
|
||||||
|
|
||||||
|
Scenario: Update a customer's information
|
||||||
|
When I update customer "0687654321" with the following information:
|
||||||
|
| prenom | nom | numeroTelephone |
|
||||||
|
| Jean | Bernard | 0666666666 |
|
||||||
|
Then the customer "0687654321" has the following updated information:
|
||||||
|
| prenom | nom | numeroTelephone |
|
||||||
|
| Jean | Bernard | 0666666666 |
|
||||||
|
And the loyalty points remain unchanged at 50
|
||||||
|
|
||||||
|
Scenario: Delete a customer
|
||||||
|
When I delete the customer with phone number "0698765432"
|
||||||
|
Then the customer "0698765432" is removed from the system
|
||||||
|
And the system now has 2 customers
|
||||||
|
|
||||||
|
Scenario: Add loyalty points to a customer
|
||||||
|
When I add 25 loyalty points to customer "0687654321"
|
||||||
|
Then customer "0687654321" now has 75 loyalty points
|
||||||
|
|
||||||
|
Scenario: Deduct loyalty points for a purchase
|
||||||
|
When I deduct 30 loyalty points from customer "0612345678" for a purchase
|
||||||
|
Then customer "0612345678" now has 70 loyalty points
|
||||||
|
|
||||||
|
Scenario: Attempt to create a customer with invalid phone number
|
||||||
|
When I try to create a new customer with the following information:
|
||||||
|
| prenom | nom | numeroTelephone |
|
||||||
|
| Thomas | Petit | abcdefgh |
|
||||||
|
Then the creation fails
|
||||||
|
And I receive an error for validation customer message containing "Phone number is not valid"
|
||||||
|
And the system still has 3 customers
|
||||||
|
|
||||||
|
Scenario: Attempt to deduct more loyalty points than available
|
||||||
|
When I try to deduct 150 loyalty points from customer "0687654321" for a purchase
|
||||||
|
Then the deduction fails
|
||||||
|
And I receive an error for illegal customer exception message containing "Cannot remove 150 points from 50 points"
|
||||||
|
And customer "0687654321" now has 50 loyalty points
|
Loading…
x
Reference in New Issue
Block a user