Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openanolis
dragonwell8_jdk
提交
8918ff6d
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看板
提交
8918ff6d
编写于
6月 04, 2013
作者:
P
psandoz
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
8015790: Remove duplicate spliterator tests
Reviewed-by: alanb, mduigou
上级
8b7a5855
变更
2
展开全部
显示空白变更内容
内联
并排
Showing
2 changed file
with
0 addition
and
1769 deletion
+0
-1769
test/java/util/stream/test/org/openjdk/tests/java/util/stream/SpliteratorLateBindingFailFastTest.java
.../java/util/stream/SpliteratorLateBindingFailFastTest.java
+0
-358
test/java/util/stream/test/org/openjdk/tests/java/util/stream/SpliteratorTraversingAndSplittingTest.java
...va/util/stream/SpliteratorTraversingAndSplittingTest.java
+0
-1411
未找到文件。
test/java/util/stream/test/org/openjdk/tests/java/util/stream/SpliteratorLateBindingFailFastTest.java
已删除
100644 → 0
浏览文件 @
8b7a5855
/*
* Copyright (c) 2013, 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.
*/
package
org.openjdk.tests.java.util.stream
;
import
org.testng.annotations.DataProvider
;
import
org.testng.annotations.Test
;
import
java.util.ArrayList
;
import
java.util.Arrays
;
import
java.util.Collection
;
import
java.util.Collections
;
import
java.util.ConcurrentModificationException
;
import
java.util.HashMap
;
import
java.util.HashSet
;
import
java.util.LinkedHashMap
;
import
java.util.LinkedHashSet
;
import
java.util.LinkedList
;
import
java.util.List
;
import
java.util.Map
;
import
java.util.PriorityQueue
;
import
java.util.Set
;
import
java.util.Spliterator
;
import
java.util.Stack
;
import
java.util.TreeMap
;
import
java.util.TreeSet
;
import
java.util.Vector
;
import
java.util.WeakHashMap
;
import
java.util.function.Consumer
;
import
java.util.function.Function
;
import
java.util.function.Supplier
;
import
static
org
.
testng
.
Assert
.*;
/**
* @test
* @summary Spliterator last-binding and fail-fast tests
* @run testng SpliteratorLateBindingFailFastTest
*/
@Test
(
groups
=
{
"serialization-hostile"
})
public
class
SpliteratorLateBindingFailFastTest
{
private
interface
Source
<
T
>
{
Collection
<
T
>
asCollection
();
void
update
();
}
private
static
class
SpliteratorDataBuilder
<
T
>
{
final
List
<
Object
[]>
data
;
final
T
newValue
;
final
List
<
T
>
exp
;
final
Map
<
T
,
T
>
mExp
;
SpliteratorDataBuilder
(
List
<
Object
[]>
data
,
T
newValue
,
List
<
T
>
exp
)
{
this
.
data
=
data
;
this
.
newValue
=
newValue
;
this
.
exp
=
exp
;
this
.
mExp
=
createMap
(
exp
);
}
Map
<
T
,
T
>
createMap
(
List
<
T
>
l
)
{
Map
<
T
,
T
>
m
=
new
LinkedHashMap
<>();
for
(
T
t
:
l
)
{
m
.
put
(
t
,
t
);
}
return
m
;
}
void
add
(
String
description
,
Supplier
<
Source
<?>>
s
)
{
description
=
joiner
(
description
).
toString
();
data
.
add
(
new
Object
[]{
description
,
s
});
}
void
addCollection
(
Function
<
Collection
<
T
>,
?
extends
Collection
<
T
>>
f
)
{
class
CollectionSource
implements
Source
<
T
>
{
final
Collection
<
T
>
c
=
f
.
apply
(
exp
);
final
Consumer
<
Collection
<
T
>>
updater
;
CollectionSource
(
Consumer
<
Collection
<
T
>>
updater
)
{
this
.
updater
=
updater
;
}
@Override
public
Collection
<
T
>
asCollection
()
{
return
c
;
}
@Override
public
void
update
()
{
updater
.
accept
(
c
);
}
}
String
description
=
"new "
+
f
.
apply
(
Collections
.<
T
>
emptyList
()).
getClass
().
getName
()
+
".spliterator() "
;
add
(
description
+
"ADD"
,
()
->
new
CollectionSource
(
c
->
c
.
add
(
newValue
)));
add
(
description
+
"REMOVE"
,
()
->
new
CollectionSource
(
c
->
c
.
remove
(
c
.
iterator
().
next
())));
}
void
addList
(
Function
<
Collection
<
T
>,
?
extends
List
<
T
>>
l
)
{
// @@@ If collection is instance of List then add sub-list tests
addCollection
(
l
);
}
void
addMap
(
Function
<
Map
<
T
,
T
>,
?
extends
Map
<
T
,
T
>>
mapConstructor
)
{
class
MapSource
<
U
>
implements
Source
<
U
>
{
final
Map
<
T
,
T
>
m
=
mapConstructor
.
apply
(
mExp
);
final
Collection
<
U
>
c
;
final
Consumer
<
Map
<
T
,
T
>>
updater
;
MapSource
(
Function
<
Map
<
T
,
T
>,
Collection
<
U
>>
f
,
Consumer
<
Map
<
T
,
T
>>
updater
)
{
this
.
c
=
f
.
apply
(
m
);
this
.
updater
=
updater
;
}
@Override
public
Collection
<
U
>
asCollection
()
{
return
c
;
}
@Override
public
void
update
()
{
updater
.
accept
(
m
);
}
}
Map
<
String
,
Consumer
<
Map
<
T
,
T
>>>
actions
=
new
HashMap
<>();
actions
.
put
(
"ADD"
,
m
->
m
.
put
(
newValue
,
newValue
));
actions
.
put
(
"REMOVE"
,
m
->
m
.
remove
(
m
.
keySet
().
iterator
().
next
()));
String
description
=
"new "
+
mapConstructor
.
apply
(
Collections
.<
T
,
T
>
emptyMap
()).
getClass
().
getName
();
for
(
Map
.
Entry
<
String
,
Consumer
<
Map
<
T
,
T
>>>
e
:
actions
.
entrySet
())
{
add
(
description
+
".keySet().spliterator() "
+
e
.
getKey
(),
()
->
new
MapSource
<
T
>(
m
->
m
.
keySet
(),
e
.
getValue
()));
add
(
description
+
".values().spliterator() "
+
e
.
getKey
(),
()
->
new
MapSource
<
T
>(
m
->
m
.
values
(),
e
.
getValue
()));
add
(
description
+
".entrySet().spliterator() "
+
e
.
getKey
(),
()
->
new
MapSource
<
Map
.
Entry
<
T
,
T
>>(
m
->
m
.
entrySet
(),
e
.
getValue
()));
}
}
StringBuilder
joiner
(
String
description
)
{
return
new
StringBuilder
(
description
).
append
(
" {"
).
append
(
"size="
).
append
(
exp
.
size
()).
append
(
"}"
);
}
}
static
Object
[][]
spliteratorDataProvider
;
@DataProvider
(
name
=
"Source"
)
public
static
Object
[][]
spliteratorDataProvider
()
{
if
(
spliteratorDataProvider
!=
null
)
{
return
spliteratorDataProvider
;
}
List
<
Object
[]>
data
=
new
ArrayList
<>();
SpliteratorDataBuilder
<
Integer
>
db
=
new
SpliteratorDataBuilder
<>(
data
,
5
,
Arrays
.
asList
(
1
,
2
,
3
,
4
));
// Collections
db
.
addList
(
ArrayList:
:
new
);
db
.
addList
(
LinkedList:
:
new
);
db
.
addList
(
Vector:
:
new
);
db
.
addCollection
(
HashSet:
:
new
);
db
.
addCollection
(
LinkedHashSet:
:
new
);
db
.
addCollection
(
TreeSet:
:
new
);
db
.
addCollection
(
c
->
{
Stack
<
Integer
>
s
=
new
Stack
<>();
s
.
addAll
(
c
);
return
s
;});
db
.
addCollection
(
PriorityQueue:
:
new
);
// ArrayDeque fails some tests since it's fail-fast support is weaker
// than other collections and limited to detecting most, but not all,
// removals. It probably requires it's own test since it is difficult
// to abstract out the conditions under which it fails-fast.
// db.addCollection(ArrayDeque::new);
// Maps
db
.
addMap
(
HashMap:
:
new
);
db
.
addMap
(
LinkedHashMap:
:
new
);
// This fails when run through jrteg but passes when run though
// ant
// db.addMap(IdentityHashMap::new);
db
.
addMap
(
WeakHashMap:
:
new
);
// @@@ Descending maps etc
db
.
addMap
(
TreeMap:
:
new
);
return
spliteratorDataProvider
=
data
.
toArray
(
new
Object
[
0
][]);
}
@Test
(
dataProvider
=
"Source"
)
public
<
T
>
void
lateBindingTestWithForEach
(
String
description
,
Supplier
<
Source
<
T
>>
ss
)
{
Source
<
T
>
source
=
ss
.
get
();
Collection
<
T
>
c
=
source
.
asCollection
();
Spliterator
<
T
>
s
=
c
.
spliterator
();
source
.
update
();
Set
<
T
>
r
=
new
HashSet
<>();
s
.
forEachRemaining
(
r:
:
add
);
assertEquals
(
r
,
new
HashSet
<>(
c
));
}
@Test
(
dataProvider
=
"Source"
)
public
<
T
>
void
lateBindingTestWithTryAdvance
(
String
description
,
Supplier
<
Source
<
T
>>
ss
)
{
Source
<
T
>
source
=
ss
.
get
();
Collection
<
T
>
c
=
source
.
asCollection
();
Spliterator
<
T
>
s
=
c
.
spliterator
();
source
.
update
();
Set
<
T
>
r
=
new
HashSet
<>();
while
(
s
.
tryAdvance
(
r:
:
add
))
{
}
assertEquals
(
r
,
new
HashSet
<>(
c
));
}
@Test
(
dataProvider
=
"Source"
)
public
<
T
>
void
lateBindingTestWithCharacteritics
(
String
description
,
Supplier
<
Source
<
T
>>
ss
)
{
Source
<
T
>
source
=
ss
.
get
();
Collection
<
T
>
c
=
source
.
asCollection
();
Spliterator
<
T
>
s
=
c
.
spliterator
();
s
.
characteristics
();
Set
<
T
>
r
=
new
HashSet
<>();
s
.
forEachRemaining
(
r:
:
add
);
assertEquals
(
r
,
new
HashSet
<>(
c
));
}
@Test
(
dataProvider
=
"Source"
)
public
<
T
>
void
testFailFastTestWithTryAdvance
(
String
description
,
Supplier
<
Source
<
T
>>
ss
)
{
{
Source
<
T
>
source
=
ss
.
get
();
Collection
<
T
>
c
=
source
.
asCollection
();
Spliterator
<
T
>
s
=
c
.
spliterator
();
s
.
tryAdvance
(
e
->
{
});
source
.
update
();
executeAndCatch
(()
->
s
.
tryAdvance
(
e
->
{
}));
}
{
Source
<
T
>
source
=
ss
.
get
();
Collection
<
T
>
c
=
source
.
asCollection
();
Spliterator
<
T
>
s
=
c
.
spliterator
();
s
.
tryAdvance
(
e
->
{
});
source
.
update
();
executeAndCatch
(()
->
s
.
forEachRemaining
(
e
->
{
}));
}
}
@Test
(
dataProvider
=
"Source"
)
public
<
T
>
void
testFailFastTestWithForEach
(
String
description
,
Supplier
<
Source
<
T
>>
ss
)
{
Source
<
T
>
source
=
ss
.
get
();
Collection
<
T
>
c
=
source
.
asCollection
();
Spliterator
<
T
>
s
=
c
.
spliterator
();
executeAndCatch
(()
->
s
.
forEachRemaining
(
e
->
{
source
.
update
();
}));
}
@Test
(
dataProvider
=
"Source"
)
public
<
T
>
void
testFailFastTestWithEstimateSize
(
String
description
,
Supplier
<
Source
<
T
>>
ss
)
{
{
Source
<
T
>
source
=
ss
.
get
();
Collection
<
T
>
c
=
source
.
asCollection
();
Spliterator
<
T
>
s
=
c
.
spliterator
();
s
.
estimateSize
();
source
.
update
();
executeAndCatch
(()
->
s
.
tryAdvance
(
e
->
{
}));
}
{
Source
<
T
>
source
=
ss
.
get
();
Collection
<
T
>
c
=
source
.
asCollection
();
Spliterator
<
T
>
s
=
c
.
spliterator
();
s
.
estimateSize
();
source
.
update
();
executeAndCatch
(()
->
s
.
forEachRemaining
(
e
->
{
}));
}
}
private
void
executeAndCatch
(
Runnable
r
)
{
executeAndCatch
(
ConcurrentModificationException
.
class
,
r
);
}
private
void
executeAndCatch
(
Class
<?
extends
Exception
>
expected
,
Runnable
r
)
{
Exception
caught
=
null
;
try
{
r
.
run
();
}
catch
(
Exception
e
)
{
caught
=
e
;
}
assertNotNull
(
caught
,
String
.
format
(
"No Exception was thrown, expected an Exception of %s to be thrown"
,
expected
.
getName
()));
assertTrue
(
expected
.
isInstance
(
caught
),
String
.
format
(
"Exception thrown %s not an instance of %s"
,
caught
.
getClass
().
getName
(),
expected
.
getName
()));
}
}
test/java/util/stream/test/org/openjdk/tests/java/util/stream/SpliteratorTraversingAndSplittingTest.java
已删除
100644 → 0
浏览文件 @
8b7a5855
此差异已折叠。
点击以展开。
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录