Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openanolis
dragonwell8_jdk
提交
a7329d55
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看板
提交
a7329d55
编写于
10月 22, 2015
作者:
R
robm
浏览文件
操作
浏览文件
下载
差异文件
Merge
上级
b074d221
a516f5e9
变更
14
隐藏空白更改
内联
并排
Showing
14 changed file
with
701 addition
and
58 deletion
+701
-58
src/macosx/classes/sun/lwawt/macosx/CDataTransferer.java
src/macosx/classes/sun/lwawt/macosx/CDataTransferer.java
+38
-37
src/macosx/lib/flavormap.properties
src/macosx/lib/flavormap.properties
+1
-0
src/share/classes/java/util/zip/Deflater.java
src/share/classes/java/util/zip/Deflater.java
+3
-1
src/share/classes/java/util/zip/ZStreamRef.java
src/share/classes/java/util/zip/ZStreamRef.java
+1
-1
src/share/classes/java/util/zip/ZipFile.java
src/share/classes/java/util/zip/ZipFile.java
+5
-4
src/share/native/java/util/zip/zip_util.c
src/share/native/java/util/zip/zip_util.c
+17
-1
src/windows/native/sun/java2d/windows/GDIWindowSurfaceData.cpp
...indows/native/sun/java2d/windows/GDIWindowSurfaceData.cpp
+5
-3
src/windows/native/sun/java2d/windows/GDIWindowSurfaceData.h
src/windows/native/sun/java2d/windows/GDIWindowSurfaceData.h
+2
-1
src/windows/native/sun/windows/awt_Component.cpp
src/windows/native/sun/windows/awt_Component.cpp
+7
-7
src/windows/native/sun/windows/awt_Component.h
src/windows/native/sun/windows/awt_Component.h
+3
-3
test/java/awt/datatransfer/DataFlavor/MacOsXFileAndMultipleFileCopingTest/MacOsXFileAndMultipleFileCopingTest.java
...leFileCopingTest/MacOsXFileAndMultipleFileCopingTest.java
+368
-0
test/java/util/zip/ZipFile/ZipEntryFreeTest.java
test/java/util/zip/ZipFile/ZipEntryFreeTest.java
+130
-0
test/javax/xml/bind/jxc/8073519/InputWithError.java
test/javax/xml/bind/jxc/8073519/InputWithError.java
+30
-0
test/javax/xml/bind/jxc/8073519/SchemagenErrorReporting.java
test/javax/xml/bind/jxc/8073519/SchemagenErrorReporting.java
+91
-0
未找到文件。
src/macosx/classes/sun/lwawt/macosx/CDataTransferer.java
浏览文件 @
a7329d55
/*
/*
* Copyright (c) 2011, 2014, Oracle and/or its affiliates. All rights reserved.
* Copyright (c) 2011, 2014, 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.
...
@@ -29,11 +30,12 @@ import java.awt.*;
...
@@ -29,11 +30,12 @@ import java.awt.*;
import
java.awt.image.*
;
import
java.awt.image.*
;
import
java.io.*
;
import
java.io.*
;
import
java.net.URI
;
import
java.net.URISyntaxException
;
import
java.net.URL
;
import
java.net.URL
;
import
java.text.Normalizer
;
import
java.text.Normalizer
;
import
java.text.Normalizer.Form
;
import
java.text.Normalizer.Form
;
import
java.util.*
;
import
java.util.*
;
import
java.util.regex.*
;
import
java.awt.datatransfer.*
;
import
java.awt.datatransfer.*
;
import
sun.awt.datatransfer.*
;
import
sun.awt.datatransfer.*
;
...
@@ -128,18 +130,34 @@ public class CDataTransferer extends DataTransferer {
...
@@ -128,18 +130,34 @@ public class CDataTransferer extends DataTransferer {
if
(
format
==
CF_URL
&&
URL
.
class
.
equals
(
flavor
.
getRepresentationClass
()))
{
if
(
format
==
CF_URL
&&
URL
.
class
.
equals
(
flavor
.
getRepresentationClass
()))
{
String
charset
=
getDefaultTextCharset
();
String
[]
strings
=
dragQueryFile
(
bytes
);
if
(
transferable
!=
null
&&
transferable
.
isDataFlavorSupported
(
javaTextEncodingFlavor
))
{
if
(
strings
==
null
||
strings
.
length
==
0
)
{
try
{
return
null
;
charset
=
new
String
((
byte
[])
transferable
.
getTransferData
(
javaTextEncodingFlavor
),
"UTF-8"
);
}
}
catch
(
UnsupportedFlavorException
cannotHappen
)
{
return
new
URL
(
strings
[
0
]);
}
else
if
(
isUriListFlavor
(
flavor
))
{
// dragQueryFile works fine with files and url,
// it parses and extracts values from property list.
// maxosx always returns property list for
// CF_URL and CF_FILE
String
[]
strings
=
dragQueryFile
(
bytes
);
if
(
strings
==
null
)
{
return
null
;
}
String
separator
=
System
.
getProperty
(
"line.separator"
);
StringBuilder
sb
=
new
StringBuilder
();
if
(
strings
.
length
>
0
)
{
sb
.
append
(
strings
[
0
]);
for
(
int
i
=
1
;
i
<
strings
.
length
;
i
++)
{
sb
.
append
(
strings
[
i
]);
sb
.
append
(
separator
);
}
}
}
}
bytes
=
sb
.
toString
().
getBytes
();
String
xml
=
new
String
(
bytes
,
charset
);
// now we extracted uri from xml, now we should treat it as
//
macosx pastboard returns a propery list that contins of one URL
//
regular string that allows to translate data to target represantation
//
let's extract it.
//
class by base method
return
new
URL
(
extractURL
(
xml
))
;
format
=
CF_STRING
;
}
else
if
(
format
==
CF_STRING
)
{
}
else
if
(
format
==
CF_STRING
)
{
bytes
=
Normalizer
.
normalize
(
new
String
(
bytes
,
"UTF8"
),
Form
.
NFC
).
getBytes
(
"UTF8"
);
bytes
=
Normalizer
.
normalize
(
new
String
(
bytes
,
"UTF8"
),
Form
.
NFC
).
getBytes
(
"UTF8"
);
}
}
...
@@ -147,31 +165,6 @@ public class CDataTransferer extends DataTransferer {
...
@@ -147,31 +165,6 @@ public class CDataTransferer extends DataTransferer {
return
super
.
translateBytes
(
bytes
,
flavor
,
format
,
transferable
);
return
super
.
translateBytes
(
bytes
,
flavor
,
format
,
transferable
);
}
}
/**
* Macosx pastboard returns xml document that contains one URL, for exmple:
* <pre>
* {@code
* <?xml version=\"1.0\" encoding=\"UTF-8\"?>
* <!DOCTYPE plist PUBLIC \"-//Apple//DTD PLIST 1.0//EN\" \"http://www.apple.com/DTDs/PropertyList-1.0.dtd\">
* <plist version=\"1.0\">
* <array>
* <string>file:///Users/mcherkas/Downloads/Version.jpg</string>
* <string></string>
* </array>
* </plist>
* }
* </pre>
*/
private
String
extractURL
(
String
xml
)
{
Pattern
urlExtractorPattern
=
Pattern
.
compile
(
"<string>(.*)</string>"
);
Matcher
matcher
=
urlExtractorPattern
.
matcher
(
xml
);
if
(
matcher
.
find
()){
return
matcher
.
group
(
1
);
}
else
{
return
null
;
}
}
@Override
@Override
synchronized
protected
Long
getFormatForNativeAsLong
(
String
str
)
{
synchronized
protected
Long
getFormatForNativeAsLong
(
String
str
)
{
Long
format
=
predefinedClipboardNameMap
.
get
(
str
);
Long
format
=
predefinedClipboardNameMap
.
get
(
str
);
...
@@ -247,6 +240,7 @@ public class CDataTransferer extends DataTransferer {
...
@@ -247,6 +240,7 @@ public class CDataTransferer extends DataTransferer {
return
nativeDragQueryFile
(
bytes
);
return
nativeDragQueryFile
(
bytes
);
}
}
@Override
@Override
protected
Image
platformImageBytesToImage
(
byte
[]
bytes
,
long
format
)
throws
IOException
{
protected
Image
platformImageBytesToImage
(
byte
[]
bytes
,
long
format
)
throws
IOException
{
return
CImage
.
getCreator
().
createImageFromPlatformImageBytes
(
bytes
);
return
CImage
.
getCreator
().
createImageFromPlatformImageBytes
(
bytes
);
...
@@ -271,7 +265,7 @@ public class CDataTransferer extends DataTransferer {
...
@@ -271,7 +265,7 @@ public class CDataTransferer extends DataTransferer {
}
}
try
{
try
{
DataFlavor
df
=
new
DataFlavor
(
nat
);
DataFlavor
df
=
new
DataFlavor
(
nat
);
if
(
df
.
getPrimaryType
().
equals
(
"text"
)
&&
df
.
getSubType
().
equals
(
"uri-list"
))
{
if
(
isUriListFlavor
(
df
))
{
return
true
;
return
true
;
}
}
}
catch
(
Exception
e
)
{
}
catch
(
Exception
e
)
{
...
@@ -279,6 +273,13 @@ public class CDataTransferer extends DataTransferer {
...
@@ -279,6 +273,13 @@ public class CDataTransferer extends DataTransferer {
}
}
return
false
;
return
false
;
}
}
private
boolean
isUriListFlavor
(
DataFlavor
df
)
{
if
(
df
.
getPrimaryType
().
equals
(
"text"
)
&&
df
.
getSubType
().
equals
(
"uri-list"
))
{
return
true
;
}
return
false
;
}
}
}
src/macosx/lib/flavormap.properties
浏览文件 @
a7329d55
...
@@ -80,5 +80,6 @@ TIFF=image/x-java-image;class=java.awt.Image
...
@@ -80,5 +80,6 @@ TIFF=image/x-java-image;class=java.awt.Image
RICH_TEXT=text/rtf
RICH_TEXT=text/rtf
HTML=text/html;charset=utf-8;eoln="
\r\n
";terminators=1
HTML=text/html;charset=utf-8;eoln="
\r\n
";terminators=1
URL=application/x-java-url;class=java.net.URL
URL=application/x-java-url;class=java.net.URL
FILE_NAME=text/uri-list;eoln="
\r\n
";terminators=1
URL=text/uri-list;eoln="
\r\n
";terminators=1
URL=text/uri-list;eoln="
\r\n
";terminators=1
XPICT=image/x-pict;class=java.io.InputStream
XPICT=image/x-pict;class=java.io.InputStream
src/share/classes/java/util/zip/Deflater.java
浏览文件 @
a7329d55
...
@@ -318,7 +318,9 @@ class Deflater {
...
@@ -318,7 +318,9 @@ class Deflater {
* should be called in order to provide more input
* should be called in order to provide more input
*/
*/
public
boolean
needsInput
()
{
public
boolean
needsInput
()
{
return
len
<=
0
;
synchronized
(
zsRef
)
{
return
len
<=
0
;
}
}
}
/**
/**
...
...
src/share/classes/java/util/zip/ZStreamRef.java
浏览文件 @
a7329d55
...
@@ -31,7 +31,7 @@ package java.util.zip;
...
@@ -31,7 +31,7 @@ package java.util.zip;
class
ZStreamRef
{
class
ZStreamRef
{
private
long
address
;
private
volatile
long
address
;
ZStreamRef
(
long
address
)
{
ZStreamRef
(
long
address
)
{
this
.
address
=
address
;
this
.
address
=
address
;
}
}
...
...
src/share/classes/java/util/zip/ZipFile.java
浏览文件 @
a7329d55
...
@@ -58,7 +58,7 @@ import static java.util.zip.ZipConstants64.*;
...
@@ -58,7 +58,7 @@ import static java.util.zip.ZipConstants64.*;
*/
*/
public
public
class
ZipFile
implements
ZipConstants
,
Closeable
{
class
ZipFile
implements
ZipConstants
,
Closeable
{
private
long
jzfile
;
// address of jzfile data
private
long
jzfile
;
// address of jzfile data
private
final
String
name
;
// zip file name
private
final
String
name
;
// zip file name
private
final
int
total
;
// total number of entries
private
final
int
total
;
// total number of entries
private
final
boolean
locsig
;
// if zip file starts with LOCSIG (usually true)
private
final
boolean
locsig
;
// if zip file starts with LOCSIG (usually true)
...
@@ -685,7 +685,7 @@ class ZipFile implements ZipConstants, Closeable {
...
@@ -685,7 +685,7 @@ class ZipFile implements ZipConstants, Closeable {
* (possibly compressed) zip file entry.
* (possibly compressed) zip file entry.
*/
*/
private
class
ZipFileInputStream
extends
InputStream
{
private
class
ZipFileInputStream
extends
InputStream
{
private
volatile
boolean
c
loseRequested
=
false
;
private
volatile
boolean
zfisC
loseRequested
=
false
;
protected
long
jzentry
;
// address of jzentry data
protected
long
jzentry
;
// address of jzentry data
private
long
pos
;
// current position within entry data
private
long
pos
;
// current position within entry data
protected
long
rem
;
// number of remaining bytes within entry
protected
long
rem
;
// number of remaining bytes within entry
...
@@ -712,6 +712,7 @@ class ZipFile implements ZipConstants, Closeable {
...
@@ -712,6 +712,7 @@ class ZipFile implements ZipConstants, Closeable {
len
=
(
int
)
rem
;
len
=
(
int
)
rem
;
}
}
// Check if ZipFile open
ensureOpenOrZipException
();
ensureOpenOrZipException
();
len
=
ZipFile
.
read
(
ZipFile
.
this
.
jzfile
,
jzentry
,
pos
,
b
,
len
=
ZipFile
.
read
(
ZipFile
.
this
.
jzfile
,
jzentry
,
pos
,
b
,
off
,
len
);
off
,
len
);
...
@@ -755,9 +756,9 @@ class ZipFile implements ZipConstants, Closeable {
...
@@ -755,9 +756,9 @@ class ZipFile implements ZipConstants, Closeable {
}
}
public
void
close
()
{
public
void
close
()
{
if
(
c
loseRequested
)
if
(
zfisC
loseRequested
)
return
;
return
;
c
loseRequested
=
true
;
zfisC
loseRequested
=
true
;
rem
=
0
;
rem
=
0
;
synchronized
(
ZipFile
.
this
)
{
synchronized
(
ZipFile
.
this
)
{
...
...
src/share/native/java/util/zip/zip_util.c
浏览文件 @
a7329d55
...
@@ -1314,12 +1314,23 @@ ZIP_GetEntryDataOffset(jzfile *zip, jzentry *entry)
...
@@ -1314,12 +1314,23 @@ ZIP_GetEntryDataOffset(jzfile *zip, jzentry *entry)
jint
jint
ZIP_Read
(
jzfile
*
zip
,
jzentry
*
entry
,
jlong
pos
,
void
*
buf
,
jint
len
)
ZIP_Read
(
jzfile
*
zip
,
jzentry
*
entry
,
jlong
pos
,
void
*
buf
,
jint
len
)
{
{
jlong
entry_size
=
(
entry
->
csize
!=
0
)
?
entry
->
csize
:
entry
->
size
;
jlong
entry_size
;
jlong
start
;
jlong
start
;
if
(
zip
==
0
)
{
return
-
1
;
}
/* Clear previous zip error */
/* Clear previous zip error */
zip
->
msg
=
NULL
;
zip
->
msg
=
NULL
;
if
(
entry
==
0
)
{
zip
->
msg
=
"ZIP_Read: jzentry is NULL"
;
return
-
1
;
}
entry_size
=
(
entry
->
csize
!=
0
)
?
entry
->
csize
:
entry
->
size
;
/* Check specified position */
/* Check specified position */
if
(
pos
<
0
||
pos
>
entry_size
-
1
)
{
if
(
pos
<
0
||
pos
>
entry_size
-
1
)
{
zip
->
msg
=
"ZIP_Read: specified offset out of range"
;
zip
->
msg
=
"ZIP_Read: specified offset out of range"
;
...
@@ -1451,6 +1462,11 @@ ZIP_ReadEntry(jzfile *zip, jzentry *entry, unsigned char *buf, char *entryname)
...
@@ -1451,6 +1462,11 @@ ZIP_ReadEntry(jzfile *zip, jzentry *entry, unsigned char *buf, char *entryname)
char
*
msg
;
char
*
msg
;
char
tmpbuf
[
1024
];
char
tmpbuf
[
1024
];
if
(
entry
==
0
)
{
jio_fprintf
(
stderr
,
"jzentry was invalid"
);
return
JNI_FALSE
;
}
strcpy
(
entryname
,
entry
->
name
);
strcpy
(
entryname
,
entry
->
name
);
if
(
entry
->
csize
==
0
)
{
if
(
entry
->
csize
==
0
)
{
/* Entry is stored */
/* Entry is stored */
...
...
src/windows/native/sun/java2d/windows/GDIWindowSurfaceData.cpp
浏览文件 @
a7329d55
/*
/*
* Copyright (c) 1999, 201
3
, Oracle and/or its affiliates. All rights reserved.
* Copyright (c) 1999, 201
5
, 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
...
@@ -114,8 +114,9 @@ void SetupThreadGraphicsInfo(JNIEnv *env, GDIWinSDOps *wsdo) {
...
@@ -114,8 +114,9 @@ void SetupThreadGraphicsInfo(JNIEnv *env, GDIWinSDOps *wsdo) {
// which may've been disposed by this time, and we have
// which may've been disposed by this time, and we have
// no means of checking against it.
// no means of checking against it.
if
(
oldhDC
!=
NULL
)
{
if
(
oldhDC
!=
NULL
)
{
MoveDCToPassiveList
(
oldhDC
);
MoveDCToPassiveList
(
oldhDC
,
info
->
hWnd
);
info
->
hDC
=
NULL
;
info
->
hDC
=
NULL
;
info
->
hWnd
=
NULL
;
}
}
if
(
wsdo
->
window
!=
NULL
){
if
(
wsdo
->
window
!=
NULL
){
...
@@ -150,6 +151,7 @@ void SetupThreadGraphicsInfo(JNIEnv *env, GDIWinSDOps *wsdo) {
...
@@ -150,6 +151,7 @@ void SetupThreadGraphicsInfo(JNIEnv *env, GDIWinSDOps *wsdo) {
// Finally, set these new values in the info for this thread
// Finally, set these new values in the info for this thread
info
->
hDC
=
hDC
;
info
->
hDC
=
hDC
;
info
->
hWnd
=
wsdo
->
window
;
}
}
// cached brush and pen are not associated with any DC, and can be
// cached brush and pen are not associated with any DC, and can be
...
@@ -187,7 +189,7 @@ void DisposeThreadGraphicsInfo(JNIEnv *env, jlong tgi) {
...
@@ -187,7 +189,7 @@ void DisposeThreadGraphicsInfo(JNIEnv *env, jlong tgi) {
if
(
info
->
hDC
!=
NULL
)
{
if
(
info
->
hDC
!=
NULL
)
{
// move the DC from the active dcs list to
// move the DC from the active dcs list to
// the passive dc list to be released later
// the passive dc list to be released later
MoveDCToPassiveList
(
info
->
hDC
);
MoveDCToPassiveList
(
info
->
hDC
,
info
->
hWnd
);
}
}
if
(
info
->
clip
!=
NULL
)
{
if
(
info
->
clip
!=
NULL
)
{
...
...
src/windows/native/sun/java2d/windows/GDIWindowSurfaceData.h
浏览文件 @
a7329d55
/*
/*
* Copyright (c) 1999, 201
0
, Oracle and/or its affiliates. All rights reserved.
* Copyright (c) 1999, 201
5
, 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
...
@@ -196,6 +196,7 @@ extern "C" {
...
@@ -196,6 +196,7 @@ extern "C" {
*/
*/
typedef
struct
{
typedef
struct
{
HDC
hDC
;
HDC
hDC
;
HWND
hWnd
;
GDIWinSDOps
*
wsdo
;
GDIWinSDOps
*
wsdo
;
LONG
wsdoTimeStamp
;
// wsdo creation time stamp.
LONG
wsdoTimeStamp
;
// wsdo creation time stamp.
// Other threads may deallocate wsdo
// Other threads may deallocate wsdo
...
...
src/windows/native/sun/windows/awt_Component.cpp
浏览文件 @
a7329d55
...
@@ -1382,7 +1382,7 @@ LRESULT AwtComponent::WindowProc(UINT message, WPARAM wParam, LPARAM lParam)
...
@@ -1382,7 +1382,7 @@ LRESULT AwtComponent::WindowProc(UINT message, WPARAM wParam, LPARAM lParam)
case
WM_AWT_RELEASEDC
:
case
WM_AWT_RELEASEDC
:
{
{
HDC
hDC
=
(
HDC
)
wParam
;
HDC
hDC
=
(
HDC
)
wParam
;
MoveDCToPassiveList
(
hDC
);
MoveDCToPassiveList
(
hDC
,
GetHWnd
()
);
ReleaseDCList
(
GetHWnd
(),
passiveDCList
);
ReleaseDCList
(
GetHWnd
(),
passiveDCList
);
mr
=
mrConsume
;
mr
=
mrConsume
;
break
;
break
;
...
@@ -7174,8 +7174,8 @@ void DCList::AddDCItem(DCItem *newItem)
...
@@ -7174,8 +7174,8 @@ void DCList::AddDCItem(DCItem *newItem)
}
}
/**
/**
* Given a DC
, remove it from the DC list and return
* Given a DC
and window handle, remove the DC from the DC list
* TRUE if it exists on the current list. Otherwise
*
and return
TRUE if it exists on the current list. Otherwise
* return FALSE.
* return FALSE.
* A DC may not exist on the list because it has already
* A DC may not exist on the list because it has already
* been released elsewhere (for example, the window
* been released elsewhere (for example, the window
...
@@ -7183,14 +7183,14 @@ void DCList::AddDCItem(DCItem *newItem)
...
@@ -7183,14 +7183,14 @@ void DCList::AddDCItem(DCItem *newItem)
* thread may also want to release a DC when it notices that
* thread may also want to release a DC when it notices that
* its DC is obsolete for the current window).
* its DC is obsolete for the current window).
*/
*/
DCItem
*
DCList
::
RemoveDC
(
HDC
hDC
)
DCItem
*
DCList
::
RemoveDC
(
HDC
hDC
,
HWND
hWnd
)
{
{
listLock
.
Enter
();
listLock
.
Enter
();
DCItem
**
prevPtrPtr
=
&
head
;
DCItem
**
prevPtrPtr
=
&
head
;
DCItem
*
listPtr
=
head
;
DCItem
*
listPtr
=
head
;
while
(
listPtr
)
{
while
(
listPtr
)
{
DCItem
*
nextPtr
=
listPtr
->
next
;
DCItem
*
nextPtr
=
listPtr
->
next
;
if
(
listPtr
->
hDC
==
hDC
)
{
if
(
listPtr
->
hDC
==
hDC
&&
listPtr
->
hWnd
==
hWnd
)
{
*
prevPtrPtr
=
nextPtr
;
*
prevPtrPtr
=
nextPtr
;
break
;
break
;
}
}
...
@@ -7244,9 +7244,9 @@ void DCList::RealizePalettes(int screen)
...
@@ -7244,9 +7244,9 @@ void DCList::RealizePalettes(int screen)
listLock
.
Leave
();
listLock
.
Leave
();
}
}
void
MoveDCToPassiveList
(
HDC
hDC
)
{
void
MoveDCToPassiveList
(
HDC
hDC
,
HWND
hWnd
)
{
DCItem
*
removedDC
;
DCItem
*
removedDC
;
if
((
removedDC
=
activeDCList
.
RemoveDC
(
hDC
))
!=
NULL
)
{
if
((
removedDC
=
activeDCList
.
RemoveDC
(
hDC
,
hWnd
))
!=
NULL
)
{
passiveDCList
.
AddDCItem
(
removedDC
);
passiveDCList
.
AddDCItem
(
removedDC
);
}
}
}
}
...
...
src/windows/native/sun/windows/awt_Component.h
浏览文件 @
a7329d55
/*
/*
* Copyright (c) 1996, 201
3
, Oracle and/or its affiliates. All rights reserved.
* Copyright (c) 1996, 201
5
, 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
...
@@ -900,13 +900,13 @@ public:
...
@@ -900,13 +900,13 @@ public:
void
AddDC
(
HDC
hDC
,
HWND
hWnd
);
void
AddDC
(
HDC
hDC
,
HWND
hWnd
);
void
AddDCItem
(
DCItem
*
newItem
);
void
AddDCItem
(
DCItem
*
newItem
);
DCItem
*
RemoveDC
(
HDC
hDC
);
DCItem
*
RemoveDC
(
HDC
hDC
,
HWND
hWnd
);
DCItem
*
RemoveAllDCs
(
HWND
hWnd
);
DCItem
*
RemoveAllDCs
(
HWND
hWnd
);
void
RealizePalettes
(
int
screen
);
void
RealizePalettes
(
int
screen
);
};
};
void
ReleaseDCList
(
HWND
hwnd
,
DCList
&
list
);
void
ReleaseDCList
(
HWND
hwnd
,
DCList
&
list
);
void
MoveDCToPassiveList
(
HDC
hDC
);
void
MoveDCToPassiveList
(
HDC
hDC
,
HWND
hWnd
);
namespace
TimeHelper
{
namespace
TimeHelper
{
jlong
getMessageTimeUTC
();
jlong
getMessageTimeUTC
();
...
...
test/java/awt/datatransfer/DataFlavor/MacOsXFileAndMultipleFileCopingTest/MacOsXFileAndMultipleFileCopingTest.java
0 → 100644
浏览文件 @
a7329d55
/*
* Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
*
* This code is free software; you can redistribute it and/or modify it
* under the terms of the GNU General Public License version 2 only, as
* published by the Free Software Foundation.
*
* This code is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
* version 2 for more details (a copy is included in the LICENSE file that
* accompanied this code).
*
* You should have received a copy of the GNU General Public License version
* 2 along with this work; if not, write to the Free Software Foundation,
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
*
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
* or visit www.oracle.com if you need additional information or have any
* questions.
*/
/*
@test
@bug 8081787 8136763
@author Mikhail Cherkasov
@run main/manual MacOsXFileAndMultipleFileCopingTest
*/
import
javax.swing.*
;
import
java.awt.*
;
import
java.awt.datatransfer.*
;
import
java.awt.event.ActionEvent
;
import
java.awt.event.ActionListener
;
import
java.net.URL
;
public
class
MacOsXFileAndMultipleFileCopingTest
{
private
static
void
init
()
{
String
[]
instructions
=
{
"Test for MacOS X only:"
,
"1. The aim is to test that java works fine with \"application/"
+
"x-java-url;class=java.net.URL\"falvor and support coping of multiple files"
,
"2. Open finder and select any file."
,
"3. Press CMD+C or press \"Copy\" in context menu"
,
"4. Focus window with \"Test URL\" Button."
,
"5. If you see URL for selected file, then test PASSED,"
,
"otherwise test FAILED."
,
"6. Open finder again and select several files."
,
"7. Press CMD+C or press \"Copy\" in context menu"
,
"8. Focus window with \"Test multiple files coping\" Button."
,
"9. If you see list of selected files, then test PASSED,"
,
"otherwise test FAILED."
,
};
Sysout
.
createDialog
();
Sysout
.
printInstructions
(
instructions
);
final
Frame
frame
=
new
Frame
();
Panel
panel
=
new
Panel
();
panel
.
setLayout
(
new
BoxLayout
(
panel
,
BoxLayout
.
PAGE_AXIS
));
frame
.
add
(
panel
);
Button
testUrlBtn
=
new
Button
(
"Test URL"
);
final
TextArea
textArea
=
new
TextArea
(
5
,
80
);
testUrlBtn
.
addActionListener
(
new
AbstractAction
()
{
@Override
public
void
actionPerformed
(
ActionEvent
ae
)
{
try
{
Clipboard
board
=
Toolkit
.
getDefaultToolkit
().
getSystemClipboard
();
URL
url
=
(
URL
)
board
.
getData
(
new
DataFlavor
(
"application/x-java-url;class=java.net.URL"
));
textArea
.
setText
(
url
.
toString
());
}
catch
(
Exception
e
)
{
throw
new
RuntimeException
(
e
);
}
}
});
panel
.
add
(
testUrlBtn
);
Button
testUriList
=
new
Button
(
"Test multiple files coping"
);
testUriList
.
addActionListener
(
new
AbstractAction
()
{
@Override
public
void
actionPerformed
(
ActionEvent
ae
)
{
try
{
Clipboard
board
=
Toolkit
.
getDefaultToolkit
().
getSystemClipboard
();
String
files
=
(
String
)
board
.
getData
(
new
DataFlavor
(
"text/uri-list;class=java.lang.String"
));
textArea
.
setText
(
files
);
}
catch
(
Exception
e
)
{
throw
new
RuntimeException
(
e
);
}
}
});
panel
.
add
(
testUriList
);
panel
.
add
(
textArea
);
frame
.
setBounds
(
200
,
200
,
400
,
400
);
frame
.
setVisible
(
true
);
}
//End init()
/*****************************************************
* Standard Test Machinery Section
* DO NOT modify anything in this section -- it's a
* standard chunk of code which has all of the
* synchronisation necessary for the test harness.
* By keeping it the same in all tests, it is easier
* to read and understand someone else's test, as
* well as insuring that all tests behave correctly
* with the test harness.
* There is a section following this for test-defined
* classes
******************************************************/
private
static
boolean
theTestPassed
=
false
;
private
static
boolean
testGeneratedInterrupt
=
false
;
private
static
String
failureMessage
=
""
;
private
static
Thread
mainThread
=
null
;
private
static
int
sleepTime
=
300000
;
public
static
void
main
(
String
args
[])
throws
InterruptedException
{
if
(!
System
.
getProperty
(
"os.name"
).
startsWith
(
"Mac"
))
{
return
;
}
mainThread
=
Thread
.
currentThread
();
try
{
init
();
}
catch
(
TestPassedException
e
)
{
//The test passed, so just return from main and harness will
// interepret this return as a pass
return
;
}
//At this point, neither test passed nor test failed has been
// called -- either would have thrown an exception and ended the
// test, so we know we have multiple threads.
//Test involves other threads, so sleep and wait for them to
// called pass() or fail()
try
{
Thread
.
sleep
(
sleepTime
);
//Timed out, so fail the test
throw
new
RuntimeException
(
"Timed out after "
+
sleepTime
/
1000
+
" seconds"
);
}
catch
(
InterruptedException
e
)
{
if
(!
testGeneratedInterrupt
)
throw
e
;
//reset flag in case hit this code more than once for some reason (just safety)
testGeneratedInterrupt
=
false
;
if
(
theTestPassed
==
false
)
{
throw
new
RuntimeException
(
failureMessage
);
}
}
}
//main
public
static
synchronized
void
setTimeoutTo
(
int
seconds
)
{
sleepTime
=
seconds
*
1000
;
}
public
static
synchronized
void
pass
()
{
Sysout
.
println
(
"The test passed."
);
Sysout
.
println
(
"The test is over, hit Ctl-C to stop Java VM"
);
//first check if this is executing in main thread
if
(
mainThread
==
Thread
.
currentThread
())
{
//Still in the main thread, so set the flag just for kicks,
// and throw a test passed exception which will be caught
// and end the test.
theTestPassed
=
true
;
throw
new
TestPassedException
();
}
//pass was called from a different thread, so set the flag and interrupt
// the main thead.
theTestPassed
=
true
;
testGeneratedInterrupt
=
true
;
if
(
mainThread
!=
null
)
{
mainThread
.
interrupt
();
}
}
//pass()
public
static
synchronized
void
fail
()
{
//test writer didn't specify why test failed, so give generic
fail
(
"it just plain failed! :-)"
);
}
public
static
synchronized
void
fail
(
String
whyFailed
)
{
Sysout
.
println
(
"The test failed: "
+
whyFailed
);
Sysout
.
println
(
"The test is over, hit Ctl-C to stop Java VM"
);
//check if this called from main thread
if
(
mainThread
==
Thread
.
currentThread
())
{
//If main thread, fail now 'cause not sleeping
throw
new
RuntimeException
(
whyFailed
);
}
theTestPassed
=
false
;
testGeneratedInterrupt
=
true
;
failureMessage
=
whyFailed
;
mainThread
.
interrupt
();
}
//fail()
}
// class ManualMainTest
//This exception is used to exit from any level of call nesting
// when it's determined that the test has passed, and immediately
// end the test.
class
TestPassedException
extends
RuntimeException
{
}
//*********** End Standard Test Machinery Section **********
/****************************************************
* Standard Test Machinery
* DO NOT modify anything below -- it's a standard
* chunk of code whose purpose is to make user
* interaction uniform, and thereby make it simpler
* to read and understand someone else's test.
****************************************************/
/**
This is part of the standard test machinery.
It creates a dialog (with the instructions), and is the interface
for sending text messages to the user.
To print the instructions, send an array of strings to Sysout.createDialog
WithInstructions method. Put one line of instructions per array entry.
To display a message for the tester to see, simply call Sysout.println
with the string to be displayed.
This mimics System.out.println but works within the test harness as well
as standalone.
*/
class
Sysout
{
private
static
TestDialog
dialog
;
private
static
boolean
numbering
=
false
;
private
static
int
messageNumber
=
0
;
public
static
void
createDialogWithInstructions
(
String
[]
instructions
)
{
dialog
=
new
TestDialog
(
new
Frame
(),
"Instructions"
);
dialog
.
printInstructions
(
instructions
);
dialog
.
setVisible
(
true
);
println
(
"Any messages for the tester will display here."
);
}
public
static
void
createDialog
()
{
dialog
=
new
TestDialog
(
new
Frame
(),
"Instructions"
);
String
[]
defInstr
=
{
"Instructions will appear here. "
,
""
};
dialog
.
printInstructions
(
defInstr
);
dialog
.
setVisible
(
true
);
println
(
"Any messages for the tester will display here."
);
}
/* Enables message counting for the tester. */
public
static
void
enableNumbering
(
boolean
enable
)
{
numbering
=
enable
;
}
public
static
void
printInstructions
(
String
[]
instructions
)
{
dialog
.
printInstructions
(
instructions
);
}
public
static
void
println
(
String
messageIn
)
{
if
(
numbering
)
{
messageIn
=
""
+
messageNumber
+
" "
+
messageIn
;
messageNumber
++;
}
dialog
.
displayMessage
(
messageIn
);
}
}
// Sysout class
/**
This is part of the standard test machinery. It provides a place for the
test instructions to be displayed, and a place for interactive messages
to the user to be displayed.
To have the test instructions displayed, see Sysout.
To have a message to the user be displayed, see Sysout.
Do not call anything in this dialog directly.
*/
class
TestDialog
extends
Dialog
implements
ActionListener
{
TextArea
instructionsText
;
TextArea
messageText
;
int
maxStringLength
=
80
;
Panel
buttonP
=
new
Panel
();
Button
passB
=
new
Button
(
"pass"
);
Button
failB
=
new
Button
(
"fail"
);
//DO NOT call this directly, go through Sysout
public
TestDialog
(
Frame
frame
,
String
name
)
{
super
(
frame
,
name
);
int
scrollBoth
=
TextArea
.
SCROLLBARS_BOTH
;
instructionsText
=
new
TextArea
(
""
,
15
,
maxStringLength
,
scrollBoth
);
add
(
"North"
,
instructionsText
);
messageText
=
new
TextArea
(
""
,
5
,
maxStringLength
,
scrollBoth
);
add
(
"Center"
,
messageText
);
passB
=
new
Button
(
"pass"
);
passB
.
setActionCommand
(
"pass"
);
passB
.
addActionListener
(
this
);
buttonP
.
add
(
"East"
,
passB
);
failB
=
new
Button
(
"fail"
);
failB
.
setActionCommand
(
"fail"
);
failB
.
addActionListener
(
this
);
buttonP
.
add
(
"West"
,
failB
);
add
(
"South"
,
buttonP
);
pack
();
setVisible
(
true
);
}
// TestDialog()
//DO NOT call this directly, go through Sysout
public
void
printInstructions
(
String
[]
instructions
)
{
//Clear out any current instructions
instructionsText
.
setText
(
""
);
//Go down array of instruction strings
String
printStr
,
remainingStr
;
for
(
int
i
=
0
;
i
<
instructions
.
length
;
i
++)
{
//chop up each into pieces maxSringLength long
remainingStr
=
instructions
[
i
];
while
(
remainingStr
.
length
()
>
0
)
{
//if longer than max then chop off first max chars to print
if
(
remainingStr
.
length
()
>=
maxStringLength
)
{
//Try to chop on a word boundary
int
posOfSpace
=
remainingStr
.
lastIndexOf
(
' '
,
maxStringLength
-
1
);
if
(
posOfSpace
<=
0
)
posOfSpace
=
maxStringLength
-
1
;
printStr
=
remainingStr
.
substring
(
0
,
posOfSpace
+
1
);
remainingStr
=
remainingStr
.
substring
(
posOfSpace
+
1
);
}
//else just print
else
{
printStr
=
remainingStr
;
remainingStr
=
""
;
}
instructionsText
.
append
(
printStr
+
"\n"
);
}
// while
}
// for
}
//printInstructions()
//DO NOT call this directly, go through Sysout
public
void
displayMessage
(
String
messageIn
)
{
messageText
.
append
(
messageIn
+
"\n"
);
System
.
out
.
println
(
messageIn
);
}
//catch presses of the passed and failed buttons.
//simply call the standard pass() or fail() static methods of
//ManualMainTest
public
void
actionPerformed
(
ActionEvent
e
)
{
if
(
e
.
getActionCommand
()
==
"pass"
)
{
MacOsXFileAndMultipleFileCopingTest
.
pass
();
}
else
{
MacOsXFileAndMultipleFileCopingTest
.
fail
();
}
}
}
// TestDialog class
\ No newline at end of file
test/java/util/zip/ZipFile/ZipEntryFreeTest.java
0 → 100644
浏览文件 @
a7329d55
/*
* Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
*
* This code is free software; you can redistribute it and/or modify it
* under the terms of the GNU General Public License version 2 only, as
* published by the Free Software Foundation.
*
* This code is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
* version 2 for more details (a copy is included in the LICENSE file that
* accompanied this code).
*
* You should have received a copy of the GNU General Public License version
* 2 along with this work; if not, write to the Free Software Foundation,
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
*
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
* or visit www.oracle.com if you need additional information or have any
* questions.
*/
/* @test
* @bug 6907252
* @summary ZipFileInputStream Not Thread-Safe
* @library /lib/testlibrary
* @build jdk.testlibrary.*
* @run main ZipEntryFreeTest
*/
import
java.io.*
;
import
java.nio.file.Paths
;
import
java.util.Random
;
import
java.util.Timer
;
import
java.util.TimerTask
;
import
java.util.zip.*
;
import
jdk.testlibrary.FileUtils
;
public
class
ZipEntryFreeTest
extends
Thread
{
private
static
final
int
NUM_THREADS
=
5
;
private
static
final
int
TEST_ITERATIONS
=
5
;
private
static
final
String
ZIPFILE_NAME
=
"large.zip"
;
private
static
final
String
ZIPENTRY_NAME
=
"random.txt"
;
private
static
InputStream
is
=
null
;
final
Timer
timer
=
new
Timer
();
public
static
void
main
(
String
args
[])
throws
Exception
{
createZipFile
();
try
{
for
(
int
i
=
0
;
i
<
TEST_ITERATIONS
;
i
++)
{
runTest
();
}
}
finally
{
FileUtils
.
deleteFileIfExistsWithRetry
(
Paths
.
get
(
ZIPFILE_NAME
));
}
}
private
static
void
runTest
()
throws
Exception
{
try
(
ZipFile
zf
=
new
ZipFile
(
new
File
(
ZIPFILE_NAME
)))
{
is
=
zf
.
getInputStream
(
zf
.
getEntry
(
ZIPENTRY_NAME
+
"_0"
));
Thread
[]
threadArray
=
new
Thread
[
NUM_THREADS
];
for
(
int
i
=
0
;
i
<
threadArray
.
length
;
i
++)
{
threadArray
[
i
]
=
new
ZipEntryFreeTest
();
}
for
(
int
i
=
0
;
i
<
threadArray
.
length
;
i
++)
{
threadArray
[
i
].
start
();
}
for
(
int
i
=
0
;
i
<
threadArray
.
length
;
i
++)
{
threadArray
[
i
].
join
();
}
}
}
private
static
void
createZipFile
()
throws
Exception
{
Random
rnd
=
new
Random
(
1000L
);
byte
[]
contents
=
new
byte
[
2_000_000
];
ZipEntry
ze
=
null
;
try
(
ZipOutputStream
zos
=
new
ZipOutputStream
(
new
FileOutputStream
(
ZIPFILE_NAME
)))
{
// uncompressed mode seemed to tickle the crash
zos
.
setMethod
(
ZipOutputStream
.
STORED
);
for
(
int
ze_count
=
0
;
ze_count
<
10
;
ze_count
++)
{
rnd
.
nextBytes
(
contents
);
ze
=
createZipEntry
(
contents
,
ze_count
);
zos
.
putNextEntry
(
ze
);
zos
.
write
(
contents
,
0
,
contents
.
length
);
}
zos
.
flush
();
}
}
private
static
ZipEntry
createZipEntry
(
byte
[]
b
,
int
i
)
{
ZipEntry
ze
=
new
ZipEntry
(
ZIPENTRY_NAME
+
"_"
+
i
);
ze
.
setCompressedSize
(
b
.
length
);
ze
.
setSize
(
b
.
length
);
CRC32
crc
=
new
CRC32
();
crc
.
update
(
b
);
ze
.
setCrc
(
crc
.
getValue
());
return
ze
;
}
@Override
public
void
run
()
{
try
{
int
iteration
=
0
;
TimerTask
tt
=
(
new
TimerTask
()
{
@Override
public
void
run
()
{
try
{
is
.
close
();
}
catch
(
Exception
ex
)
{
ex
.
printStackTrace
(
System
.
out
);
}
}
});
timer
.
schedule
(
tt
,
50
);
while
(
is
.
read
()
!=
-
1
&&
iteration
++
<
1_000
)
{
}
}
catch
(
ZipException
ze
)
{
// ZipException now expected instead of ZIP_Read crash
System
.
out
.
println
(
ze
);
}
catch
(
Exception
e
)
{
throw
new
RuntimeException
(
e
);
}
finally
{
timer
.
cancel
();
}
}
}
test/javax/xml/bind/jxc/8073519/InputWithError.java
0 → 100644
浏览文件 @
a7329d55
/*
* Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
*
* This code is free software; you can redistribute it and/or modify it
* under the terms of the GNU General Public License version 2 only, as
* published by the Free Software Foundation.
*
* This code is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
* version 2 for more details (a copy is included in the LICENSE file that
* accompanied this code).
*
* You should have received a copy of the GNU General Public License version
* 2 along with this work; if not, write to the Free Software Foundation,
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
*
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
* or visit www.oracle.com if you need additional information or have any
* questions.
*/
import
javax.xml.bind.annotation.XmlType
;
@XmlType
public
class
InputWithError
{
public
int
a
;
int
compile
-
error
;
}
test/javax/xml/bind/jxc/8073519/SchemagenErrorReporting.java
0 → 100644
浏览文件 @
a7329d55
/*
* Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
*
* This code is free software; you can redistribute it and/or modify it
* under the terms of the GNU General Public License version 2 only, as
* published by the Free Software Foundation.
*
* This code is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
* version 2 for more details (a copy is included in the LICENSE file that
* accompanied this code).
*
* You should have received a copy of the GNU General Public License version
* 2 along with this work; if not, write to the Free Software Foundation,
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
*
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
* or visit www.oracle.com if you need additional information or have any
* questions.
*/
/*
* @test
* @bug 8073519
* @summary test that schemagen tool reports errors during
* xsd generation process
* @library /lib/testlibrary
* @run testng/othervm SchemagenErrorReporting
*/
import
java.nio.file.Files
;
import
java.nio.file.Path
;
import
java.nio.file.Paths
;
import
java.nio.file.StandardCopyOption
;
import
java.util.Arrays
;
import
java.util.stream.Collectors
;
import
jdk.testlibrary.JDKToolLauncher
;
import
org.testng.Assert
;
import
org.testng.annotations.Test
;
public
class
SchemagenErrorReporting
{
@Test
public
void
schemagenErrorReporting
()
throws
Exception
{
//schemagen tool output file name
final
String
SCHEMA_FILE
=
"schema1.xsd"
;
//Schemagen input java file with not compilable source
final
String
CLASS_FILE
=
"InputWithError.java"
;
//Test working, src directories and test output file
Path
testWorkDir
,
testSrcDir
,
testOutput
;
//Prepare test environment
//Create test directory inside scratch
testWorkDir
=
Paths
.
get
(
System
.
getProperty
(
"user.dir"
,
"."
))
.
resolve
(
"SchemagenErrorReporting"
);
//Get test source directory
testSrcDir
=
Paths
.
get
(
System
.
getProperty
(
"test.src"
,
"."
));
//Set test output file path
testOutput
=
testWorkDir
.
resolve
(
"stdErrContent"
);
//Create test directory inside scratch directory
Files
.
createDirectory
(
testWorkDir
);
//Copy java source from test.src to the test directory
Files
.
copy
(
testSrcDir
.
resolve
(
CLASS_FILE
),
testWorkDir
.
resolve
(
CLASS_FILE
),
StandardCopyOption
.
REPLACE_EXISTING
);
//Prepare process builder to run schemagen tool and save its output
JDKToolLauncher
sgl
=
JDKToolLauncher
.
createUsingTestJDK
(
"schemagen"
);
sgl
.
addToolArg
(
CLASS_FILE
);
System
.
out
.
println
(
"Executing: "
+
Arrays
.
asList
(
sgl
.
getCommand
()));
ProcessBuilder
pb
=
new
ProcessBuilder
(
sgl
.
getCommand
());
//Set schemagen work directory with the input java file
pb
.
directory
(
testWorkDir
.
toFile
());
//Redirect schemagen output to file
pb
.
redirectError
(
testOutput
.
toFile
());
Process
p
=
pb
.
start
();
int
result
=
p
.
waitFor
();
p
.
destroy
();
//Read schemagen output from the file
String
stdErrContent
=
Files
.
lines
(
testOutput
)
.
collect
(
Collectors
.
joining
(
System
.
lineSeparator
(),
System
.
lineSeparator
(),
""
));
System
.
out
.
println
(
"Schemagen return value:"
+
result
);
System
.
out
.
println
(
"Error output:"
+
stdErrContent
);
//Check test results:
//Schemagen finished with non-0 return value
Assert
.
assertNotEquals
(
result
,
0
);
//Schemagen output contains compile error message
Assert
.
assertTrue
(
stdErrContent
.
contains
(
"InputWithError.java:28: error"
));
}
}
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录