All Downloads are FREE. Search and download functionalities are using the official Maven repository.

at.spardat.enterprise.exc.test.SysExceptionTest Maven / Gradle / Ivy

/*
 * /*******************************************************************************
 * Copyright (c) 2003, 2007 s IT Solutions AT Spardat GmbH .
 * 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:
 *     s IT Solutions AT Spardat GmbH - initial API and implementation
 * @(#) $Id:  $
 *******************************************************************************/
package at.spardat.enterprise.exc.test;

import java.io.ByteArrayOutputStream;
import java.io.CharArrayWriter;
import java.io.PrintStream;
import java.io.PrintWriter;

import at.spardat.enterprise.exc.BaseException;
import at.spardat.enterprise.exc.INotification;
import at.spardat.enterprise.exc.SysException;
import junit.framework.Assert;
import junit.framework.TestCase;

public class SysExceptionTest extends TestCase {

    public void testSysExceptionStringObjectArray() {
        SysException exc = new SysException("test with parameters: p1={0} p2={1}",new Object[]{"one","two"});
        Assert.assertEquals("test with parameters: p1=one p2=two", exc.getMessage());
        Assert.assertEquals("test with parameters: p1=one p2=two", exc.getLocalizedMessage());
        Assert.assertEquals("at.spardat.enterprise.exc.SysException: test with parameters: p1=one p2=two", exc.toString());
        String trace = stackTraceToString(exc);
        Assert.assertTrue(trace.startsWith("at.spardat.enterprise.exc.SysException: test with parameters: p1=one p2=two"));
        Assert.assertNull(exc.getCause());
        Assert.assertEquals(exc.getDetail(), exc.getCause());
    }

    public void testSysExceptionStringObjectObject() {
        SysException exc = new SysException("test with parameters: p1={0} p2={1}","one","two");
        Assert.assertEquals("test with parameters: p1=one p2=two", exc.getMessage());
        Assert.assertEquals("test with parameters: p1=one p2=two", exc.getLocalizedMessage());
        Assert.assertEquals("at.spardat.enterprise.exc.SysException: test with parameters: p1=one p2=two", exc.toString());
        String trace = stackTraceToString(exc);
        Assert.assertTrue(trace.startsWith("at.spardat.enterprise.exc.SysException: test with parameters: p1=one p2=two"));
        Assert.assertNull(exc.getCause());
        Assert.assertEquals(exc.getDetail(), exc.getCause());
    }

    public void testSysExceptionStringObject() {
        SysException exc = new SysException("test with parameters: p1={0}","one");
        Assert.assertEquals("test with parameters: p1=one", exc.getMessage());
        Assert.assertEquals("test with parameters: p1=one", exc.getLocalizedMessage());
        Assert.assertEquals("at.spardat.enterprise.exc.SysException: test with parameters: p1=one", exc.toString());
        String trace = stackTraceToString(exc);
        Assert.assertTrue(trace.startsWith("at.spardat.enterprise.exc.SysException: test with parameters: p1=one"));
        Assert.assertNull(exc.getCause());
        Assert.assertEquals(exc.getDetail(), exc.getCause());
    }

    public void testSysExceptionString() {
        Exception rt = new RuntimeException("test without parameters");
        SysException exc = new SysException("test without parameters");
        String message = exc.toString();
        Assert.assertEquals("at.spardat.enterprise.exc.SysException: test without parameters", message);
        message = exc.getMessage();
        String expected = rt.getMessage();
        Assert.assertEquals(expected,message);
        message = exc.getLocalizedMessage();
        expected = rt.getLocalizedMessage();
        Assert.assertEquals(expected,message);

        String trace = stackTraceToString(exc);
        String rttrace = stackTraceToString(rt);
        rttrace = rttrace.replaceAll("java\\.lang\\.RuntimeException", "at.spardat.enterprise.exc.SysException");
        rttrace = fixLineNumber(rttrace, trace);
        Assert.assertEquals(rttrace, trace);

        Assert.assertNull(exc.getCause());
        Assert.assertEquals(exc.getDetail(), exc.getCause());

    }

