/*******************************************************************************
* Copyright (c) 1998, 2015 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 v1.0 and Eclipse Distribution License v. 1.0
* which accompanies this distribution.
* The Eclipse Public License is available at http://www.eclipse.org/legal/epl-v10.html
* and the Eclipse Distribution License is available at
* http://www.eclipse.org/org/documents/edl-v10.php.
*
* 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");
}
public void setup() {
caughtException = null;
oldLog = getSession().getSessionLog();
DefaultSessionLog newLog = new DefaultSessionLog();
newLog.setLevel(SessionLog.FINE);
getSession().setSessionLog(newLog);
}
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
}
}
public void verify() throws Exception {
if (caughtException != null) {
//The caughtException is the TestErrorException thrown from the MessageLoggingEfficiencyTestClass
// object's toString() method
throw caughtException;
}
}
public void reset() {
getSession().setSessionLog(oldLog);
getSession().getIdentityMapAccessor().initializeAllIdentityMaps();
}
}