BAEL-1509 jpa attribute converters (#3599)
* fix converter * fix converter * fix converter * fix converter + more tests
This commit is contained in:
parent
53627ae439
commit
2399b4d817
|
@ -11,31 +11,49 @@ public class PersonNameConverter implements AttributeConverter<PersonName, Strin
|
||||||
private static final String SEPARATOR = ", ";
|
private static final String SEPARATOR = ", ";
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public String convertToDatabaseColumn(PersonName person) {
|
public String convertToDatabaseColumn(PersonName personName) {
|
||||||
|
if (personName == null) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
StringBuilder sb = new StringBuilder();
|
StringBuilder sb = new StringBuilder();
|
||||||
if (person.getSurname() != null) {
|
if (personName.getSurname() != null && !personName.getSurname()
|
||||||
sb.append(person.getSurname());
|
.isEmpty()) {
|
||||||
|
sb.append(personName.getSurname());
|
||||||
sb.append(SEPARATOR);
|
sb.append(SEPARATOR);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (person.getName() != null) {
|
if (personName.getName() != null && !personName.getName()
|
||||||
sb.append(person.getName());
|
.isEmpty()) {
|
||||||
|
sb.append(personName.getName());
|
||||||
}
|
}
|
||||||
|
|
||||||
return sb.toString();
|
return sb.toString();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public PersonName convertToEntityAttribute(String dbPerson) {
|
public PersonName convertToEntityAttribute(String dbPersonName) {
|
||||||
String[] pieces = dbPerson.split(SEPARATOR);
|
if (dbPersonName == null || dbPersonName.isEmpty()) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
if (pieces == null || pieces.length != 2) {
|
String[] pieces = dbPersonName.split(SEPARATOR);
|
||||||
|
|
||||||
|
if (pieces == null || pieces.length == 0) {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
PersonName personName = new PersonName();
|
PersonName personName = new PersonName();
|
||||||
personName.setSurname(pieces[0]);
|
String firstPiece = !pieces[0].isEmpty() ? pieces[0] : null;
|
||||||
personName.setName(pieces[1]);
|
if (dbPersonName.contains(SEPARATOR)) {
|
||||||
|
personName.setSurname(firstPiece);
|
||||||
|
|
||||||
|
if (pieces.length >= 2 && pieces[1] != null && !pieces[1].isEmpty()) {
|
||||||
|
personName.setName(pieces[1]);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
personName.setName(firstPiece);
|
||||||
|
}
|
||||||
|
|
||||||
return personName;
|
return personName;
|
||||||
}
|
}
|
||||||
|
|
|
@ -71,4 +71,130 @@ public class PersonNameConverterTest {
|
||||||
.getSurname(), surname);
|
.getSurname(), surname);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void givenPersonNameNull_WhenSaving_ThenNullStored() {
|
||||||
|
final String name = null;
|
||||||
|
final String surname = null;
|
||||||
|
|
||||||
|
PersonName personName = new PersonName();
|
||||||
|
personName.setName(name);
|
||||||
|
personName.setSurname(surname);
|
||||||
|
|
||||||
|
Person person = new Person();
|
||||||
|
person.setPersonName(personName);
|
||||||
|
|
||||||
|
Long id = (Long) session.save(person);
|
||||||
|
|
||||||
|
session.flush();
|
||||||
|
session.clear();
|
||||||
|
|
||||||
|
String dbPersonName = (String) session.createNativeQuery("select p.personName from PersonTable p where p.id = :id")
|
||||||
|
.setParameter("id", id)
|
||||||
|
.getSingleResult();
|
||||||
|
|
||||||
|
assertEquals("", dbPersonName);
|
||||||
|
|
||||||
|
Person dbPerson = session.createNativeQuery("select * from PersonTable p where p.id = :id", Person.class)
|
||||||
|
.setParameter("id", id)
|
||||||
|
.getSingleResult();
|
||||||
|
|
||||||
|
assertEquals(dbPerson.getPersonName(), null);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void givenPersonNameWithoutName_WhenSaving_ThenNotNameStored() {
|
||||||
|
final String name = null;
|
||||||
|
final String surname = "surname";
|
||||||
|
|
||||||
|
PersonName personName = new PersonName();
|
||||||
|
personName.setName(name);
|
||||||
|
personName.setSurname(surname);
|
||||||
|
|
||||||
|
Person person = new Person();
|
||||||
|
person.setPersonName(personName);
|
||||||
|
|
||||||
|
Long id = (Long) session.save(person);
|
||||||
|
|
||||||
|
session.flush();
|
||||||
|
session.clear();
|
||||||
|
|
||||||
|
String dbPersonName = (String) session.createNativeQuery("select p.personName from PersonTable p where p.id = :id")
|
||||||
|
.setParameter("id", id)
|
||||||
|
.getSingleResult();
|
||||||
|
|
||||||
|
assertEquals("surname, ", dbPersonName);
|
||||||
|
|
||||||
|
Person dbPerson = session.createNativeQuery("select * from PersonTable p where p.id = :id", Person.class)
|
||||||
|
.setParameter("id", id)
|
||||||
|
.getSingleResult();
|
||||||
|
|
||||||
|
assertEquals(dbPerson.getPersonName()
|
||||||
|
.getName(), name);
|
||||||
|
assertEquals(dbPerson.getPersonName()
|
||||||
|
.getSurname(), surname);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void givenPersonNameWithoutSurName_WhenSaving_ThenNotSurNameStored() {
|
||||||
|
final String name = "name";
|
||||||
|
final String surname = null;
|
||||||
|
|
||||||
|
PersonName personName = new PersonName();
|
||||||
|
personName.setName(name);
|
||||||
|
personName.setSurname(surname);
|
||||||
|
|
||||||
|
Person person = new Person();
|
||||||
|
person.setPersonName(personName);
|
||||||
|
|
||||||
|
Long id = (Long) session.save(person);
|
||||||
|
|
||||||
|
session.flush();
|
||||||
|
session.clear();
|
||||||
|
|
||||||
|
String dbPersonName = (String) session.createNativeQuery("select p.personName from PersonTable p where p.id = :id")
|
||||||
|
.setParameter("id", id)
|
||||||
|
.getSingleResult();
|
||||||
|
|
||||||
|
assertEquals("name", dbPersonName);
|
||||||
|
|
||||||
|
Person dbPerson = session.createNativeQuery("select * from PersonTable p where p.id = :id", Person.class)
|
||||||
|
.setParameter("id", id)
|
||||||
|
.getSingleResult();
|
||||||
|
|
||||||
|
assertEquals(dbPerson.getPersonName()
|
||||||
|
.getName(), name);
|
||||||
|
assertEquals(dbPerson.getPersonName()
|
||||||
|
.getSurname(), surname);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void givenPersonNameEmptyFields_WhenSaving_ThenFielsNotStored() {
|
||||||
|
final String name = "";
|
||||||
|
final String surname = "";
|
||||||
|
|
||||||
|
PersonName personName = new PersonName();
|
||||||
|
personName.setName(name);
|
||||||
|
personName.setSurname(surname);
|
||||||
|
|
||||||
|
Person person = new Person();
|
||||||
|
person.setPersonName(personName);
|
||||||
|
|
||||||
|
Long id = (Long) session.save(person);
|
||||||
|
|
||||||
|
session.flush();
|
||||||
|
session.clear();
|
||||||
|
|
||||||
|
String dbPersonName = (String) session.createNativeQuery("select p.personName from PersonTable p where p.id = :id")
|
||||||
|
.setParameter("id", id)
|
||||||
|
.getSingleResult();
|
||||||
|
|
||||||
|
assertEquals("", dbPersonName);
|
||||||
|
|
||||||
|
Person dbPerson = session.createNativeQuery("select * from PersonTable p where p.id = :id", Person.class)
|
||||||
|
.setParameter("id", id)
|
||||||
|
.getSingleResult();
|
||||||
|
|
||||||
|
assertEquals(dbPerson.getPersonName(), null);
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue