mirror of
https://github.com/haraldk/TwelveMonkeys.git
synced 2025-08-05 12:35:29 -04:00
Added test case for IIOOutputStreamAdapter + fixed bug in flush method.
Strengthened tests for IIOInputStreamAdapter Minor clean up of the code.
This commit is contained in:
parent
d1e72d1ece
commit
2a282cf8e4
@ -28,6 +28,8 @@
|
|||||||
|
|
||||||
package com.twelvemonkeys.imageio.util;
|
package com.twelvemonkeys.imageio.util;
|
||||||
|
|
||||||
|
import com.twelvemonkeys.lang.Validate;
|
||||||
|
|
||||||
import javax.imageio.stream.ImageInputStream;
|
import javax.imageio.stream.ImageInputStream;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.io.InputStream;
|
import java.io.InputStream;
|
||||||
@ -75,16 +77,12 @@ class IIOInputStreamAdapter extends InputStream {
|
|||||||
}
|
}
|
||||||
|
|
||||||
private IIOInputStreamAdapter(ImageInputStream pInput, long pLength, boolean pHasLength) {
|
private IIOInputStreamAdapter(ImageInputStream pInput, long pLength, boolean pHasLength) {
|
||||||
if (pInput == null) {
|
Validate.notNull(pInput, "stream");
|
||||||
throw new IllegalArgumentException("stream == null");
|
Validate.isTrue(!pHasLength || pLength >= 0, pLength, "length < 0: %f");
|
||||||
}
|
|
||||||
if (pHasLength && pLength < 0) {
|
|
||||||
throw new IllegalArgumentException("length < 0");
|
|
||||||
}
|
|
||||||
|
|
||||||
input = pInput;
|
input = pInput;
|
||||||
hasLength = pHasLength;
|
|
||||||
left = pLength;
|
left = pLength;
|
||||||
|
hasLength = pHasLength;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -105,6 +103,7 @@ class IIOInputStreamAdapter extends InputStream {
|
|||||||
if (hasLength) {
|
if (hasLength) {
|
||||||
return left > 0 ? (int) Math.min(Integer.MAX_VALUE, left) : 0;
|
return left > 0 ? (int) Math.min(Integer.MAX_VALUE, left) : 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
return 0; // We don't really know, so we say 0 to be safe.
|
return 0; // We don't really know, so we say 0 to be safe.
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -28,6 +28,8 @@
|
|||||||
|
|
||||||
package com.twelvemonkeys.imageio.util;
|
package com.twelvemonkeys.imageio.util;
|
||||||
|
|
||||||
|
import com.twelvemonkeys.lang.Validate;
|
||||||
|
|
||||||
import javax.imageio.stream.ImageOutputStream;
|
import javax.imageio.stream.ImageOutputStream;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.io.OutputStream;
|
import java.io.OutputStream;
|
||||||
@ -43,27 +45,40 @@ class IIOOutputStreamAdapter extends OutputStream {
|
|||||||
private ImageOutputStream output;
|
private ImageOutputStream output;
|
||||||
|
|
||||||
public IIOOutputStreamAdapter(final ImageOutputStream pOutput) {
|
public IIOOutputStreamAdapter(final ImageOutputStream pOutput) {
|
||||||
|
Validate.notNull(pOutput, "stream == null");
|
||||||
|
|
||||||
output = pOutput;
|
output = pOutput;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void write(final byte[] pBytes) throws IOException {
|
public void write(final byte[] pBytes) throws IOException {
|
||||||
|
assertOpen();
|
||||||
output.write(pBytes);
|
output.write(pBytes);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void write(final byte[] pBytes, final int pOffset, final int pLength) throws IOException {
|
public void write(final byte[] pBytes, final int pOffset, final int pLength) throws IOException {
|
||||||
|
assertOpen();
|
||||||
output.write(pBytes, pOffset, pLength);
|
output.write(pBytes, pOffset, pLength);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void write(final int pByte) throws IOException {
|
public void write(final int pByte) throws IOException {
|
||||||
|
assertOpen();
|
||||||
output.write(pByte);
|
output.write(pByte);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void flush() throws IOException {
|
public void flush() throws IOException {
|
||||||
output.flush();
|
// NOTE: The contract of OutputStream.flush is very different from ImageOutputStream.flush. We can't delegate.
|
||||||
|
// TODO: Fulfill the contract of OutputStream.flush? This seems to be good enough for now.
|
||||||
|
assertOpen();
|
||||||
|
}
|
||||||
|
|
||||||
|
private void assertOpen() throws IOException {
|
||||||
|
if (output == null) {
|
||||||
|
throw new IOException("stream already closed");
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -51,6 +51,11 @@ public class IIOInputStreamAdapterTestCase extends InputStreamAbstractTestCase {
|
|||||||
return new IIOInputStreamAdapter(new MemoryCacheImageInputStream(new ByteArrayInputStream(pBytes)), pBytes.length);
|
return new IIOInputStreamAdapter(new MemoryCacheImageInputStream(new ByteArrayInputStream(pBytes)), pBytes.length);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test(expected = IllegalArgumentException.class)
|
||||||
|
public void testCreateNull() {
|
||||||
|
new IIOInputStreamAdapter(null);
|
||||||
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testReadSubstreamOpenEnd() throws IOException {
|
public void testReadSubstreamOpenEnd() throws IOException {
|
||||||
byte[] bytes = new byte[20];
|
byte[] bytes = new byte[20];
|
||||||
|
@ -0,0 +1,87 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2011, Harald Kuhr
|
||||||
|
* All rights reserved.
|
||||||
|
*
|
||||||
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
* modification, are permitted provided that the following conditions are met:
|
||||||
|
* * Redistributions of source code must retain the above copyright
|
||||||
|
* notice, this list of conditions and the following disclaimer.
|
||||||
|
* * Redistributions in binary form must reproduce the above copyright
|
||||||
|
* notice, this list of conditions and the following disclaimer in the
|
||||||
|
* documentation and/or other materials provided with the distribution.
|
||||||
|
* * Neither the name "TwelveMonkeys" nor the
|
||||||
|
* names of its contributors may be used to endorse or promote products
|
||||||
|
* derived from this software without specific prior written permission.
|
||||||
|
*
|
||||||
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
||||||
|
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
||||||
|
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
||||||
|
* A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR
|
||||||
|
* CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
|
||||||
|
* EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
|
||||||
|
* PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
|
||||||
|
* PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
|
||||||
|
* LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
|
||||||
|
* NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
||||||
|
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package com.twelvemonkeys.imageio.util;
|
||||||
|
|
||||||
|
import com.twelvemonkeys.io.OutputStreamAbstractTestCase;
|
||||||
|
import org.junit.Test;
|
||||||
|
|
||||||
|
import javax.imageio.stream.MemoryCacheImageOutputStream;
|
||||||
|
import java.io.ByteArrayOutputStream;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.io.OutputStream;
|
||||||
|
|
||||||
|
import static org.junit.Assert.*;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* IIOOutputStreamAdapterTestCase
|
||||||
|
*
|
||||||
|
* @author <a href="mailto:harald.kuhr@gmail.com">Harald Kuhr</a>
|
||||||
|
* @author last modified by $Author: haraldk$
|
||||||
|
* @version $Id: IIOOutputStreamAdapterTestCase.java,v 1.0 30.11.11 12:21 haraldk Exp$
|
||||||
|
*/
|
||||||
|
public class IIOOutputStreamAdapterTestCase extends OutputStreamAbstractTestCase {
|
||||||
|
@Override
|
||||||
|
protected OutputStream makeObject() {
|
||||||
|
return new IIOOutputStreamAdapter(new MemoryCacheImageOutputStream(new ByteArrayOutputStream()));
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test(expected = IllegalArgumentException.class)
|
||||||
|
public void testCreateNull() {
|
||||||
|
new IIOOutputStreamAdapter(null);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testFlushOnAdapterDoesNotMoveFlushedPositionInBacking() throws IOException {
|
||||||
|
MemoryCacheImageOutputStream backing = new MemoryCacheImageOutputStream(new ByteArrayOutputStream());
|
||||||
|
IIOOutputStreamAdapter adapter = new IIOOutputStreamAdapter(backing);
|
||||||
|
|
||||||
|
// Sanity check
|
||||||
|
assertEquals(0, backing.getFlushedPosition());
|
||||||
|
|
||||||
|
// Write & flush
|
||||||
|
adapter.write(0xCA);
|
||||||
|
adapter.write(new byte[8]);
|
||||||
|
adapter.write(0xFE);
|
||||||
|
adapter.flush();
|
||||||
|
|
||||||
|
// Assertions
|
||||||
|
assertEquals(10, backing.length());
|
||||||
|
assertEquals(10, backing.getStreamPosition());
|
||||||
|
assertEquals(0, backing.getFlushedPosition());
|
||||||
|
|
||||||
|
// Just make sure we can safely seek back to start and read data back
|
||||||
|
backing.seek(0);
|
||||||
|
assertEquals(0, backing.getStreamPosition());
|
||||||
|
|
||||||
|
// If this can be read, I think the contract of flush is also fulfilled (kind of)
|
||||||
|
assertEquals(0xCA, backing.read());
|
||||||
|
assertEquals(8, backing.skipBytes(8));
|
||||||
|
assertEquals(0xFE, backing.read());
|
||||||
|
}
|
||||||
|
}
|
Loading…
x
Reference in New Issue
Block a user