    public void testSysExceptionThrowableString() {
        Exception detail = new Exception("testdetail");
        Exception rt = new RuntimeException("outher message",detail);
        SysException exc = new SysException(detail,"outher message");
        String message = exc.toString();
        String expected = rt.toString();
        expected = expected.replaceAll("java\\.lang\\.RuntimeException", "at.spardat.enterprise.exc.SysException");
        Assert.assertEquals(expected, message);
        message = exc.getMessage();
        expected = rt.getMessage();
        Assert.assertEquals(expected,message);
        message = exc.getLocalizedMessage();
        expected = rt.getLocalizedMessage();
        Assert.assertEquals(expected,message);

        String trace = stackTraceToString(exc);
        String rttrace = stackTraceToString(rt);
        rttrace = rttrace.replaceAll("java\\.lang\\.RuntimeException", "at.spardat.enterprise.exc.SysException");
        rttrace = fixLineNumber(rttrace, trace);
        Assert.assertEquals(rttrace, trace);

        Assert.assertEquals(detail,exc.getDetail());
        Assert.assertEquals(exc.getDetail(), exc.getCause());
        Assert.assertEquals(rt.getCause(),exc.getCause());
}


    // message handled differently:
    // java uses detail.toString()
    // sysException uses ""
//    public void testSysExceptionThrowable() {
//        Exception detail = new Exception("testdetail");
//        Exception rt = new RuntimeException(detail);
//        Exception exc = new SysException(detail);
//        String message = exc.toString();
//        String expected = rt.toString();
//        expected = expected.replaceAll("java\\.lang\\.RuntimeException", "at.spardat.enterprise.exc.SysException");
//        Assert.assertEquals(expected, message);
//        message = exc.getMessage();
//        expected = rt.getMessage();
//        Assert.assertEquals(expected,message);
//        message = exc.getLocalizedMessage();
//        expected = rt.getLocalizedMessage();
//        Assert.assertEquals(expected,message);
//
//        String trace = stackTraceToString(exc);
//        String rttrace = stackTraceToString(rt);
//        rttrace = rttrace.replaceAll("java\\.lang\\.RuntimeException", "at.spardat.enterprise.exc.SysException");
//        rttrace = fixLineNumber(rttrace, trace);
//        Assert.assertEquals(rttrace, trace);
//    }
    public void testSysExceptionThrowable() {
        Exception detail = new Exception("testdetail");
        SysException exc = new SysException(detail);
        String message = exc.toString();
        Assert.assertEquals("at.spardat.enterprise.exc.SysException: ", message);
        message = exc.getMessage();
        Assert.assertEquals("",message);
        message = exc.getLocalizedMessage();
        Assert.assertEquals("",message);

        Assert.assertEquals(detail,exc.getDetail());
        Assert.assertEquals(exc.getDetail(), exc.getCause());
}

    public void testSysExceptionThrowableStringObjectObject() {
        Exception detail = new Exception("testdetail");
        Exception rt = new RuntimeException("test with parameters: p1=one p2=two",detail);
        SysException exc = new SysException(detail,"test with parameters: p1={0} p2={1}","one","two");
        Assert.assertEquals("test with parameters: p1=one p2=two", exc.getMessage());
        Assert.assertEquals("test with parameters: p1=one p2=two", exc.getLocalizedMessage());
        Assert.assertEquals("at.spardat.enterprise.exc.SysException: test with parameters: p1=one p2=two", exc.toString());
        String trace = stackTraceToString(exc);
        Assert.assertTrue(trace.startsWith("at.spardat.enterprise.exc.SysException: test with parameters: p1=one p2=two"));

        String message = exc.toString();
        String expected = rt.toString();
        expected = expected.replaceAll("java\\.lang\\.RuntimeException", "at.spardat.enterprise.exc.SysException");
        Assert.assertEquals(expected, message);
        message = exc.getMessage();
        expected = rt.getMessage();
        Assert.assertEquals(expected,message);
        message = exc.getLocalizedMessage();
        expected = rt.getLocalizedMessage();
        Assert.assertEquals(expected,message);

        trace = stackTraceToString(exc);
        String rttrace = stackTraceToString(rt);
        rttrace = rttrace.replaceAll("java\\.lang\\.RuntimeException", "at.spardat.enterprise.exc.SysException");
        rttrace = fixLineNumber(rttrace, trace);
        Assert.assertEquals(rttrace, trace);

        Assert.assertEquals(detail,exc.getDetail());
        Assert.assertEquals(exc.getDetail(), exc.getCause());
        Assert.assertEquals(rt.getCause(),exc.getCause());

    }

