You are viewing a plain text version of this content. The canonical link for it is here.
Posted to commits@qpid.apache.org by ri...@apache.org on 2010/01/13 22:53:37 UTC
svn commit: r898953 -
/qpid/trunk/qpid/java/broker/src/test/java/org/apache/qpid/server/logging/LogMessageTest.java
Author: ritchiem
Date: Wed Jan 13 21:53:36 2010
New Revision: 898953
URL: http://svn.apache.org/viewvc?rev=898953&view=rev
Log:
QPID-2137 : Add a test that creates log messages simultaneously in multiple threads to validate the previous change.
Modified:
qpid/trunk/qpid/java/broker/src/test/java/org/apache/qpid/server/logging/LogMessageTest.java
Modified: qpid/trunk/qpid/java/broker/src/test/java/org/apache/qpid/server/logging/LogMessageTest.java
URL: http://svn.apache.org/viewvc/qpid/trunk/qpid/java/broker/src/test/java/org/apache/qpid/server/logging/LogMessageTest.java?rev=898953&r1=898952&r2=898953&view=diff
==============================================================================
--- qpid/trunk/qpid/java/broker/src/test/java/org/apache/qpid/server/logging/LogMessageTest.java (original)
+++ qpid/trunk/qpid/java/broker/src/test/java/org/apache/qpid/server/logging/LogMessageTest.java Wed Jan 13 21:53:36 2010
@@ -21,6 +21,7 @@
package org.apache.qpid.server.logging;
import junit.framework.TestCase;
+import org.apache.qpid.server.logging.messages.BrokerMessages;
import java.util.Locale;
import java.util.ResourceBundle;
@@ -31,7 +32,7 @@
/**
* Test that the US local has a loadable bundle.
* No longer have a specific en_US bundle so cannot verify that that version
- * is loaded.
+ * is loaded. Can only verify that we get a ResourceBundle loaded.
*/
public void testBundle()
{
@@ -44,7 +45,7 @@
}
/**
- * Test that loading an undefined locale will result in loadig of the
+ * Test that loading an undefined locale will result in loading of the
* default US locale.
*/
public void testUndefinedLocale()
@@ -68,4 +69,101 @@
}
}
-}
+ /**
+ * test Simultaneous log message generation.
+ * QPID-2137 highlighted that log message generation was not thread-safe.
+ * Test to ensure that simultaneous logging is possible and does not throw an exception.
+ * @throws InterruptedException if there is a problem joining logging threads.
+ */
+ public void testSimultaneousLogging() throws InterruptedException
+ {
+ int LOGGERS = 10;
+ int LOG_COUNT = 10;
+ LogGenerator[] logGenerators = new LogGenerator[LOGGERS];
+ Thread[] threads = new Thread[LOGGERS];
+
+ //Create Loggers
+ for (int i = 0; i < LOGGERS; i++)
+ {
+ logGenerators[i] = new LogGenerator(LOG_COUNT);
+ threads[i] = new Thread(logGenerators[i]);
+ }
+
+ //Run Loggers
+ for (int i = 0; i < LOGGERS; i++)
+ {
+ threads[i].start();
+ }
+
+ //End Loggers
+ for (int i = 0; i < LOGGERS; i++)
+ {
+ threads[i].join();
+ Exception e = logGenerators[i].getThrowException();
+ // If we have an exception something went wrong.
+ // Check and see if it was QPID-2137
+ if (e != null)
+ {
+ // Just log out if we find the usual exception causing QPID-2137
+ if (e instanceof StringIndexOutOfBoundsException)
+ {
+ System.err.println("Detected QPID-2137");
+ }
+ fail("Exception thrown during log generation:" + e);
+ }
+ }
+ }
+
+ /**
+ * Inner class used by testSimultaneousLogging.
+ *
+ * This class creates a given number of LogMessages using the BrokerMessages package.
+ * BRK_CONFIG and BRK_LISTENING messages are both created per count.
+ *
+ * This class is run multiple times simultaneously so that we increase the chance of
+ * reproducing QPID-2137. This is reproduced when the pattern string used in the MessageFormat
+ * class is changed whilst formatting is taking place.
+ *
+ */
+ class LogGenerator implements Runnable
+ {
+ private Exception _exception = null;
+ private int _count;
+
+ /**
+ * @param count The number of Log Messages to generate
+ */
+ LogGenerator(int count)
+ {
+ _count = count;
+ }
+
+ public void run()
+ {
+ try
+ {
+ // try and generate _count iterations of Config & Listening messages.
+ for (int i = 0; i < _count; i++)
+ {
+ BrokerMessages.BRK_CONFIG("Config");
+ BrokerMessages.BRK_LISTENING("TCP", 1234);
+ }
+ }
+ catch (Exception e)
+ {
+ // if something goes wrong recorded it for later analysis.
+ _exception = e;
+ }
+ }
+
+ /**
+ * Return any exception that was thrown during the log generation.
+ * @return Exception
+ */
+ public Exception getThrowException()
+ {
+ return _exception;
+ }
+ }
+
+}
\ No newline at end of file
---------------------------------------------------------------------
Apache Qpid - AMQP Messaging Implementation
Project: http://qpid.apache.org
Use/Interact: mailto:commits-subscribe@qpid.apache.org