8339154: Cleanups and JUnit conversion of test/jdk/java/util/zip/Available.java

Reviewed-by: lancea
This commit is contained in:
Eirik Bjørsnøs 2024-08-30 06:21:49 +00:00
parent 4675913edb
commit f927c1210e

View File

@ -1,5 +1,5 @@
/* /*
* Copyright (c) 1998, 2011, Oracle and/or its affiliates. All rights reserved. * Copyright (c) 1998, 2024, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
* *
* This code is free software; you can redistribute it and/or modify it * This code is free software; you can redistribute it and/or modify it
@ -22,69 +22,136 @@
*/ */
/* @test /* @test
@bug 4028605 4109069 4234207 4401122 * @bug 4028605 4109069 4234207 4401122 8339154
@summary Make sure ZipInputStream/InflaterInputStream.available() will * @summary Verify that ZipInputStream, InflaterInputStream, ZipFileInputStream,
return 0 after EOF has reached and 1 otherwise. * ZipFileInflaterInputStream.available() return values according
*/ * to their specification or long-standing behavior
* @run junit Available
*/
import org.junit.jupiter.api.AfterEach;
import org.junit.jupiter.api.BeforeEach;
import org.junit.jupiter.api.Test;
import org.junit.jupiter.params.ParameterizedTest;
import org.junit.jupiter.params.provider.ValueSource;
import java.io.*; import java.io.*;
import java.nio.charset.StandardCharsets;
import java.nio.file.Files;
import java.nio.file.Path;
import java.util.zip.*; import java.util.zip.*;
import static org.junit.jupiter.api.Assertions.assertEquals;
import static org.junit.jupiter.api.Assertions.assertThrows;
public class Available { public class Available {
public static void main(String[] args) throws Exception { // ZIP file produced in this test
// 4028605 4109069 4234207 private final Path zip = Path.of("available.jar");
test1();
// test 4401122 /**
test2(); * Create the ZIP file used in this test, containing
* one deflated and one stored entry.
*
* @throws IOException if an unexpected error occurs
*/
@BeforeEach
public void setup() throws IOException {
byte[] contents = "contents".repeat(10).getBytes(StandardCharsets.UTF_8);
try (ZipOutputStream zo = new ZipOutputStream(Files.newOutputStream(zip))) {
// First entry uses DEFLATE method
zo.putNextEntry(new ZipEntry("deflated.txt"));
zo.write(contents);
// Second entry uses STORED method
ZipEntry stored = new ZipEntry("stored.txt");
stored.setMethod(ZipEntry.STORED);
stored.setSize(contents.length);
CRC32 crc32 = new CRC32();
crc32.update(contents);
stored.setCrc(crc32.getValue());
zo.putNextEntry(stored);
zo.write(contents);
}
} }
private static void test1() throws Exception { /**
File f = new File(System.getProperty("test.src", "."), "input.jar"); * Delete the ZIP file created by this test
*
* @throws IOException if an unexpected error occurs
*/
@AfterEach
public void cleanup() throws IOException {
Files.deleteIfExists(zip);
}
// test ZipInputStream /**
try (FileInputStream fis = new FileInputStream(f); * Verify that ZipInputStream.available() returns 0 after EOF or
ZipInputStream z = new ZipInputStream(fis)) * closeEntry, otherwise 1, as specified in the API description.
{ * This tests 4028605 4109069 4234207
* @throws IOException if an unexpected error occurs
*/
@Test
public void testZipInputStream() throws IOException {
try (InputStream in = Files.newInputStream(zip)) {
ZipInputStream z = new ZipInputStream(in);
z.getNextEntry(); z.getNextEntry();
tryAvail(z); assertEquals(1, z.available());
z.read();
assertEquals(1, z.available());
z.transferTo(OutputStream.nullOutputStream());
assertEquals(0, z.available(),
"ZipInputStream.available() should return 0 after EOF");
z.close();
assertThrows(IOException.class, () -> z.available(),
"Expected an IOException when calling available on a closed stream");
} }
// test InflaterInputStream try (InputStream in = Files.newInputStream(zip);
try (ZipFile zfile = new ZipFile(f)) { ZipInputStream z = new ZipInputStream(in)) {
tryAvail(zfile.getInputStream(zfile.getEntry("Available.java"))); z.getNextEntry();
z.closeEntry();
assertEquals(0, z.available(),
"ZipInputStream.available() should return 0 after closeEntry");
} }
} }
static void tryAvail(InputStream in) throws Exception { /**
byte[] buf = new byte[1024]; * Verify that ZipFileInputStream|ZipFileInflaterInputStream.available()
int n; * return the number of remaining uncompressed bytes.
*
while ((n = in.read(buf)) != -1); * This verifies unspecified, but long-standing behavior. See 4401122.
if (in.available() != 0) { *
throw new Exception("available should return 0 after EOF"); * @throws IOException if an unexpected error occurs
} */
} @ParameterizedTest
@ValueSource(strings = { "stored.txt", "deflated.txt" })
// To reproduce 4401122 public void testZipFileStreamsRemainingBytes(String entryName) throws IOException {
private static void test2() throws Exception { try (ZipFile zfile = new ZipFile(zip.toFile())) {
File f = new File(System.getProperty("test.src", "."), "input.jar"); ZipEntry entry = zfile.getEntry(entryName);
try (ZipFile zf = new ZipFile(f)) { // Could be ZipFileInputStream or ZipFileInflaterInputStream
InputStream in = zf.getInputStream(zf.getEntry("Available.java")); InputStream in = zfile.getInputStream(entry);
int initialAvailable = in.available(); int initialAvailable = in.available();
in.read();
if (in.available() != initialAvailable - 1) // Initally, the number of remaining uncompressed bytes is the entry size
throw new RuntimeException("Available not decremented."); assertEquals(entry.getSize(), initialAvailable);
for(int j=0; j<initialAvailable-1; j++)
// Read all bytes one by one
for (int i = initialAvailable; i > 0; i--) {
// Reading a single byte should decrement available by 1
in.read(); in.read();
if (in.available() != 0) assertEquals(i - 1, in.available(), "Available not decremented");
throw new RuntimeException(); }
// No remaining uncompressed bytes
assertEquals(0, in.available());
// available() should still return 0 after close
in.close(); in.close();
if (in.available() != 0) assertEquals(0, in.available());
throw new RuntimeException();
} }
} }
} }