    public void testSysExceptionThrowableStringObject() {
        Exception detail = new Exception("testdetail");
        Exception rt = new RuntimeException("test with parameters: p1=one",detail);
        SysException exc = new SysException(detail,"test with parameters: p1={0}","one");
        Assert.assertEquals("test with parameters: p1=one", exc.getMessage());
        Assert.assertEquals("test with parameters: p1=one", exc.getLocalizedMessage());
        Assert.assertEquals("at.spardat.enterprise.exc.SysException: test with parameters: p1=one", exc.toString());
        String trace = stackTraceToString(exc);
        Assert.assertTrue(trace.startsWith("at.spardat.enterprise.exc.SysException: test with parameters: p1=one"));

        String message = exc.toString();
        String expected = rt.toString();
        expected = expected.replaceAll("java\\.lang\\.RuntimeException", "at.spardat.enterprise.exc.SysException");
        Assert.assertEquals(expected, message);
        message = exc.getMessage();
        expected = rt.getMessage();
        Assert.assertEquals(expected,message);
        message = exc.getLocalizedMessage();
        expected = rt.getLocalizedMessage();
        Assert.assertEquals(expected,message);

        trace = stackTraceToString(exc);
        String rttrace = stackTraceToString(rt);
        rttrace = rttrace.replaceAll("java\\.lang\\.RuntimeException", "at.spardat.enterprise.exc.SysException");
        rttrace = fixLineNumber(rttrace, trace);
        Assert.assertEquals(rttrace, trace);

        Assert.assertEquals(detail,exc.getDetail());
        Assert.assertEquals(exc.getDetail(), exc.getCause());
        Assert.assertEquals(rt.getCause(),exc.getCause());
    }

    public void testSysExceptionThrowableStringObjectArray() {
        Exception detail = new Exception("testdetail");
        Exception rt = new RuntimeException("test with parameters: p1=one p2=two",detail);
        SysException exc = new SysException(detail,"test with parameters: p1={0} p2={1}",new Object[]{"one","two"});
        Assert.assertEquals("test with parameters: p1=one p2=two", exc.getMessage());
        Assert.assertEquals("test with parameters: p1=one p2=two", exc.getLocalizedMessage());
        Assert.assertEquals("at.spardat.enterprise.exc.SysException: test with parameters: p1=one p2=two", exc.toString());
        String trace = stackTraceToString(exc);
        Assert.assertTrue(trace.startsWith("at.spardat.enterprise.exc.SysException: test with parameters: p1=one p2=two"));

        String message = exc.toString();
        String expected = rt.toString();
        expected = expected.replaceAll("java\\.lang\\.RuntimeException", "at.spardat.enterprise.exc.SysException");
        Assert.assertEquals(expected, message);
        message = exc.getMessage();
        expected = rt.getMessage();
        Assert.assertEquals(expected,message);
        message = exc.getLocalizedMessage();
        expected = rt.getLocalizedMessage();
        Assert.assertEquals(expected,message);

        trace = stackTraceToString(exc);
        String rttrace = stackTraceToString(rt);
        rttrace = rttrace.replaceAll("java\\.lang\\.RuntimeException", "at.spardat.enterprise.exc.SysException");
        rttrace = fixLineNumber(rttrace, trace);
        Assert.assertEquals(rttrace, trace);

        Assert.assertEquals(detail,exc.getDetail());
        Assert.assertEquals(exc.getDetail(), exc.getCause());
        Assert.assertEquals(rt.getCause(),exc.getCause());
    }

    // shown in toString, not shown in getMessage
    public void testSetCode() {
        SysException exc = new SysException("bla bla");
        exc.setCode(4711);
        Assert.assertEquals(4711,exc.getCode());
        Assert.assertTrue(exc.containsCode(4711));
        String message = exc.toString();
        Assert.assertEquals("at.spardat.enterprise.exc.SysException [4711]: bla bla", message);
        message = exc.getMessage();
        Assert.assertEquals("bla bla",message);
        message = exc.getLocalizedMessage();
        Assert.assertEquals("bla bla",message);
    }

    // not shown in toString and getMessage
    public void testSetReaction() {
        SysException exc = new SysException("bla bla");
        exc.setReaction(INotification.R_YES_NO_CANCEL);
        Assert.assertEquals(INotification.R_YES_NO_CANCEL,exc.getReaction());
        String message = exc.toString();
        Assert.assertEquals("at.spardat.enterprise.exc.SysException: bla bla", message);
        message = exc.getMessage();
        Assert.assertEquals("bla bla",message);
        message = exc.getLocalizedMessage();
        Assert.assertEquals("bla bla",message);
    }

