blob: a5b4451493934bc778aad4620aad7fc179862b5d [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.feature;
import org.eclipse.persistence.sessions.*;
import org.eclipse.persistence.testing.framework.*;
import org.eclipse.persistence.logging.DefaultSessionLog;
import org.eclipse.persistence.logging.SessionLog;
/**
* Test the efficiency of Message Logging. This is for CR#2272 to test that toString()
* is not unnecessarily called when Message Logging is enabled, but Debug logging disabled.
*/
public class MessageLoggingEfficiencyTest extends AutoVerifyTestCase {
SessionLog oldLog;
protected Exception caughtException = null;
public MessageLoggingEfficiencyTest() {
setDescription("Tests that Message Logging does not call toString on objects unless Debugging is enabled");
}
@Override
public void setup() {
caughtException = null;
oldLog = getSession().getSessionLog();
DefaultSessionLog newLog = new DefaultSessionLog();
newLog.setLevel(SessionLog.FINE);
getSession().setSessionLog(newLog);
}
@Override
public void test() {
Session s = getSession();
UnitOfWork uow = s.acquireUnitOfWork();
MessageLoggingEfficiencyTestClass testClass = new MessageLoggingEfficiencyTestClass();
try {
uow.registerNewObject(testClass);
} catch (TestErrorException tee) {
caughtException = tee;
} catch (org.eclipse.persistence.exceptions.ValidationException vE) {
//a ValidationException is expected because the MessageLoggingEfficiencyTestClass is not mapped
}
try {
uow.registerExistingObject(testClass);
} catch (TestErrorException tee) {
caughtException = tee;
} catch (org.eclipse.persistence.exceptions.ValidationException vE) {
//a ValidationException is expected because the MessageLoggingEfficiencyTestClass is not mapped
}
try {
uow.registerObject(testClass);
} catch (TestErrorException tee) {
caughtException = tee;
} catch (org.eclipse.persistence.exceptions.ValidationException vE) {
//a ValidationException is expected because the MessageLoggingEfficiencyTestClass is not mapped
}
try {
uow.mergeClone(testClass);
} catch (TestErrorException tee) {
caughtException = tee;
} catch (java.lang.NullPointerException npE) {
//a NullPointerException is expected because the MessageLoggingEfficiencyTestClass is not mapped
}
}
@Override
public void verify() throws Exception {
if (caughtException != null) {
//The caughtException is the TestErrorException thrown from the MessageLoggingEfficiencyTestClass
// object's toString() method
throw caughtException;
}
}
@Override
public void reset() {
getSession().setSessionLog(oldLog);
getSession().getIdentityMapAccessor().initializeAllIdentityMaps();
}
}