Class TestEntityManager
java.lang.Object
org.springframework.boot.test.autoconfigure.orm.jpa.TestEntityManager
Alternative to 
EntityManager for use in JPA tests. Provides a subset of
 EntityManager methods that are useful for tests as well as helper methods for
 common testing tasks such as persist/flush/find.- Since:
- 1.4.0
- Author:
- Phillip Webb
- 
Constructor SummaryConstructorsConstructorDescriptionTestEntityManager(EntityManagerFactory entityManagerFactory) Create a newTestEntityManagerinstance for the givenEntityManagerFactory.
- 
Method SummaryModifier and TypeMethodDescriptionvoidclear()Clear the persistence context, causing all managed entities to become detached.voidRemove the given entity from the persistence context, causing a managed entity to become detached.<E> EFind by primary key.voidflush()Synchronize the persistence context to the underlying database.final EntityManagerReturn the underlyingEntityManagerthat's actually used to perform all operations.Return the ID of the given entity.<T> TReturn the ID of the given entity cast to a specific type.<E> Emerge(E entity) Merge the state of the given entity into the current persistence context.<E> Epersist(E entity) Make an instance managed and persistent.<E> EpersistAndFlush(E entity) Make an instance managed and persistent then synchronize the persistence context to the underlying database.persistAndGetId(Object entity) Make an instance managed and persistent then return its ID.<T> TpersistAndGetId(Object entity, Class<T> idType) Make an instance managed and persistent then return its ID.<E> EpersistFlushFind(E entity) Make an instance managed and persistent, synchronize the persistence context to the underlying database and finally find the persisted entity by its ID.<E> Erefresh(E entity) Refresh the state of the instance from the database, overwriting changes made to the entity, if any.voidRemove the entity instance.
- 
Constructor Details- 
TestEntityManagerCreate a newTestEntityManagerinstance for the givenEntityManagerFactory.- Parameters:
- entityManagerFactory- the source entity manager factory
 
 
- 
- 
Method Details- 
persistAndGetIdMake an instance managed and persistent then return its ID. Delegates toEntityManager.persist(Object)thengetId(Object).Helpful when setting up test data in a test: Object entityId = this.testEntityManager.persist(new MyEntity("Spring"));- Parameters:
- entity- the source entity
- Returns:
- the ID of the newly persisted entity
 
- 
persistAndGetIdMake an instance managed and persistent then return its ID. Delegates toEntityManager.persist(Object)thengetId(Object, Class).Helpful when setting up test data in a test: Long entityId = this.testEntityManager.persist(new MyEntity("Spring"), Long.class);- Type Parameters:
- T- the ID type
- Parameters:
- entity- the source entity
- idType- the ID type
- Returns:
- the ID of the newly persisted entity
 
- 
persistpublic <E> E persist(E entity) Make an instance managed and persistent. Delegates toEntityManager.persist(Object)then returns the original source entity.Helpful when setting up test data in a test: MyEntity entity = this.testEntityManager.persist(new MyEntity("Spring"));- Type Parameters:
- E- the entity type
- Parameters:
- entity- the entity to persist
- Returns:
- the persisted entity
 
- 
persistFlushFindpublic <E> E persistFlushFind(E entity) Make an instance managed and persistent, synchronize the persistence context to the underlying database and finally find the persisted entity by its ID. Delegates topersistAndFlush(Object)thenfind(Class, Object)with theentity ID.Helpful when ensuring that entity data is actually written and read from the underlying database correctly. - Type Parameters:
- E- the entity type
- Parameters:
- entity- the entity to persist
- Returns:
- the entity found using the ID of the persisted entity
 
- 
persistAndFlushpublic <E> E persistAndFlush(E entity) Make an instance managed and persistent then synchronize the persistence context to the underlying database. Delegates toEntityManager.persist(Object)thenflush()and finally returns the original source entity.Helpful when setting up test data in a test: MyEntity entity = this.testEntityManager.persistAndFlush(new MyEntity("Spring"));- Type Parameters:
- E- the entity type
- Parameters:
- entity- the entity to persist
- Returns:
- the persisted entity
 
- 
mergepublic <E> E merge(E entity) Merge the state of the given entity into the current persistence context. Delegates toEntityManager.merge(Object)- Type Parameters:
- E- the entity type
- Parameters:
- entity- the entity to merge
- Returns:
- the merged entity
 
- 
removeRemove the entity instance. Delegates toEntityManager.remove(Object)- Parameters:
- entity- the entity to remove
 
- 
findFind by primary key. Delegates toEntityManager.find(Class, Object).- Type Parameters:
- E- the entity type
- Parameters:
- entityClass- the entity class
- primaryKey- the entity primary key
- Returns:
- the found entity or nullif the entity does not exist
- See Also:
 
- 
flushpublic void flush()Synchronize the persistence context to the underlying database. Delegates toEntityManager.flush().
- 
refreshpublic <E> E refresh(E entity) Refresh the state of the instance from the database, overwriting changes made to the entity, if any. Delegates toEntityManager.refresh(Object).- Type Parameters:
- E- the entity type
- Parameters:
- entity- the entity to refresh
- Returns:
- the refreshed entity
 
- 
clearpublic void clear()Clear the persistence context, causing all managed entities to become detached. Delegates toEntityManager.clear()
- 
detachRemove the given entity from the persistence context, causing a managed entity to become detached. Delegates toEntityManager.detach(Object).- Parameters:
- entity- the entity to detach.
 
- 
getIdReturn the ID of the given entity. Delegates toPersistenceUnitUtil.getIdentifier(Object).- Parameters:
- entity- the source entity
- Returns:
- the ID of the entity or null
- See Also:
 
- 
getIdReturn the ID of the given entity cast to a specific type. Delegates toPersistenceUnitUtil.getIdentifier(Object).- Type Parameters:
- T- the ID type
- Parameters:
- entity- the source entity
- idType- the expected ID type
- Returns:
- the ID of the entity or null
- See Also:
 
- 
getEntityManagerReturn the underlyingEntityManagerthat's actually used to perform all operations.- Returns:
- the entity manager
 
 
-