From 30697061c5a1678630c974fa7cdb07aee0cfd63c Mon Sep 17 00:00:00 2001 From: Marco Russo Date: Fri, 28 Feb 2025 12:18:33 +0000 Subject: [PATCH] Chore/split organisation endpoint test coverage tests (#171) * chore: moving test class * chore: adjusting tests * chore: adjusting tests * chore: spotless * chore: small refactoring for sonar issues --- ...ngCoreEventHandlerDuplicateEventsTest.java | 2 +- .../service/OrganisationServiceTest.java | 131 ----------- organisation/build.gradle.kts | 4 - .../domain/entity/Organisation.java | 3 - ...ionUpsert.java => OrganisationCreate.java} | 5 +- .../domain/request/OrganisationUpdate.java | 46 ++++ .../domain/view/OrganisationView.java | 13 +- .../resource/OrganisationResource.java | 83 ++++++- .../service/OrganisationService.java | 108 +++++---- ...3__lob_service_app_organisation_module.sql | 2 - .../service/OrganisationServiceTest.java | 210 ++++++++++++++++++ 11 files changed, 406 insertions(+), 201 deletions(-) delete mode 100644 accounting_reporting_core/src/test/java/org/cardanofoundation/lob/app/organisation/service/OrganisationServiceTest.java rename organisation/src/main/java/org/cardanofoundation/lob/app/organisation/domain/request/{OrganisationUpsert.java => OrganisationCreate.java} (92%) create mode 100644 organisation/src/main/java/org/cardanofoundation/lob/app/organisation/domain/request/OrganisationUpdate.java create mode 100644 organisation/src/test/java/org/cardanofoundation/lob/app/organisation/service/OrganisationServiceTest.java diff --git a/accounting_reporting_core/src/test/java/org/cardanofoundation/lob/app/accounting_reporting_core/service/internal/AccountingCoreEventHandlerDuplicateEventsTest.java b/accounting_reporting_core/src/test/java/org/cardanofoundation/lob/app/accounting_reporting_core/service/internal/AccountingCoreEventHandlerDuplicateEventsTest.java index 54b509a9..294a9512 100644 --- a/accounting_reporting_core/src/test/java/org/cardanofoundation/lob/app/accounting_reporting_core/service/internal/AccountingCoreEventHandlerDuplicateEventsTest.java +++ b/accounting_reporting_core/src/test/java/org/cardanofoundation/lob/app/accounting_reporting_core/service/internal/AccountingCoreEventHandlerDuplicateEventsTest.java @@ -71,7 +71,7 @@ class AccountingCoreEventHandlerDuplicateEventsTest { private TransactionReconcilationRepository transactionReconcilationRepository; @BeforeEach - public void clearDatabase(@Autowired Flyway flyway){ + void clearDatabase(@Autowired Flyway flyway){ flyway.clean(); flyway.migrate(); } diff --git a/accounting_reporting_core/src/test/java/org/cardanofoundation/lob/app/organisation/service/OrganisationServiceTest.java b/accounting_reporting_core/src/test/java/org/cardanofoundation/lob/app/organisation/service/OrganisationServiceTest.java deleted file mode 100644 index 748f1d60..00000000 --- a/accounting_reporting_core/src/test/java/org/cardanofoundation/lob/app/organisation/service/OrganisationServiceTest.java +++ /dev/null @@ -1,131 +0,0 @@ -package org.cardanofoundation.lob.app.organisation.service; - -import static org.junit.jupiter.api.Assertions.*; -import static org.mockito.ArgumentMatchers.any; -import static org.mockito.Mockito.when; - -import java.util.HashSet; -import java.util.List; -import java.util.Optional; -import java.util.Set; - -import org.mockito.InjectMocks; -import org.mockito.Mock; -import org.mockito.junit.jupiter.MockitoExtension; - -import org.junit.jupiter.api.BeforeEach; -import org.junit.jupiter.api.Test; -import org.junit.jupiter.api.extension.ExtendWith; - -import org.cardanofoundation.lob.app.organisation.domain.entity.Organisation; -import org.cardanofoundation.lob.app.organisation.domain.entity.OrganisationCostCenter; -import org.cardanofoundation.lob.app.organisation.domain.entity.OrganisationProject; -import org.cardanofoundation.lob.app.organisation.domain.request.OrganisationUpsert; -import org.cardanofoundation.lob.app.organisation.domain.view.OrganisationView; -import org.cardanofoundation.lob.app.organisation.repository.*; - -@ExtendWith(MockitoExtension.class) -class OrganisationServiceTest { - - @Mock - private OrganisationRepository organisationRepository; - - @Mock - private CostCenterService costCenterService; - - @Mock - private ProjectMappingRepository projectMappingRepository; - - @Mock - private OrganisationChartOfAccountTypeRepository organisationChartOfAccountTypeRepository; - - @Mock - private ChartOfAccountRepository organisationChartOfAccountRepository; - - @Mock - private OrganisationChartOfAccountSubTypeRepository organisationChartOfAccountSubTypeRepository; - - @Mock - private AccountEventRepository accountEventRepository; - - @Mock - private OrganisationCurrencyService organisationCurrencyService; - - @InjectMocks - private OrganisationService organisationService; - - private Organisation organisation; - - @BeforeEach - void setUp() { - organisation = new Organisation(); - organisation.setId("org-123"); - } - - @Test - void testFindById_WhenOrganisationExists() { - when(organisationRepository.findById("org-123")).thenReturn(Optional.of(organisation)); - Optional result = organisationService.findById("org-123"); - assertTrue(result.isPresent()); - assertEquals("org-123", result.get().getId()); - } - - @Test - void testFindById_WhenOrganisationDoesNotExist() { - when(organisationRepository.findById("org-123")).thenReturn(Optional.empty()); - Optional result = organisationService.findById("org-123"); - assertFalse(result.isPresent()); - } - - @Test - void testFindAll() { - List organisations = List.of(organisation); - when(organisationRepository.findAll()).thenReturn(organisations); - List result = organisationService.findAll(); - assertEquals(1, result.size()); - } - - @Test - void testGetAllCostCenter() { - Set costCenters = new HashSet<>(); - when(costCenterService.getAllCostCenter("org-123")).thenReturn(costCenters); - Set result = organisationService.getAllCostCenter("org-123"); - assertEquals(costCenters, result); - } - - @Test - void testGetAllProjects() { - Set projects = new HashSet<>(); - when(projectMappingRepository.findAllByOrganisationId("org-123")).thenReturn(projects); - Set result = organisationService.getAllProjects("org-123"); - assertEquals(projects, result); - } - - @Test - void testUpsertOrganisation_NewOrganisation() { - OrganisationUpsert organisationUpsert = new OrganisationUpsert(); - organisationUpsert.setCountryCode("US"); - organisationUpsert.setTaxIdNumber("12345"); - organisationUpsert.setAddress("Street"); - organisationUpsert.setName("Company name"); - organisationUpsert.setAdminEmail("the@email.com"); - organisationUpsert.setCity("City name"); - organisationUpsert.setCountry("Country name"); - organisationUpsert.setCurrencyId("ISO_4217:CHF"); - organisationUpsert.setPostCode("A127"); - organisationUpsert.setProvince("County co."); - organisationUpsert.setReportCurrencyId("ISO_4217:CHF"); - organisationUpsert.setPhoneNumber("0101010101"); - - when(organisationRepository.findById(any())).thenReturn(Optional.empty()); - when(organisationRepository.saveAndFlush(any())).thenReturn(organisation); - - OrganisationView result = organisationService.upsertOrganisation(organisationUpsert); - assertNotNull(result); - assertEquals("6d50ed2208aba5047f54a0b4e603d77463db27f108de9a268bb1670fa9afef11",result.getId()); - assertEquals("Street",result.getAddress()); - assertEquals("City name",result.getCity()); - assertEquals("Country name",result.getCountry()); - assertEquals("County co.",result.getProvince()); - } -} diff --git a/organisation/build.gradle.kts b/organisation/build.gradle.kts index fea992f5..c23fc91a 100644 --- a/organisation/build.gradle.kts +++ b/organisation/build.gradle.kts @@ -1,7 +1,3 @@ -plugins { - id("org.sonarqube") -} - dependencies { implementation("org.springframework.modulith:spring-modulith-api") diff --git a/organisation/src/main/java/org/cardanofoundation/lob/app/organisation/domain/entity/Organisation.java b/organisation/src/main/java/org/cardanofoundation/lob/app/organisation/domain/entity/Organisation.java index 711cc255..7a46be87 100644 --- a/organisation/src/main/java/org/cardanofoundation/lob/app/organisation/domain/entity/Organisation.java +++ b/organisation/src/main/java/org/cardanofoundation/lob/app/organisation/domain/entity/Organisation.java @@ -46,9 +46,6 @@ public class Organisation extends CommonEntity implements Persistable { @Column(name = "province", nullable = false) private String province; - @Column(name = "country", nullable = false) - private String country; - @Column(name = "address", nullable = false) private String address; diff --git a/organisation/src/main/java/org/cardanofoundation/lob/app/organisation/domain/request/OrganisationUpsert.java b/organisation/src/main/java/org/cardanofoundation/lob/app/organisation/domain/request/OrganisationCreate.java similarity index 92% rename from organisation/src/main/java/org/cardanofoundation/lob/app/organisation/domain/request/OrganisationUpsert.java rename to organisation/src/main/java/org/cardanofoundation/lob/app/organisation/domain/request/OrganisationCreate.java index b5ba60b5..fc3c4f17 100644 --- a/organisation/src/main/java/org/cardanofoundation/lob/app/organisation/domain/request/OrganisationUpsert.java +++ b/organisation/src/main/java/org/cardanofoundation/lob/app/organisation/domain/request/OrganisationCreate.java @@ -11,7 +11,7 @@ @Setter @AllArgsConstructor @NoArgsConstructor -public class OrganisationUpsert { +public class OrganisationCreate { @Schema(example = "My company name") private String name; @@ -25,9 +25,6 @@ public class OrganisationUpsert { @Schema(example = "Co. Wexford") private String province; - @Schema(example = "Ireland") - private String country; - @Schema(example = "IE") private String countryCode; diff --git a/organisation/src/main/java/org/cardanofoundation/lob/app/organisation/domain/request/OrganisationUpdate.java b/organisation/src/main/java/org/cardanofoundation/lob/app/organisation/domain/request/OrganisationUpdate.java new file mode 100644 index 00000000..047c5ea8 --- /dev/null +++ b/organisation/src/main/java/org/cardanofoundation/lob/app/organisation/domain/request/OrganisationUpdate.java @@ -0,0 +1,46 @@ +package org.cardanofoundation.lob.app.organisation.domain.request; + +import lombok.AllArgsConstructor; +import lombok.Getter; +import lombok.NoArgsConstructor; +import lombok.Setter; + +import io.swagger.v3.oas.annotations.media.Schema; + +@Getter +@Setter +@AllArgsConstructor +@NoArgsConstructor +public class OrganisationUpdate { + + @Schema(example = "My company name") + private String name; + + @Schema(example = "Ballyhealy") + private String city; + + @Schema(example = "Y35 C6KC") + private String postCode; + + @Schema(example = "Co. Wexford") + private String province; + + @Schema(example = "Ballyhealy Cottage") + private String address; + + @Schema(example = "0035863286566") + private String phoneNumber; + + @Schema(example = "lob@cardanofoundation.org") + private String adminEmail; + + @Schema(example = "http://cardanofoundation.org") + private String websiteUrl; + + @Schema(example = "ISO_4217:CHF") + private String currencyId; + + @Schema(example = "ISO_4217:CHF") + private String reportCurrencyId; + +} diff --git a/organisation/src/main/java/org/cardanofoundation/lob/app/organisation/domain/view/OrganisationView.java b/organisation/src/main/java/org/cardanofoundation/lob/app/organisation/domain/view/OrganisationView.java index 7a463fe1..9d5b07b1 100644 --- a/organisation/src/main/java/org/cardanofoundation/lob/app/organisation/domain/view/OrganisationView.java +++ b/organisation/src/main/java/org/cardanofoundation/lob/app/organisation/domain/view/OrganisationView.java @@ -28,9 +28,12 @@ public class OrganisationView { @Schema(example = "CHE-184477354") String taxIdNumber; - @Schema(example = "Currency Id") + @Schema(example = "CHE") String currencyId; + @Schema(example = "CHE") + String reportCurrencyId; + @JsonFormat(shape = JsonFormat.Shape.STRING, pattern = "yyyy-MM-dd") @Schema(example = "2021-02-05") LocalDate accountPeriodFrom; @@ -57,15 +60,17 @@ public class OrganisationView { @Schema(example = "Co. Wexford") private String province; - @Schema(example = "Ireland") - private String country; + @Schema(example = "IE") + private String countryCode; - private Set costCenter; + private Set costCenters; private Set projects; private Set organisationCurrencies; + private String webSite; + @Schema(example = "") private String logo; diff --git a/organisation/src/main/java/org/cardanofoundation/lob/app/organisation/resource/OrganisationResource.java b/organisation/src/main/java/org/cardanofoundation/lob/app/organisation/resource/OrganisationResource.java index 6e2fd290..edb11f9b 100644 --- a/organisation/src/main/java/org/cardanofoundation/lob/app/organisation/resource/OrganisationResource.java +++ b/organisation/src/main/java/org/cardanofoundation/lob/app/organisation/resource/OrganisationResource.java @@ -26,7 +26,9 @@ import org.zalando.problem.Problem; import org.zalando.problem.Status; -import org.cardanofoundation.lob.app.organisation.domain.request.OrganisationUpsert; +import org.cardanofoundation.lob.app.organisation.domain.entity.Organisation; +import org.cardanofoundation.lob.app.organisation.domain.request.OrganisationCreate; +import org.cardanofoundation.lob.app.organisation.domain.request.OrganisationUpdate; import org.cardanofoundation.lob.app.organisation.domain.view.*; import org.cardanofoundation.lob.app.organisation.service.OrganisationService; @@ -59,6 +61,7 @@ public ResponseEntity organisationList() { organisation.getTaxIdNumber(), organisation.getTaxIdNumber(), organisation.getCurrencyId(), + organisation.getReportCurrencyId(), monthsAgo, yesterday, organisation.getAdminEmail(), @@ -67,10 +70,11 @@ public ResponseEntity organisationList() { organisation.getCity(), organisation.getPostCode(), organisation.getProvince(), - organisation.getCountry(), + organisation.getCountryCode(), new LinkedHashSet<>(), new LinkedHashSet<>(), new LinkedHashSet<>(), + organisation.getWebSite(), organisation.getLogo() ); }).toList() @@ -201,6 +205,47 @@ public ResponseEntity> organisationEvent(@PathVariab } + @Operation(description = "Organistion create", responses = { + @ApiResponse(content = + {@Content(mediaType = "application/json", schema = @Schema(implementation = OrganisationView.class))} + ), + @ApiResponse(responseCode = "404", description = "Error: response status is 404", content = {@Content(mediaType = "application/json", schema = @Schema(example = "{\n" + + " \"title\": \"ORGANISATION_ALREADY_EXIST\",\n" + + " \"status\": 404,\n" + + " \"detail\": \"Unable to crate Organisation with IdNumber\"\n" + + "}"))}) + }) + @PostMapping(value = "/organisation", produces = "application/json") + @PreAuthorize("hasRole(@securityConfig.getManagerRole())") + public ResponseEntity organisationCreate(@Valid @RequestBody OrganisationCreate organisationCreate) { + + Optional organisationChe = organisationService.findById(Organisation.id(organisationCreate.getCountryCode(), organisationCreate.getTaxIdNumber())); + if (organisationChe.isPresent()) { + val issue = Problem.builder() + .withTitle("ORGANISATION_ALREADY_EXIST") + .withDetail(STR."Unable to crate Organisation with IdNumber: \{organisationCreate.getTaxIdNumber()} and CountryCode: \{organisationCreate.getCountryCode()}") + .withStatus(Status.NOT_FOUND) + .build(); + + return ResponseEntity.status(issue.getStatus().getStatusCode()).body(issue); + } + + Optional organisation = organisationService.createOrganisation(organisationCreate).map(organisationService::getOrganisationView); + if (organisation.isEmpty()) { + val issue = Problem.builder() + .withTitle("ORGANISATION_CREATE_ERROR") + .withDetail(STR."Unable to create Organisation by Id: \{organisationCreate.getName()}") + .withStatus(Status.NOT_FOUND) + .build(); + + return ResponseEntity.status(issue.getStatus().getStatusCode()).body(issue); + } + + return ResponseEntity.ok().body(organisation.get()); + + + } + @Operation(description = "Organistion update", responses = { @ApiResponse(content = {@Content(mediaType = "application/json", schema = @Schema(implementation = OrganisationView.class))} @@ -209,13 +254,41 @@ public ResponseEntity> organisationEvent(@PathVariab " \"title\": \"Organisation not found\",\n" + " \"status\": 404,\n" + " \"detail\": \"Unable to get the organisation\"\n" + + "}"))}), + @ApiResponse(responseCode = "404", description = "Error: response status is 404", content = {@Content(mediaType = "application/json", schema = @Schema(example = "{\n" + + " \"title\": \"ORGANISATION_UPDATE_ERROR\",\n" + + " \"status\": 404,\n" + + " \"detail\": \"Unable to create Organisation\"\n" + "}"))}) }) - @PutMapping(value = "/organisation", produces = "application/json") + @PutMapping(value = "/organisation/{orgId}", produces = "application/json") @PreAuthorize("hasRole(@securityConfig.getManagerRole())") - public ResponseEntity organisationUpsertOrganisation(@Valid @RequestBody OrganisationUpsert organisationUpsert) { + public ResponseEntity organisationUpdate(@PathVariable("orgId") @Parameter(example = "75f95560c1d883ee7628993da5adf725a5d97a13929fd4f477be0faf5020ca94") String orgId, @Valid @RequestBody OrganisationUpdate organisationUpdate) { + Optional organisationChe = organisationService.findById(orgId); + if (organisationChe.isEmpty()) { + val issue = Problem.builder() + .withTitle("ORGANISATION_NOT_FOUND") + .withDetail(STR."Unable to find Organisation by Id: \{orgId}") + .withStatus(Status.NOT_FOUND) + .build(); + + return ResponseEntity.status(issue.getStatus().getStatusCode()).body(issue); + } + + Optional organisation = organisationService.upsertOrganisation(organisationChe.get(), organisationUpdate).map(organisationService::getOrganisationView); + if (organisation.isEmpty()) { + val issue = Problem.builder() + .withTitle("ORGANISATION_UPDATE_ERROR") + .withDetail(STR."Unable to create Organisation by Id: \{organisationUpdate.getName()}") + .withStatus(Status.NOT_FOUND) + .build(); + + return ResponseEntity.status(issue.getStatus().getStatusCode()).body(issue); + } + + return ResponseEntity.ok().body(organisation.get()); + - return ResponseEntity.ok().body(organisationService.upsertOrganisation(organisationUpsert)); } } diff --git a/organisation/src/main/java/org/cardanofoundation/lob/app/organisation/service/OrganisationService.java b/organisation/src/main/java/org/cardanofoundation/lob/app/organisation/service/OrganisationService.java index 8fbc6a35..2cec1e5f 100644 --- a/organisation/src/main/java/org/cardanofoundation/lob/app/organisation/service/OrganisationService.java +++ b/organisation/src/main/java/org/cardanofoundation/lob/app/organisation/service/OrganisationService.java @@ -13,7 +13,8 @@ import org.springframework.transaction.annotation.Transactional; import org.cardanofoundation.lob.app.organisation.domain.entity.*; -import org.cardanofoundation.lob.app.organisation.domain.request.OrganisationUpsert; +import org.cardanofoundation.lob.app.organisation.domain.request.OrganisationCreate; +import org.cardanofoundation.lob.app.organisation.domain.request.OrganisationUpdate; import org.cardanofoundation.lob.app.organisation.domain.view.OrganisationCostCenterView; import org.cardanofoundation.lob.app.organisation.domain.view.OrganisationView; import org.cardanofoundation.lob.app.organisation.repository.*; @@ -29,11 +30,8 @@ public class OrganisationService { private final ProjectMappingRepository projectMappingRepository; private final OrganisationChartOfAccountTypeRepository organisationChartOfAccountTypeRepository; private final ChartOfAccountRepository organisationChartOfAccountRepository; - private final OrganisationChartOfAccountSubTypeRepository organisationChartOfAccountSubTypeRepository; private final AccountEventRepository accountEventRepository; private final OrganisationCurrencyService organisationCurrencyService; - private final OrganisationChartOfAccountSubTypeRepository chartOfAccountSubTypeRepository; - public Optional findById(String organisationId) { return organisationRepository.findById(organisationId); @@ -65,25 +63,39 @@ public Set getOrganisationEventCode(String orgId) { } @Transactional - public OrganisationView upsertOrganisation(OrganisationUpsert organisationUpsert) { - Optional organisationO = findById(Organisation.id(organisationUpsert.getCountryCode(), organisationUpsert.getTaxIdNumber())); - if (organisationO.isEmpty()) { - organisationO = Optional.of(new Organisation()); - organisationO.get().setId(Organisation.id(organisationUpsert.getCountryCode(), organisationUpsert.getTaxIdNumber())); - organisationO.get().setCountryCode(organisationUpsert.getCountryCode()); - organisationO.get().setTaxIdNumber(organisationUpsert.getTaxIdNumber()); - /** - * Those fields are needed but at the moment we don't want to set it from UI CRUD - */ - organisationO.get().setDummyAccount("0000000000"); - organisationO.get().setAccountPeriodDays(7305); - } - - - Organisation organisation = getOrganisation(organisationUpsert, organisationO); + public Optional createOrganisation(OrganisationCreate organisationCreate){ + + Organisation organisationO = new Organisation(); + organisationO.setId(Organisation.id(organisationCreate.getCountryCode(), organisationCreate.getTaxIdNumber())); + organisationO.setCountryCode(organisationCreate.getCountryCode()); + organisationO.setTaxIdNumber(organisationCreate.getTaxIdNumber()); + /** + * Those fields are needed but at the moment we don't want to set it from UI CRUD + */ + organisationO.setDummyAccount("0000000000"); + organisationO.setAccountPeriodDays(7305); + Organisation organisation = getOrganisation(organisationCreate, organisationO); organisationRepository.saveAndFlush(organisation); - return getOrganisationView(organisation); + return Optional.of(organisation); + } + + @Transactional + public Optional upsertOrganisation(Organisation organisationO, OrganisationUpdate organisationUpdate) { + + organisationO.setName(organisationUpdate.getName()); + organisationO.setCity(organisationUpdate.getCity()); + organisationO.setPostCode(organisationUpdate.getPostCode()); + organisationO.setProvince(organisationUpdate.getProvince()); + organisationO.setAddress(organisationUpdate.getAddress()); + organisationO.setPhoneNumber(organisationUpdate.getPhoneNumber()); + organisationO.setAdminEmail(organisationUpdate.getAdminEmail()); + organisationO.setWebSite(organisationUpdate.getWebsiteUrl()); + organisationO.setCurrencyId(organisationUpdate.getCurrencyId()); + organisationO.setReportCurrencyId(organisationUpdate.getReportCurrencyId()); + + Organisation organisation = organisationRepository.saveAndFlush(organisationO); + return Optional.of(organisation); } @@ -95,9 +107,10 @@ public OrganisationView getOrganisationView(Organisation organisation) { return new OrganisationView( organisation.getId(), organisation.getName(), - organisation.getTaxIdNumber(), + "", // Description is deprecated and should be removed organisation.getTaxIdNumber(), organisation.getCurrencyId(), + organisation.getReportCurrencyId(), monthsAgo, yesterday, organisation.getAdminEmail(), @@ -106,43 +119,44 @@ public OrganisationView getOrganisationView(Organisation organisation) { organisation.getCity(), organisation.getPostCode(), organisation.getProvince(), - organisation.getCountry(), - getAllCostCenter(organisation.getId()).stream().map(organisationCostCenter -> { - return new OrganisationCostCenterView( + organisation.getCountryCode(), + getAllCostCenter(organisation.getId()).stream().map(organisationCostCenter -> + new OrganisationCostCenterView( organisationCostCenter.getId() != null ? organisationCostCenter.getId().getCustomerCode() : null, organisationCostCenter.getExternalCustomerCode(), organisationCostCenter.getName() - ); - }).collect(Collectors.toSet()), - getAllProjects(organisation.getId()).stream().map(organisationProject -> { - return new OrganisationCostCenterView( + )).collect(Collectors.toSet()), + getAllProjects(organisation.getId()).stream().map(organisationProject -> + new OrganisationCostCenterView( organisationProject.getId() != null ? organisationProject.getId().getCustomerCode() : null, organisationProject.getExternalCustomerCode(), organisationProject.getName() - ); - }).collect(Collectors.toSet()), + )).collect(Collectors.toSet()), organisationCurrencyService.findAllByOrganisationId(organisation.getId()) .stream() - .map(organisationCurrency -> { - return organisationCurrency.getId() != null ? organisationCurrency.getId().getCustomerCode() : null; - }).collect(Collectors.toSet()), + .map(organisationCurrency -> + organisationCurrency.getId() != null ? organisationCurrency.getId().getCustomerCode() : null + ).collect(Collectors.toSet()), + organisation.getWebSite(), organisation.getLogo() ); } - private static Organisation getOrganisation(OrganisationUpsert organisationUpsert, Optional organisationO) { - Organisation organisation = organisationO.get(); - organisation.setName(organisationUpsert.getName()); - organisation.setCity(organisationUpsert.getCity()); - organisation.setPostCode(organisationUpsert.getPostCode()); - organisation.setProvince(organisationUpsert.getProvince()); - organisation.setCountry(organisationUpsert.getCountry()); - organisation.setAddress(organisationUpsert.getAddress()); - organisation.setCurrencyId(organisationUpsert.getCurrencyId()); - organisation.setReportCurrencyId(organisationUpsert.getReportCurrencyId()); - organisation.setPhoneNumber(organisationUpsert.getPhoneNumber()); - organisation.setAdminEmail(organisationUpsert.getAdminEmail()); - organisation.setWebSite(organisationUpsert.getWebsiteUrl()); + private static Organisation getOrganisation(OrganisationCreate organisationCreate, Organisation organisation) { + organisation.setName(organisationCreate.getName()); + organisation.setCity(organisationCreate.getCity()); + organisation.setPostCode(organisationCreate.getPostCode()); + organisation.setProvince(organisationCreate.getProvince()); + organisation.setAddress(organisationCreate.getAddress()); + organisation.setPhoneNumber(organisationCreate.getPhoneNumber()); + organisation.setAdminEmail(organisationCreate.getAdminEmail()); + organisation.setWebSite(organisationCreate.getWebsiteUrl()); + organisation.setCurrencyId(organisationCreate.getCurrencyId()); + organisation.setReportCurrencyId(organisationCreate.getReportCurrencyId()); + + + + return organisation; } diff --git a/organisation/src/main/resources/db/migration/postgresql/common/V1.0_100_3__lob_service_app_organisation_module.sql b/organisation/src/main/resources/db/migration/postgresql/common/V1.0_100_3__lob_service_app_organisation_module.sql index fadf565c..c16ce70f 100644 --- a/organisation/src/main/resources/db/migration/postgresql/common/V1.0_100_3__lob_service_app_organisation_module.sql +++ b/organisation/src/main/resources/db/migration/postgresql/common/V1.0_100_3__lob_service_app_organisation_module.sql @@ -12,7 +12,6 @@ CREATE TABLE IF NOT EXISTS organisation ( city VARCHAR(255) NOT NULL, post_code VARCHAR(255) NOT NULL, province VARCHAR(255) NOT NULL, - country VARCHAR(255) NOT NULL, address VARCHAR(255) NOT NULL, admin_email VARCHAR(255) NOT NULL, pre_approve_transactions BOOLEAN, @@ -41,7 +40,6 @@ CREATE TABLE IF NOT EXISTS organisation_aud ( city VARCHAR(255) NOT NULL, post_code VARCHAR(255) NOT NULL, province VARCHAR(255) NOT NULL, - country VARCHAR(255) NOT NULL, address VARCHAR(255) NOT NULL, admin_email VARCHAR(255) NOT NULL, pre_approve_transactions BOOLEAN, diff --git a/organisation/src/test/java/org/cardanofoundation/lob/app/organisation/service/OrganisationServiceTest.java b/organisation/src/test/java/org/cardanofoundation/lob/app/organisation/service/OrganisationServiceTest.java new file mode 100644 index 00000000..947ed111 --- /dev/null +++ b/organisation/src/test/java/org/cardanofoundation/lob/app/organisation/service/OrganisationServiceTest.java @@ -0,0 +1,210 @@ +package org.cardanofoundation.lob.app.organisation.service; + +import static org.junit.jupiter.api.Assertions.*; +import static org.mockito.ArgumentMatchers.any; +import static org.mockito.ArgumentMatchers.anyString; +import static org.mockito.Mockito.verify; +import static org.mockito.Mockito.verifyNoMoreInteractions; +import static org.mockito.Mockito.when; + +import java.util.HashSet; +import java.util.List; +import java.util.Optional; +import java.util.Set; + +import org.mockito.InjectMocks; +import org.mockito.Mock; +import org.mockito.junit.jupiter.MockitoExtension; + +import org.junit.jupiter.api.BeforeEach; +import org.junit.jupiter.api.Test; +import org.junit.jupiter.api.extension.ExtendWith; + +import org.cardanofoundation.lob.app.organisation.domain.entity.Organisation; +import org.cardanofoundation.lob.app.organisation.domain.entity.OrganisationCostCenter; +import org.cardanofoundation.lob.app.organisation.domain.entity.OrganisationCurrency; +import org.cardanofoundation.lob.app.organisation.domain.entity.OrganisationProject; +import org.cardanofoundation.lob.app.organisation.domain.request.OrganisationCreate; +import org.cardanofoundation.lob.app.organisation.domain.request.OrganisationUpdate; +import org.cardanofoundation.lob.app.organisation.domain.view.OrganisationView; +import org.cardanofoundation.lob.app.organisation.repository.*; + +@ExtendWith(MockitoExtension.class) +class OrganisationServiceTest { + + @Mock + private OrganisationRepository organisationRepository; + + @Mock + private CostCenterService costCenterService; + + @Mock + private ProjectMappingRepository projectMappingRepository; + + @Mock + private OrganisationChartOfAccountTypeRepository organisationChartOfAccountTypeRepository; + + @Mock + private ChartOfAccountRepository organisationChartOfAccountRepository; + + @Mock + private AccountEventRepository accountEventRepository; + + @Mock + private OrganisationCurrencyService organisationCurrencyService; + + @InjectMocks + private OrganisationService organisationService; + + private Organisation organisation; + + @BeforeEach + void setUp() { + organisation = new Organisation(); + organisation.setId("f3b7485e96cc45b98e825a48a80d856be260b53de5fe45f23287da5b4970b9b0"); + organisation.setCountryCode("IE"); + organisation.setTaxIdNumber("1"); + } + + @Test + void testFindById_WhenOrganisationExists() { + when(organisationRepository.findById("f3b7485e96cc45b98e825a48a80d856be260b53de5fe45f23287da5b4970b9b0")).thenReturn(Optional.of(organisation)); + Optional result = organisationService.findById("f3b7485e96cc45b98e825a48a80d856be260b53de5fe45f23287da5b4970b9b0"); + assertTrue(result.isPresent()); + assertEquals("f3b7485e96cc45b98e825a48a80d856be260b53de5fe45f23287da5b4970b9b0", result.get().getId()); + } + + @Test + void testFindById_WhenOrganisationDoesNotExist() { + when(organisationRepository.findById("f3b7485e96cc45b98e825a48a80d856be260b53de5fe45f23287da5b4970b9b0")).thenReturn(Optional.empty()); + Optional result = organisationService.findById("f3b7485e96cc45b98e825a48a80d856be260b53de5fe45f23287da5b4970b9b0"); + assertFalse(result.isPresent()); + } + + @Test + void testFindAll() { + List organisations = List.of(organisation); + when(organisationRepository.findAll()).thenReturn(organisations); + List result = organisationService.findAll(); + assertEquals(1, result.size()); + } + + @Test + void testGetAllCostCenter() { + Set costCenters = new HashSet<>(); + when(costCenterService.getAllCostCenter("f3b7485e96cc45b98e825a48a80d856be260b53de5fe45f23287da5b4970b9b0")).thenReturn(costCenters); + Set result = organisationService.getAllCostCenter("f3b7485e96cc45b98e825a48a80d856be260b53de5fe45f23287da5b4970b9b0"); + assertEquals(costCenters, result); + } + + @Test + void testGetAllProjects() { + Set projects = new HashSet<>(); + when(projectMappingRepository.findAllByOrganisationId("f3b7485e96cc45b98e825a48a80d856be260b53de5fe45f23287da5b4970b9b0")).thenReturn(projects); + Set result = organisationService.getAllProjects("f3b7485e96cc45b98e825a48a80d856be260b53de5fe45f23287da5b4970b9b0"); + assertEquals(projects, result); + verify(projectMappingRepository).findAllByOrganisationId("f3b7485e96cc45b98e825a48a80d856be260b53de5fe45f23287da5b4970b9b0"); + verifyNoMoreInteractions(projectMappingRepository); + } + + @Test + void testUpsertOrganisation_NewOrganisation() { + + OrganisationUpdate organisationUpdate = new OrganisationUpdate(); + organisationUpdate.setAddress("Street"); + organisationUpdate.setName("Company name"); + organisationUpdate.setAdminEmail("the@email.com"); + organisationUpdate.setCity("City name"); + organisationUpdate.setCurrencyId("ISO_4217:CHF"); + organisationUpdate.setPostCode("A127"); + organisationUpdate.setProvince("County co."); + organisationUpdate.setReportCurrencyId("ISO_4217:CHF"); + organisationUpdate.setPhoneNumber("0101010101"); + + when(organisationRepository.saveAndFlush(any())).thenReturn(organisation); + + Organisation result = organisationService.upsertOrganisation(organisation, organisationUpdate).get(); + assertNotNull(result); + assertEquals("f3b7485e96cc45b98e825a48a80d856be260b53de5fe45f23287da5b4970b9b0",result.getId()); + assertEquals("Street",result.getAddress()); + assertEquals("City name",result.getCity()); + assertEquals("County co.",result.getProvince()); + verify(organisationRepository).saveAndFlush(any()); + verifyNoMoreInteractions(organisationRepository); + } + + @Test + void testCreateOrganisation_NewOrganisation() { + OrganisationCreate organisationCreate = new OrganisationCreate(); + organisationCreate.setAddress("Street"); + organisationCreate.setCountryCode("IE"); + organisationCreate.setTaxIdNumber("1"); + organisationCreate.setName("Company name"); + organisationCreate.setAdminEmail("the@email.com"); + organisationCreate.setCity("City name"); + organisationCreate.setCurrencyId("ISO_4217:CHF"); + organisationCreate.setPostCode("A127"); + organisationCreate.setProvince("County co."); + organisationCreate.setReportCurrencyId("ISO_4217:CHF"); + organisationCreate.setPhoneNumber("0101010101"); + + when(organisationRepository.saveAndFlush(any())).thenReturn(organisation); + + Optional optionalOrg = organisationService.createOrganisation(organisationCreate); + assertTrue(optionalOrg.isPresent()); + Organisation result = optionalOrg.get(); + assertEquals("f3b7485e96cc45b98e825a48a80d856be260b53de5fe45f23287da5b4970b9b0",result.getId()); + assertEquals("Street",result.getAddress()); + assertEquals("City name",result.getCity()); + assertEquals("County co.",result.getProvince()); + verify(organisationRepository).saveAndFlush(any()); + verifyNoMoreInteractions(organisationRepository); + } + + @Test + void testGetOrganisationView() { + Organisation org = new Organisation(); + org.setId("orgId"); + org.setName("orgName"); + org.setTaxIdNumber("taxId"); + org.setCurrencyId("currencyId"); + org.setAdminEmail("adminEmail"); + org.setPhoneNumber("phoneNumber"); + org.setAddress("address"); + org.setCity("city"); + org.setPostCode("postCode"); + org.setProvince("province"); + org.setCountryCode("countryCode"); + org.setWebSite("webSite"); + org.setLogo("logo"); + + when(costCenterService.getAllCostCenter(anyString())).thenReturn(Set.of(new OrganisationCostCenter())); + when(projectMappingRepository.findAllByOrganisationId(anyString())).thenReturn(Set.of(new OrganisationProject())); + when(organisationCurrencyService.findAllByOrganisationId(anyString())).thenReturn(Set.of(new OrganisationCurrency())); + + OrganisationView organisationView = organisationService.getOrganisationView(org); + + assertNotNull(organisationView); + assertEquals(org.getId(), organisationView.getId()); + assertEquals(org.getName(), organisationView.getName()); + assertEquals(org.getTaxIdNumber(), organisationView.getTaxIdNumber()); + assertEquals(org.getCurrencyId(), organisationView.getCurrencyId()); + assertEquals(org.getAdminEmail(), organisationView.getAdminEmail()); + assertEquals(org.getPhoneNumber(), organisationView.getPhoneNumber()); + assertEquals(org.getAddress(), organisationView.getAddress()); + assertEquals(org.getCity(), organisationView.getCity()); + assertEquals(org.getPostCode(), organisationView.getPostCode()); + assertEquals(org.getProvince(), organisationView.getProvince()); + assertEquals(org.getCountryCode(), organisationView.getCountryCode()); + assertEquals(org.getWebSite(), organisationView.getWebSite()); + assertEquals(org.getLogo(), organisationView.getLogo()); + assertEquals(1, organisationView.getCostCenters().size()); + assertEquals(1, organisationView.getProjects().size()); + assertEquals(1, organisationView.getOrganisationCurrencies().size()); + + verify(costCenterService).getAllCostCenter(anyString()); + verify(projectMappingRepository).findAllByOrganisationId(anyString()); + verify(organisationCurrencyService).findAllByOrganisationId(anyString()); + verifyNoMoreInteractions(costCenterService, projectMappingRepository, organisationCurrencyService); + } +}