nullValuePropertyMappingStrategy not working
Asked Answered
M

2

5

I have the following mapper

@Mapper(config = MappingConfig.class)
public interface PokerRoomMapper {

  @Mapping(target = "phase", nullValuePropertyMappingStrategy = NullValuePropertyMappingStrategy.IGNORE)
  PokerRoom pokerRoomDtoToPokerRoom(PokerRoomDto pokerRoomDto);

}

The pokerRoomDto which is passed to it has a "phase" field which can be null. I want this field to be ignored when it is null. But right now the "null" value still gets mapped to the pokerRoom entity.

If I just ignore the field in the mapper it works and the default value for phase in PokerRoom stays untouched however I dont want to always ignore it.

@Mapper(config = MappingConfig.class)
public interface PokerRoomMapper {

  @Mapping(target = "phase", ignore = true)
  PokerRoom pokerRoomDtoToPokerRoom(PokerRoomDto pokerRoomDto);

}
Mashe answered 1/3, 2021 at 15:56 Comment(3)
Does the phase on PokerRoom have default value? If not then I am not sure how you workout that the mapping is not working. If mapstruct ignores a field during mapping which has no default value then it will be null after mapping anywayApia
Yes it has a default value which correctly stays untouched if I use the second Mapper where I just ignore it.Mashe
according to javadoc for NullValuePropertyMappingStrategy only applies to update methods: methods that update a pre-existing target (annotated with @MappingTarget). Have a look at #54174937 and #46670094Apia
A
5

This works as designed. NullValuePropertyMappingStrategy is only applied to update method. It is not used for normal mappings.

I think that you are looking for NullValueCheckStrategy, if you use NullValueCheckStrategy#ALWAYS then MapStruct will always do a null check non the PokerRoomDto and only invoke the setter on the PokerRoom if the value was not null

Activism answered 1/3, 2021 at 20:12 Comment(0)
S
1

If you initialise your field at declaration and want to keep that value, I've come up with a solution. A bit hacky, not very general (depends on generated variable name), but works. Assuming:

class PokerRoom {
    Integer phase = 0;
}

You can use

@Mapping(target = "phase", defaultExpression = "java( pokerRoom.getPhase() )")
PokerRoom pokerRoomDtoToPokerRoom(PokerRoomDto pokerRoomDto);

A simpler solution would be to use the same constant you use at field declaration.

@Mapping(target = "phase", defaultValue = "0")
PokerRoom pokerRoomDtoToPokerRoom(PokerRoomDto pokerRoomDto);
Strephon answered 11/11, 2021 at 18:19 Comment(0)

© 2022 - 2024 — McMap. All rights reserved.