Skip to main content
aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorEike Stepper2012-08-30 11:41:19 +0000
committerEike Stepper2012-08-30 11:41:19 +0000
commitf5a3132c378b508c24e1b20ecc7c2f336a0e8860 (patch)
treec15a900c2d60be5d80fed91a88044af2abdd7ce5 /plugins
parentfe49c7d03e8368779f6620fa1923a4c631931635 (diff)
downloadcdo-f5a3132c378b508c24e1b20ecc7c2f336a0e8860.tar.gz
cdo-f5a3132c378b508c24e1b20ecc7c2f336a0e8860.tar.xz
cdo-f5a3132c378b508c24e1b20ecc7c2f336a0e8860.zip
[357469] CDO server NPE in DBStoreAccessor.detachObjects
https://bugs.eclipse.org/bugs/show_bug.cgi?id=357469
Diffstat (limited to 'plugins')
-rw-r--r--plugins/org.eclipse.emf.cdo.tests/src/org/eclipse/emf/cdo/tests/DetachTest.java41
1 files changed, 40 insertions, 1 deletions
diff --git a/plugins/org.eclipse.emf.cdo.tests/src/org/eclipse/emf/cdo/tests/DetachTest.java b/plugins/org.eclipse.emf.cdo.tests/src/org/eclipse/emf/cdo/tests/DetachTest.java
index 5715d2a6fe..ccf6a47ee6 100644
--- a/plugins/org.eclipse.emf.cdo.tests/src/org/eclipse/emf/cdo/tests/DetachTest.java
+++ b/plugins/org.eclipse.emf.cdo.tests/src/org/eclipse/emf/cdo/tests/DetachTest.java
@@ -27,7 +27,9 @@ import org.eclipse.emf.cdo.util.ObjectNotFoundException;
import org.eclipse.net4j.util.WrappedException;
+import org.eclipse.emf.common.util.EList;
import org.eclipse.emf.common.util.URI;
+import org.eclipse.emf.ecore.EObject;
import org.eclipse.emf.ecore.InternalEObject;
import org.eclipse.emf.ecore.resource.ResourceSet;
import org.eclipse.emf.ecore.util.EcoreUtil;
@@ -71,7 +73,7 @@ public class DetachTest extends AbstractCDOTest
Company c1 = getModel1Factory().createCompany();
c1.setName("Test");
resource.getContents().add(c1);
- transaction.commit(); // (1)
+ transaction.commit(); // (2)
final URI uriC1 = EcoreUtil.getURI(c1);
final CDOID id = CDOUtil.getCDOObject(c1).cdoID();
@@ -400,4 +402,41 @@ public class DetachTest extends AbstractCDOTest
assertEquals(true, resource.isExisting());
transaction.commit();
}
+
+ /**
+ * Bug 357469.
+ */
+ public void _testDetachConcurrently() throws Exception
+ {
+ String path = getResourcePath("/test1");
+
+ {
+ CDOSession session = openSession();
+ CDOTransaction transaction = session.openTransaction();
+ CDOResource resource = transaction.createResource(path);
+ resource.getContents().add(getModel1Factory().createCompany());
+ transaction.commit();
+ session.close();
+ }
+
+ CDOSession session1 = openSession();
+ session1.options().setPassiveUpdateEnabled(false);
+ CDOTransaction transaction1 = session1.openTransaction();
+ CDOResource resource1 = transaction1.getResource(path);
+ EList<EObject> contents1 = resource1.getContents();
+ contents1.get(0);
+
+ CDOSession session2 = openSession();
+ session2.options().setPassiveUpdateEnabled(false);
+ CDOTransaction transaction2 = session2.openTransaction();
+ CDOResource resource2 = transaction2.getResource(path);
+ EList<EObject> contents2 = resource2.getContents();
+ contents2.get(0);
+
+ contents1.remove(0);
+ transaction1.commit();
+
+ contents2.remove(0);
+ transaction2.commit();
+ }
}

Back to the top