8339154: Cleanups and JUnit conversion of test/jdk/java/util/zip/Available.java
Reviewed-by: lancea
This commit is contained in:
parent
4675913edb
commit
f927c1210e
@ -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();
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user