mirror of https://github.com/apache/openjpa.git
make sure tests close EMs and EMFs
git-svn-id: https://svn.apache.org/repos/asf/openjpa/trunk@1022228 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
71ae858f91
commit
1a3d16a013
|
@ -24,19 +24,15 @@ import javax.persistence.Id;
|
|||
import javax.persistence.OneToOne;
|
||||
import javax.persistence.Persistence;
|
||||
|
||||
import junit.framework.TestCase;
|
||||
|
||||
import org.apache.openjpa.jdbc.meta.MappingRepository;
|
||||
import org.apache.openjpa.persistence.OpenJPAEntityManagerFactorySPI;
|
||||
import org.apache.openjpa.persistence.test.AbstractPersistenceTestCase;
|
||||
|
||||
/**
|
||||
* Testcase that verifies the names for Foreign Key columns is as expected.
|
||||
*/
|
||||
public class TestFKColumnNames extends TestCase {
|
||||
public class TestFKColumnNames extends AbstractPersistenceTestCase {
|
||||
|
||||
OpenJPAEntityManagerFactorySPI emf =
|
||||
(OpenJPAEntityManagerFactorySPI) Persistence
|
||||
.createEntityManagerFactory("test");
|
||||
|
||||
/**
|
||||
* <P>
|
||||
|
@ -49,6 +45,9 @@ public class TestFKColumnNames extends TestCase {
|
|||
* </P>
|
||||
*/
|
||||
public void testSQLKeywords() {
|
||||
OpenJPAEntityManagerFactorySPI emf =
|
||||
(OpenJPAEntityManagerFactorySPI) Persistence
|
||||
.createEntityManagerFactory("test");
|
||||
MappingRepository repos =
|
||||
(MappingRepository) emf.getConfiguration()
|
||||
.getMetaDataRepositoryInstance();
|
||||
|
@ -58,6 +57,7 @@ public class TestFKColumnNames extends TestCase {
|
|||
|
||||
assertEquals("FROM_ID", repos.getMapping(Inner2.class, null, true)
|
||||
.getFieldMapping("from").getColumns()[0].getName());
|
||||
closeEMF(emf);
|
||||
}
|
||||
|
||||
@Entity
|
||||
|
|
|
@ -27,28 +27,32 @@ import org.apache.openjpa.persistence.test.PersistenceTestCase;
|
|||
public class TestMixedAccess extends AbstractCachedEMFTestCase {
|
||||
|
||||
public void testMixedAccessEntityError() {
|
||||
EntityManagerFactory emf = null;
|
||||
try {
|
||||
EntityManagerFactory emf =
|
||||
createEMF(UnenhancedMixedAccess.class, "openjpa.RuntimeUnenhancedClasses", "supported");
|
||||
emf = createEMF(UnenhancedMixedAccess.class, "openjpa.RuntimeUnenhancedClasses", "supported");
|
||||
emf.createEntityManager().close();
|
||||
} catch (RuntimeException e) {
|
||||
String msg = e.getMessage();
|
||||
if (!(msg.contains("UnenhancedMixedAccess.id") &&
|
||||
msg.contains("UnenhancedMixedAccess.getStringField")))
|
||||
throw e;
|
||||
} finally {
|
||||
closeEMF(emf);
|
||||
}
|
||||
}
|
||||
|
||||
public void testInappropriateTransientError() {
|
||||
EntityManagerFactory emf = null;
|
||||
try {
|
||||
EntityManagerFactory emf = createEMF(
|
||||
UnenhancedInappropriateTransient.class, "openjpa.RuntimeUnenhancedClasses", "supported");
|
||||
emf = createEMF(UnenhancedInappropriateTransient.class, "openjpa.RuntimeUnenhancedClasses", "supported");
|
||||
emf.createEntityManager().close();
|
||||
} catch (RuntimeException e) {
|
||||
String msg = e.getMessage();
|
||||
if (!(msg.contains("UnenhancedInappropriateTransient.id") &&
|
||||
msg.contains("UnenhancedInappropriateTransient.prePersist")))
|
||||
throw e;
|
||||
} finally {
|
||||
closeEMF(emf);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
|
@ -63,6 +63,7 @@ public class TestMultiColumnVersion extends SingleEMFTestCase {
|
|||
em.merge(pc);
|
||||
em.getTransaction().commit();
|
||||
assertVersionEquals(new Number[]{2,2, 2.0f}, em.getVersion(pc));
|
||||
em.close();
|
||||
}
|
||||
|
||||
public void testConcurrentOptimisticUpdateFailsForSingleTable() {
|
||||
|
@ -84,6 +85,7 @@ public class TestMultiColumnVersion extends SingleEMFTestCase {
|
|||
pc1.setName("Updated in em1");
|
||||
pc2.setName("Updated in em2");
|
||||
em1.getTransaction().commit();
|
||||
em1.close();
|
||||
|
||||
try {
|
||||
em2.getTransaction().commit();
|
||||
|
@ -111,7 +113,9 @@ public class TestMultiColumnVersion extends SingleEMFTestCase {
|
|||
assertVersionEquals(em1.getVersion(pc1), em2.getVersion(pc2));
|
||||
|
||||
em1.getTransaction().commit();
|
||||
em1.close();
|
||||
em2.getTransaction().commit();
|
||||
em2.close();
|
||||
}
|
||||
|
||||
public void testVersionOnPersistAndUpdateForMultiTable() {
|
||||
|
@ -128,6 +132,7 @@ public class TestMultiColumnVersion extends SingleEMFTestCase {
|
|||
em.merge(pc);
|
||||
em.getTransaction().commit();
|
||||
assertVersionEquals(new Number[]{2,2,2,2}, em.getVersion(pc));
|
||||
em.close();
|
||||
}
|
||||
|
||||
public void testConcurrentOptimisticUpdateFailsForMultiTable() {
|
||||
|
@ -150,6 +155,7 @@ public class TestMultiColumnVersion extends SingleEMFTestCase {
|
|||
pc1.setName("Updated in em1");
|
||||
pc2.setName("Updated in em2");
|
||||
em1.getTransaction().commit();
|
||||
em1.close();
|
||||
|
||||
try {
|
||||
em2.getTransaction().commit();
|
||||
|
@ -178,7 +184,9 @@ public class TestMultiColumnVersion extends SingleEMFTestCase {
|
|||
assertVersionEquals(em1.getVersion(pc1), em2.getVersion(pc2));
|
||||
|
||||
em1.getTransaction().commit();
|
||||
em1.close();
|
||||
em2.getTransaction().commit();
|
||||
em2.close();
|
||||
}
|
||||
|
||||
static void assertVersionEquals(Object expected, Object actual) {
|
||||
|
|
|
@ -346,4 +346,5 @@ public class TestNonstandardMappingAnnotations
|
|||
}
|
||||
|
||||
em.close();
|
||||
}}
|
||||
}
|
||||
}
|
||||
|
|
|
@ -47,6 +47,7 @@ public class TestPropertyAccess
|
|||
assertNotNull(pa1_2);
|
||||
assertEquals(10, pa1_2.getId());
|
||||
assertEquals("foo", pa1_2.getName());
|
||||
em.close();
|
||||
}
|
||||
|
||||
public void testPropertyAccessBasicMutation() {
|
||||
|
@ -70,6 +71,7 @@ public class TestPropertyAccess
|
|||
PropertyAccess1 pa1_3 = em.find(PropertyAccess1.class, 10);
|
||||
assertNotSame(pa1_2, pa1_3);
|
||||
assertEquals("foobar", pa1_3.getName());
|
||||
em.close();
|
||||
}
|
||||
|
||||
public void testJPQL() {
|
||||
|
|
Loading…
Reference in New Issue