blob: 9317b98e55ea285450569dc11d03d65ef089b867 [file] [log] [blame]
/*
* Copyright (c) 2011-2013 Eike Stepper (Berlin, Germany) and others.
* All rights reserved. This program and the accompanying materials
* are made available under the terms of the Eclipse Public License v1.0
* which accompanies this distribution, and is available at
* http://www.eclipse.org/legal/epl-v10.html
*
* Contributors:
* Caspar De Groot - initial API and implementation
*/
package org.eclipse.emf.cdo.tests.bugzilla;
import org.eclipse.emf.cdo.CDOObject;
import org.eclipse.emf.cdo.common.commit.CDOCommitInfo;
import org.eclipse.emf.cdo.eresource.CDOResource;
import org.eclipse.emf.cdo.session.CDOSession;
import org.eclipse.emf.cdo.tests.AbstractCDOTest;
import org.eclipse.emf.cdo.tests.model1.Category;
import org.eclipse.emf.cdo.tests.model1.Model1Factory;
import org.eclipse.emf.cdo.tests.util.TestSessionManager;
import org.eclipse.emf.cdo.transaction.CDOTransaction;
import org.eclipse.emf.cdo.util.CDOUtil;
import org.eclipse.emf.cdo.util.CommitException;
import java.util.concurrent.TimeUnit;
/**
* Bug 341995:
*
* @author Caspar De Groot
*/
public class Bugzilla_341995_Test extends AbstractCDOTest
{
public void test() throws Exception
{
CDOSession session = openSession();
CDOTransaction transaction = session.openTransaction();
CDOResource resource = transaction.createResource(getResourcePath("test"));
Model1Factory factory = getModel1Factory();
Category category = factory.createCategory();
resource.getContents().add(category);
transaction.commit();
CDOObject cdoCategory = CDOUtil.getCDOObject(category);
msg(cdoCategory.cdoRevision().getVersion());
long delay = 2000L;
TestSessionManager sessionManager = (TestSessionManager)getRepository().getSessionManager();
sessionManager.setCommitNotificationDelay(delay);
try
{
doSecondSessionAsync();
sessionManager.getDelayLatch().await(DEFAULT_TIMEOUT, TimeUnit.MILLISECONDS); // Wait until the delay commences
long time1 = System.currentTimeMillis();
// Attempt the lock; this must block for a while, because it needs to receive
// the commitNotification from the commit in the other session, which we are
// artificially delaying
cdoCategory.cdoWriteLock().lock(DEFAULT_TIMEOUT, TimeUnit.MILLISECONDS);
long timeTaken = System.currentTimeMillis() - time1;
// We verify that there really was a delay
assertEquals("timeTaken == " + timeTaken, true, timeTaken >= delay - 10);
transaction.close();
session.close();
}
finally
{
sessionManager.setCommitNotificationDelay(0L);
}
}
private void doSecondSessionAsync() throws CommitException
{
Runnable r = new Runnable()
{
public void run()
{
CDOSession session = openSession();
CDOTransaction transaction = session.openTransaction();
CDOResource resource = transaction.getResource(getResourcePath("test"));
Category category = (Category)resource.getContents().get(0);
category.setName("dirty");
CDOCommitInfo info;
try
{
info = transaction.commit();
}
catch (CommitException ex)
{
throw new RuntimeException(ex);
}
msg(info.getTimeStamp());
transaction.close();
session.close();
}
};
Thread thread = new Thread(r);
thread.setDaemon(true);
thread.start();
}
}