/* * Licensed to the Apache Software Foundation (ASF) under one or more * contributor license agreements. See the NOTICE file distributed with * this work for additional information regarding copyright ownership. * The ASF licenses this file to You under the Apache License, Version 2.0 * (the "License"); you may not use this file except in compliance with * the License. You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ using System; using System.IO; using Apache.NMS; using Apache.NMS.Test; using Apache.NMS.ActiveMQ.Commands; using NUnit.Framework; namespace Apache.NMS.ActiveMQ.Test { [TestFixture] public class MessageCompressionTest : NMSTestSupport { protected static string TEST_CLIENT_ID = "MessageCompressionTestClientId"; protected static string DESTINATION_NAME = "TEST.MessageCompressionTestDest"; // The following text should compress well private const string TEXT = "The quick red fox jumped over the lazy brown dog. " + "The quick red fox jumped over the lazy brown dog. " + "The quick red fox jumped over the lazy brown dog. " + "The quick red fox jumped over the lazy brown dog. " + "The quick red fox jumped over the lazy brown dog. " + "The quick red fox jumped over the lazy brown dog. " + "The quick red fox jumped over the lazy brown dog. " + "The quick red fox jumped over the lazy brown dog. " + "The quick red fox jumped over the lazy brown dog. " + "The quick red fox jumped over the lazy brown dog. " + "The quick red fox jumped over the lazy brown dog. " + "The quick red fox jumped over the lazy brown dog. " + "The quick red fox jumped over the lazy brown dog. " + "The quick red fox jumped over the lazy brown dog. " + "The quick red fox jumped over the lazy brown dog. " + "The quick red fox jumped over the lazy brown dog. " + "The quick red fox jumped over the lazy brown dog. "; protected bool a = true; protected byte b = 123; protected char c = 'c'; protected short d = 0x1234; protected int e = 0x12345678; protected long f = 0x1234567812345678; protected string g = "Hello World!"; protected bool h = false; protected byte i = 0xFF; protected short j = -0x1234; protected int k = -0x12345678; protected long l = -0x1234567812345678; protected float m = 2.1F; protected double n = 2.3; [Test] public void TestTextMessageCompression() { using(Connection connection = CreateConnection(TEST_CLIENT_ID) as Connection) { connection.UseCompression = true; connection.Start(); Assert.IsTrue(connection.UseCompression); using(ISession session = connection.CreateSession(AcknowledgementMode.AutoAcknowledge)) { ITextMessage message = session.CreateTextMessage(TEXT); IDestination destination = session.CreateTemporaryQueue(); IMessageProducer producer = session.CreateProducer(destination); IMessageConsumer consumer = session.CreateConsumer(destination); producer.Send(message); message = consumer.Receive(TimeSpan.FromMilliseconds(6000)) as ITextMessage; Assert.IsNotNull(message); Assert.IsTrue(((ActiveMQMessage) message).Compressed); Assert.AreEqual(TEXT, message.Text); } } } [Test] public void TestObjectMessageCompression() { using(Connection connection = CreateConnection(TEST_CLIENT_ID) as Connection) { connection.UseCompression = true; connection.Start(); Assert.IsTrue(connection.UseCompression); using(ISession session = connection.CreateSession(AcknowledgementMode.AutoAcknowledge)) { IObjectMessage message = session.CreateObjectMessage(TEXT); IDestination destination = session.CreateTemporaryQueue(); IMessageProducer producer = session.CreateProducer(destination); IMessageConsumer consumer = session.CreateConsumer(destination); producer.Send(message); message = consumer.Receive(TimeSpan.FromMilliseconds(6000)) as IObjectMessage; Assert.IsNotNull(message); Assert.IsTrue(((ActiveMQMessage) message).Compressed); Assert.AreEqual(TEXT, message.Body); } } } [Test] public void TestStreamMessageCompression() { using(Connection connection = CreateConnection(TEST_CLIENT_ID) as Connection) { connection.UseCompression = true; connection.Start(); Assert.IsTrue(connection.UseCompression); using(ISession session = connection.CreateSession(AcknowledgementMode.AutoAcknowledge)) { IStreamMessage message = session.CreateStreamMessage(); IDestination destination = session.CreateTemporaryQueue(); IMessageProducer producer = session.CreateProducer(destination); IMessageConsumer consumer = session.CreateConsumer(destination); message.WriteBoolean(a); message.WriteByte(b); message.WriteChar(c); message.WriteInt16(d); message.WriteInt32(e); message.WriteInt64(f); message.WriteString(g); message.WriteBoolean(h); message.WriteByte(i); message.WriteInt16(j); message.WriteInt32(k); message.WriteInt64(l); message.WriteSingle(m); message.WriteDouble(n); producer.Send(message); message = consumer.Receive(TimeSpan.FromMilliseconds(4000)) as IStreamMessage; Assert.IsNotNull(message); Assert.IsTrue(((ActiveMQMessage) message).Compressed); // use generic API to access entries Assert.AreEqual(a, message.ReadBoolean(), "Stream Boolean Value: a"); Assert.AreEqual(b, message.ReadByte(), "Stream Byte Value: b"); Assert.AreEqual(c, message.ReadChar(), "Stream Char Value: c"); Assert.AreEqual(d, message.ReadInt16(), "Stream Int16 Value: d"); Assert.AreEqual(e, message.ReadInt32(), "Stream Int32 Value: e"); Assert.AreEqual(f, message.ReadInt64(), "Stream Int64 Value: f"); Assert.AreEqual(g, message.ReadString(), "Stream String Value: g"); Assert.AreEqual(h, message.ReadBoolean(), "Stream Boolean Value: h"); Assert.AreEqual(i, message.ReadByte(), "Stream Byte Value: i"); Assert.AreEqual(j, message.ReadInt16(), "Stream Int16 Value: j"); Assert.AreEqual(k, message.ReadInt32(), "Stream Int32 Value: k"); Assert.AreEqual(l, message.ReadInt64(), "Stream Int64 Value: l"); Assert.AreEqual(m, message.ReadSingle(), "Stream Single Value: m"); Assert.AreEqual(n, message.ReadDouble(), "Stream Double Value: n"); } } } [Test] public void TestMapMessageCompression() { using(Connection connection = CreateConnection(TEST_CLIENT_ID) as Connection) { connection.UseCompression = true; connection.Start(); Assert.IsTrue(connection.UseCompression); using(ISession session = connection.CreateSession(AcknowledgementMode.AutoAcknowledge)) { IMapMessage message = session.CreateMapMessage(); IDestination destination = session.CreateTemporaryQueue(); IMessageProducer producer = session.CreateProducer(destination); IMessageConsumer consumer = session.CreateConsumer(destination); message.Body["a"] = a; message.Body["b"] = b; message.Body["c"] = c; message.Body["d"] = d; message.Body["e"] = e; message.Body["f"] = f; message.Body["g"] = g; message.Body["h"] = h; message.Body["i"] = i; message.Body["j"] = j; message.Body["k"] = k; message.Body["l"] = l; message.Body["m"] = m; message.Body["n"] = n; producer.Send(message); message = consumer.Receive(TimeSpan.FromMilliseconds(4000)) as IMapMessage; Assert.IsNotNull(message); Assert.IsTrue(((ActiveMQMessage) message).Compressed); Assert.AreEqual(a, message.Body.GetBool("a"), "map entry: a"); Assert.AreEqual(b, message.Body.GetByte("b"), "map entry: b"); Assert.AreEqual(c, message.Body.GetChar("c"), "map entry: c"); Assert.AreEqual(d, message.Body.GetShort("d"), "map entry: d"); Assert.AreEqual(e, message.Body.GetInt("e"), "map entry: e"); Assert.AreEqual(f, message.Body.GetLong("f"), "map entry: f"); Assert.AreEqual(g, message.Body.GetString("g"), "map entry: g"); Assert.AreEqual(h, message.Body.GetBool("h"), "map entry: h"); Assert.AreEqual(i, message.Body.GetByte("i"), "map entry: i"); Assert.AreEqual(j, message.Body.GetShort("j"), "map entry: j"); Assert.AreEqual(k, message.Body.GetInt("k"), "map entry: k"); Assert.AreEqual(l, message.Body.GetLong("l"), "map entry: l"); Assert.AreEqual(m, message.Body.GetFloat("m"), "map entry: m"); Assert.AreEqual(n, message.Body.GetDouble("n"), "map entry: n"); } } } [Test] public void TestBytesMessageCompression() { using(Connection connection = CreateConnection(TEST_CLIENT_ID) as Connection) { connection.UseCompression = true; connection.Start(); using(ISession session = connection.CreateSession(AcknowledgementMode.AutoAcknowledge)) { IDestination destination = session.CreateTemporaryQueue(); using(IMessageConsumer consumer = session.CreateConsumer(destination)) using(IMessageProducer producer = session.CreateProducer(destination)) { IBytesMessage message = session.CreateBytesMessage(); message.WriteBoolean(a); message.WriteByte(b); message.WriteChar(c); message.WriteInt16(d); message.WriteInt32(e); message.WriteInt64(f); message.WriteString(g); message.WriteBoolean(h); message.WriteByte(i); message.WriteInt16(j); message.WriteInt32(k); message.WriteInt64(l); message.WriteSingle(m); message.WriteDouble(n); producer.Send(message); message = consumer.Receive(receiveTimeout) as IBytesMessage; Assert.IsNotNull(message); Assert.IsTrue(((ActiveMQMessage) message).Compressed); Assert.AreEqual(a, message.ReadBoolean(), "Stream Boolean Value: a"); Assert.AreEqual(b, message.ReadByte(), "Stream Byte Value: b"); Assert.AreEqual(c, message.ReadChar(), "Stream Char Value: c"); Assert.AreEqual(d, message.ReadInt16(), "Stream Int16 Value: d"); Assert.AreEqual(e, message.ReadInt32(), "Stream Int32 Value: e"); Assert.AreEqual(f, message.ReadInt64(), "Stream Int64 Value: f"); Assert.AreEqual(g, message.ReadString(), "Stream String Value: g"); Assert.AreEqual(h, message.ReadBoolean(), "Stream Boolean Value: h"); Assert.AreEqual(i, message.ReadByte(), "Stream Byte Value: i"); Assert.AreEqual(j, message.ReadInt16(), "Stream Int16 Value: j"); Assert.AreEqual(k, message.ReadInt32(), "Stream Int32 Value: k"); Assert.AreEqual(l, message.ReadInt64(), "Stream Int64 Value: l"); Assert.AreEqual(m, message.ReadSingle(), "Stream Single Value: m"); Assert.AreEqual(n, message.ReadDouble(), "Stream Double Value: n"); } } } } } }