blob: f25c4c086be2a11757506474a000b86d9dd2f916 [file] [log] [blame]
/*
* Copyright (c) 1998, 2021 Oracle and/or its affiliates. All rights reserved.
*
* This program and the accompanying materials are made available under the
* terms of the Eclipse Public License v. 2.0 which is available at
* http://www.eclipse.org/legal/epl-2.0,
* or the Eclipse Distribution License v. 1.0 which is available at
* http://www.eclipse.org/org/documents/edl-v10.php.
*
* SPDX-License-Identifier: EPL-2.0 OR BSD-3-Clause
*/
// Contributors:
// Oracle - initial API and implementation from Oracle TopLink
package org.eclipse.persistence.testing.tests.unitofwork.transactionisolation;
import java.util.Vector;
import org.eclipse.persistence.sessions.UnitOfWork;
import org.eclipse.persistence.testing.framework.AutoVerifyTestCase;
import org.eclipse.persistence.testing.models.employee.domain.Address;
import org.eclipse.persistence.testing.models.employee.domain.Employee;
/**
* Tests the Session read refactoring / reading through the write connection
* properly feature.
* <p>
* Merge test to handle the following advanced scenario:
* <ul>
* <li> begin early transaction and read employee in UOW
* <li> trigger address indirection in UOW, do not change it
* <li> read address on session into shared cache
* <li> commit. verify that two originals in shared cache pointing to each
* other, and no clones places in the shared cache.
* </ul>
* <p>
* In this version of the test the address already exists in the shared cache.
* This test is for code coverage mostly, if even that.
* @author smcritch
*/
public class TransactionIsolationMergeIndirectionOriginalsExistTest extends AutoVerifyTestCase {
UnitOfWork unitOfWork;
Employee original;
String originalFirstName;
@Override
protected void setup() throws Exception {
getSession().getIdentityMapAccessor().initializeAllIdentityMaps();
unitOfWork = getSession().acquireUnitOfWork();
}
@Override
public void reset() throws Exception {
if (unitOfWork != null) {
unitOfWork.release();
unitOfWork = null;
}
unitOfWork = getSession().acquireUnitOfWork();
Employee clone = (Employee)unitOfWork.readObject(original);
clone.setFirstName(originalFirstName);
unitOfWork.commit();
unitOfWork = null;
originalFirstName = null;
original = null;
getSession().getIdentityMapAccessor().initializeAllIdentityMaps();
}
@Override
public void test() {
// read all the addresses first, so they exist in the shared cache.
Vector addresses = getSession().readAllObjects(Address.class);
unitOfWork.beginEarlyTransaction();
Employee employeeClone = (Employee)unitOfWork.readObject(Employee.class);
// Just need the pk to reset() later.
original = employeeClone;
originalFirstName = original.getFirstName();
employeeClone.setFirstName("elle");
Address addressClone = employeeClone.getAddress();
Address originalAddress = (Address)getSession().readObject(addressClone);
unitOfWork.commit();
unitOfWork = null;
// Because the address was triggered, it should get merged into the old
// original.
Employee newOriginal = (Employee)getSession().getIdentityMapAccessor().getFromIdentityMap(employeeClone);
strongAssert(newOriginal != employeeClone, "Somehow the employee clone was merged into the shared cache.");
Address newAddress = (Address)getSession().getIdentityMapAccessor().getFromIdentityMap(addressClone);
strongAssert(newAddress == originalAddress, "Identity was lost on address accross the 1-1");
}
}