From 4b3a800bd249a02efff1578a685808f3b7d2c2e6 Mon Sep 17 00:00:00 2001 From: "Jurgen J. Vinju" Date: Tue, 12 Sep 2023 13:05:26 +0200 Subject: [PATCH] fixed overflow issue in Set.removal tests and cleaned up usage of streams --- .../usethesource/vallang/specification/SetTests.java | 10 ++++++---- 1 file changed, 6 insertions(+), 4 deletions(-) diff --git a/src/test/java/io/usethesource/vallang/specification/SetTests.java b/src/test/java/io/usethesource/vallang/specification/SetTests.java index 9a3daf5cc..f316be2e6 100644 --- a/src/test/java/io/usethesource/vallang/specification/SetTests.java +++ b/src/test/java/io/usethesource/vallang/specification/SetTests.java @@ -14,6 +14,7 @@ import io.usethesource.vallang.ISet; import io.usethesource.vallang.ISourceLocation; import io.usethesource.vallang.IValue; +import io.usethesource.vallang.IValueFactory; import io.usethesource.vallang.ValueProvider; public class SetTests { @@ -34,12 +35,12 @@ public void insertion( @ExpectedType("set[real]") ISet set, IInteger i) { } @ParameterizedTest @ArgumentsSource(ValueProvider.class) - public void removal( @ExpectedType("set[int]") ISet set, IInteger i) { + public void removal(Random rnd, IValueFactory vf, @ExpectedType("set[int]") ISet set) { if (set.isEmpty()) { return; } - - IValue elem = StreamSupport.stream(set.spliterator(), false).skip(Math.abs(i.intValue() % set.size())).findFirst().get(); + int index = rnd.nextInt(set.size()); + IValue elem = set.stream().skip(index).findFirst().get(); ISet smaller = set.delete(elem); assertEquals(smaller.size() + 1, set.size()); assertTrue(!smaller.contains(elem)); @@ -51,7 +52,8 @@ public void removalLocations(Random rnd, @ExpectedType("set[loc]") ISet set, ISo return; } - IValue elem = StreamSupport.stream(set.spliterator(), false).skip(rnd.nextInt(set.size())).findFirst().get(); + int index = rnd.nextInt(set.size()); + IValue elem = set.stream().skip(index).findFirst().get(); ISet smaller = set.delete(elem); assertEquals(smaller.size() + 1, set.size()); assertTrue(!smaller.contains(elem));