    // not shown in toString and getMessage
    public void testSetShortMessage() {
        SysException exc = new SysException("bla bla");
        exc.setReaction(INotification.R_YES_NO_CANCEL);
        Assert.assertEquals(INotification.R_YES_NO_CANCEL,exc.getReaction());
        String message = exc.toString();
        Assert.assertEquals("at.spardat.enterprise.exc.SysException: bla bla", message);
        message = exc.getMessage();
        Assert.assertEquals("bla bla",message);
        message = exc.getLocalizedMessage();
        Assert.assertEquals("bla bla",message);
    }

    // not shown in toString and getMessage
    public void testSetType() {
        SysException exc = new SysException("bla bla");
        exc.setType(INotification.T_ERROR);
        Assert.assertEquals(INotification.T_ERROR,exc.getType());
        String message = exc.toString();
        Assert.assertEquals("at.spardat.enterprise.exc.SysException: bla bla", message);
        message = exc.getMessage();
        Assert.assertEquals("bla bla",message);
        message = exc.getLocalizedMessage();
        Assert.assertEquals("bla bla",message);
    }

    // not shown in toString and getMessage
    public void testSetShowToEndUser() {
        SysException exc = new SysException("bla bla");
        Assert.assertEquals(false,exc.showToEndUser());
        exc.setShowToEndUser(true);
        Assert.assertEquals(true,exc.showToEndUser());
        String message = exc.toString();
        Assert.assertEquals("at.spardat.enterprise.exc.SysException: bla bla", message);
        message = exc.getMessage();
        Assert.assertEquals("bla bla",message);
        message = exc.getLocalizedMessage();
        Assert.assertEquals("bla bla",message);
        exc.setShowToEndUser(false);
        Assert.assertEquals(false,exc.showToEndUser());
    }


    public void testGetCode() {
        SysException detail = new SysException("testdetail");
        SysException exc = new SysException("bla bla");
        Assert.assertEquals(0,exc.getCode());
        exc.setCode(1);
        Assert.assertEquals(1,exc.getCode());
        exc.setCode(Integer.MAX_VALUE);
        Assert.assertEquals(Integer.MAX_VALUE,exc.getCode());

        SysException nest = new SysException(detail,"outhermessage");
        nest.setCode(13);
        detail.setCode(24);
        Assert.assertEquals(24,detail.getCode());
        Assert.assertEquals(13,nest.getCode());
    }

    public void testContainsCode() {
        SysException detail = new SysException("testdetail");
        SysException exc = new SysException("bla bla");
        Assert.assertTrue(exc.containsCode(0));
        exc.setCode(5);
        Assert.assertTrue(exc.containsCode(5));
        exc.setCode(Integer.MAX_VALUE);
        Assert.assertTrue(exc.containsCode(Integer.MAX_VALUE));

        SysException nest = new SysException(detail,"outhermessage");
        nest.setCode(13);
        detail.setCode(24);
        Assert.assertTrue(nest.containsCode(13));
        Assert.assertTrue(nest.containsCode(24));
        Assert.assertTrue(detail.containsCode(24));
        Assert.assertFalse(detail.containsCode(13));
    }

    public void testGetType() {
        SysException detail = new SysException("testdetail");
        SysException exc = new SysException("bla bla");
        Assert.assertEquals(0,exc.getCode());
        exc.setType(1);
        Assert.assertEquals(1,exc.getType());
        exc.setType(Integer.MAX_VALUE);
        Assert.assertEquals(Integer.MAX_VALUE,exc.getType());

        SysException nest = new SysException(detail,"outhermessage");
        nest.setType(13);
        detail.setType(24);
        Assert.assertEquals(24,detail.getType());
        Assert.assertEquals(13,nest.getType());
    }

    public void testGetReaction() {
        SysException detail = new SysException("testdetail");
        SysException exc = new SysException("bla bla");
        Assert.assertEquals(0,exc.getCode());
        exc.setReaction(1);
        Assert.assertEquals(1,exc.getReaction());
        exc.setReaction(Integer.MAX_VALUE);
        Assert.assertEquals(Integer.MAX_VALUE,exc.getReaction());

        SysException nest = new SysException(detail,"outhermessage");
        nest.setReaction(13);
        detail.setReaction(24);
        Assert.assertEquals(24,detail.getReaction());
        Assert.assertEquals(13,nest.getReaction());
    }

