package com.cedarsoft.serialization.stax.mate.primitives; import com.cedarsoft.serialization.StreamSerializer; import com.cedarsoft.serialization.test.utils.AbstractXmlSerializerTest2; import com.cedarsoft.serialization.test.utils.Entry; import org.junit.*; import org.junit.experimental.theories.*; import javax.annotation.Nonnull; import java.io.ByteArrayOutputStream; import java.io.FilterOutputStream; import java.io.IOException; import java.io.OutputStream; import static org.assertj.core.api.Fail.fail; /** * @author Johannes Schneider (<a href="mailto:js@cedarsoft.com">js@cedarsoft.com</a>) */ public class LongSerializerTest extends AbstractXmlSerializerTest2<Long> { @Nonnull @Override protected StreamSerializer<Long> getSerializer() throws Exception { return new LongSerializer(); } @Test public void testNotClose() throws Exception { final boolean[] shallAcceptClose = {false}; OutputStream out = new FilterOutputStream( new ByteArrayOutputStream() ) { private boolean closed; @Override public void close() throws IOException { if ( !shallAcceptClose[0] ) { fail( "Unacceptable close!" ); } super.close(); closed = true; } }; getSerializer().serialize( 123L, out ); shallAcceptClose[0] = true; out.close(); } @DataPoint public static final Entry<?> ENTRY1 = create( 123L, "<long>123</long>" ); @DataPoint public static final Entry<?> ENTRY4 = create( Long.MAX_VALUE, "<long>9223372036854775807</long>" ); @DataPoint public static final Entry<?> ENTRY5 = create( Long.MIN_VALUE, "<long>-9223372036854775808</long>" ); }