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

test.tck.TestHarness Maven / Gradle / Ivy

package test.tck;

import gov.nist.javax.sip.address.AddressFactoryImpl;
import gov.nist.javax.sip.stack.NioMessageProcessorFactory;

import java.io.File;
import java.io.FileInputStream;
import java.io.PrintWriter;
import java.io.StringWriter;
import java.util.Enumeration;
import java.util.Properties;

import javax.sip.SipFactory;
import javax.sip.address.AddressFactory;
import javax.sip.header.HeaderFactory;
import javax.sip.message.MessageFactory;

import junit.framework.TestCase;
import junit.framework.TestResult;

import org.apache.log4j.Appender;
import org.apache.log4j.BasicConfigurator;
import org.apache.log4j.ConsoleAppender;
import org.apache.log4j.FileAppender;
import org.apache.log4j.Logger;
import org.apache.log4j.SimpleLayout;

public class TestHarness extends TestCase {

    private static final String PATH_GOV_NIST = "gov.nist";

    protected static final String IMPLEMENTATION_PATH = "javax.sip.tck.PATH";

    protected static final String ABORT_ON_FAIL = "javax.sip.tck.ABORT_ON_FAIL";

    protected static final String LOG_FILE_NAME = "javax.sip.tck.LOG_FILE";

    protected static final String LOCAL_ADDRESS = "127.0.0.1";

    protected static final int TI_PORT = 5060;

    protected static final int RI_PORT = 6050;

    // Keep these static but initialize from the constructor to allow
    // changing from the GUI
    protected static String logFileName = "tcklog.txt";

    protected static String path = null;

    protected static PrintWriter printWriter;

    protected static boolean abortOnFail  = true;

    // this flag is set to false if there is any failure throughout the test
    // cycle
    // on either side of the protocol. It helps account for failures that are
    // not triggered in the
    // main test thread. It has to be initialized before each run.
    private static boolean testPassed = true;

    protected static MessageFactory tiMessageFactory;

    protected static HeaderFactory tiHeaderFactory;

    protected static AddressFactory tiAddressFactory;

    protected static MessageFactory riMessageFactory;

    protected static HeaderFactory riHeaderFactory;

    protected static AddressFactory riAddressFactory;

    protected static int testCounter;

    protected static SipFactory riFactory;

    protected static SipFactory tiFactory;

    protected TestResult testResult;

    private static Logger logger = Logger.getLogger("test.tck");

    private static String currentMethodName;

    private static String currentClassName;

    protected static Appender console = new ConsoleAppender(new SimpleLayout());


    static {
        try {
            Properties tckProperties = new Properties();


//            tckProperties.load(TestHarness.class.getClassLoader()
//                    .getResourceAsStream("tck.properties"));
            tckProperties.load(new FileInputStream("tck.properties"));
            Enumeration props = tckProperties.propertyNames();
            while (props.hasMoreElements()) {
                String propname = (String) props.nextElement();
                System.setProperty(propname, tckProperties
                        .getProperty(propname));
            }

            path = System.getProperties().getProperty(IMPLEMENTATION_PATH);
            String flag = System.getProperties().getProperty(ABORT_ON_FAIL);

            String lf = System.getProperties().getProperty(LOG_FILE_NAME);
            if (lf != null)
                logFileName = lf;
            abortOnFail = (flag != null && flag.equalsIgnoreCase("true"));

            // JvB: init log4j
            //PropertyConfigurator.configure("log4j.properties");

            BasicConfigurator.configure();

            // If already created a print writer then just use it.
            if (lf != null)
                logger.addAppender(new FileAppender(new SimpleLayout(),
                        logFileName));
            else
                logger.addAppender(new FileAppender(new SimpleLayout(),
                        "tckoutput.txt"));
        } catch (Exception ex) {
            throw new RuntimeException(ex);
        }

    }

    private static void println(String messageToPrint) {
        logger.info(messageToPrint);
    }

    /**
     * Default constructor
     */
    protected TestHarness() {

    }

    protected String getImplementationPath() {
        return System.getProperties().getProperty( IMPLEMENTATION_PATH, "gov.nist" );
    }

    public TestHarness(String name) {
        this(name, false); // default: disable auto-dialog
    }

