diff --git a/pom.xml b/pom.xml index d867374..cb0b629 100644 --- a/pom.xml +++ b/pom.xml @@ -87,6 +87,26 @@ spring-web 6.1.0 + + + com.oracle.database.jdbc + ojdbc8 + 21.3.0.0 + + + com.oracle.database.xml + xdb + + + org.springframework.boot + spring-boot-starter-data-jpa + + + org.springframework.boot + spring-boot-starter-logging + + + diff --git a/src/main/java/fr/abes/kbart2kafka/Kbart2kafkaApplication.java b/src/main/java/fr/abes/kbart2kafka/Kbart2kafkaApplication.java index 46379f5..81ec156 100644 --- a/src/main/java/fr/abes/kbart2kafka/Kbart2kafkaApplication.java +++ b/src/main/java/fr/abes/kbart2kafka/Kbart2kafkaApplication.java @@ -1,9 +1,14 @@ package fr.abes.kbart2kafka; +import fr.abes.kbart2kafka.exception.IllegalDateException; import fr.abes.kbart2kafka.exception.IllegalFileFormatException; +import fr.abes.kbart2kafka.exception.IllegalPackageException; import fr.abes.kbart2kafka.exception.IllegalProviderException; +import fr.abes.kbart2kafka.repository.ProviderRepository; import fr.abes.kbart2kafka.service.FileService; +import fr.abes.kbart2kafka.service.ProviderPackageService; import fr.abes.kbart2kafka.utils.CheckFiles; +import fr.abes.kbart2kafka.utils.Utils; import lombok.extern.slf4j.Slf4j; import org.apache.logging.log4j.ThreadContext; import org.springframework.beans.factory.annotation.Value; @@ -21,8 +26,14 @@ public class Kbart2kafkaApplication implements CommandLineRunner { private String kbartHeader; private final FileService service; - public Kbart2kafkaApplication(FileService service) { + private final ProviderPackageService providerPackageService; + + private final ProviderRepository providerRepository; + + public Kbart2kafkaApplication(FileService service, ProviderPackageService providerPackageService, ProviderRepository providerRepository) { this.service = service; + this.providerPackageService = providerPackageService; + this.providerRepository = providerRepository; } public static void main(String[] args) { @@ -46,10 +57,10 @@ public void run(String... args) throws IOException { ThreadContext.put("package", args[0]); // Récupération du chemin d'accès au fichier File tsvFile = new File(args[0]); - // Appelle du service de vérification de fichier try { CheckFiles.verifyFile(tsvFile, kbartHeader); - } catch (IllegalFileFormatException | IllegalProviderException e) { + checkExistingPackage(tsvFile.getName()); + } catch (IllegalFileFormatException | IllegalProviderException | IllegalPackageException | IllegalDateException e) { log.error(e.getMessage()); throw new RuntimeException(e); } @@ -59,4 +70,9 @@ public void run(String... args) throws IOException { double executionTime = (double) (endTime - startTime) / 1000; log.info("Temps d'exécution : " + executionTime + " secondes"); } + + private void checkExistingPackage(String filename) throws IllegalProviderException, IllegalPackageException, IllegalDateException { + if (providerPackageService.hasMoreRecentPackageInBdd(Utils.extractProvider(filename), Utils.extractPackageName(filename), Utils.extractDate(filename))) + throw new IllegalPackageException("Un package plus récent est déjà présent dans la base"); + } } diff --git a/src/main/java/fr/abes/kbart2kafka/configuration/AbstractConfig.java b/src/main/java/fr/abes/kbart2kafka/configuration/AbstractConfig.java new file mode 100644 index 0000000..549a2dc --- /dev/null +++ b/src/main/java/fr/abes/kbart2kafka/configuration/AbstractConfig.java @@ -0,0 +1,25 @@ +package fr.abes.kbart2kafka.configuration; + +import org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean; +import org.springframework.orm.jpa.vendor.HibernateJpaVendorAdapter; + +import java.util.HashMap; + +public abstract class AbstractConfig { + protected void configHibernate(LocalContainerEntityManagerFactoryBean em, String platform, boolean showsql, String dialect, String ddlAuto, boolean generateDdl, String initMode) { + HibernateJpaVendorAdapter vendorAdapter + = new HibernateJpaVendorAdapter(); + vendorAdapter.setGenerateDdl(generateDdl); + vendorAdapter.setShowSql(showsql); + vendorAdapter.setDatabasePlatform(platform); + em.setJpaVendorAdapter(vendorAdapter); + HashMap properties = new HashMap<>(); + properties.put("hibernate.format_sql", true); + properties.put("hibernate.hbm2ddl.auto", ddlAuto); + properties.put("hibernate.dialect", dialect); + properties.put("logging.level.org.hibernate", "DEBUG"); + properties.put("hibernate.type", "trace"); + properties.put("spring.sql.init.mode", initMode); + em.setJpaPropertyMap(properties); + } +} diff --git a/src/main/java/fr/abes/kbart2kafka/configuration/BaconDbConfig.java b/src/main/java/fr/abes/kbart2kafka/configuration/BaconDbConfig.java new file mode 100644 index 0000000..0877955 --- /dev/null +++ b/src/main/java/fr/abes/kbart2kafka/configuration/BaconDbConfig.java @@ -0,0 +1,56 @@ +package fr.abes.kbart2kafka.configuration; + +import lombok.NoArgsConstructor; +import org.springframework.beans.factory.annotation.Qualifier; +import org.springframework.beans.factory.annotation.Value; +import org.springframework.boot.context.properties.ConfigurationProperties; +import org.springframework.boot.jdbc.DataSourceBuilder; +import org.springframework.context.annotation.Bean; +import org.springframework.context.annotation.Configuration; +import org.springframework.context.annotation.Primary; +import org.springframework.data.jpa.repository.config.EnableJpaRepositories; +import org.springframework.orm.jpa.JpaTransactionManager; +import org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean; +import org.springframework.transaction.PlatformTransactionManager; + +import javax.sql.DataSource; + +@Configuration +@EnableJpaRepositories(entityManagerFactoryRef = "baconEntityManager", transactionManagerRef = "baconTransactionManager", basePackages = "fr.abes.kbart2kafka.repository") +@NoArgsConstructor +public class BaconDbConfig extends AbstractConfig { + @Value("${spring.jpa.bacon.show-sql}") + protected boolean showsql; + @Value("${spring.jpa.bacon.properties.hibernate.dialect}") + protected String dialect; + @Value("${spring.jpa.bacon.hibernate.ddl-auto}") + protected String ddlAuto; + @Value("${spring.jpa.bacon.database-platform}") + protected String platform; + @Value("${spring.jpa.bacon.generate-ddl}") + protected boolean generateDdl; + @Value("${spring.sql.bacon.init.mode}") + protected String initMode; + + @Bean + @ConfigurationProperties(prefix = "spring.datasource.bacon") + public DataSource baconDataSource() { return DataSourceBuilder.create().build(); } + + @Bean + public LocalContainerEntityManagerFactoryBean baconEntityManager() { + LocalContainerEntityManagerFactoryBean em = new LocalContainerEntityManagerFactoryBean(); + em.setDataSource(baconDataSource()); + em.setPackagesToScan("fr.abes.kbart2kafka.entity"); + configHibernate(em, platform, showsql, dialect, ddlAuto, generateDdl, initMode); + return em; + } + + @Primary + @Bean + public PlatformTransactionManager baconTransactionManager(@Qualifier("baconEntityManager") LocalContainerEntityManagerFactoryBean entityManagerFactory) { + final JpaTransactionManager transactionManager = new JpaTransactionManager(); + transactionManager.setEntityManagerFactory(entityManagerFactory.getObject()); + return transactionManager; + } + +} diff --git a/src/main/java/fr/abes/kbart2kafka/entity/Provider.java b/src/main/java/fr/abes/kbart2kafka/entity/Provider.java new file mode 100644 index 0000000..58e1d04 --- /dev/null +++ b/src/main/java/fr/abes/kbart2kafka/entity/Provider.java @@ -0,0 +1,42 @@ +package fr.abes.kbart2kafka.entity; + +import jakarta.persistence.*; +import lombok.AllArgsConstructor; +import lombok.Getter; +import lombok.NoArgsConstructor; +import lombok.Setter; + +import java.io.Serializable; + +@Entity +@Table(name = "PROVIDER") +@Getter +@Setter +@NoArgsConstructor +@AllArgsConstructor +public class Provider implements Serializable { + @Id + @GeneratedValue(strategy = GenerationType.SEQUENCE, generator = "seq-provider") + @SequenceGenerator(name = "seq-provider", sequenceName = "PROVIDER_SEQ", allocationSize = 1) + @Column(name = "IDT_PROVIDER") + private Integer idtProvider; + @Column(name = "PROVIDER") + private String provider; + @Column(name = "NOM_CONTACT") + private String nomContact; + @Column(name = "PRENOM_CONTACT") + private String prenomContact; + @Column(name = "MAIL_CONTACT") + private String mailContact; + @Column(name = "DISPLAY_NAME") + private String displayName; + + + public Provider(String provider) { + this.provider = provider; + //on ne connait pas le display name à l'avance, on l'initialise au provider pour éviter une erreur not null dans la table + this.displayName = provider; + } + + +} diff --git a/src/main/java/fr/abes/kbart2kafka/entity/ProviderPackage.java b/src/main/java/fr/abes/kbart2kafka/entity/ProviderPackage.java new file mode 100644 index 0000000..411f15e --- /dev/null +++ b/src/main/java/fr/abes/kbart2kafka/entity/ProviderPackage.java @@ -0,0 +1,59 @@ +package fr.abes.kbart2kafka.entity; + +import jakarta.persistence.*; +import lombok.AllArgsConstructor; +import lombok.Getter; +import lombok.NoArgsConstructor; +import lombok.Setter; + +import java.io.Serializable; +import java.util.Date; + +@Entity +@Table(name = "PROVIDER_PACKAGE") +@Getter @Setter +@AllArgsConstructor +@NoArgsConstructor +public class ProviderPackage implements Serializable, Comparable { + @Id + @GeneratedValue(strategy = GenerationType.IDENTITY) + @Column(name = "ID_PROVIDER_PACKAGE") + private Integer idProviderPackage; + @Column(name = "PACKAGE") + private String packageName; + @Column(name = "DATE_P") + private Date dateP; + @Column(name = "PROVIDER_IDT_PROVIDER") + private Integer providerIdtProvider; + @Column(name = "LABEL_ABES") + private char labelAbes; + + @ManyToOne + @JoinColumn(referencedColumnName = "IDT_PROVIDER", insertable = false, updatable = false) + private Provider provider; + + public ProviderPackage(String packageName, Date dateP, Integer providerIdtProvider, char labelAbes) { + this.packageName = packageName; + this.dateP = dateP; + this.providerIdtProvider = providerIdtProvider; + this.labelAbes = labelAbes; + } + + public ProviderPackage(Integer idProviderPackage, String packageName, Date dateP, Integer providerIdtProvider, char labelAbes) { + this.idProviderPackage = idProviderPackage; + this.packageName = packageName; + this.dateP = dateP; + this.providerIdtProvider = providerIdtProvider; + this.labelAbes = labelAbes; + } + + @Override + public String toString() { + return "{ id:"+idProviderPackage + ", packageName:"+packageName+", providerIdt:"+providerIdtProvider+" dateP:"+dateP+" }"; + } + + @Override + public int compareTo(ProviderPackage o) { + return o.getDateP().compareTo(this.getDateP()); + } +} diff --git a/src/main/java/fr/abes/kbart2kafka/exception/IllegalDateException.java b/src/main/java/fr/abes/kbart2kafka/exception/IllegalDateException.java new file mode 100644 index 0000000..2458c8f --- /dev/null +++ b/src/main/java/fr/abes/kbart2kafka/exception/IllegalDateException.java @@ -0,0 +1,7 @@ +package fr.abes.kbart2kafka.exception; + +public class IllegalDateException extends Throwable { + public IllegalDateException(Exception e) { + super(e); + } +} diff --git a/src/main/java/fr/abes/kbart2kafka/exception/IllegalPackageException.java b/src/main/java/fr/abes/kbart2kafka/exception/IllegalPackageException.java new file mode 100644 index 0000000..394288d --- /dev/null +++ b/src/main/java/fr/abes/kbart2kafka/exception/IllegalPackageException.java @@ -0,0 +1,11 @@ +package fr.abes.kbart2kafka.exception; + +public class IllegalPackageException extends Throwable { + public IllegalPackageException(Exception e) { + super(e); + } + + public IllegalPackageException(String s) { + super(s); + } +} diff --git a/src/main/java/fr/abes/kbart2kafka/exception/IllegalProviderException.java b/src/main/java/fr/abes/kbart2kafka/exception/IllegalProviderException.java index c862c75..a4c5176 100644 --- a/src/main/java/fr/abes/kbart2kafka/exception/IllegalProviderException.java +++ b/src/main/java/fr/abes/kbart2kafka/exception/IllegalProviderException.java @@ -1,7 +1,9 @@ package fr.abes.kbart2kafka.exception; -public class IllegalProviderException extends Throwable { +public class IllegalProviderException extends Exception { public IllegalProviderException(String message) { super(message); } + + public IllegalProviderException(Exception e) { super(e); } } diff --git a/src/main/java/fr/abes/kbart2kafka/repository/ProviderPackageRepository.java b/src/main/java/fr/abes/kbart2kafka/repository/ProviderPackageRepository.java new file mode 100644 index 0000000..095df01 --- /dev/null +++ b/src/main/java/fr/abes/kbart2kafka/repository/ProviderPackageRepository.java @@ -0,0 +1,13 @@ +package fr.abes.kbart2kafka.repository; + +import fr.abes.kbart2kafka.entity.ProviderPackage; +import org.springframework.data.jpa.repository.JpaRepository; +import org.springframework.stereotype.Repository; + +import java.util.List; + +@Repository +public interface ProviderPackageRepository extends JpaRepository { + List findByPackageNameAndProviderIdtProvider(String packageName, Integer providerIdtProvider); + +} diff --git a/src/main/java/fr/abes/kbart2kafka/repository/ProviderRepository.java b/src/main/java/fr/abes/kbart2kafka/repository/ProviderRepository.java new file mode 100644 index 0000000..fd60119 --- /dev/null +++ b/src/main/java/fr/abes/kbart2kafka/repository/ProviderRepository.java @@ -0,0 +1,13 @@ +package fr.abes.kbart2kafka.repository; + + +import fr.abes.kbart2kafka.entity.Provider; +import org.springframework.data.jpa.repository.JpaRepository; +import org.springframework.stereotype.Repository; + +import java.util.Optional; + +@Repository +public interface ProviderRepository extends JpaRepository { + Optional findByProvider(String provider); +} diff --git a/src/main/java/fr/abes/kbart2kafka/service/FileService.java b/src/main/java/fr/abes/kbart2kafka/service/FileService.java index 3e3fe96..40deb19 100644 --- a/src/main/java/fr/abes/kbart2kafka/service/FileService.java +++ b/src/main/java/fr/abes/kbart2kafka/service/FileService.java @@ -18,7 +18,6 @@ import java.io.File; import java.io.FileReader; import java.io.IOException; -import java.nio.charset.StandardCharsets; import java.util.ArrayList; import java.util.List; import java.util.Random; @@ -90,8 +89,7 @@ private void executeMultiThread(File fichier, String kbartHeader) throws IOExcep assert result != null; result.whenComplete((sr, ex) -> { try { -// log.debug("Message envoyé : {}", mapper.writeValueAsString(result.get().getProducerRecord().value())); - mapper.writeValueAsString(result.get().getProducerRecord().value()); + log.debug(mapper.writeValueAsString(result.get().getProducerRecord().value())); // vérification du résultat de la transaction et log } catch (JsonProcessingException | InterruptedException | ExecutionException e) { log.warn("Erreur dans le mapping du résultat de l'envoi dans le topic pour la ligne " + ligneKbartDto); } @@ -112,7 +110,7 @@ private void executeMultiThread(File fichier, String kbartHeader) throws IOExcep } private void sendErrorToKafka(String errorMessage, Exception exception, String filename) { - log.debug("Envoi erreur"); + log.error(errorMessage + exception + " - " + filename); kafkaTemplate.send(new ProducerRecord<>(topicErrors, new Random().nextInt(nbThread), filename, errorMessage + exception.getMessage())); } diff --git a/src/main/java/fr/abes/kbart2kafka/service/ProviderPackageService.java b/src/main/java/fr/abes/kbart2kafka/service/ProviderPackageService.java new file mode 100644 index 0000000..ca80f16 --- /dev/null +++ b/src/main/java/fr/abes/kbart2kafka/service/ProviderPackageService.java @@ -0,0 +1,34 @@ +package fr.abes.kbart2kafka.service; + +import fr.abes.kbart2kafka.entity.Provider; +import fr.abes.kbart2kafka.entity.ProviderPackage; +import fr.abes.kbart2kafka.repository.ProviderPackageRepository; +import fr.abes.kbart2kafka.repository.ProviderRepository; +import org.springframework.stereotype.Service; + +import java.util.Collections; +import java.util.Date; +import java.util.List; +import java.util.Optional; + +@Service +public class ProviderPackageService { + private final ProviderPackageRepository repository; + + private final ProviderRepository providerRepository; + + public ProviderPackageService(ProviderPackageRepository repository, ProviderRepository providerRepository) { + this.repository = repository; + this.providerRepository = providerRepository; + } + + public boolean hasMoreRecentPackageInBdd(String provider, String packageName, Date datePackage) { + Optional providerBdd = providerRepository.findByProvider(provider); + if (providerBdd.isPresent()) { + List packageList = repository.findByPackageNameAndProviderIdtProvider(packageName, providerBdd.get().getIdtProvider()); + Collections.sort(packageList); + return packageList.get(0).getDateP().after(datePackage); + } + return false; + } +} diff --git a/src/main/java/fr/abes/kbart2kafka/utils/CheckFiles.java b/src/main/java/fr/abes/kbart2kafka/utils/CheckFiles.java index 9b5e0e0..46c1b66 100644 --- a/src/main/java/fr/abes/kbart2kafka/utils/CheckFiles.java +++ b/src/main/java/fr/abes/kbart2kafka/utils/CheckFiles.java @@ -23,7 +23,7 @@ public static Boolean detectFileName(File file) throws IllegalFileFormatExceptio public static void detectProvider(File file) throws IllegalProviderException { String filename = file.getName(); filename = filename.replace("\\", "/"); - if(!filename.contains("_") || filename.substring(0, filename.indexOf('_')).length() <= 0) { + if(!filename.contains("_") || filename.substring(0, filename.indexOf('_')).isEmpty()) { log.error("Message envoyé : {}", "Le nom du fichier ne contient pas de provider"); throw new IllegalProviderException("Le nom du fichier "+ filename +" ne contient pas de provider"); } diff --git a/src/main/java/fr/abes/kbart2kafka/utils/Utils.java b/src/main/java/fr/abes/kbart2kafka/utils/Utils.java index c382520..d919179 100644 --- a/src/main/java/fr/abes/kbart2kafka/utils/Utils.java +++ b/src/main/java/fr/abes/kbart2kafka/utils/Utils.java @@ -1,10 +1,15 @@ package fr.abes.kbart2kafka.utils; +import fr.abes.kbart2kafka.exception.IllegalDateException; +import fr.abes.kbart2kafka.exception.IllegalPackageException; +import fr.abes.kbart2kafka.exception.IllegalProviderException; + import java.net.URI; import java.net.URISyntaxException; -import java.util.Collections; -import java.util.HashMap; -import java.util.Map; +import java.text.SimpleDateFormat; +import java.util.Date; +import java.util.regex.Matcher; +import java.util.regex.Pattern; public class Utils { @@ -17,16 +22,42 @@ public static String extractDomainFromUrl(String url) throws URISyntaxException return host; } - public static > Map getMaxValuesFromMap(Map map) { - Map maxKeys = new HashMap<>(); - if (!map.isEmpty()) { - V maxValue = Collections.max(map.values()); - for (Map.Entry entry : map.entrySet()) { - if (entry.getValue().equals(maxValue)) { - maxKeys.put(entry.getKey(), entry.getValue()); - } + public static String extractProvider(String filename) throws IllegalProviderException { + try { + return filename.substring(0, filename.indexOf('_')); + } catch (Exception e) { + throw new IllegalProviderException(e); + } + } + + public static String extractPackageName(String filename) throws IllegalPackageException { + try { + if (filename.contains("_FORCE")) { + String tempsStr = filename.substring(0, filename.indexOf("_FORCE")); + return tempsStr.substring(tempsStr.indexOf('_') + 1, tempsStr.lastIndexOf('_')); + } else if (filename.contains("_BYPASS")) { + String tempStr = filename.substring(0, filename.indexOf("_BYPASS")); + return tempStr.substring(tempStr.indexOf('_') + 1, tempStr.lastIndexOf('_')); + } else { + return filename.substring(filename.indexOf('_') + 1, filename.lastIndexOf('_')); + } + } catch (Exception e) { + throw new IllegalPackageException(e); + } + } + + public static Date extractDate(String filename) throws IllegalDateException { + Date date = new Date(); + try { + Matcher matcher = Pattern.compile("(\\d{4}-\\d{2}-\\d{2})", Pattern.CASE_INSENSITIVE).matcher(filename); + if(matcher.find()){ + date = new SimpleDateFormat("yyyy-MM-dd").parse(matcher.group(1)); } + return date; + } catch (Exception e) { + throw new IllegalDateException(e); } - return maxKeys; } + + } diff --git a/src/main/resources/application-dev.properties b/src/main/resources/application-dev.properties index 7a45c9c..f8f2d4d 100644 --- a/src/main/resources/application-dev.properties +++ b/src/main/resources/application-dev.properties @@ -4,3 +4,16 @@ spring.kafka.producer.nbthread= logging.level.root=INFO logging.level.fr.abes=DEBUG + +# Base Bacon +spring.datasource.bacon.driver-class-name=oracle.jdbc.OracleDriver +spring.datasource.bacon.jdbcurl= +spring.datasource.bacon.username= +spring.datasource.bacon.password= + +spring.jpa.bacon.database-platform=org.hibernate.dialect.OracleDialect +spring.jpa.bacon.properties.hibernate.dialect=org.hibernate.dialect.OracleDialect +spring.jpa.bacon.generate-ddl=false +spring.jpa.bacon.hibernate.ddl-auto=none +spring.jpa.bacon.show-sql=false +spring.sql.bacon.init.mode=never \ No newline at end of file diff --git a/src/main/resources/application-prod.properties b/src/main/resources/application-prod.properties index 6a2195c..1c3aebe 100644 --- a/src/main/resources/application-prod.properties +++ b/src/main/resources/application-prod.properties @@ -3,4 +3,17 @@ spring.kafka.producer.bootstrap-servers= spring.kafka.producer.nbthread= logging.level.root=INFO -logging.level.fr.abes=ERROR \ No newline at end of file +logging.level.fr.abes=ERROR + +# Base Bacon +spring.datasource.bacon.driver-class-name=oracle.jdbc.OracleDriver +spring.datasource.bacon.jdbcurl= +spring.datasource.bacon.username= +spring.datasource.bacon.password= + +spring.jpa.bacon.database-platform=org.hibernate.dialect.OracleDialect +spring.jpa.bacon.properties.hibernate.dialect=org.hibernate.dialect.OracleDialect +spring.jpa.bacon.generate-ddl=false +spring.jpa.bacon.hibernate.ddl-auto=none +spring.jpa.bacon.show-sql=false +spring.sql.bacon.init.mode=never \ No newline at end of file diff --git a/src/main/resources/application-test.properties b/src/main/resources/application-test.properties index 1863a7f..8701684 100644 --- a/src/main/resources/application-test.properties +++ b/src/main/resources/application-test.properties @@ -3,4 +3,17 @@ spring.kafka.producer.bootstrap-servers= spring.kafka.producer.nbthread= logging.level.root=INFO -logging.level.fr.abes=INFO \ No newline at end of file +logging.level.fr.abes=INFO + +# Base Bacon +spring.datasource.bacon.driver-class-name=oracle.jdbc.OracleDriver +spring.datasource.bacon.jdbcurl= +spring.datasource.bacon.username= +spring.datasource.bacon.password= + +spring.jpa.bacon.database-platform=org.hibernate.dialect.OracleDialect +spring.jpa.bacon.properties.hibernate.dialect=org.hibernate.dialect.OracleDialect +spring.jpa.bacon.generate-ddl=false +spring.jpa.bacon.hibernate.ddl-auto=none +spring.jpa.bacon.show-sql=false +spring.sql.bacon.init.mode=never \ No newline at end of file diff --git a/src/main/resources/log4j2-all.xml b/src/main/resources/log4j2-all.xml index 0113a5c..e3f3541 100644 --- a/src/main/resources/log4j2-all.xml +++ b/src/main/resources/log4j2-all.xml @@ -17,15 +17,11 @@ - + + ${kafkaServer} - - - - - ${kafkaServer} - + diff --git a/src/test/java/fr/abes/kbart2kafka/service/ProviderPackageServiceTest.java b/src/test/java/fr/abes/kbart2kafka/service/ProviderPackageServiceTest.java new file mode 100644 index 0000000..8305e68 --- /dev/null +++ b/src/test/java/fr/abes/kbart2kafka/service/ProviderPackageServiceTest.java @@ -0,0 +1,72 @@ +package fr.abes.kbart2kafka.service; + +import fr.abes.kbart2kafka.entity.Provider; +import fr.abes.kbart2kafka.entity.ProviderPackage; +import fr.abes.kbart2kafka.repository.ProviderPackageRepository; +import fr.abes.kbart2kafka.repository.ProviderRepository; +import org.assertj.core.util.Lists; +import org.junit.jupiter.api.Assertions; +import org.junit.jupiter.api.DisplayName; +import org.junit.jupiter.api.Test; +import org.mockito.Mockito; +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.boot.test.context.SpringBootTest; +import org.springframework.boot.test.mock.mockito.MockBean; + +import java.util.Calendar; +import java.util.Date; +import java.util.List; +import java.util.Optional; + +@SpringBootTest(classes = {ProviderPackageService.class}) +class ProviderPackageServiceTest { + @Autowired + ProviderPackageService service; + + @MockBean + ProviderPackageRepository providerPackageRepository; + + @MockBean + ProviderRepository providerRepository; + + @Test + @DisplayName("test isMoreRecentPackage : cas général") + void isMoreRecentPackageInBdd() { + Provider provider = new Provider(1, "provider", "nomContact", "prenomContact", "mail@contact.com", "displayName"); + Mockito.when(providerRepository.findByProvider("provider")).thenReturn(Optional.of(provider)); + Calendar calendar = Calendar.getInstance(); + calendar.set(2022, 10, 1); + Date date1 = calendar.getTime(); + ProviderPackage package1 = new ProviderPackage(1, "package", date1, 1, 'Y'); + calendar.set(2023, 8, 10); + Date date2 = calendar.getTime(); + ProviderPackage package2 = new ProviderPackage(2, "package", date2, 1, 'Y'); + calendar.set(2023, 7, 5); + Date date3 = calendar.getTime(); + ProviderPackage package3 = new ProviderPackage(3, "package", date3, 1, 'Y'); + + List packageList = Lists.newArrayList(package1, package2, package3); + Mockito.when(providerPackageRepository.findByPackageNameAndProviderIdtProvider("package", 1)).thenReturn(packageList); + + calendar.set(2023, 4, 20); + Date inputDate = calendar.getTime(); + Assertions.assertTrue(service.hasMoreRecentPackageInBdd("provider", "package", inputDate)); + + + calendar.set(2023, 11, 20); + inputDate = calendar.getTime(); + Assertions.assertFalse(service.hasMoreRecentPackageInBdd("provider", "package", inputDate)); + + //cas date égale + calendar.set(2023, 8, 10); + inputDate = calendar.getTime(); + Assertions.assertFalse(service.hasMoreRecentPackageInBdd("provider", "package", inputDate)); + } + + @Test + @DisplayName("test isMoreRecentPacakge : cas pas de provider trouvé") + void isMoreRecentPacakageInBddNoProvider() { + Mockito.when(providerRepository.findByProvider("provider")).thenReturn(Optional.empty()); + Assertions.assertFalse(service.hasMoreRecentPackageInBdd("provider", "package", Calendar.getInstance().getTime())); + } +} \ No newline at end of file diff --git a/src/test/java/fr/abes/kbart2kafka/utils/UtilsTest.java b/src/test/java/fr/abes/kbart2kafka/utils/UtilsTest.java index ae78fc0..1dee2e6 100644 --- a/src/test/java/fr/abes/kbart2kafka/utils/UtilsTest.java +++ b/src/test/java/fr/abes/kbart2kafka/utils/UtilsTest.java @@ -1,9 +1,17 @@ package fr.abes.kbart2kafka.utils; +import fr.abes.kbart2kafka.exception.IllegalDateException; +import fr.abes.kbart2kafka.exception.IllegalPackageException; +import fr.abes.kbart2kafka.exception.IllegalProviderException; +import jdk.jshell.execution.Util; import org.junit.jupiter.api.Assertions; +import org.junit.jupiter.api.DisplayName; import org.junit.jupiter.api.Test; import java.net.URISyntaxException; +import java.text.ParseException; +import java.text.SimpleDateFormat; +import java.util.Date; class UtilsTest { @Test @@ -23,4 +31,33 @@ void extractDomainFromUrlTest3() { String url = "teskljgfklj/test"; Assertions.assertThrows(URISyntaxException.class, () -> Utils.extractDomainFromUrl(url)); } + + @Test + void extractDate() throws IllegalDateException, ParseException { + String string = "2023-08-21"; + Date date = new SimpleDateFormat("yyyy-MM-dd").parse(string); + + Assertions.assertEquals(date, Utils.extractDate("SPRINGER_GLOBAL_ALLEBOOKS_2023-08-21.tsv")); + } + + @Test + @DisplayName("test récupération package dans nom de fichier") + void testextractPackageName() throws IllegalPackageException { + String filename = "SPRINGER_GLOBAL_ALLEBOOKS_2023-05-01_FORCE.tsv"; + Assertions.assertEquals("GLOBAL_ALLEBOOKS", Utils.extractPackageName(filename)); + + filename = "SPRINGER_GLOBAL_ALLEBOOKS_2023-05-01.tsv"; + Assertions.assertEquals("GLOBAL_ALLEBOOKS", Utils.extractPackageName(filename)); + + } + + @Test + @DisplayName("test récupération provider dans nom de fichier") + void testExtractProvider() throws IllegalProviderException { + String filename = "SPRINGER_GLOBAL_ALLEBOOKS_2023-05-01_FORCE.tsv"; + Assertions.assertEquals("SPRINGER", Utils.extractProvider(filename)); + + String filename2 = "test"; + Assertions.assertThrows(IllegalProviderException.class, () -> Utils.extractProvider(filename2)); + } }