added code for mapstruct tutorial
This commit is contained in:
parent
55ea01d4bd
commit
f0947ae8fb
|
@ -5,6 +5,7 @@ public class EmployeeDTO {
|
||||||
private int employeeId;
|
private int employeeId;
|
||||||
private String employeeName;
|
private String employeeName;
|
||||||
private DivisionDTO division;
|
private DivisionDTO division;
|
||||||
|
private String employeeStartDt;
|
||||||
|
|
||||||
public int getEmployeeId() {
|
public int getEmployeeId() {
|
||||||
return employeeId;
|
return employeeId;
|
||||||
|
@ -30,4 +31,12 @@ public class EmployeeDTO {
|
||||||
this.division = division;
|
this.division = division;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public String getEmployeeStartDt() {
|
||||||
|
return employeeStartDt;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setEmployeeStartDt(String employeeStartDt) {
|
||||||
|
this.employeeStartDt = employeeStartDt;
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,10 +1,13 @@
|
||||||
package org.baeldung.entity;
|
package org.baeldung.entity;
|
||||||
|
|
||||||
|
import java.util.Date;
|
||||||
|
|
||||||
public class Employee {
|
public class Employee {
|
||||||
|
|
||||||
private int id;
|
private int id;
|
||||||
private String name;
|
private String name;
|
||||||
private Division division;
|
private Division division;
|
||||||
|
private Date startDt;
|
||||||
|
|
||||||
public int getId() {
|
public int getId() {
|
||||||
return id;
|
return id;
|
||||||
|
@ -30,4 +33,12 @@ public class Employee {
|
||||||
this.division = division;
|
this.division = division;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public Date getStartDt() {
|
||||||
|
return startDt;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setStartDt(Date startDt) {
|
||||||
|
this.startDt = startDt;
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,5 +1,7 @@
|
||||||
package org.baeldung.mapper;
|
package org.baeldung.mapper;
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
import org.baeldung.dto.DivisionDTO;
|
import org.baeldung.dto.DivisionDTO;
|
||||||
import org.baeldung.dto.EmployeeDTO;
|
import org.baeldung.dto.EmployeeDTO;
|
||||||
import org.baeldung.entity.Division;
|
import org.baeldung.entity.Division;
|
||||||
|
@ -11,14 +13,22 @@ import org.mapstruct.Mappings;
|
||||||
@Mapper
|
@Mapper
|
||||||
public interface EmployeeMapper {
|
public interface EmployeeMapper {
|
||||||
|
|
||||||
@Mappings({ @Mapping(target = "employeeId", source = "entity.id"), @Mapping(target = "employeeName", source = "entity.name") })
|
@Mappings({ @Mapping(target = "employeeId", source = "entity.id"),
|
||||||
|
@Mapping(target = "employeeName", source = "entity.name"),
|
||||||
|
@Mapping(target = "employeeStartDt",source = "entity.startDt", dateFormat = "dd-MM-yyyy HH:mm:ss")})
|
||||||
EmployeeDTO employeeToEmployeeDTO(Employee entity);
|
EmployeeDTO employeeToEmployeeDTO(Employee entity);
|
||||||
|
|
||||||
@Mappings({ @Mapping(target = "id", source = "dto.employeeId"), @Mapping(target = "name", source = "dto.employeeName") })
|
@Mappings({ @Mapping(target = "id", source = "dto.employeeId"),
|
||||||
|
@Mapping(target = "name", source = "dto.employeeName"),
|
||||||
|
@Mapping(target = "startDt",source = "dto.employeeStartDt", dateFormat = "dd-MM-yyyy HH:mm:ss")})
|
||||||
Employee employeeDTOtoEmployee(EmployeeDTO dto);
|
Employee employeeDTOtoEmployee(EmployeeDTO dto);
|
||||||
|
|
||||||
DivisionDTO divisionToDivisionDTO(Division entity);
|
DivisionDTO divisionToDivisionDTO(Division entity);
|
||||||
|
|
||||||
Division divisionDTOtoDivision(DivisionDTO dto);
|
Division divisionDTOtoDivision(DivisionDTO dto);
|
||||||
|
|
||||||
|
List<Employee> convertEmployeeDTOListToEmployeeList(List<EmployeeDTO> list);
|
||||||
|
|
||||||
|
List<EmployeeDTO> convertEmployeeListToEmployeeDTOList(List<Employee> list);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -4,7 +4,7 @@ import org.baeldung.dto.SimpleSource;
|
||||||
import org.baeldung.entity.SimpleDestination;
|
import org.baeldung.entity.SimpleDestination;
|
||||||
import org.mapstruct.Mapper;
|
import org.mapstruct.Mapper;
|
||||||
|
|
||||||
@Mapper
|
@Mapper(componentModel = "spring")
|
||||||
public interface SimpleSourceDestinationMapper {
|
public interface SimpleSourceDestinationMapper {
|
||||||
|
|
||||||
SimpleDestination sourceToDestination(SimpleSource source);
|
SimpleDestination sourceToDestination(SimpleSource source);
|
||||||
|
|
|
@ -1,14 +0,0 @@
|
||||||
package org.baeldung.mapper;
|
|
||||||
|
|
||||||
import org.baeldung.dto.SimpleSource;
|
|
||||||
import org.baeldung.entity.SimpleDestination;
|
|
||||||
import org.mapstruct.Mapper;
|
|
||||||
|
|
||||||
@Mapper(componentModel = "spring")
|
|
||||||
public interface SimpleSourceDestinationSpringMapper {
|
|
||||||
|
|
||||||
SimpleDestination sourceToDestination(SimpleSource source);
|
|
||||||
|
|
||||||
SimpleSource destinationToSource(SimpleDestination destination);
|
|
||||||
|
|
||||||
}
|
|
|
@ -2,6 +2,12 @@ package org.baeldung.mapper;
|
||||||
|
|
||||||
import static org.junit.Assert.assertEquals;
|
import static org.junit.Assert.assertEquals;
|
||||||
|
|
||||||
|
import java.text.ParseException;
|
||||||
|
import java.text.SimpleDateFormat;
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.Date;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
import org.baeldung.dto.DivisionDTO;
|
import org.baeldung.dto.DivisionDTO;
|
||||||
import org.baeldung.dto.EmployeeDTO;
|
import org.baeldung.dto.EmployeeDTO;
|
||||||
import org.baeldung.entity.Division;
|
import org.baeldung.entity.Division;
|
||||||
|
@ -11,10 +17,12 @@ import org.mapstruct.factory.Mappers;
|
||||||
|
|
||||||
public class EmployeeMapperTest {
|
public class EmployeeMapperTest {
|
||||||
|
|
||||||
|
EmployeeMapper mapper = Mappers.getMapper(EmployeeMapper.class);
|
||||||
|
|
||||||
|
private static final String DATE_FORMAT = "dd-MM-yyyy HH:mm:ss";
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void givenEmployeeDTOwithDiffNametoEmployee_whenMaps_thenCorrect() {
|
public void givenEmployeeDTOwithDiffNametoEmployee_whenMaps_thenCorrect() {
|
||||||
EmployeeMapper mapper = Mappers.getMapper(EmployeeMapper.class);
|
|
||||||
|
|
||||||
EmployeeDTO dto = new EmployeeDTO();
|
EmployeeDTO dto = new EmployeeDTO();
|
||||||
dto.setEmployeeId(1);
|
dto.setEmployeeId(1);
|
||||||
dto.setEmployeeName("John");
|
dto.setEmployeeName("John");
|
||||||
|
@ -27,8 +35,6 @@ public class EmployeeMapperTest {
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void givenEmployeewithDiffNametoEmployeeDTO_whenMaps_thenCorrect() {
|
public void givenEmployeewithDiffNametoEmployeeDTO_whenMaps_thenCorrect() {
|
||||||
EmployeeMapper mapper = Mappers.getMapper(EmployeeMapper.class);
|
|
||||||
|
|
||||||
Employee entity = new Employee();
|
Employee entity = new Employee();
|
||||||
entity.setId(1);
|
entity.setId(1);
|
||||||
entity.setName("John");
|
entity.setName("John");
|
||||||
|
@ -41,8 +47,6 @@ public class EmployeeMapperTest {
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void givenEmployeeDTOwithNestedMappingToEmployee_whenMaps_thenCorrect() {
|
public void givenEmployeeDTOwithNestedMappingToEmployee_whenMaps_thenCorrect() {
|
||||||
EmployeeMapper mapper = Mappers.getMapper(EmployeeMapper.class);
|
|
||||||
|
|
||||||
EmployeeDTO dto = new EmployeeDTO();
|
EmployeeDTO dto = new EmployeeDTO();
|
||||||
dto.setDivision(new DivisionDTO(1, "Division1"));
|
dto.setDivision(new DivisionDTO(1, "Division1"));
|
||||||
|
|
||||||
|
@ -54,8 +58,6 @@ public class EmployeeMapperTest {
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void givenEmployeeWithNestedMappingToEmployeeDTO_whenMaps_thenCorrect() {
|
public void givenEmployeeWithNestedMappingToEmployeeDTO_whenMaps_thenCorrect() {
|
||||||
EmployeeMapper mapper = Mappers.getMapper(EmployeeMapper.class);
|
|
||||||
|
|
||||||
Employee entity = new Employee();
|
Employee entity = new Employee();
|
||||||
entity.setDivision(new Division(1, "Division1"));
|
entity.setDivision(new Division(1, "Division1"));
|
||||||
|
|
||||||
|
@ -65,4 +67,59 @@ public class EmployeeMapperTest {
|
||||||
assertEquals(dto.getDivision().getName(), entity.getDivision().getName());
|
assertEquals(dto.getDivision().getName(), entity.getDivision().getName());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void givenEmployeeListToEmployeeDTOList_whenMaps_thenCorrect() {
|
||||||
|
List<Employee> employeeList = new ArrayList<>();
|
||||||
|
Employee emp = new Employee();
|
||||||
|
emp.setId(1);
|
||||||
|
emp.setName("EmpName");
|
||||||
|
emp.setDivision(new Division(1, "Division1"));
|
||||||
|
employeeList.add(emp);
|
||||||
|
|
||||||
|
List<EmployeeDTO> employeeDtoList = mapper.convertEmployeeListToEmployeeDTOList(employeeList);
|
||||||
|
EmployeeDTO employeeDTO = employeeDtoList.get(0);
|
||||||
|
assertEquals(employeeDTO.getEmployeeId(), emp.getId());
|
||||||
|
assertEquals(employeeDTO.getEmployeeName(), emp.getName());
|
||||||
|
assertEquals(employeeDTO.getDivision().getId(), emp.getDivision().getId());
|
||||||
|
assertEquals(employeeDTO.getDivision().getName(), emp.getDivision().getName());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void givenEmployeeDTOListToEmployeeList_whenMaps_thenCorrect() {
|
||||||
|
List<EmployeeDTO> employeeDTOList = new ArrayList<>();
|
||||||
|
EmployeeDTO empDTO = new EmployeeDTO();
|
||||||
|
empDTO.setEmployeeId(1);
|
||||||
|
empDTO.setEmployeeName("EmpName");
|
||||||
|
empDTO.setDivision(new DivisionDTO(1, "Division1"));
|
||||||
|
employeeDTOList.add(empDTO);
|
||||||
|
|
||||||
|
List<Employee> employeeList = mapper.convertEmployeeDTOListToEmployeeList(employeeDTOList);
|
||||||
|
Employee employee = employeeList.get(0);
|
||||||
|
assertEquals(employee.getId(), empDTO.getEmployeeId());
|
||||||
|
assertEquals(employee.getName(), empDTO.getEmployeeName());
|
||||||
|
assertEquals(employee.getDivision().getId(), empDTO.getDivision().getId());
|
||||||
|
assertEquals(employee.getDivision().getName(), empDTO.getDivision().getName());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void givenEmployeeWithStartDateMappingToEmployeeDTO_whenMaps_thenCorrect() throws ParseException {
|
||||||
|
Employee entity = new Employee();
|
||||||
|
entity.setStartDt(new Date());
|
||||||
|
|
||||||
|
EmployeeDTO dto = mapper.employeeToEmployeeDTO(entity);
|
||||||
|
SimpleDateFormat format = new SimpleDateFormat(DATE_FORMAT);
|
||||||
|
assertEquals(format.parse(dto.getEmployeeStartDt()).toString(),
|
||||||
|
entity.getStartDt().toString());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void givenEmployeeDTOWithStartDateMappingToEmployee_whenMaps_thenCorrect() throws ParseException {
|
||||||
|
EmployeeDTO dto = new EmployeeDTO();
|
||||||
|
dto.setEmployeeStartDt("01-04-2016 01:00:00");
|
||||||
|
|
||||||
|
Employee entity = mapper.employeeDTOtoEmployee(dto);
|
||||||
|
SimpleDateFormat format = new SimpleDateFormat(DATE_FORMAT);
|
||||||
|
assertEquals(format.parse(dto.getEmployeeStartDt()).toString(),
|
||||||
|
entity.getStartDt().toString());
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,18 +1,24 @@
|
||||||
package org.baeldung.mapper;
|
package org.baeldung.mapper;
|
||||||
|
|
||||||
import static org.junit.Assert.*;
|
import static org.junit.Assert.assertEquals;
|
||||||
|
|
||||||
import org.baeldung.dto.SimpleSource;
|
import org.baeldung.dto.SimpleSource;
|
||||||
import org.baeldung.entity.SimpleDestination;
|
import org.baeldung.entity.SimpleDestination;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
import org.mapstruct.factory.Mappers;
|
import org.junit.runner.RunWith;
|
||||||
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
|
import org.springframework.test.context.ContextConfiguration;
|
||||||
|
import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;
|
||||||
|
|
||||||
|
@RunWith(SpringJUnit4ClassRunner.class)
|
||||||
|
@ContextConfiguration("classpath:applicationContext.xml")
|
||||||
public class SimpleSourceDestinationMapperTest {
|
public class SimpleSourceDestinationMapperTest {
|
||||||
|
|
||||||
|
@Autowired
|
||||||
|
SimpleSourceDestinationMapper simpleSourceDestinationMapper;
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void givenSimpleSourceToSimpleDestination_whenMaps_thenCorrect() {
|
public void givenSimpleSourceToSimpleDestination_whenMaps_thenCorrect() {
|
||||||
SimpleSourceDestinationMapper simpleSourceDestinationMapper = Mappers.getMapper(SimpleSourceDestinationMapper.class);
|
|
||||||
|
|
||||||
SimpleSource simpleSource = new SimpleSource();
|
SimpleSource simpleSource = new SimpleSource();
|
||||||
simpleSource.setName("SourceName");
|
simpleSource.setName("SourceName");
|
||||||
simpleSource.setDescription("SourceDescription");
|
simpleSource.setDescription("SourceDescription");
|
||||||
|
@ -25,8 +31,6 @@ public class SimpleSourceDestinationMapperTest {
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void givenSimpleDestinationToSourceDestination_whenMaps_thenCorrect() {
|
public void givenSimpleDestinationToSourceDestination_whenMaps_thenCorrect() {
|
||||||
SimpleSourceDestinationMapper simpleSourceDestinationMapper = Mappers.getMapper(SimpleSourceDestinationMapper.class);
|
|
||||||
|
|
||||||
SimpleDestination destination = new SimpleDestination();
|
SimpleDestination destination = new SimpleDestination();
|
||||||
destination.setName("DestinationName");
|
destination.setName("DestinationName");
|
||||||
destination.setDescription("DestinationDescription");
|
destination.setDescription("DestinationDescription");
|
||||||
|
|
|
@ -1,45 +0,0 @@
|
||||||
package org.baeldung.mapper;
|
|
||||||
|
|
||||||
import static org.junit.Assert.assertEquals;
|
|
||||||
|
|
||||||
import org.baeldung.dto.SimpleSource;
|
|
||||||
import org.baeldung.entity.SimpleDestination;
|
|
||||||
import org.junit.Test;
|
|
||||||
import org.junit.runner.RunWith;
|
|
||||||
import org.springframework.beans.factory.annotation.Autowired;
|
|
||||||
import org.springframework.test.context.ContextConfiguration;
|
|
||||||
import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;
|
|
||||||
|
|
||||||
@RunWith(SpringJUnit4ClassRunner.class)
|
|
||||||
@ContextConfiguration("classpath:/applicationContext.xml")
|
|
||||||
public class SimpleSourceDestinationSpringMapperTest {
|
|
||||||
|
|
||||||
@Autowired
|
|
||||||
private SimpleSourceDestinationSpringMapper simpleSourceDestinationSpringMapper;
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void givenSimpleSourceToSimpleDestination_whenMaps_thenCorrect() {
|
|
||||||
|
|
||||||
SimpleSource simpleSource = new SimpleSource();
|
|
||||||
simpleSource.setName("SourceName");
|
|
||||||
simpleSource.setDescription("SourceDescription");
|
|
||||||
|
|
||||||
SimpleDestination destination = simpleSourceDestinationSpringMapper.sourceToDestination(simpleSource);
|
|
||||||
|
|
||||||
assertEquals(simpleSource.getName(), destination.getName());
|
|
||||||
assertEquals(simpleSource.getDescription(), destination.getDescription());
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void givenSimpleDestinationToSourceDestination_whenMaps_thenCorrect() {
|
|
||||||
SimpleDestination destination = new SimpleDestination();
|
|
||||||
destination.setName("DestinationName");
|
|
||||||
destination.setDescription("DestinationDescription");
|
|
||||||
|
|
||||||
SimpleSource source = simpleSourceDestinationSpringMapper.destinationToSource(destination);
|
|
||||||
|
|
||||||
assertEquals(destination.getName(), source.getName());
|
|
||||||
assertEquals(destination.getDescription(), source.getDescription());
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
Loading…
Reference in New Issue