mirror of
https://github.com/mapstruct/mapstruct.git
synced 2025-07-12 00:00:08 +08:00
#2060: MapStruct should work properly on the module path
This commit is contained in:
parent
4f76208c62
commit
853ff7f74f
@ -130,4 +130,10 @@ public class MavenIntegrationTest {
|
|||||||
void targetTypeGenerationTest() {
|
void targetTypeGenerationTest() {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ProcessorTest(baseDir = "moduleInfoTest")
|
||||||
|
@EnabledForJreRange(min = JRE.JAVA_11)
|
||||||
|
void moduleInfoTest() {
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
24
integrationtest/src/test/resources/moduleInfoTest/pom.xml
Normal file
24
integrationtest/src/test/resources/moduleInfoTest/pom.xml
Normal file
@ -0,0 +1,24 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<!--
|
||||||
|
|
||||||
|
Copyright MapStruct Authors.
|
||||||
|
|
||||||
|
Licensed under the Apache License version 2.0, available at http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
|
||||||
|
-->
|
||||||
|
<project xmlns="http://maven.apache.org/POM/4.0.0"
|
||||||
|
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
|
||||||
|
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
|
||||||
|
<modelVersion>4.0.0</modelVersion>
|
||||||
|
|
||||||
|
<parent>
|
||||||
|
<groupId>org.mapstruct</groupId>
|
||||||
|
<artifactId>mapstruct-it-parent</artifactId>
|
||||||
|
<version>1.0.0</version>
|
||||||
|
<relativePath>../pom.xml</relativePath>
|
||||||
|
</parent>
|
||||||
|
|
||||||
|
<artifactId>modulesTest</artifactId>
|
||||||
|
<packaging>jar</packaging>
|
||||||
|
|
||||||
|
</project>
|
@ -0,0 +1,9 @@
|
|||||||
|
/*
|
||||||
|
* Copyright MapStruct Authors.
|
||||||
|
*
|
||||||
|
* Licensed under the Apache License version 2.0, available at http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*/
|
||||||
|
module test.mapstruct {
|
||||||
|
requires org.mapstruct;
|
||||||
|
exports org.mapstruct.itest.modules;
|
||||||
|
}
|
@ -0,0 +1,31 @@
|
|||||||
|
/*
|
||||||
|
* Copyright MapStruct Authors.
|
||||||
|
*
|
||||||
|
* Licensed under the Apache License version 2.0, available at http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*/
|
||||||
|
package org.mapstruct.itest.modules;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @author Filip Hrisafov
|
||||||
|
*/
|
||||||
|
public class CustomerDto {
|
||||||
|
|
||||||
|
private String name;
|
||||||
|
private String email;
|
||||||
|
|
||||||
|
public String getName() {
|
||||||
|
return name;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setName(String name) {
|
||||||
|
this.name = name;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getEmail() {
|
||||||
|
return email;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setEmail(String email) {
|
||||||
|
this.email = email;
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,31 @@
|
|||||||
|
/*
|
||||||
|
* Copyright MapStruct Authors.
|
||||||
|
*
|
||||||
|
* Licensed under the Apache License version 2.0, available at http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*/
|
||||||
|
package org.mapstruct.itest.modules;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @author Filip Hrisafov
|
||||||
|
*/
|
||||||
|
public class CustomerEntity {
|
||||||
|
|
||||||
|
private String name;
|
||||||
|
private String mail;
|
||||||
|
|
||||||
|
public String getName() {
|
||||||
|
return name;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setName(String name) {
|
||||||
|
this.name = name;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getMail() {
|
||||||
|
return mail;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setMail(String mail) {
|
||||||
|
this.mail = mail;
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,23 @@
|
|||||||
|
/*
|
||||||
|
* Copyright MapStruct Authors.
|
||||||
|
*
|
||||||
|
* Licensed under the Apache License version 2.0, available at http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*/
|
||||||
|
package org.mapstruct.itest.modules;
|
||||||
|
|
||||||
|
import org.mapstruct.Mapper;
|
||||||
|
import org.mapstruct.Mapping;
|
||||||
|
import org.mapstruct.factory.Mappers;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @author Filip Hrisafov
|
||||||
|
*/
|
||||||
|
@Mapper
|
||||||
|
public interface CustomerMapper {
|
||||||
|
|
||||||
|
CustomerMapper INSTANCE = Mappers.getMapper( CustomerMapper.class );
|
||||||
|
|
||||||
|
@Mapping(target = "mail", source = "email")
|
||||||
|
CustomerEntity fromDto(CustomerDto record);
|
||||||
|
|
||||||
|
}
|
@ -0,0 +1,28 @@
|
|||||||
|
/*
|
||||||
|
* Copyright MapStruct Authors.
|
||||||
|
*
|
||||||
|
* Licensed under the Apache License version 2.0, available at http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*/
|
||||||
|
package org.mapstruct.itest.modules;
|
||||||
|
|
||||||
|
import static org.assertj.core.api.Assertions.assertThat;
|
||||||
|
|
||||||
|
import org.junit.Test;
|
||||||
|
import org.mapstruct.itest.modules.CustomerDto;
|
||||||
|
import org.mapstruct.itest.modules.CustomerEntity;
|
||||||
|
import org.mapstruct.itest.modules.CustomerMapper;
|
||||||
|
|
||||||
|
public class ModulesTest {
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void shouldMapRecord() {
|
||||||
|
CustomerDto dto = new CustomerDto();
|
||||||
|
dto.setName( "Kermit" );
|
||||||
|
dto.setEmail( "kermit@test.com" );
|
||||||
|
CustomerEntity customer = CustomerMapper.INSTANCE.fromDto( dto );
|
||||||
|
|
||||||
|
assertThat( customer ).isNotNull();
|
||||||
|
assertThat( customer.getName() ).isEqualTo( "Kermit" );
|
||||||
|
assertThat( customer.getMail() ).isEqualTo( "kermit@test.com" );
|
||||||
|
}
|
||||||
|
}
|
@ -184,9 +184,8 @@ public class Conversions {
|
|||||||
register( Enum.class, String.class, new EnumStringConversion() );
|
register( Enum.class, String.class, new EnumStringConversion() );
|
||||||
register( Date.class, String.class, new DateToStringConversion() );
|
register( Date.class, String.class, new DateToStringConversion() );
|
||||||
register( BigDecimal.class, BigInteger.class, new BigDecimalToBigIntegerConversion() );
|
register( BigDecimal.class, BigInteger.class, new BigDecimalToBigIntegerConversion() );
|
||||||
register( Date.class, Time.class, new DateToSqlTimeConversion() );
|
|
||||||
register( Date.class, java.sql.Date.class, new DateToSqlDateConversion() );
|
registerJavaTimeSqlConversions();
|
||||||
register( Date.class, Timestamp.class, new DateToSqlTimestampConversion() );
|
|
||||||
|
|
||||||
// java.util.Currency <~> String
|
// java.util.Currency <~> String
|
||||||
register( Currency.class, String.class, new CurrencyToStringConversion() );
|
register( Currency.class, String.class, new CurrencyToStringConversion() );
|
||||||
@ -227,15 +226,28 @@ public class Conversions {
|
|||||||
register( ZonedDateTime.class, Date.class, new JavaZonedDateTimeToDateConversion() );
|
register( ZonedDateTime.class, Date.class, new JavaZonedDateTimeToDateConversion() );
|
||||||
register( LocalDateTime.class, Date.class, new JavaLocalDateTimeToDateConversion() );
|
register( LocalDateTime.class, Date.class, new JavaLocalDateTimeToDateConversion() );
|
||||||
register( LocalDate.class, Date.class, new JavaLocalDateToDateConversion() );
|
register( LocalDate.class, Date.class, new JavaLocalDateToDateConversion() );
|
||||||
register( LocalDate.class, java.sql.Date.class, new JavaLocalDateToSqlDateConversion() );
|
|
||||||
register( Instant.class, Date.class, new JavaInstantToDateConversion() );
|
register( Instant.class, Date.class, new JavaInstantToDateConversion() );
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private void registerJavaTimeSqlConversions() {
|
||||||
|
if ( isJavaSqlAvailable() ) {
|
||||||
|
register( LocalDate.class, java.sql.Date.class, new JavaLocalDateToSqlDateConversion() );
|
||||||
|
|
||||||
|
register( Date.class, Time.class, new DateToSqlTimeConversion() );
|
||||||
|
register( Date.class, java.sql.Date.class, new DateToSqlDateConversion() );
|
||||||
|
register( Date.class, Timestamp.class, new DateToSqlTimestampConversion() );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
private boolean isJodaTimeAvailable() {
|
private boolean isJodaTimeAvailable() {
|
||||||
return typeFactory.isTypeAvailable( JodaTimeConstants.DATE_TIME_FQN );
|
return typeFactory.isTypeAvailable( JodaTimeConstants.DATE_TIME_FQN );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private boolean isJavaSqlAvailable() {
|
||||||
|
return typeFactory.isTypeAvailable( "java.sql.Date" );
|
||||||
|
}
|
||||||
|
|
||||||
private void registerNativeTypeConversion(Class<?> sourceType, Class<?> targetType) {
|
private void registerNativeTypeConversion(Class<?> sourceType, Class<?> targetType) {
|
||||||
if ( sourceType.isPrimitive() && targetType.isPrimitive() ) {
|
if ( sourceType.isPrimitive() && targetType.isPrimitive() ) {
|
||||||
register( sourceType, targetType, new PrimitiveToPrimitiveConversion( sourceType ) );
|
register( sourceType, targetType, new PrimitiveToPrimitiveConversion( sourceType ) );
|
||||||
|
Loading…
x
Reference in New Issue
Block a user