    protected TestHarness(String name, boolean autoDialog) {
        super(name);
        this.testResult = new TestResult();

        getRIFactories(autoDialog);
        getTIFactories();

    }

    private static void logSuccess(String message) {
        testCounter++;
        Throwable throwable = new Throwable();
        StackTraceElement frameset[] = throwable.getStackTrace();
        StackTraceElement frame = frameset[2];
        String className = frame.getClassName();
        //int ind = className.lastIndexOf(".");
        //if (ind != -1) {
        //  className = className.substring(ind + 1);
        //}

        logger.info(className + ":" + frame.getMethodName() + "(" +
                        frame.getFileName() + ":"+ frame.getLineNumber() + ")" +  " : Status =  passed ! ");
        String methodName = frame.getMethodName();

        if (!(currentMethodName != null && methodName.equals(currentMethodName) && currentClassName
                .equals(className))) {
            currentClassName = className;
            currentMethodName = methodName;
            System.out.println("\n");
            System.out.print(currentClassName + ":" + currentMethodName);
        }
    }



    private static void logSuccess() {
        Throwable throwable = new Throwable();
        StackTraceElement frameset[] = throwable.getStackTrace();
        StackTraceElement frame = frameset[2];
        String className = frame.getClassName();
        //int ind = className.lastIndexOf(".");
        //if (ind != -1) {
        //  className = className.substring(ind + 1);
        //}
        logger.info(className + ":" + frame.getMethodName() + ": Status =  passed ! ");
        String methodName = frame.getMethodName();

        if (!(currentMethodName != null && methodName.equals(currentMethodName) && currentClassName
                .equals(className))) {
            currentClassName = className;
            currentMethodName = methodName;
            System.out.println("\n");
            System.out.print(currentClassName + ":" + currentMethodName);
        }
    }



    private static void logFailureDetails(String reason) {
        Throwable throwable = new Throwable();
        StackTraceElement frameset[] = throwable.getStackTrace();
        StackTraceElement frame = frameset[2];
        String className = frame.getClassName();
        logFailure(className, frame.getMethodName(), reason);

    }



    private static void logFailure(String className, String methodName,
            String reason) {
        println(" Test in function " + className
                + ":" + methodName + " failed because of " + reason);

        StringWriter stringWriter = new StringWriter();
        new Exception().printStackTrace(new PrintWriter(stringWriter));
        println(stringWriter.getBuffer().toString());

        testPassed = false;
        if (abortOnFail) {
            new Exception().printStackTrace();
            System.exit(0);
        }
    }

    private static void logFailure(String reason) {
        logFailureDetails(reason);
    }

    public static void assertTrue(boolean cond) {
        if (cond) {
            logSuccess();
        } else {
            logFailure("assertTrue failed");
        }
        if (!cond) {
            new Exception().printStackTrace();
            fail("assertion failure");
        }

        TestCase.assertTrue(cond);
    }

    public static void assertTrue(String diagnostic, boolean cond) {
        if (cond) {
            logSuccess("assertTrue " + diagnostic);
        } else {
            logFailure(diagnostic);
        }
        if (!cond) {
            new Exception(diagnostic).printStackTrace();
            fail(diagnostic + " : Assertion Failure ");

        }

        TestCase.assertTrue(diagnostic, cond);
    }

    public static void assertEquals(Object me, Object him) {
        if (me == him) {
            logSuccess();
        } else if (me == null && him != null) {
            logFailure("assertEquals failed");

        } else if (me != null && him == null) {
            logFailure("assertEquals failed");

        } else if (!me.equals(him)) {
            logFailure("assertEquals failed");

        }
        TestCase.assertEquals(me, him);
    }

    public static void assertEquals(String me, String him) {
        if (me == him) {
            logSuccess();
        } else if (me == null && him != null) {
            logFailure("assertEquals failed");

        } else if (me != null && him == null) {
            logFailure("assertEquals failed");

        } else if (!me.equals(him)) {
            logFailure("assertEquals failed");

        }
        TestCase.assertEquals(me, him);
    }

