Lombok: A anotação @Builder perde o valor padrão do campo

Criado em 28 jul. 2016  ·  3Comentários  ·  Fonte: projectlombok/lombok

public class BuilderAnnotationTest {

    <strong i="5">@Test</strong>
    public void defalutValue() throws Exception {
        assertThat(Entity.builder().build().isSingle()).isTrue();
    }
}

<strong i="6">@Getter</strong>
<strong i="7">@Builder</strong>
class Entity{
    private String name;
    private boolean single = true;
}

Comentários muito úteis

Duplicado de # 916. Há uma solução alternativa

<strong i="6">@Getter</strong>
@Builder(toBuilder=true)
<strong i="7">@AllArgsConstructor</strong>
@NoArgsConstructor(access=AccessLevel.PRIVATE)
public class Entity {
    public static EntityBuilder builder() {
        return PROTOTYPE.toBuilder();
    }

    private static final Entity PROTOTYPE = new Entity();

    private String name;
    private boolean single = true;
}

Todos 3 comentários

Duplicado de # 916. Há uma solução alternativa

<strong i="6">@Getter</strong>
@Builder(toBuilder=true)
<strong i="7">@AllArgsConstructor</strong>
@NoArgsConstructor(access=AccessLevel.PRIVATE)
public class Entity {
    public static EntityBuilder builder() {
        return PROTOTYPE.toBuilder();
    }

    private static final Entity PROTOTYPE = new Entity();

    private String name;
    private boolean single = true;
}

Isso também funciona

public class BuilderAnnotationTest {

    <strong i="6">@Test</strong>
    public void defalutValue() throws Exception {
        assertThat(new Entity().toBuilder().build().isSingle()).isTrue(); // note the "new" here
    }
}

<strong i="7">@Getter</strong>
@Builder(toBuilder = true)
class Entity{
    private String name;
    private boolean single = true;
}

Use @Builder.Default para corrigir este problema.

Esta página foi útil?
0 / 5 - 0 avaliações