Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat: P4ADEV-1625 classifyiufactivity-retrieve-iuvs-save #48

Merged
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
45 commits
Select commit Hold shift + click to select a range
54f4cda
implementation
silvanotamburini Dec 10, 2024
02e1ee4
add tests
silvanotamburini Dec 10, 2024
537d88e
change version
silvanotamburini Dec 10, 2024
eaa34ae
implementation of Iuf Classification Activity save
silvanotamburini Dec 11, 2024
c588181
Merge branch 'main' into P4ADEV-1625-classifyiufactivity-retrieve-iuv…
silvanotamburini Dec 11, 2024
8dcc24c
deleted wrong parameter
silvanotamburini Dec 11, 2024
09ded78
fix problems in Exception handling
silvanotamburini Dec 11, 2024
e364913
change Exception handling
silvanotamburini Dec 11, 2024
7a94b3f
delete function not correctly merged with main
silvanotamburini Dec 11, 2024
7ff7d0b
change Exception handling
silvanotamburini Dec 11, 2024
74a101c
add tests
silvanotamburini Dec 11, 2024
84ea58a
Merge branch 'main' into P4ADEV-1625-classifyiufactivity-retrieve-iuv…
silvanotamburini Dec 11, 2024
283170c
review implementation
silvanotamburini Dec 13, 2024
026986f
Merge branch 'main' into P4ADEV-1625-classifyiufactivity-retrieve-iuv…
silvanotamburini Dec 13, 2024
4db2509
fix issues
silvanotamburini Dec 13, 2024
f07ec0e
add new tests
silvanotamburini Dec 13, 2024
2f02d74
delete wrong message
silvanotamburini Dec 13, 2024
746200a
changed wrong method
silvanotamburini Dec 13, 2024
3de5b75
Merge branch 'main' into P4ADEV-1625-classifyiufactivity-retrieve-iuv…
silvanotamburini Dec 18, 2024
d4430b7
Merge remote-tracking branch 'origin/main' into P4ADEV-1625-classifyi…
silvanotamburini Dec 18, 2024
b8655d2
added temporal annotations in IufClassificationActivity interface
silvanotamburini Dec 18, 2024
5380b53
Update version
silvanotamburini Dec 18, 2024
bb4be55
partial adding of requested changes, waiting other merge
silvanotamburini Dec 19, 2024
9bc81f6
change version
silvanotamburini Dec 19, 2024
1d4a86d
Merge remote-tracking branch 'origin/main' into P4ADEV-1625-classifyi…
silvanotamburini Dec 19, 2024
252eb5f
add requested changes
silvanotamburini Dec 19, 2024
3a055ce
add requested changes anche changed dtos
silvanotamburini Dec 19, 2024
d832a07
small change of implementation
silvanotamburini Dec 19, 2024
0ebb3a2
change version
silvanotamburini Dec 19, 2024
5764283
renamed DTO
silvanotamburini Dec 19, 2024
e541827
renamed DTO in Dao
silvanotamburini Dec 19, 2024
c5c5dd7
change activity and implementation classify method parameters
silvanotamburini Dec 19, 2024
3e58446
change tests according to activity implementation
silvanotamburini Dec 19, 2024
6bcd856
change version
silvanotamburini Dec 19, 2024
901caf4
delete useless local method
silvanotamburini Dec 20, 2024
7e40522
fix maintanability issue on previous code change
silvanotamburini Dec 20, 2024
fb9d24f
requested changes made
silvanotamburini Dec 20, 2024
1734488
rename wrong naming of test class
silvanotamburini Dec 20, 2024
44b51ae
Merge branch 'main' into P4ADEV-1625-classifyiufactivity-retrieve-iuv…
silvanotamburini Dec 20, 2024
467d07f
fix list veriification
silvanotamburini Dec 20, 2024
8962b12
insert verify on mocks
silvanotamburini Dec 23, 2024
b140b6f
change version
silvanotamburini Dec 23, 2024
ee161d4
change version
silvanotamburini Dec 23, 2024
4029eeb
Merge branch 'main' into P4ADEV-1625-classifyiufactivity-retrieve-iuv…
silvanotamburini Dec 23, 2024
97a6921
chenge test
silvanotamburini Dec 23, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Original file line number Diff line number Diff line change
@@ -1,15 +1,23 @@
package it.gov.pagopa.payhub.activities.activity.classifications;

