Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openanolis
dragonwell8_jdk
提交
6016e36e
D
dragonwell8_jdk
项目概览
openanolis
/
dragonwell8_jdk
通知
4
Star
2
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
D
dragonwell8_jdk
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
6016e36e
编写于
10月 16, 2013
作者:
E
erikj
浏览文件
操作
浏览文件
下载
差异文件
Merge
上级
86a729cc
9dc9b1e6
变更
1
显示空白变更内容
内联
并排
Showing
1 changed file
with
35 addition
and
16 deletion
+35
-16
test/java/util/zip/GZIP/GZIPInZip.java
test/java/util/zip/GZIP/GZIPInZip.java
+35
-16
未找到文件。
test/java/util/zip/GZIP/GZIPInZip.java
浏览文件 @
6016e36e
...
@@ -22,12 +22,15 @@
...
@@ -22,12 +22,15 @@
*/
*/
/* @test
/* @test
* @bug 7021870
* @bug 7021870 8023431
* @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.
*/
*/
import
java.io.*
;
import
java.io.IOException
;
import
java.util.*
;
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,6 +43,15 @@ public class GZIPInZip {
...
@@ -40,6 +43,15 @@ public class GZIPInZip {
private
static
volatile
Throwable
trouble
;
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
,
true
);
doTest
(
true
,
false
);
doTest
(
true
,
true
);
}
private
static
void
doTest
(
final
boolean
appendGarbage
,
final
boolean
limitGISBuff
)
throws
Throwable
{
final
PipedOutputStream
pos
=
new
PipedOutputStream
();
final
PipedOutputStream
pos
=
new
PipedOutputStream
();
final
PipedInputStream
pis
=
new
PipedInputStream
(
pos
);
final
PipedInputStream
pis
=
new
PipedInputStream
(
pos
);
...
@@ -47,17 +59,23 @@ public class GZIPInZip {
...
@@ -47,17 +59,23 @@ public class GZIPInZip {
Thread
compressor
=
new
Thread
()
{
Thread
compressor
=
new
Thread
()
{
public
void
run
()
{
public
void
run
()
{
final
byte
[]
xbuf
=
{
'x'
};
final
byte
[]
xbuf
=
{
'x'
};
try
{
try
(
ZipOutputStream
zos
=
new
ZipOutputStream
(
pos
))
{
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
.
finish
();
gos1
.
write
(
xbuf
);
gos1
.
finish
();
}
if
(
appendGarbage
)
zos
.
write
(
xbuf
);
zos
.
closeEntry
();
zos
.
closeEntry
();
zos
.
putNextEntry
(
new
ZipEntry
(
"b.gz"
));
zos
.
putNextEntry
(
new
ZipEntry
(
"b.gz"
));
GZIPOutputStream
gos2
=
new
GZIPOutputStream
(
zos
);
try
(
GZIPOutputStream
gos2
=
new
GZIPOutputStream
(
zos
))
{
gos2
.
write
(
xbuf
);
gos2
.
finish
();
gos2
.
write
(
xbuf
);
gos2
.
finish
();
}
zos
.
closeEntry
();
zos
.
closeEntry
();
}
catch
(
Throwable
t
)
{
}
catch
(
Throwable
t
)
{
...
@@ -68,19 +86,20 @@ public class GZIPInZip {
...
@@ -68,19 +86,20 @@ public class GZIPInZip {
Thread
uncompressor
=
new
Thread
()
{
Thread
uncompressor
=
new
Thread
()
{
public
void
run
()
{
public
void
run
()
{
try
{
try
(
ZipInputStream
zis
=
new
ZipInputStream
(
pis
))
{
ZipInputStream
zis
=
new
ZipInputStream
(
pis
);
zis
.
getNextEntry
();
zis
.
getNextEntry
();
InputStream
gis
=
new
GZIPInputStream
(
zis
);
try
(
InputStream
gis
=
limitGISBuff
?
new
GZIPInputStream
(
zis
,
4
)
:
new
GZIPInputStream
(
zis
))
{
// try to read more than the entry has
// try to read more than the entry has
gis
.
skip
(
2
);
gis
.
skip
(
2
);
}
try
{
try
{
zis
.
getNextEntry
();
zis
.
getNextEntry
();
}
catch
(
IOException
e
)
{
}
catch
(
IOException
e
)
{
throw
new
AssertionError
(
"ZIP stream was prematurely closed"
);
throw
new
AssertionError
(
"ZIP stream was prematurely closed"
);
}
}
}
catch
(
Throwable
t
)
{
}
catch
(
Throwable
t
)
{
trouble
=
t
;
trouble
=
t
;
}
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录