提交 07b9e3b6 编写于 作者: I igerasim

8026756: Test java/util/zip/GZIP/GZIPInZip.java failed

Reviewed-by: alanb
上级 d935583f
...@@ -22,15 +22,14 @@ ...@@ -22,15 +22,14 @@
*/ */
/* @test /* @test
* @bug 7021870 8023431 * @bug 7021870 8023431 8026756
* @summary Reading last gzip chain member must not close the input stream. * @summary Reading last gzip chain member must not close the input stream.
* Garbage following gzip entry must be ignored. * Garbage following gzip entry must be ignored.
*/ */
import java.io.ByteArrayInputStream;
import java.io.ByteArrayOutputStream;
import java.io.IOException; import java.io.IOException;
import java.io.InputStream;
import java.io.PipedInputStream;
import java.io.PipedOutputStream;
import java.util.zip.GZIPInputStream; import java.util.zip.GZIPInputStream;
import java.util.zip.GZIPOutputStream; import java.util.zip.GZIPOutputStream;
import java.util.zip.ZipEntry; import java.util.zip.ZipEntry;
...@@ -40,9 +39,9 @@ import java.util.zip.ZipOutputStream; ...@@ -40,9 +39,9 @@ import java.util.zip.ZipOutputStream;
public class GZIPInZip { public class GZIPInZip {
private static volatile Throwable trouble; public static void main(String[] args)
throws Throwable {
public static void main(String[] args) throws Throwable {
doTest(false, false); doTest(false, false);
doTest(false, true); doTest(false, true);
doTest(true, false); doTest(true, false);
...@@ -53,63 +52,46 @@ public class GZIPInZip { ...@@ -53,63 +52,46 @@ public class GZIPInZip {
final boolean limitGISBuff) final boolean limitGISBuff)
throws Throwable { throws Throwable {
final PipedOutputStream pos = new PipedOutputStream(); byte[] buf;
final PipedInputStream pis = new PipedInputStream(pos);
try (ByteArrayOutputStream baos = new ByteArrayOutputStream();
Thread compressor = new Thread() { ZipOutputStream zos = new ZipOutputStream(baos)) {
public void run() {
final byte[] xbuf = { 'x' }; final byte[] xbuf = { 'x' };
try (ZipOutputStream zos = new ZipOutputStream(pos)) {
zos.putNextEntry(new ZipEntry("a.gz"));
zos.putNextEntry(new ZipEntry("a.gz")); GZIPOutputStream gos1 = new GZIPOutputStream(zos);
try (GZIPOutputStream gos1 = new GZIPOutputStream(zos)) { gos1.write(xbuf);
gos1.write(xbuf); gos1.finish();
gos1.finish(); if (appendGarbage)
} zos.write(xbuf);
if (appendGarbage) zos.closeEntry();
zos.write(xbuf);
zos.putNextEntry(new ZipEntry("b.gz"));
zos.closeEntry(); GZIPOutputStream gos2 = new GZIPOutputStream(zos);
gos2.write(xbuf);
zos.putNextEntry(new ZipEntry("b.gz")); gos2.finish();
try (GZIPOutputStream gos2 = new GZIPOutputStream(zos)) { zos.closeEntry();
gos2.write(xbuf);
gos2.finish(); zos.flush();
} buf = baos.toByteArray();
zos.closeEntry(); }
} catch (Throwable t) { try (ByteArrayInputStream bais = new ByteArrayInputStream(buf);
trouble = t; ZipInputStream zis = new ZipInputStream(bais)) {
}
} zis.getNextEntry();
}; GZIPInputStream gis1 = limitGISBuff ?
new GZIPInputStream(zis, 4) :
Thread uncompressor = new Thread() { new GZIPInputStream(zis);
public void run() { // try to read more than the entry has
try (ZipInputStream zis = new ZipInputStream(pis)) { gis1.skip(2);
zis.getNextEntry();
try (InputStream gis = limitGISBuff ? try {
new GZIPInputStream(zis, 4) : zis.getNextEntry();
new GZIPInputStream(zis)) { } catch (IOException e) {
// try to read more than the entry has throw new RuntimeException("ZIP stream was prematurely closed", e);
gis.skip(2);
}
try {
zis.getNextEntry();
} catch (IOException e) {
throw new AssertionError("ZIP stream was prematurely closed");
}
} catch (Throwable t) {
trouble = t;
}
} }
}; }
compressor.start(); uncompressor.start();
compressor.join(); uncompressor.join();
if (trouble != null)
throw trouble;
} }
} }
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册