|
| 1 | +package com.baeldung.recordbuilderguide; |
| 2 | + |
| 3 | +import org.junit.jupiter.api.Test; |
| 4 | + |
| 5 | +import static org.junit.jupiter.api.Assertions.assertEquals; |
| 6 | + |
| 7 | +public class RecordBuilderDemoUnitTest { |
| 8 | + |
| 9 | + @Test |
| 10 | + void givenNoInput_whenCreateInitialPerson_thenCorrectFieldsSet() { |
| 11 | + Person p1 = RecordBuilderDemo.createInitialPerson(); |
| 12 | + assertEquals("foo", p1.name()); |
| 13 | + assertEquals(123, p1.age()); |
| 14 | + } |
| 15 | + |
| 16 | + @Test |
| 17 | + void givenPerson_whenUpdateName_thenNameChangesAndAgeUnchanged() { |
| 18 | + Person p1 = RecordBuilderDemo.createInitialPerson(); |
| 19 | + Person p2 = RecordBuilderDemo.updateName(p1); |
| 20 | + |
| 21 | + assertEquals("bar", p2.name()); |
| 22 | + assertEquals(123, p2.age()); |
| 23 | + } |
| 24 | + |
| 25 | + @Test |
| 26 | + void givenPerson_whenUpdateAge_thenAgeChangesAndNameUnchanged() { |
| 27 | + Person p2 = RecordBuilderDemo.updateName(RecordBuilderDemo.createInitialPerson()); |
| 28 | + Person p3 = RecordBuilderDemo.updateAge(p2); |
| 29 | + |
| 30 | + assertEquals("bar", p3.name()); |
| 31 | + assertEquals(456, p3.age()); |
| 32 | + } |
| 33 | + |
| 34 | + @Test |
| 35 | + void givenPerson_whenUpdateBothFieldsWithBuilder_thenBothFieldsChange() { |
| 36 | + Person p3 = RecordBuilderDemo.updateAge( |
| 37 | + RecordBuilderDemo.updateName( |
| 38 | + RecordBuilderDemo.createInitialPerson())); |
| 39 | + Person p4 = RecordBuilderDemo.updateBothFieldsWithBuilder(p3); |
| 40 | + |
| 41 | + assertEquals("baz", p4.name()); |
| 42 | + assertEquals(101, p4.age()); |
| 43 | + } |
| 44 | + |
| 45 | + @Test |
| 46 | + void givenPerson_whenUpdateWithConsumer_thenFieldsChangeCorrectly() { |
| 47 | + Person p4 = RecordBuilderDemo.updateBothFieldsWithBuilder( |
| 48 | + RecordBuilderDemo.updateAge( |
| 49 | + RecordBuilderDemo.updateName( |
| 50 | + RecordBuilderDemo.createInitialPerson()))); |
| 51 | + Person p5 = RecordBuilderDemo.updateWithConsumer(p4); |
| 52 | + |
| 53 | + assertEquals("whatever", p5.name()); |
| 54 | + assertEquals(200, p5.age()); |
| 55 | + } |
| 56 | + |
| 57 | + @Test |
| 58 | + void givenPerson_whenUpdateWithConditionalConsumer_thenNameIsConditionallySet() { |
| 59 | + Person p5 = RecordBuilderDemo.updateWithConsumer( |
| 60 | + RecordBuilderDemo.updateBothFieldsWithBuilder( |
| 61 | + RecordBuilderDemo.updateAge( |
| 62 | + RecordBuilderDemo.updateName( |
| 63 | + RecordBuilderDemo.createInitialPerson())))); |
| 64 | + Person p6 = RecordBuilderDemo.updateWithConditionalConsumer(p5); |
| 65 | + |
| 66 | + assertEquals("Teen whatever", p6.name()); |
| 67 | + assertEquals(200, p6.age()); |
| 68 | + } |
| 69 | + |
| 70 | + @Test |
| 71 | + void givenPerson_whenUpdateWithStaticBuilderAndConsumer_thenFieldsAreUpdated() { |
| 72 | + Person p6 = RecordBuilderDemo.updateWithConditionalConsumer( |
| 73 | + RecordBuilderDemo.updateWithConsumer( |
| 74 | + RecordBuilderDemo.updateBothFieldsWithBuilder( |
| 75 | + RecordBuilderDemo.updateAge( |
| 76 | + RecordBuilderDemo.updateName( |
| 77 | + RecordBuilderDemo.createInitialPerson()))))); |
| 78 | + Person p7 = RecordBuilderDemo.updateWithStaticBuilderAndConsumer(p6); |
| 79 | + |
| 80 | + assertEquals("Manual Copy", p7.name()); |
| 81 | + assertEquals(300, p7.age()); |
| 82 | + } |
| 83 | + |
| 84 | + @Test |
| 85 | + void givenPerson_whenUpdateWithStaticBuilderAndName_thenOnlyNameChanges() { |
| 86 | + Person p6 = RecordBuilderDemo.updateWithConditionalConsumer( |
| 87 | + RecordBuilderDemo.updateWithConsumer( |
| 88 | + RecordBuilderDemo.updateBothFieldsWithBuilder( |
| 89 | + RecordBuilderDemo.updateAge( |
| 90 | + RecordBuilderDemo.updateName( |
| 91 | + RecordBuilderDemo.createInitialPerson()))))); |
| 92 | + Person p8 = RecordBuilderDemo.updateWithStaticBuilderAndName(p6); |
| 93 | + |
| 94 | + assertEquals("boop", p8.name()); |
| 95 | + assertEquals(200, p8.age()); |
| 96 | + } |
| 97 | +} |
0 commit comments