Commit b9b94a9fc86b2858f929f4d0e08994ad057600ba
test: TestDataBuilders in den master gemergt
Showing
5 changed files
with
184 additions
and
1 deletions
src/main/java/net/ziemers/swxercise/lg/model/user/Profile.java
| @@ -133,7 +133,7 @@ public class Profile extends BaseEntity { | @@ -133,7 +133,7 @@ public class Profile extends BaseEntity { | ||
| 133 | return username; | 133 | return username; |
| 134 | } | 134 | } |
| 135 | 135 | ||
| 136 | - public void setUsername(String username) { | 136 | + private void setUsername(String username) { |
| 137 | this.username = username; | 137 | this.username = username; |
| 138 | } | 138 | } |
| 139 | 139 | ||
| @@ -183,4 +183,9 @@ public class Profile extends BaseEntity { | @@ -183,4 +183,9 @@ public class Profile extends BaseEntity { | ||
| 183 | this.mailaddress = mailaddress; | 183 | this.mailaddress = mailaddress; |
| 184 | } | 184 | } |
| 185 | 185 | ||
| 186 | + public Profile withMailaddress(final String mailaddress) { | ||
| 187 | + setMailaddress(mailaddress); | ||
| 188 | + return this; | ||
| 189 | + } | ||
| 190 | + | ||
| 186 | } | 191 | } |
src/main/java/net/ziemers/swxercise/lg/model/user/User.java
| @@ -71,4 +71,9 @@ public class User extends BaseEntity { | @@ -71,4 +71,9 @@ public class User extends BaseEntity { | ||
| 71 | this.address = address; | 71 | this.address = address; |
| 72 | } | 72 | } |
| 73 | 73 | ||
| 74 | + public User withAddress(final Address address) { | ||
| 75 | + setAddress(address); | ||
| 76 | + return this; | ||
| 77 | + } | ||
| 78 | + | ||
| 74 | } | 79 | } |
src/test/java/net/ziemers/swxercise/lg/testdata/testdatabuilder/AbstractTestDataBuilder.java
0 → 100644
| 1 | +package net.ziemers.swxercise.lg.testdata.testdatabuilder; | ||
| 2 | + | ||
| 3 | +import javax.persistence.EntityManager; | ||
| 4 | + | ||
| 5 | +public abstract class AbstractTestDataBuilder<T> { | ||
| 6 | + | ||
| 7 | + private static int count = 0; | ||
| 8 | + | ||
| 9 | + private EntityManager entityManager; | ||
| 10 | + | ||
| 11 | + /** | ||
| 12 | + * Creates an new TestdataBuilder with persistence. | ||
| 13 | + * | ||
| 14 | + * @param entityManager | ||
| 15 | + */ | ||
| 16 | + public AbstractTestDataBuilder(final EntityManager entityManager) { | ||
| 17 | + this.entityManager = entityManager; | ||
| 18 | + } | ||
| 19 | + | ||
| 20 | + /** | ||
| 21 | + * Creates an new TestdataBuilder without persistence. | ||
| 22 | + */ | ||
| 23 | + public AbstractTestDataBuilder() { | ||
| 24 | + } | ||
| 25 | + | ||
| 26 | + public abstract T build(); | ||
| 27 | + | ||
| 28 | + /** | ||
| 29 | + * Returns the EntityManager or null. | ||
| 30 | + * | ||
| 31 | + * @return {@link EntityManager} or null | ||
| 32 | + */ | ||
| 33 | + protected final EntityManager getEntityManager() { | ||
| 34 | + return entityManager; | ||
| 35 | + } | ||
| 36 | + | ||
| 37 | + /** | ||
| 38 | + * Ensure the TestdataBuilder is constructed with a | ||
| 39 | + * {@link EntityManager} | ||
| 40 | + * | ||
| 41 | + * @throws IllegalStateException | ||
| 42 | + * if the TestdataBuilder is constructed without a | ||
| 43 | + * {@link EntityManager} | ||
| 44 | + */ | ||
| 45 | + protected final void ensureEntityManager() { | ||
| 46 | + if (entityManager == null) { | ||
| 47 | + throw new IllegalStateException("Cannot persist w/o entity manager"); | ||
| 48 | + } | ||
| 49 | + } | ||
| 50 | + | ||
| 51 | + /** | ||
| 52 | + * {@inheritDoc} Executed within a new transaction. | ||
| 53 | + * | ||
| 54 | + * @throws IllegalStateException | ||
| 55 | + * if the TestdataBuilder is constructed without a | ||
| 56 | + * {@link EntityManager} | ||
| 57 | + */ | ||
| 58 | + public final T buildAndSave() { | ||
| 59 | + ensureEntityManager(); | ||
| 60 | + try { | ||
| 61 | + final T obj = build(); | ||
| 62 | + entityManager.persist(obj); | ||
| 63 | + return obj; | ||
| 64 | + } catch (Exception e) { | ||
| 65 | + throw new RuntimeException(e); | ||
| 66 | + } | ||
| 67 | + } | ||
| 68 | + | ||
| 69 | + /** | ||
| 70 | + * Returns an integer value from an static counter. | ||
| 71 | + * | ||
| 72 | + * @return value of the static counter. | ||
| 73 | + */ | ||
| 74 | + protected final int getId() { | ||
| 75 | + return count++; | ||
| 76 | + } | ||
| 77 | + | ||
| 78 | +} | ||
| 79 | + |
src/test/java/net/ziemers/swxercise/lg/testdata/testdatabuilder/user/ProfileTestDataBuilder.java
0 → 100644
| 1 | +package net.ziemers.swxercise.lg.testdata.testdatabuilder.user; | ||
| 2 | + | ||
| 3 | +import net.ziemers.swxercise.lg.model.user.Profile; | ||
| 4 | +import net.ziemers.swxercise.lg.testdata.testdatabuilder.AbstractTestDataBuilder; | ||
| 5 | + | ||
| 6 | +import javax.persistence.EntityManager; | ||
| 7 | + | ||
| 8 | +public class ProfileTestDataBuilder extends AbstractTestDataBuilder { | ||
| 9 | + | ||
| 10 | + private String username = "tziemer"; | ||
| 11 | + | ||
| 12 | + private String password = "secret"; | ||
| 13 | + | ||
| 14 | + private String mailaddress = "tziemer@ziemers.net"; | ||
| 15 | + | ||
| 16 | + public ProfileTestDataBuilder(final EntityManager em) { | ||
| 17 | + super(em); | ||
| 18 | + } | ||
| 19 | + | ||
| 20 | + @Override | ||
| 21 | + public Profile build() { | ||
| 22 | + return new Profile(username, password) | ||
| 23 | + .withMailaddress(mailaddress); | ||
| 24 | + } | ||
| 25 | + | ||
| 26 | + public ProfileTestDataBuilder withUsername(final String username) { | ||
| 27 | + this.username = username; | ||
| 28 | + return this; | ||
| 29 | + } | ||
| 30 | + | ||
| 31 | + public ProfileTestDataBuilder withPassword(final String password) { | ||
| 32 | + this.password = password; | ||
| 33 | + return this; | ||
| 34 | + } | ||
| 35 | + | ||
| 36 | + public ProfileTestDataBuilder withMailaddress(final String mailaddress) { | ||
| 37 | + this.mailaddress = mailaddress; | ||
| 38 | + return this; | ||
| 39 | + } | ||
| 40 | + | ||
| 41 | +} |
src/test/java/net/ziemers/swxercise/lg/testdata/testdatabuilder/user/UserTestDataBuilder.java
0 → 100644
| 1 | +package net.ziemers.swxercise.lg.testdata.testdatabuilder.user; | ||
| 2 | + | ||
| 3 | +import net.ziemers.swxercise.lg.model.user.Address; | ||
| 4 | +import net.ziemers.swxercise.lg.model.user.Profile; | ||
| 5 | +import net.ziemers.swxercise.lg.model.user.User; | ||
| 6 | +import net.ziemers.swxercise.lg.testdata.testdatabuilder.AbstractTestDataBuilder; | ||
| 7 | + | ||
| 8 | +import javax.persistence.EntityManager; | ||
| 9 | + | ||
| 10 | +public class UserTestDataBuilder extends AbstractTestDataBuilder<User> { | ||
| 11 | + | ||
| 12 | + private String firstname = "Hein"; | ||
| 13 | + | ||
| 14 | + private String lastname = "Bloed"; | ||
| 15 | + | ||
| 16 | + private Profile profile; | ||
| 17 | + | ||
| 18 | + private Address address = null; | ||
| 19 | + | ||
| 20 | + public UserTestDataBuilder(final EntityManager em) { | ||
| 21 | + super(em); | ||
| 22 | + profile = new ProfileTestDataBuilder(em).build(); | ||
| 23 | + } | ||
| 24 | + | ||
| 25 | + @Override | ||
| 26 | + public User build() { | ||
| 27 | + return new User(firstname, lastname) | ||
| 28 | + .withProfile(profile) | ||
| 29 | + .withAddress(address); | ||
| 30 | + } | ||
| 31 | + | ||
| 32 | + public UserTestDataBuilder withFirstname(final String firstname) { | ||
| 33 | + this.firstname = firstname; | ||
| 34 | + return this; | ||
| 35 | + } | ||
| 36 | + | ||
| 37 | + public UserTestDataBuilder withLastname(final String lastname) { | ||
| 38 | + this.lastname = lastname; | ||
| 39 | + return this; | ||
| 40 | + } | ||
| 41 | + | ||
| 42 | + public UserTestDataBuilder withProfile(final Profile profile) { | ||
| 43 | + this.profile = profile; | ||
| 44 | + return this; | ||
| 45 | + } | ||
| 46 | + | ||
| 47 | + public UserTestDataBuilder withAddress(final Address address) { | ||
| 48 | + this.address = address; | ||
| 49 | + return this; | ||
| 50 | + } | ||
| 51 | + | ||
| 52 | +} | ||
| 53 | + |