    public void testGetShortMessage() {
        SysException detail = new SysException("testdetail");
        SysException exc = new SysException("bla bla");
        Assert.assertEquals("",exc.getShortMessage());
        exc.setShortMessage("one");
        Assert.assertEquals("one",exc.getShortMessage());
        exc.setShortMessage(""+Integer.MAX_VALUE);
        Assert.assertEquals(""+Integer.MAX_VALUE,exc.getShortMessage());

        SysException nest = new SysException(detail,"outhermessage");
        nest.setShortMessage("13");
        detail.setShortMessage("24");
        Assert.assertEquals("24",detail.getShortMessage());
        Assert.assertEquals("13",nest.getShortMessage());
    }


    public void testGetFirstNonEmptyMessage() {
        Exception detail = new SysException("testdetail");
        SysException exc = new SysException("bla bla");
        assertEquals("bla bla", exc.getFirstNonEmptyMessage(false));
        assertEquals("at.spardat.enterprise.exc.SysException: bla bla", exc.getFirstNonEmptyMessage(true));
        SysException nest = new SysException(detail);
        assertEquals("testdetail", nest.getFirstNonEmptyMessage(false));
        assertEquals("at.spardat.enterprise.exc.SysException: testdetail", nest.getFirstNonEmptyMessage(true));
        detail = new Exception("testdetail");
        nest = new SysException(detail);
        assertEquals("testdetail", nest.getFirstNonEmptyMessage(false));
        assertEquals("java.lang.Exception: testdetail", nest.getFirstNonEmptyMessage(true));
        detail = new Exception();
        nest = new SysException(detail);
        assertEquals("", nest.getFirstNonEmptyMessage(false));
        assertEquals("java.lang.Exception", nest.getFirstNonEmptyMessage(true));

        detail = new Exception("testdetail");
        exc = new SysException(detail,"bla bla");
        nest = new SysException(exc);
        assertEquals("bla bla", nest.getFirstNonEmptyMessage(false));
        assertEquals("at.spardat.enterprise.exc.SysException: bla bla", nest.getFirstNonEmptyMessage(true));

        detail = new Exception("testdetail");
        exc = new SysException(detail);
        nest = new SysException(exc);
        assertEquals("testdetail", nest.getFirstNonEmptyMessage(false));
        assertEquals("java.lang.Exception: testdetail", nest.getFirstNonEmptyMessage(true));

        // java.lang exceptions allways return something for getMessage()!
        detail = new Exception("testdetail");
        Exception exc2 = new RuntimeException(detail);
        nest = new SysException(exc2);
        assertEquals("java.lang.Exception: testdetail", nest.getFirstNonEmptyMessage(false));
        assertEquals("java.lang.RuntimeException: java.lang.Exception: testdetail", nest.getFirstNonEmptyMessage(true));
    }

    public void testGetMessageBoolean() {
        Exception rt = new RuntimeException("message");
        SysException exc = new SysException("message");
        String message = exc.getMessage(false);
        String expected = rt.getMessage();
        Assert.assertEquals(expected, message);
        Assert.assertEquals("message", message);
        message = exc.getMessage(true);
        expected = rt.toString();
        expected = expected.replaceAll("java\\.lang\\.RuntimeException", "at.spardat.enterprise.exc.SysException");
        Assert.assertEquals(expected, message);
        Assert.assertEquals("at.spardat.enterprise.exc.SysException: message", message);
    }

    public void testGetDetail() {
        SysException detail = new SysException("testdetail");
        SysException exc = new SysException(detail,"bla bla");
        assertNull(detail.getDetail());
        assertEquals(detail, exc.getDetail());
        assertEquals(exc.getDetail(),exc.getCause());

        exc = new SysException("later");
        exc.initCause(detail);
        assertEquals(exc.getDetail(),exc.getCause());
    }

    public void testPrepareMigration() {
        SysException exc = new SysException("bla bla");
        assertNull(exc.getDetail()); // no detail before
        exc.prepareMigration(); // does nothing
        assertNull(exc.getDetail()); // no detail after
        assertNull(exc.getCause());

        Exception detail = new SysException("testdetail");
        exc = new SysException(detail,"bla bla");
        assertEquals(detail, exc.getDetail());
        exc.prepareMigration(); // keep sysexception
        assertEquals(detail, exc.getDetail());
        assertEquals(detail, exc.getCause());

        detail = new Exception("testdetail");
        exc = new SysException(detail,"bla bla");
        String before = stackTraceToString(exc);
        assertEquals(detail, exc.getDetail());
        exc.prepareMigration(); // strip exception
        assertNull(exc.getDetail()); // no detail after
        assertNull(exc.getCause());
        String after = stackTraceToString(exc);
        assertEquals(before,after); // detail still in printstacktrace

        // deeper nested
        detail = new Exception("testdetail");
        Exception nest = new Exception("nest",detail);
        exc = new SysException(nest,"bla bla");
        before = stackTraceToString(exc);
        assertEquals(nest, exc.getDetail());
        assertEquals(detail, nest.getCause());
        exc.prepareMigration(); // strip exception
        assertNull(exc.getDetail()); // no detail after
        assertNull(exc.getCause());
        after = stackTraceToString(exc);
        assertEquals(before,after); // detail still in printstacktrace
    }

