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 FloatSerializerTest extends AbstractXmlSerializerTest2<Float> {
@Nonnull
@Override
protected StreamSerializer<Float> getSerializer() throws Exception {
return new FloatSerializer();
}
@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( 123.0f, out );
shallAcceptClose[0] = true;
out.close();
}
@DataPoint
public static final Entry<?> ENTRY1 = create( 123.0f, "<float>123.0</float>" );
@DataPoint
public static final Entry<?> ENTRY2 = create( 123.5f, "<float>123.5</float>" );
@DataPoint
public static final Entry<?> ENTRY3 = create( -123.5f, "<float>-123.5</float>" );
@DataPoint
public static final Entry<?> ENTRY4 = create( Float.MAX_VALUE, "<float>3.4028235E38</float>" );
@DataPoint
public static final Entry<?> ENTRY5 = create( -Float.MAX_VALUE, "<float>-3.4028235E38</float>" );
}