Skip to content

Commit

Permalink
[VAS-976] feat: add notice institutions api (#401)
Browse files Browse the repository at this point in the history
Co-authored-by: Jacopo Carlini <jacopo.carlini@gmail.com>
Co-authored-by: svariant <samuele.varianti@nttdata.com>
  • Loading branch information
3 people committed Jun 24, 2024
1 parent a1f580b commit c0b31d5
Show file tree
Hide file tree
Showing 6 changed files with 109 additions and 5 deletions.
2 changes: 1 addition & 1 deletion openapi/openapi.json
Original file line number Diff line number Diff line change
Expand Up @@ -14159,4 +14159,4 @@
}
}
}
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,7 @@ public interface InstitutionsClient {

@PostMapping(value = "/institutions/data", consumes = {
MediaType.MULTIPART_FORM_DATA_VALUE})
void updateInstitutions(
public void updateInstitutions(
@RequestPart("institutions-data") String institutionsDataContent,
@RequestPart(value = "file") MultipartFile logo);

Expand Down
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
package it.pagopa.selfcare.pagopa.backoffice.controller;

import com.fasterxml.jackson.databind.ObjectMapper;
import io.swagger.v3.oas.annotations.Operation;
import io.swagger.v3.oas.annotations.Parameter;
import io.swagger.v3.oas.annotations.media.Content;
Expand All @@ -18,6 +19,7 @@
import org.springframework.web.multipart.MultipartFile;

import javax.validation.Valid;
import javax.validation.Validator;
import javax.validation.constraints.NotNull;

/**
Expand All @@ -32,8 +34,14 @@ public class NoticeController {

private final InstitutionsService institutionsService;

public NoticeController(InstitutionsService institutionsService) {
private final ObjectMapper objectMapper;

private final Validator validator;

public NoticeController(InstitutionsService institutionsService, ObjectMapper objectMapper, Validator validator) {
this.institutionsService = institutionsService;
this.objectMapper = objectMapper;
this.validator = validator;
}

/**
Expand Down Expand Up @@ -73,7 +81,7 @@ public void updateInstitutions(
schema = @Schema(implementation = InstitutionUploadData.class))
@Valid @NotNull @RequestPart("institutions-data") String institutionsDataContent,
@Parameter(description = "logo file to upload (not to send on update unless it is changed)")
@RequestPart(value = "file", required = false) MultipartFile logo
@Valid @NotNull @RequestParam(value = "file", required = false) MultipartFile logo
) {
institutionsService.uploadInstitutionsData(institutionsDataContent, logo);
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -16,6 +16,7 @@ public class InstitutionsService {

private final InstitutionsClient institutionClient;


public InstitutionsService(InstitutionsClient institutionClient) {
this.institutionClient = institutionClient;
}
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,91 @@
package it.pagopa.selfcare.pagopa.backoffice.controller;

import com.fasterxml.jackson.databind.ObjectMapper;
import it.pagopa.selfcare.pagopa.backoffice.model.notices.InstitutionUploadData;
import it.pagopa.selfcare.pagopa.backoffice.service.InstitutionsService;
import org.junit.jupiter.api.BeforeEach;
import org.junit.jupiter.api.Test;
import org.mockito.Mockito;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.autoconfigure.web.servlet.AutoConfigureMockMvc;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.boot.test.mock.mockito.MockBean;
import org.springframework.http.MediaType;
import org.springframework.mock.web.MockPart;
import org.springframework.test.web.servlet.MockMvc;

import java.io.IOException;

import static org.mockito.ArgumentMatchers.any;
import static org.mockito.Mockito.doAnswer;
import static org.mockito.Mockito.verify;
import static org.springframework.test.web.servlet.request.MockMvcRequestBuilders.multipart;
import static org.springframework.test.web.servlet.result.MockMvcResultMatchers.status;

@SpringBootTest
@AutoConfigureMockMvc
class InstitutionsControllerTest {

@Autowired
private MockMvc mvc;

@MockBean
private InstitutionsService institutionsService;

private ObjectMapper objectMapper = new ObjectMapper();

@BeforeEach
void setUp() {
Mockito.reset(institutionsService);
}

@Test
void updateInstitutionsShouldReturnOk() throws Exception {
InstitutionUploadData uploadData =
InstitutionUploadData.builder()
.cbill("cbill")
.info("info")
.webChannel(true)
.taxCode("123132")
.posteAccountNumber("1313")
.fullName("121212")
.organization("test")
.physicalChannel("1212")
.build();
String url = "/notice/institutions/data";
mvc.perform(multipart(url)
.file("file","".getBytes())
.part(new MockPart("institutions-data",
objectMapper.writeValueAsString(uploadData).getBytes()))
.contentType(MediaType.MULTIPART_FORM_DATA_VALUE))
.andExpect(status().isOk());
verify(institutionsService).uploadInstitutionsData(any(), any());
}

@Test
void updateInstitutionsShouldReturnKoOnIoException() throws Exception {
InstitutionUploadData uploadData =
InstitutionUploadData.builder()
.cbill("cbill")
.info("info")
.webChannel(true)
.taxCode("123132")
.posteAccountNumber("1313")
.fullName("121212")
.organization("test")
.physicalChannel("1212")
.build();
doAnswer(invocationOnMock -> {
throw new IOException();
}).when(institutionsService).uploadInstitutionsData(any(), any());
String url = "/notice/institutions/data";
mvc.perform(multipart(url)
.file("file", "".getBytes())
.part(new MockPart("institutions-data",
objectMapper.writeValueAsString(uploadData).getBytes()))
.contentType(MediaType.MULTIPART_FORM_DATA_VALUE))
.andExpect(status().is5xxServerError());
verify(institutionsService).uploadInstitutionsData(any(), any());
}

}
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,10 @@
import org.mockito.junit.jupiter.MockitoExtension;
import org.springframework.web.multipart.MultipartFile;

import java.io.File;
import java.io.IOException;
import java.nio.file.Files;

import static org.junit.jupiter.api.Assertions.*;
import static org.mockito.ArgumentMatchers.any;
import static org.mockito.Mockito.*;
Expand Down Expand Up @@ -93,4 +97,4 @@ void shouldThrowExceptionOnInstitutionDataRecoveryKOUnexpected() {
assertEquals(AppError.INSTITUTION_RETRIEVE_ERROR.title, appException.getTitle());
}

}
}

0 comments on commit c0b31d5

Please sign in to comment.