import io.temporal.activity.ActivityInterface;
import io.temporal.activity.ActivityMethod;
import it.gov.pagopa.payhub.activities.dto.classifications.IufClassificationActivityResult;

/**
* Interface for defining an activity to process payment reporting classifications based on IUF.
*/
@ActivityInterface
public interface IufClassificationActivity {

/**
* Processes IUF classification based on the provided parameters.
*
* @param organizationId the unique identifier of the organization
* @param treasuryId the unique identifier of treasury
* @param iuf the unique identifier of the payment reporting flow (IUF)
* @return true if the classification is successful, false otherwise
* @return IufClassificationActivityResult containing a list of payments and success flag
*/
boolean classify(String organizationId, String iuf);
@ActivityMethod
IufClassificationActivityResult classify(Long organizationId, Long treasuryId, String iuf);
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,71 @@
package it.gov.pagopa.payhub.activities.activity.classifications;

import it.gov.pagopa.payhub.activities.dao.ClassificationDao;
import it.gov.pagopa.payhub.activities.dao.PaymentsReportingDao;
import it.gov.pagopa.payhub.activities.dto.classifications.ClassificationDTO;
import it.gov.pagopa.payhub.activities.dto.classifications.IufClassificationActivityResult;
import it.gov.pagopa.payhub.activities.dto.classifications.Transfer2ClassifyDTO;
import it.gov.pagopa.payhub.activities.enums.ClassificationsEnum;
import lombok.extern.slf4j.Slf4j;
import org.springframework.context.annotation.Lazy;
import org.springframework.stereotype.Component;

import java.util.List;

@Slf4j
@Lazy
@Component
public class IufClassificationActivityImpl implements IufClassificationActivity {
private final PaymentsReportingDao paymentsReportingDao;
private final ClassificationDao classificationDao;

public IufClassificationActivityImpl(PaymentsReportingDao paymentsReportingDao, ClassificationDao classificationDao) {
this.paymentsReportingDao = paymentsReportingDao;
this.classificationDao = classificationDao;
}

@Override
public IufClassificationActivityResult classify(Long organizationId, Long treasuryId, String iuf) {
log.debug("Starting IUF Classification for organization id {} and iuf {}", organizationId,iuf);

List<Transfer2ClassifyDTO> transfers2classify =
paymentsReportingDao.findByOrganizationIdAndIuf(organizationId, iuf)
.stream()
.map(paymentsReportingDTO ->
Transfer2ClassifyDTO.builder()
.iuv(paymentsReportingDTO.getCreditorReferenceId())
.iur(paymentsReportingDTO.getRegulationUniqueIdentifier())
.transferIndex(paymentsReportingDTO.getTransferIndex())
.build())
.toList();

if (transfers2classify.isEmpty()) {
log.debug("Saving payments reporting found for organization id {} and iuf: {}", organizationId, iuf);
saveClassification(organizationId, treasuryId, iuf);
}

return IufClassificationActivityResult.builder()
.organizationId(organizationId)
.transfers2classify(transfers2classify)
.success(true)
.build();
}

/**
* save classification data
*
* @param organizationId organization id
* @param treasuryId treasury id
* @param iuf flow unique identifier
*/
private void saveClassification(Long organizationId, Long treasuryId, String iuf) {
log.debug("Saving classification TES_NO_MATCH for organizationId: {} - treasuryId: {} - iuf: {}", organizationId, treasuryId, iuf);

classificationDao.save(ClassificationDTO.builder()
.organizationId(organizationId)
.treasuryId(treasuryId)
.iuf(iuf)
.classificationsEnum(ClassificationsEnum.TES_NO_MATCH)
.build());
}
}
Original file line number Diff line number Diff line change
@@ -1,18 +1,27 @@
package it.gov.pagopa.payhub.activities.dao;

import it.gov.pagopa.payhub.activities.dto.classifications.ClassificationDTO;
import it.gov.pagopa.payhub.activities.enums.ClassificationsEnum;

/**
* Data Access Object interface for saving payments classification
* Data Access Object interface for saving payments classification
*/
public interface ClassificationDao {
/**
* save classification
*
* @param organizationId organization id
* @param iuf fow identifier
* @param classification classification to delete
* @return true for success deletion
*/
* @param classificationDTO dto classification to save
*/
void save(ClassificationDTO classificationDTO);

/**
* delete classification
*
* @param organizationId organization id
* @param iuf fow identifier
* @param classification classification to delete
* @return true for success deletion
*/
boolean deleteClassificationByIuf(Long organizationId, String iuf, ClassificationsEnum classification);

/**
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -18,4 +18,13 @@ public interface PaymentsReportingDao {
* fields (e.g., generated IDs or timestamps).
*/
List<PaymentsReportingDTO> saveAll(List<PaymentsReportingDTO> dtos);

/**
*
* @param organizationId organization id
* @param iuf identifies a specific reporting code
* @return List of PaymentsReportingDTO objects that may be an empty list
*/
List<PaymentsReportingDTO> findByOrganizationIdAndIuf(Long organizationId, String iuf);

}
Original file line number Diff line number Diff line change
@@ -0,0 +1,29 @@
package it.gov.pagopa.payhub.activities.dto.classifications;

import it.gov.pagopa.payhub.activities.enums.ClassificationsEnum;
import lombok.AllArgsConstructor;
import lombok.Builder;
import lombok.Data;
import lombok.NoArgsConstructor;

import java.io.Serializable;
import java.time.LocalDate;

@Data
@Builder(toBuilder = true)
@NoArgsConstructor
@AllArgsConstructor
public class ClassificationDTO implements Serializable {
private Long organizationId;
private Long transferId;
private Long paymentNotifyId;
private Long paymentReportingId;
private Long treasuryId;
private String iuf;
private String iud;
private String iuv;
private String iur;
private int transferIndex;
private ClassificationsEnum classificationsEnum;
private LocalDate creationDate;
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,18 @@
package it.gov.pagopa.payhub.activities.dto.classifications;

import lombok.AllArgsConstructor;
import lombok.Builder;
import lombok.Data;
import lombok.NoArgsConstructor;

import java.util.List;

@Data
@Builder(toBuilder = true)
@NoArgsConstructor
@AllArgsConstructor
public class IufClassificationActivityResult {
private Long organizationId;
private List<Transfer2ClassifyDTO> transfers2classify;
private boolean success;
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,16 @@
package it.gov.pagopa.payhub.activities.dto.classifications;

import lombok.AllArgsConstructor;
import lombok.Builder;
import lombok.Data;
import lombok.NoArgsConstructor;

@Data
@Builder(toBuilder = true)
@NoArgsConstructor
@AllArgsConstructor
public class Transfer2ClassifyDTO {
private String iuv;
private String iur;
private int transferIndex;
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,112 @@
package it.gov.pagopa.payhub.activities.activity.classifications;

import it.gov.pagopa.payhub.activities.dao.ClassificationDao;
import it.gov.pagopa.payhub.activities.dao.PaymentsReportingDao;
import it.gov.pagopa.payhub.activities.dto.classifications.ClassificationDTO;
import it.gov.pagopa.payhub.activities.dto.classifications.Transfer2ClassifyDTO;
import it.gov.pagopa.payhub.activities.dto.classifications.IufClassificationActivityResult;
import it.gov.pagopa.payhub.activities.dto.paymentsreporting.PaymentsReportingDTO;
import it.gov.pagopa.payhub.activities.utility.faker.ClassificationFaker;
import it.gov.pagopa.payhub.activities.utility.faker.PaymentsReportingFaker;
import org.junit.jupiter.api.AfterEach;
import org.junit.jupiter.api.BeforeEach;
import org.junit.jupiter.api.Test;
import org.junit.jupiter.api.extension.ExtendWith;
import org.mockito.Mock;
import org.mockito.Mockito;
import org.mockito.junit.jupiter.MockitoExtension;

import java.util.ArrayList;
import java.util.List;

import static org.junit.jupiter.api.Assertions.assertEquals;
import static org.mockito.Mockito.when;

@ExtendWith(MockitoExtension.class)
class IufClassificationActivityTest {
@Mock
private PaymentsReportingDao paymentsReportingDaoMock;

@Mock
private ClassificationDao classificationDaoMock;

private IufClassificationActivity iufClassificationActivity;

private static final Long ORGANIZATIONID = 1L;
private static final Long TREASURYID = 1L;
private static final String IUF = "IUF";

@BeforeEach
void init() {
iufClassificationActivity = new IufClassificationActivityImpl(paymentsReportingDaoMock, classificationDaoMock);
}

@AfterEach
void verifyNoMoreInteractions(){
Mockito.verifyNoMoreInteractions(paymentsReportingDaoMock,classificationDaoMock);
}

antonioT90 marked this conversation as resolved.
Show resolved Hide resolved
@Test
void givenReportedTransferWhenClassifyThenOk() {
ClassificationDTO classificationDTO = ClassificationFaker.buildClassificationDTO();

PaymentsReportingDTO expectedPaymentsReportingDTO = PaymentsReportingFaker.buildClassifyResultDTO();
List<PaymentsReportingDTO> expectedPaymentsReportingDTOS = new ArrayList<>();
expectedPaymentsReportingDTOS.add(expectedPaymentsReportingDTO);

List<Transfer2ClassifyDTO> expectedTransfer2ClassifyDTOS =
expectedPaymentsReportingDTOS
.stream()
.map(paymentsReportingDTO ->
Transfer2ClassifyDTO.builder()
.iuv(paymentsReportingDTO.getCreditorReferenceId())
.iur(paymentsReportingDTO.getRegulationUniqueIdentifier())
.transferIndex(paymentsReportingDTO.getTransferIndex())
.build())
.toList();

IufClassificationActivityResult expectedIufClassificationActivityResult =
IufClassificationActivityResult
.builder()
.organizationId(1L)
.transfers2classify(expectedTransfer2ClassifyDTOS)
.success(true)
.build();

when(paymentsReportingDaoMock.findByOrganizationIdAndIuf(ORGANIZATIONID, IUF))
.thenReturn(expectedPaymentsReportingDTOS);

IufClassificationActivityResult iufClassificationActivityResult =
iufClassificationActivity.classify(ORGANIZATIONID, TREASURYID, IUF);

assertEquals(iufClassificationActivityResult,expectedIufClassificationActivityResult);

Mockito.verify(paymentsReportingDaoMock, Mockito.times(1)).findByOrganizationIdAndIuf(ORGANIZATIONID, IUF);
Mockito.verify(classificationDaoMock, Mockito.times(0)).save(classificationDTO);
}

@Test
void givenNoReportedTransferWhenClassifyThenAnomalyClassificationSave() {
ClassificationDTO classificationDTO = ClassificationFaker.buildClassificationDTO();

IufClassificationActivityResult expectedIufClassificationActivityResult =
IufClassificationActivityResult
.builder()
.organizationId(1L)
.transfers2classify(new ArrayList<>())
.success(true)
.build();

when(paymentsReportingDaoMock.findByOrganizationIdAndIuf(ORGANIZATIONID, IUF))
.thenReturn(new ArrayList<>());

IufClassificationActivityResult iufClassificationActivityResult =
iufClassificationActivity.classify(ORGANIZATIONID, TREASURYID, IUF);

assertEquals(iufClassificationActivityResult,expectedIufClassificationActivityResult);

Mockito.verify(paymentsReportingDaoMock, Mockito.times(1)).findByOrganizationIdAndIuf(ORGANIZATIONID, IUF);
Mockito.verify(classificationDaoMock, Mockito.times(1)).save(classificationDTO);
}
}

Original file line number Diff line number Diff line change
@@ -0,0 +1,16 @@
package it.gov.pagopa.payhub.activities.utility.faker;

import it.gov.pagopa.payhub.activities.dto.classifications.ClassificationDTO;
import it.gov.pagopa.payhub.activities.enums.ClassificationsEnum;

public class ClassificationFaker {

public static ClassificationDTO buildClassificationDTO(){
return ClassificationDTO.builder()
.organizationId(1L)
.treasuryId(1L)
.iuf("IUF")
.classificationsEnum(ClassificationsEnum.TES_NO_MATCH)
.build();
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,15 @@
package it.gov.pagopa.payhub.activities.utility.faker;

import it.gov.pagopa.payhub.activities.dto.paymentsreporting.PaymentsReportingDTO;

public class PaymentsReportingFaker {

public static PaymentsReportingDTO buildClassifyResultDTO(){
return PaymentsReportingDTO.builder()
.organizationId(1L)
.creditorReferenceId("IUV")
.regulationUniqueIdentifier("IUR")
.transferIndex(1)
.build();
}
}
2 changes: 1 addition & 1 deletion version
Original file line number Diff line number Diff line change
@@ -1 +1 @@
1.20.0
1.20.2-SNAPSHOT
Loading