    public void testToString() {
        SysException exc = new SysException("message");
        String result = exc.toString();
        Assert.assertEquals("at.spardat.enterprise.exc.SysException: message", result);
        String expected = exc.getClass().getName() + ": " + exc.getMessage();
        Assert.assertEquals(expected, result);

        exc.setCode(15);
        Assert.assertEquals("at.spardat.enterprise.exc.SysException [15]: message", exc.toString());

    }

    public void testGetOwnStackTrace() {
        Exception rt = new RuntimeException("message");
        SysException exc = new SysException("message");
        String trace = exc.getOwnStackTrace();
        String expected = stackTraceToString(rt);
        expected = expected.replaceAll("java\\.lang\\.RuntimeException", "at.spardat.enterprise.exc.SysException");
        expected = fixLineNumber(expected, trace);
        Assert.assertEquals(expected, trace);

        Exception detail = new Exception("detail");
        rt = new RuntimeException("message"); // without detail
        exc = new SysException(detail,"message");
        trace = exc.getOwnStackTrace(); // contains no detail
        expected = stackTraceToString(rt);
        expected = expected.replaceAll("java\\.lang\\.RuntimeException", "at.spardat.enterprise.exc.SysException");
        expected = fixLineNumber(expected, trace);
        Assert.assertEquals(expected, trace);
    }

    // in baseexceptio the stacktrace is created in the constructor
    // getStackOfThis fixes the header lines if the message changes later on
    public void testGetStackOfThis() {
        SysException exc = new SysException("message");
        String trace = stackTraceToString(exc);
        Assert.assertTrue(trace.startsWith("at.spardat.enterprise.exc.SysException: message"));
        exc.setMessage("changed");
        trace = stackTraceToString(exc);
        Assert.assertTrue(trace.startsWith("at.spardat.enterprise.exc.SysException: changed"));

        SysException detail = new SysException("detail");
        exc = new SysException(detail,"message");
        trace = stackTraceToString(exc);
        Assert.assertTrue(trace.startsWith("at.spardat.enterprise.exc.SysException: message"));
        exc.setMessage("changed");
        trace = stackTraceToString(exc);
        Assert.assertTrue(trace.startsWith("at.spardat.enterprise.exc.SysException: changed"));
        int start = trace.indexOf("Caused by");
        Assert.assertTrue(trace.substring(start).startsWith("Caused by: at.spardat.enterprise.exc.SysException: detail"));
        detail.setMessage("something completly different");
        trace = stackTraceToString(exc);
        start = trace.indexOf("Caused by");
        Assert.assertTrue(trace.substring(start).startsWith("Caused by: at.spardat.enterprise.exc.SysException: something completly different"));
    }

    public void testTruncateSubclasses() {
        SysException exc = new SysException("message");
        BaseException my = new MySysException("message");
        Assert.assertEquals(MySysException.class, my.getClass());
        my = my.truncateSubclasses();
        Assert.assertEquals(SysException.class, my.getClass());

        String trace = stackTraceToString(my);
        String expected = stackTraceToString(exc);
        expected = fixLineNumber(expected, trace);
        Assert.assertEquals(expected, trace);

        // both deails must be in same line for the stacktrace to be identical
        Exception detail = new SysException("detail");   Exception myDetail = new MySysException("detail");
        exc = new SysException(detail,"message");
        my = new MySysException(myDetail,"message");
        Assert.assertEquals(MySysException.class, my.getClass());
        Assert.assertEquals(MySysException.class, my.getDetail().getClass());
        my = my.truncateSubclasses();
        Assert.assertEquals(SysException.class, my.getClass());
        Assert.assertEquals(SysException.class, my.getDetail().getClass());

        trace = stackTraceToString(my);
        expected = stackTraceToString(exc);
        expected = fixLineNumber(expected, trace);
        Assert.assertEquals(expected, trace);
    }