    public static void assertEquals(String reason, Object me, Object him) {
        if (me == him) {
            logSuccess("assertEquals : " + reason);
        } else if (me == null && him != null) {
            logFailure("assertEquals failed:" + reason );
        } else if (me != null && him == null) {
            logFailure("assertEquals failed:" + reason );
        } else if (!me.equals(him)) {
            logFailure(reason);
        }
        TestCase.assertEquals(reason, me, him);
    }

    public static void assertEquals(String reason, String me, String him) {
        if (me == him) {
            logSuccess("assertEquals " + reason);
        } else if (me == null && him != null) {
            logFailure("assertEquals failed");
        } else if (me != null && him == null) {
            logFailure("assertEquals failed");
        } else if (!me.equals(him)) {
            logFailure("assertEquals failed");
        }
        TestCase.assertEquals(reason, me, him);

    }

    public static void assertNotNull(String reason, Object thing) {
        if (thing != null) {
            logSuccess("assertNotNull " + reason);
        } else {
            logFailure(reason);
        }
        TestCase.assertNotNull(reason, thing);
    }

    public static void assertNull(String reason, Object thing) {
        if (thing == null) {
            logSuccess("assertNull " + reason);
        } else {
            logFailure(reason);
        }
        TestCase.assertNull(reason, thing);
    }

    public static void assertSame(String diagnostic, Object thing,
            Object thingie) {
        if (thing == thingie) {
            logSuccess("assertSame " + diagnostic);
        } else {
            logFailure(diagnostic);
        }
        TestCase.assertSame(diagnostic, thing, thingie);
    }

    public static void fail(String message) {
        logFailure(message);

        TestCase.fail(message);
    }

    public static void fail(String message, Exception ex) {
        logFailure(message);
        logger.error(message,ex);
        TestCase.fail( message );
    }

    public static void fail() {
        logFailure("Unknown reason for failure. Check logs for more info.");
        new Exception().printStackTrace();
        TestCase.fail();
    }

    public static void checkImplementsInterface(Class implementationClass,
            Class jainInterface) {

        assertTrue(jainInterface.toString() + " is_assignable_from "
                + implementationClass.toString(), jainInterface
                .isAssignableFrom(implementationClass));
    }

    public static boolean implementsInterface(Class implementationClass,
            Class jainInterface) {
        return jainInterface.isAssignableFrom(implementationClass);
    }

    static void getTIFactories() {
        try {
            tiFactory = SipFactory.getInstance();

            // JvB: need this! but before setting path
            tiFactory.resetFactory();

            // if no TI path is specified on the command line, then assume
            // RI self-test mode

            //String tiPathName = System.getProperty( IMPLEMENTATION_PATH, PATH_RI_HELPER );
            String tiPathName = System.getProperty( IMPLEMENTATION_PATH, "gov.nist" );

            // Yes this does access implementation classes but we have to do
            // things
            // this way for self test. v1.2 only assumes one instance of
            // factories per vendor
            // per jvm.
            tiFactory.setPathName(tiPathName);

            tiAddressFactory = tiFactory.createAddressFactory();
            tiHeaderFactory = tiFactory.createHeaderFactory();
            tiMessageFactory = tiFactory.createMessageFactory();
        } catch (Exception ex) {
            ex.printStackTrace();
            System.out
                    .println("Cannot get TI factories -- cannot proceed! Bailing");
            System.exit(0);
        }
        // Cannot sensibly proceed so bail out.
        if (tiAddressFactory == null || tiMessageFactory == null
                || tiHeaderFactory == null) {
            System.out
                    .println("Cannot get TI factories --  cannot proceed! Bailing!!");
            System.exit(0);
        }
    }

    static void getRIFactories(boolean autoDialog) {
        try {
            riFactory = SipFactory.getInstance();
            if (riFactory == null) {
                throw new TckInternalError("could not get SipFactory");
            }
            riFactory.resetFactory();

            // Testing against the RI.
            riFactory.setPathName(PATH_GOV_NIST);

            riAddressFactory = riFactory.createAddressFactory();

            assertTrue( "RI must be gov.nist implementation", riAddressFactory instanceof AddressFactoryImpl );

            riHeaderFactory = riFactory.createHeaderFactory();
            riMessageFactory = riFactory.createMessageFactory();
        } catch (Exception ex) {
            throw new TckInternalError("Could not get factories");
        }
    }

