forked from External/mage
[app-wiring-refactor]: Define external configuration
This commit is contained in:
parent
e3733dfae7
commit
cf3dd2d94c
14 changed files with 1083 additions and 2 deletions
116
Mage.Common/src/test/java/mage/utils/FluentBuilderTest.java
Normal file
116
Mage.Common/src/test/java/mage/utils/FluentBuilderTest.java
Normal file
|
|
@ -0,0 +1,116 @@
|
|||
package mage.utils;
|
||||
|
||||
import org.junit.jupiter.api.DisplayName;
|
||||
import org.junit.jupiter.api.Test;
|
||||
|
||||
import static org.assertj.core.api.AssertionsForInterfaceTypes.assertThat;
|
||||
|
||||
public class FluentBuilderTest {
|
||||
|
||||
|
||||
private ABuilder baseBuilder() {
|
||||
return new ABuilder();
|
||||
}
|
||||
|
||||
@Test
|
||||
@DisplayName("build with default parameters")
|
||||
void testDefault() {
|
||||
final A actual = baseBuilder().build();
|
||||
|
||||
verifyAB(actual, null, 0);
|
||||
}
|
||||
|
||||
private void verifyAB(A actual, String a, int b) {
|
||||
assertThat(actual.getA()).isEqualTo(a);
|
||||
assertThat(actual.getB()).isEqualTo(b);
|
||||
}
|
||||
|
||||
@Test
|
||||
@DisplayName("chain with clause and add new parameters")
|
||||
void testBaseChain() {
|
||||
final A actual = baseBuilder().with(a -> a.a = "hello").build();
|
||||
|
||||
verifyAB(actual, "hello", 0);
|
||||
}
|
||||
|
||||
@Test
|
||||
@DisplayName("chain multiple with clauses and add new parameters")
|
||||
void testMultiChain() {
|
||||
final A actual = baseBuilder().with(a -> a.a = "world").with(a -> a.b = 6).build();
|
||||
|
||||
verifyAB(actual, "world", 6);
|
||||
}
|
||||
|
||||
@Test
|
||||
@DisplayName("chain multiple with clauses and override latest writes")
|
||||
void testMultiChainOverride() {
|
||||
final A actual = baseBuilder().with(a -> a.a = "world").with(a -> a.b = 4).with(a -> a.a = "foobar").build();
|
||||
|
||||
verifyAB(actual, "foobar", 4);
|
||||
}
|
||||
|
||||
@Test
|
||||
@DisplayName("not mutate the state of previous builder in the chain")
|
||||
void testImmutability() {
|
||||
final ABuilder builder1 = baseBuilder().with(a -> a.a = "world");
|
||||
final ABuilder builder2 = builder1.with(a -> {
|
||||
a.a = "hello";
|
||||
a.b = 42;
|
||||
});
|
||||
|
||||
verifyAB(builder1.build(), "world", 0);
|
||||
verifyAB(builder2.build(), "hello", 42);
|
||||
}
|
||||
|
||||
@Test
|
||||
@DisplayName("produce different objects")
|
||||
void differentObjects() {
|
||||
final ABuilder builder = baseBuilder().with(a -> {
|
||||
a.a = "hello";
|
||||
a.b = 42;
|
||||
});
|
||||
final A a1 = builder.build();
|
||||
final A a2 = builder.build();
|
||||
|
||||
assertThat(a1).isNotSameAs(a2);
|
||||
verifyAB(a1, "hello", 42);
|
||||
verifyAB(a2, "hello", 42);
|
||||
}
|
||||
|
||||
static class A {
|
||||
public final String a;
|
||||
private int b;
|
||||
|
||||
public A(String a) {
|
||||
this.a = a;
|
||||
}
|
||||
|
||||
public String getA() {
|
||||
return a;
|
||||
}
|
||||
|
||||
public int getB() {
|
||||
return b;
|
||||
}
|
||||
|
||||
public void setB(int b) {
|
||||
this.b = b;
|
||||
}
|
||||
}
|
||||
|
||||
static class ABuilder extends FluentBuilder<A, ABuilder> {
|
||||
public String a;
|
||||
public int b;
|
||||
|
||||
private ABuilder() {
|
||||
super(ABuilder::new);
|
||||
}
|
||||
|
||||
@Override
|
||||
protected A makeValue() {
|
||||
final A result = new A(a);
|
||||
result.setB(b);
|
||||
return result;
|
||||
}
|
||||
}
|
||||
}
|
||||
Loading…
Add table
Add a link
Reference in a new issue