From b71acc704a13b816621b9db65b4c5107f2ae032f Mon Sep 17 00:00:00 2001 From: Per Minborg Date: Fri, 5 Apr 2024 07:38:43 +0000 Subject: [PATCH] 8329089: Empty immutable list throws the wrong exception type for remove(first | last) operations Reviewed-by: rriggs --- .../share/classes/java/util/ImmutableCollections.java | 2 ++ test/jdk/java/util/Collection/MOAT.java | 7 +++++++ 2 files changed, 9 insertions(+) diff --git a/src/java.base/share/classes/java/util/ImmutableCollections.java b/src/java.base/share/classes/java/util/ImmutableCollections.java index 525cdf15ecd..726c7bb923b 100644 --- a/src/java.base/share/classes/java/util/ImmutableCollections.java +++ b/src/java.base/share/classes/java/util/ImmutableCollections.java @@ -258,6 +258,8 @@ class ImmutableCollections { @Override public void add(int index, E element) { throw uoe(); } @Override public boolean addAll(int index, Collection c) { throw uoe(); } @Override public E remove(int index) { throw uoe(); } + @Override public E removeFirst() { throw uoe(); } + @Override public E removeLast() { throw uoe(); } @Override public void replaceAll(UnaryOperator operator) { throw uoe(); } @Override public E set(int index, E element) { throw uoe(); } @Override public void sort(Comparator c) { throw uoe(); } diff --git a/test/jdk/java/util/Collection/MOAT.java b/test/jdk/java/util/Collection/MOAT.java index bbc332cc211..0e5eadc9799 100644 --- a/test/jdk/java/util/Collection/MOAT.java +++ b/test/jdk/java/util/Collection/MOAT.java @@ -246,6 +246,7 @@ public class MOAT { testCollection(list); testImmutableList(list); testListMutatorsAlwaysThrow(list); + testImmutableListMutatorsAlwaysThrow(list); if (list.size() >= 1) { // test subLists List headList = list.subList(0, list.size() - 1); @@ -564,6 +565,12 @@ public class MOAT { () -> c.addAll(0, Collections.emptyList())); } + private static void testImmutableListMutatorsAlwaysThrow(List c) { + THROWS(UnsupportedOperationException.class, + c::removeFirst, + c::removeLast); + } + /** * As above, for an empty list. *