    public void testSetMessageStringObjectObject() {
        Exception detail = new Exception("detail");
        SysException exc = new SysException(detail);
        exc.setMessage("test with parameters: p1={0} p2={1}","one","two");
        Assert.assertEquals("test with parameters: p1=one p2=two", exc.getMessage());
        Assert.assertEquals("test with parameters: p1=one p2=two", exc.getLocalizedMessage());
        Assert.assertEquals("at.spardat.enterprise.exc.SysException: test with parameters: p1=one p2=two", exc.toString());
        String trace = stackTraceToString(exc);
        Assert.assertTrue(trace.startsWith("at.spardat.enterprise.exc.SysException: test with parameters: p1=one p2=two"));
    }

    public void testSetMessageStringObject() {
        Exception detail = new Exception("detail");
        SysException exc = new SysException(detail);
        exc.setMessage("test with parameters: p1={0}","one");
        Assert.assertEquals("test with parameters: p1=one", exc.getMessage());
        Assert.assertEquals("test with parameters: p1=one", exc.getLocalizedMessage());
        Assert.assertEquals("at.spardat.enterprise.exc.SysException: test with parameters: p1=one", exc.toString());
        String trace = stackTraceToString(exc);
        Assert.assertTrue(trace.startsWith("at.spardat.enterprise.exc.SysException: test with parameters: p1=one"));
    }

    public void testSetMessageString() {
        SysException exc = new SysException("message");
        Assert.assertEquals("message", exc.getMessage());
        exc.setMessage("bla bla");
        Assert.assertEquals("bla bla", exc.getMessage());
        Assert.assertEquals("at.spardat.enterprise.exc.SysException: bla bla", exc.toString());
        String trace = stackTraceToString(exc);
        Assert.assertTrue(trace.startsWith("at.spardat.enterprise.exc.SysException: bla bla"));

        Exception detail = new Exception("detail");
        exc = new SysException(detail);
        Assert.assertEquals("", exc.getMessage());
        exc.setMessage("bla bla");
        Assert.assertEquals("bla bla", exc.getMessage());
        Assert.assertEquals("at.spardat.enterprise.exc.SysException: bla bla", exc.toString());
        trace = stackTraceToString(exc);
        Assert.assertTrue(trace.startsWith("at.spardat.enterprise.exc.SysException: bla bla"));

    }

    public void testGetStackTrace() {
        Exception rt = new RuntimeException("message");
        SysException exc = new SysException("message");

        StackTraceElement[] trace = exc.getStackTrace();
        StackTraceElement[] expected = rt.getStackTrace();
        Assert.assertTrue(equalsStackTrace(expected, trace));

        Exception detail = new Exception("detail");
        rt = new RuntimeException("message",detail);
        exc = new SysException(detail,"message");

        trace = exc.getStackTrace();
        expected = rt.getStackTrace();
        Assert.assertTrue(equalsStackTrace(expected, trace));

        // works only with new implementation
        trace = exc.getCause().getStackTrace();
        expected = rt.getCause().getStackTrace();
        Assert.assertTrue(equalsStackTrace(expected, trace));
        // works with both implementations
        trace = exc.getDetail().getStackTrace();
        expected = rt.getCause().getStackTrace();
        Assert.assertTrue(equalsStackTrace(expected, trace));

    }

    // setStackTrace not supported in SysException and AppException
//    public void testSetStackTrace() {
//        Exception rt = new RuntimeException("message");
//        Exception exc = new SysException("message");
//        String oldTrace = stackTraceToString(exc);
//        String expected = stackTraceToString(rt);
//        expected = expected.replaceAll("java\\.lang\\.RuntimeException", "at.spardat.enterprise.exc.SysException");
//        Assert.assertFalse(expected.equals(oldTrace)); // different line numbers
//        exc.setStackTrace(rt.getStackTrace());
//        String newTrace = stackTraceToString(exc);
//        // new behaviour
//        Assert.assertEquals(expected, newTrace); // now same line numbers
//    }

//    public void testFillInStackTrace() {
//        fail("Not yet implemented");
//    }