    public void logTestCompleted() {
    	TestCase.assertTrue( testPassed );
        logger.info(this.getName() + " Completed");
    }

    public void logTestCompleted(String info) {
      TestCase.assertTrue( testPassed );
        logger.info(this.getName() + ":" + info +" Completed");
    }


    /**
     * Returns a properties object containing all RI settings. The result from
     * this method is passed to the SipFactory when creating the RI Stack
     */
    public static Properties getRiProperties(boolean autoDialog) {
        // TODO collect all system properties
        // prefixed javax.sip.tck.ri and add them to the local
        // properties object

        Properties properties = new Properties();

        // IP_ADDRESS is deprecated as of jsip 1.2.
        // Each listening point associated with a stack has its own IP address.
        properties.setProperty("javax.sip.STACK_NAME", "RiStack");
//        properties.setProperty("gov.nist.javax.sip.TRACE_LEVEL", "0");

        properties.setProperty("gov.nist.javax.sip.TRACE_LEVEL", "32");
        properties.setProperty("gov.nist.javax.sip.DEBUG_LOG",
                "logs/riDebugLog.txt");
        properties.setProperty("gov.nist.javax.sip.SERVER_LOG",
                "logs/riMessageLog.txt");

        // JvB: Most TCK tests dont work well with automatic dialog support
        // enabled
        // Disable it for the moment
        properties.setProperty("javax.sip.AUTOMATIC_DIALOG_SUPPORT", autoDialog ? "ON" : "OFF");

        // JvB: for testing of ACK to non-2xx
        properties.setProperty(
                "gov.nist.javax.sip.PASS_INVITE_NON_2XX_ACK_TO_LISTENER",
                "true");
        // For testing sending of stateless null keepalive messages.
        //@see test.tck.msgflow.SipProviderTest.testSendNullRequest
        properties.setProperty("javax.sip.OUTBOUND_PROXY", LOCAL_ADDRESS + ":" + TI_PORT + "/udp");
        if(System.getProperty("enableNIO") != null && System.getProperty("enableNIO").equalsIgnoreCase("true")) {
        	logger.info("\nNIO Enabled\n");
        	properties.setProperty("gov.nist.javax.sip.MESSAGE_PROCESSOR_FACTORY", NioMessageProcessorFactory.class.getName());
        }

        return properties;
    }

    /**
     * Returns a properties object containing all TI settings. The result from
     * this method is passed to the SipFactory when creating the TI Stack
     *
     *
     */
    public static Properties getTiProperties() {
        // TODO collect all system properties
        // prefixed javax.sip.tck.ti and add them to the local
        // properties object

        Properties properties = new Properties();
        // IP_ADDRESS is deprecated as of jsip 1.2.
        // Each listening point associated with a stack has its own IP address.
        // properties.setProperty("javax.sip.IP_ADDRESS", LOCAL_ADDRESS);
        properties.setProperty("javax.sip.STACK_NAME", "TiStack");

        properties.setProperty("gov.nist.javax.sip.TRACE_LEVEL", "32");
        properties.setProperty("gov.nist.javax.sip.DEBUG_LOG",
                "logs/tiDebugLog.txt");
        properties.setProperty("gov.nist.javax.sip.SERVER_LOG",
                "logs/tiMessageLog.txt");
        // For testing sending of stateless null keepalive messages.
        //@see test.tck.msgflow.SipProviderTest.testSendNullRequest
        properties.setProperty("javax.sip.OUTBOUND_PROXY", LOCAL_ADDRESS + ":" + RI_PORT + "/udp");
        if(System.getProperty("enableNIO") != null && System.getProperty("enableNIO").equalsIgnoreCase("true")) {
        	logger.info("\nNIO Enabled\n");
        	properties.setProperty("gov.nist.javax.sip.MESSAGE_PROCESSOR_FACTORY", NioMessageProcessorFactory.class.getName());
        }
        return properties;
    }

    public void setUp() throws Exception {
        testPassed = true;
    }

    public void tearDown() throws Exception {
        assertTrue("Test failed. See log for details.", testPassed);
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy