/**
* GRANITE DATA SERVICES
* Copyright (C) 2006-2015 GRANITE DATA SERVICES S.A.S.
*
* This file is part of the Granite Data Services Platform.
*
* Granite Data Services is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation; either
* version 2.1 of the License, or (at your option) any later version.
*
* Granite Data Services is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser
* General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this library; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
* USA, or see <http://www.gnu.org/licenses/>.
*/
package org.granite.test.jmf;
import java.io.IOException;
import java.io.PrintStream;
import java.util.Arrays;
import java.util.Collection;
import java.util.EnumSet;
import java.util.LinkedHashSet;
import java.util.Stack;
import java.util.Vector;
import org.granite.messaging.jmf.CodecRegistry;
import org.granite.messaging.jmf.DefaultCodecRegistry;
import org.granite.messaging.jmf.JMFConstants;
import org.granite.messaging.jmf.JMFDumper;
import org.granite.test.jmf.Util.ByteArrayJMFDeserializer;
import org.granite.test.jmf.Util.ByteArrayJMFDumper;
import org.granite.test.jmf.Util.ByteArrayJMFSerializer;
import org.junit.After;
import org.junit.Assert;
import org.junit.Before;
import org.junit.Test;
public class TestJMFGenericCollection implements JMFConstants {
private CodecRegistry codecRegistry;
@Before
public void before() {
codecRegistry = new DefaultCodecRegistry();
}
@After
public void after() {
codecRegistry = null;
}
static enum TestEnum {
ONE,
TWO,
THREE,
FOUR,
FIVE,
SIX,
SEVEN,
EIGHT,
NINE,
TEN
};
@SuppressWarnings("unchecked")
@Test
public void testGenericCollection() throws ClassNotFoundException, IOException {
Collection<?> collection = new LinkedHashSet<Object>();
Collection<?> clone = serializeDeserialize(collection);
Assert.assertEquals(collection.getClass(), clone.getClass());
Assert.assertEquals(collection, clone);
collection = new LinkedHashSet<Object>(Arrays.asList(new Object[]{Boolean.TRUE}));
clone = serializeDeserialize(collection);
Assert.assertEquals(collection.getClass(), clone.getClass());
Assert.assertEquals(collection, clone);
collection = new LinkedHashSet<Object>(Arrays.asList(new Boolean[]{Boolean.TRUE, Boolean.TRUE, Boolean.FALSE}));
clone = serializeDeserialize(collection);
Assert.assertEquals(collection.getClass(), clone.getClass());
Assert.assertEquals(collection, clone);
collection = new LinkedHashSet<Object>(Arrays.asList(new Object[]{
Boolean.TRUE,
Byte.valueOf(Byte.MAX_VALUE),
Byte.valueOf((byte)0),
null,
Double.NaN,
"Bla bla"
}));
clone = serializeDeserialize(collection);
Assert.assertEquals(collection.getClass(), clone.getClass());
Assert.assertEquals(collection, clone);
collection = new Stack<Object>();
clone = serializeDeserialize(collection);
Assert.assertEquals(collection.getClass(), clone.getClass());
Assert.assertEquals(collection, clone);
collection = new Stack<Object>();
((Stack<Object>)collection).push(Boolean.TRUE);
((Stack<Object>)collection).push(Boolean.TRUE);
((Stack<Object>)collection).push(Boolean.FALSE);
((Stack<Object>)collection).push("bla");
clone = serializeDeserialize(collection);
Assert.assertEquals(collection.getClass(), clone.getClass());
Assert.assertEquals(collection, clone);
collection = new Vector<Object>();
clone = serializeDeserialize(collection);
Assert.assertEquals(collection.getClass(), clone.getClass());
Assert.assertEquals(collection, clone);
collection = new Vector<Object>(Arrays.asList(new Object[]{
Boolean.TRUE,
Byte.valueOf(Byte.MAX_VALUE),
Byte.valueOf((byte)0),
null,
Double.NaN,
"Bla bla"
}));
clone = serializeDeserialize(collection);
Assert.assertEquals(collection.getClass(), clone.getClass());
Assert.assertEquals(collection, clone);
// Use standard object codec with writeReplace / readResolve...
collection = EnumSet.noneOf(TestEnum.class);
clone = serializeDeserialize(collection);
Assert.assertEquals(collection.getClass(), clone.getClass());
Assert.assertEquals(collection, clone);
collection = EnumSet.allOf(TestEnum.class);
clone = serializeDeserialize(collection);
Assert.assertEquals(collection.getClass(), clone.getClass());
Assert.assertEquals(collection, clone);
}
private Collection<?> serializeDeserialize(Collection<?> v) throws ClassNotFoundException, IOException {
return serializeDeserialize(v, false);
}
private Collection<?> serializeDeserialize(Collection<?> v, boolean dump) throws ClassNotFoundException, IOException {
ByteArrayJMFSerializer serializer = new ByteArrayJMFSerializer(codecRegistry);
serializer.writeObject(v);
serializer.close();
byte[] bytes = serializer.toByteArray();
PrintStream ps = Util.newNullPrintStream();
if (dump) {
System.out.println(bytes.length + "B. " + Util.toHexString(bytes));
ps = System.out;
}
JMFDumper dumper = new ByteArrayJMFDumper(bytes, codecRegistry, ps);
dumper.dump();
dumper.close();
ByteArrayJMFDeserializer deserializer = new ByteArrayJMFDeserializer(bytes, codecRegistry);
Collection<?> clone = (Collection<?>)deserializer.readObject();
deserializer.close();
return clone;
}
}