    public void testGetCause() {
        Exception rt = new RuntimeException("message");
        SysException exc = new SysException("message");
        Assert.assertNull(exc.getCause());
        Assert.assertEquals(exc.getDetail(), exc.getCause());
        Assert.assertEquals(rt.getCause(), exc.getCause());

        Exception detail = new Exception("detail");
        rt = new RuntimeException(detail);
        exc = new SysException(detail);
        Assert.assertEquals(detail, exc.getCause());
        Assert.assertEquals(exc.getDetail(), exc.getCause());
        Assert.assertEquals(rt.getCause(), exc.getCause());


        rt = new RuntimeException("message");
        rt.initCause(detail);
        exc = new SysException("message");
        exc.initCause(detail);
        Assert.assertEquals(detail, exc.getCause());
        Assert.assertEquals(exc.getDetail(), exc.getCause());
        Assert.assertEquals(rt.getCause(), exc.getCause());
        String trace = stackTraceToString(exc);
        String expected = stackTraceToString(rt);
        expected = expected.replaceAll("java\\.lang\\.RuntimeException", "at.spardat.enterprise.exc.SysException");
        expected = fixLineNumber(expected, trace);
        Assert.assertEquals(expected, trace);
    }

    public void testInitCause() {
        Exception detail = new Exception("detail");
        Exception rt = new RuntimeException("message");
        SysException exc = new SysException("message");
        Assert.assertNull(exc.getCause());
        exc.initCause(detail);
        rt.initCause(detail);
        Assert.assertEquals(detail, exc.getCause());
        Assert.assertEquals(exc.getDetail(), exc.getCause());
        Assert.assertEquals(rt.getCause(), exc.getCause());
        String trace = stackTraceToString(exc);
        String expected = stackTraceToString(rt);
        expected = expected.replaceAll("java\\.lang\\.RuntimeException", "at.spardat.enterprise.exc.SysException");
        expected = fixLineNumber(expected, trace);
        Assert.assertEquals(expected, trace);

        Exception newdetail = new RuntimeException("newdetail");
        try {
            exc.initCause(newdetail);
            Assert.assertTrue("missing exception", false);
        } catch(Exception eise) {
            Assert.assertTrue(eise instanceof IllegalStateException);
            Assert.assertEquals("java.lang.IllegalStateException: Can't overwrite cause", eise.toString());
        }

        exc = new SysException(detail,"message");
        try {
            exc.initCause(newdetail);
            Assert.assertTrue("missing exception", false);
        } catch(Exception eise) {
            Assert.assertTrue(eise instanceof IllegalStateException);
            Assert.assertEquals("java.lang.IllegalStateException: Can't overwrite cause", eise.toString());
        }

        exc = new SysException("message");
        try {
            exc.initCause(exc);
            Assert.assertTrue("missing exception", false);
        } catch(Exception eise) {
            Assert.assertTrue(eise instanceof IllegalArgumentException);
            Assert.assertEquals("java.lang.IllegalArgumentException: Self-causation not permitted", eise.toString());
        }
    }

    /**
     * Converts the stacktrace of exc to a string using both
     * printStackTrace(PrintStream) and printStackTrace(PrintWriter).
     * It asserts, that both method give the same result.
     * @returns the result
     */
    private String stackTraceToString(Throwable exc) {
        ByteArrayOutputStream bout = new ByteArrayOutputStream();
        PrintStream out = new PrintStream(bout);
        exc.printStackTrace(out);
        out.close();
        String first = bout.toString();

        CharArrayWriter cout = new CharArrayWriter();
        PrintWriter pout = new PrintWriter(cout);
        exc.printStackTrace(pout);
        pout.close();
        String second = cout.toString();

        Assert.assertEquals(first, second);
        return first;
    }

    private String fixLineNumber(String toChange,String template) {
        String filename = this.getClass().getName();
        filename = filename.substring(filename.lastIndexOf('.')+1)+".java";

        // find line number in template
        int start = template.indexOf(filename)+filename.length();
        int end = template.indexOf(')', start);
        String rightNumber = template.substring(start, end);

        // find lin number in toChange
        start = toChange.indexOf(filename)+filename.length();
        end = toChange.indexOf(')', start);

        // convert
        StringBuffer out = new StringBuffer(toChange.length()+10);
        out.append(toChange.substring(0, start));
        out.append(rightNumber);
        out.append(toChange.substring(end));

        return out.toString();
    }

    boolean equalsStackTrace(StackTraceElement[] expected,StackTraceElement[] actual) {
        assertEquals(expected.length, actual.length);
        // className and lineNumber will differ in first entry
        assertEquals(expected[0].getFileName(), actual[0].getFileName());
        assertEquals(expected[0].getMethodName(), actual[0].getMethodName());
        for(int i=1;i




© 2015 - 2025 Weber Informatics LLC | Privacy Policy