.github
.jcheck
bin
doc
make
src
test
docs
failure_handler
hotspot
jaxp
jdk
build
com
demo
java
awt
beans
foreign
io
lang
math
net
nio
rmi
security
sql
text
time
util
AbstractCollection
AbstractList
AbstractMap
AbstractSequentialList
ArrayDeque
ArrayList
Arrays
Base64
BitSet
Calendar
Collection
Collections
AddAll.java
AsLifoQueue.java
BigBinarySearch.java
BinarySearchNullComparator.java
CheckedIdentityMap.java
CheckedListBash.java
CheckedListReplaceAll.java
CheckedMapBash.java
CheckedMapReplaceAll.java
CheckedNull.java
CheckedQueue.java
CheckedSetBash.java
DelegatingIteratorForEachRemaining.java
Disjoint.java
EmptyCollectionSerialization.java
EmptyIterator.java
EmptyNavigableMap.java
EmptyNavigableSet.java
Enum.java
EnumerationAsIterator.java
EqualsTest.java
FindSubList.java
Frequency.java
MinMax.java
NCopies.java
NullComparator.java
RacingCollections.java
ReplaceAll.java
ReverseOrder.java
ReverseOrder2.java
Rotate.java
RotateEmpty.java
RotateHuge.java
Ser.java
SetFromMap.java
Shuffle.java
SingletonIterator.java
Swap.java
SyncSubMutexes.java
T5078378.java
T6433170.java
UnmodifiableMapEntrySet.java
ViewSynch.java
WrappedNull.java
WrappedUnmodifiableCollections.java
Wrappers.java
Comparator
Currency
Date
Deque
DoubleStreamSums
DoubleSummaryStatistics
EnumMap
EnumSet
Formattable
Formatter
HashMap
HashSet
Hashtable
HexFormat
IdentityHashMap
IllegalFormatException
Iterator
LinkedHashMap
LinkedHashSet
LinkedList
List
Locale
Map
MissingFormatArgumentException
NavigableMap
Objects
Observable
Optional
PluggableLocale
PriorityQueue
Properties
PropertyPermission
Random
RandomAccess
ResourceBundle
Scanner
SequencedCollection
ServiceLoader
Spliterator
StringJoiner
StringTokenizer
TimSort
TimeZone
Timer
TreeMap
UUID
Vector
WeakHashMap
concurrent
function
jar
logging
prefs
regex
spi
stream
zip
javax
jdk
jni
lib
native_sanity
performance
sanity
security
sun
tools
ProblemList-AotJdk.txt
ProblemList-Virtual.txt
ProblemList-Xcomp.txt
ProblemList-shenandoah.txt
ProblemList-zgc.txt
ProblemList.txt
TEST.ROOT
TEST.groups
req.flg
start-Xvfb.sh
jtreg-ext
jtreg_test_thread_factory
langtools
lib
lib-test
make
micro
.gitattributes
.gitignore
ADDITIONAL_LICENSE_INFO
ASSEMBLY_EXCEPTION
CONTRIBUTING.md
LICENSE
Makefile
README.md
SECURITY.md
configure
83 lines
3.1 KiB
Java
83 lines
3.1 KiB
Java
/*
|
|
* Copyright (c) 2001, 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 4486049
|
|
* @summary min and max methods fail if size changes in between a call to size
|
|
* and an attempt to iterate.
|
|
* @author Josh Bloch
|
|
*/
|
|
|
|
import java.util.Collections;
|
|
import java.util.LinkedHashSet;
|
|
import java.util.Set;
|
|
|
|
public class MinMax {
|
|
public static void main(String[] args) {
|
|
Set s = new LyingSet();
|
|
s.add("x");
|
|
if (!Collections.min(s).equals("x"))
|
|
throw new RuntimeException("1: " + Collections.min(s));
|
|
if (!Collections.max(s).equals("x"))
|
|
throw new RuntimeException("2: " + Collections.max(s));
|
|
|
|
s.add("y");
|
|
if (!Collections.min(s).equals("x"))
|
|
throw new RuntimeException("3: " + Collections.min(s));
|
|
if (!Collections.max(s).equals("y"))
|
|
throw new RuntimeException("4: " + Collections.max(s));
|
|
|
|
s.add("w");
|
|
if (!Collections.min(s).equals("w"))
|
|
throw new RuntimeException("5: " + Collections.min(s));
|
|
if (!Collections.max(s).equals("y"))
|
|
throw new RuntimeException("6: " + Collections.max(s));
|
|
|
|
s.clear();
|
|
s.add("x");
|
|
if (!Collections.min(s, Collections.reverseOrder()).equals("x"))
|
|
throw new RuntimeException("1a: " + Collections.min(s));
|
|
if (!Collections.max(s, Collections.reverseOrder()).equals("x"))
|
|
throw new RuntimeException("2a: " + Collections.max(s));
|
|
|
|
s.add("y");
|
|
if (!Collections.min(s, Collections.reverseOrder()).equals("y"))
|
|
throw new RuntimeException("3a: " + Collections.min(s));
|
|
if (!Collections.max(s, Collections.reverseOrder()).equals("x"))
|
|
throw new RuntimeException("4a: " + Collections.max(s));
|
|
|
|
s.add("w");
|
|
if (!Collections.min(s, Collections.reverseOrder()).equals("y"))
|
|
throw new RuntimeException("5a: " + Collections.min(s));
|
|
if (!Collections.max(s, Collections.reverseOrder()).equals("w"))
|
|
throw new RuntimeException("6a: " + Collections.max(s));
|
|
}
|
|
}
|
|
|
|
class LyingSet extends LinkedHashSet {
|
|
public int size() {
|
|
return super.size() + 1; // Lies, lies, all lies!
|
|
}
|
|
}
|