1 /* 2 * Copyright (c) 2012, 2017, Oracle and/or its affiliates. All rights reserved. 3 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. 4 * 5 * This code is free software; you can redistribute it and/or modify it 6 * under the terms of the GNU General Public License version 2 only, as 7 * published by the Free Software Foundation. 8 * 9 * This code is distributed in the hope that it will be useful, but WITHOUT 10 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or 11 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License 12 * version 2 for more details (a copy is included in the LICENSE file that 13 * accompanied this code). 14 * 15 * You should have received a copy of the GNU General Public License version 16 * 2 along with this work; if not, write to the Free Software Foundation, 17 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. 18 * 19 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA 20 * or visit www.oracle.com if you need additional information or have any 21 * questions. 22 */ 23 package org.openjdk.tests.java.util.stream; 24 25 import org.openjdk.testlib.java.util.stream.OpTestCase; 26 import org.openjdk.testlib.java.util.stream.SpliteratorTestHelper; 27 import org.openjdk.testlib.java.util.stream.TestData; 28 29 import java.util.Arrays; 30 import java.util.Optional; 31 import java.util.Spliterator; 32 import java.util.stream.IntStream; 33 import java.util.stream.LongStream; 34 import java.util.stream.Stream; 35 36 import org.testng.annotations.Test; 37 38 /** 39 * Primitive range tests 40 * 41 * @author Brian Goetz 42 */ 43 @Test 44 public class RangeTest extends OpTestCase { 45 testInfiniteRangeFindFirst()46 public void testInfiniteRangeFindFirst() { 47 Integer first = Stream.iterate(0, i -> i + 1).filter(i -> i > 10000).findFirst().get(); 48 assertEquals(first, Stream.iterate(0, i -> i + 1).parallel().filter(i -> i > 10000).findFirst().get()); 49 50 // Limit is required to transform the infinite stream to a finite stream 51 // since the exercising requires a finite stream 52 withData(TestData.Factory.ofSupplier( 53 "", () -> Stream.iterate(0, i -> i + 1).filter(i -> i > 10000).limit(20000))). 54 terminal(s->s.findFirst()).expectedResult(Optional.of(10001)).exercise(); 55 } 56 57 // 58 testIntRange()59 public void testIntRange() { 60 // Half-open 61 for (int start : Arrays.asList(1, 10, -1, -10)) { 62 setContext("start", start); 63 for (int end : Arrays.asList(1, 10, -1, -10)) { 64 setContext("end", end); 65 int size = (start < end) ? end - start : 0; 66 int[] exp = new int[size]; 67 for (int i = start, p = 0; i < end; i++, p++) { 68 exp[p] = i; 69 } 70 71 int[] inc = IntStream.range(start, end).toArray(); 72 assertEquals(inc.length, size); 73 assertTrue(Arrays.equals(exp, inc)); 74 75 withData(intRangeData(start, end)).stream(s -> s). 76 expectedResult(exp).exercise(); 77 } 78 } 79 80 // Closed 81 for (int start : Arrays.asList(1, 10, -1, -10)) { 82 setContext("start", start); 83 for (int end : Arrays.asList(1, 10, -1, -10)) { 84 setContext("end", end); 85 int size = (start <= end) ? end - start + 1 : 0; 86 int[] exp = new int[size]; 87 for (int i = start, p = 0; i <= end; i++, p++) { 88 exp[p] = i; 89 } 90 91 int[] inc = IntStream.rangeClosed(start, end).toArray(); 92 assertEquals(inc.length, size); 93 assertTrue(Arrays.equals(exp, inc)); 94 95 withData(intRangeClosedData(start, end)).stream(s -> s). 96 expectedResult(exp).exercise(); 97 } 98 } 99 100 // Closed, maximum upper bound of Integer.MAX_VALUE 101 { 102 int[] inc = IntStream.rangeClosed(Integer.MAX_VALUE - 1, Integer.MAX_VALUE).toArray(); 103 assertEquals(2, inc.length); 104 assertEquals(Integer.MAX_VALUE - 1, inc[0]); 105 assertEquals(Integer.MAX_VALUE, inc[1]); 106 107 inc = IntStream.rangeClosed(Integer.MAX_VALUE, Integer.MAX_VALUE).toArray(); 108 assertEquals(1, inc.length); 109 assertEquals(Integer.MAX_VALUE, inc[0]); 110 111 SpliteratorTestHelper.testIntSpliterator( 112 () -> IntStream.rangeClosed(Integer.MAX_VALUE - 8, Integer.MAX_VALUE).spliterator()); 113 } 114 115 // Range wider than Integer.MAX_VALUE 116 { 117 Spliterator.OfInt s = IntStream.rangeClosed(Integer.MIN_VALUE, Integer.MAX_VALUE). 118 spliterator(); 119 assertEquals(s.estimateSize(), 1L << 32); 120 } 121 } 122 intRangeData(int start, int end)123 TestData.OfInt intRangeData(int start, int end) { 124 return TestData.Factory.ofIntSupplier("int range", () -> IntStream.range(start, end)); 125 } 126 intRangeClosedData(int start, int end)127 TestData.OfInt intRangeClosedData(int start, int end) { 128 return TestData.Factory.ofIntSupplier("int rangeClosed", () -> IntStream.rangeClosed(start, end)); 129 } 130 tesIntRangeReduce()131 public void tesIntRangeReduce() { 132 withData(intRangeData(0, 10000)). 133 terminal(s -> s.reduce(0, Integer::sum)).exercise(); 134 } 135 testIntInfiniteRangeLimit()136 public void testIntInfiniteRangeLimit() { 137 withData(TestData.Factory.ofIntSupplier( 138 "int range", () -> IntStream.iterate(0, i -> i + 1).limit(10000))). 139 terminal(s -> s.reduce(0, Integer::sum)).exercise(); 140 } 141 testIntInfiniteRangeFindFirst()142 public void testIntInfiniteRangeFindFirst() { 143 int first = IntStream.iterate(0, i -> i + 1).filter(i -> i > 10000).findFirst().getAsInt(); 144 assertEquals(first, IntStream.iterate(0, i -> i + 1).parallel().filter(i -> i > 10000).findFirst().getAsInt()); 145 } 146 147 // 148 testLongRange()149 public void testLongRange() { 150 // Half-open 151 for (long start : Arrays.asList(1, 1000, -1, -1000)) { 152 setContext("start", start); 153 for (long end : Arrays.asList(1, 1000, -1, -1000)) { 154 setContext("end", end); 155 long size = start < end ? end - start : 0; 156 long[] exp = new long[(int) size]; 157 for (long i = start, p = 0; i < end; i++, p++) { 158 exp[(int) p] = i; 159 } 160 161 long[] inc = LongStream.range(start, end).toArray(); 162 assertEquals(inc.length, size); 163 assertTrue(Arrays.equals(exp, inc)); 164 165 withData(longRangeData(start, end)).stream(s -> s). 166 expectedResult(exp).exercise(); 167 } 168 } 169 170 // Closed 171 for (long start : Arrays.asList(1, 1000, -1, -1000)) { 172 setContext("start", start); 173 for (long end : Arrays.asList(1, 1000, -1, -1000)) { 174 setContext("end", end); 175 long size = start <= end ? end - start + 1: 0; 176 long[] exp = new long[(int) size]; 177 for (long i = start, p = 0; i <= end; i++, p++) { 178 exp[(int) p] = i; 179 } 180 181 long[] inc = LongStream.rangeClosed(start, end).toArray(); 182 assertEquals(inc.length, size); 183 assertTrue(Arrays.equals(exp, inc)); 184 185 withData(longRangeClosedData(start, end)).stream(s -> s). 186 expectedResult(exp).exercise(); 187 } 188 } 189 190 // Closed, maximum upper bound of Long.MAX_VALUE 191 { 192 long[] inc = LongStream.rangeClosed(Long.MAX_VALUE - 1, Long.MAX_VALUE).toArray(); 193 assertEquals(2, inc.length); 194 assertEquals(Long.MAX_VALUE - 1, inc[0]); 195 assertEquals(Long.MAX_VALUE, inc[1]); 196 197 inc = LongStream.rangeClosed(Long.MAX_VALUE, Long.MAX_VALUE).toArray(); 198 assertEquals(1, inc.length); 199 assertEquals(Long.MAX_VALUE, inc[0]); 200 201 SpliteratorTestHelper.testLongSpliterator( 202 () -> LongStream.rangeClosed(Long.MAX_VALUE - 8, Long.MAX_VALUE).spliterator()); 203 } 204 } 205 206 TestData.OfLong longRangeData(long start, long end) { 207 return TestData.Factory.ofLongSupplier("long range", () -> LongStream.range(start, end)); 208 } 209 longRangeClosedData(long start, long end)210 TestData.OfLong longRangeClosedData(long start, long end) { 211 return TestData.Factory.ofLongSupplier("long rangeClosed", () -> LongStream.rangeClosed(start, end)); 212 } 213 testLongRangeReduce()214 public void testLongRangeReduce() { 215 withData(longRangeData(0, 10000)). 216 terminal(s -> s.reduce(0, Long::sum)).exercise(); 217 } 218 testLongInfiniteRangeLimit()219 public void testLongInfiniteRangeLimit() { 220 withData(TestData.Factory.ofLongSupplier( 221 "long range", () -> LongStream.iterate(0, i -> i + 1).limit(10000))). 222 terminal(s -> s.reduce(0, Long::sum)).exercise(); 223 } 224 testLongInfiniteRangeFindFirst()225 public void testLongInfiniteRangeFindFirst() { 226 long first = LongStream.iterate(0, i -> i + 1).filter(i -> i > 10000).findFirst().getAsLong(); 227 assertEquals(first, LongStream.iterate(0, i -> i + 1).parallel().filter(i -> i > 10000).findFirst().getAsLong()); 228 } 229 assertSizedAndSubSized(Spliterator<?> s)230 private static void assertSizedAndSubSized(Spliterator<?> s) { 231 assertTrue(s.hasCharacteristics(Spliterator.SIZED | Spliterator.SUBSIZED)); 232 } 233 assertNotSizedAndSubSized(Spliterator<?> s)234 private static void assertNotSizedAndSubSized(Spliterator<?> s) { 235 assertFalse(s.hasCharacteristics(Spliterator.SIZED | Spliterator.SUBSIZED)); 236 } 237 testLongLongRange()238 public void testLongLongRange() { 239 // Test [Long.MIN_VALUE, Long.MAX_VALUE) 240 // This will concatenate streams of three ranges 241 // [Long.MIN_VALUE, x) [x, 0) [0, Long.MAX_VALUE) 242 // where x = Long.divideUnsigned(0 - Long.MIN_VALUE, 2) + 1 243 { 244 Spliterator.OfLong s = LongStream.range(Long.MIN_VALUE, Long.MAX_VALUE).spliterator(); 245 246 assertEquals(s.estimateSize(), Long.MAX_VALUE); 247 assertNotSizedAndSubSized(s); 248 249 Spliterator.OfLong s1 = s.trySplit(); 250 assertNotSizedAndSubSized(s1); 251 assertSizedAndSubSized(s); 252 253 Spliterator.OfLong s2 = s1.trySplit(); 254 assertSizedAndSubSized(s1); 255 assertSizedAndSubSized(s2); 256 257 assertTrue(s.estimateSize() == Long.MAX_VALUE); 258 assertTrue(s1.estimateSize() < Long.MAX_VALUE); 259 assertTrue(s2.estimateSize() < Long.MAX_VALUE); 260 261 assertEquals(s.estimateSize() + s1.estimateSize() + s2.estimateSize(), 262 Long.MAX_VALUE - Long.MIN_VALUE); 263 } 264 265 long[][] ranges = { {Long.MIN_VALUE, 0}, {-1, Long.MAX_VALUE} }; 266 for (int i = 0; i < ranges.length; i++) { 267 long start = ranges[i][0]; 268 long end = ranges[i][1]; 269 270 Spliterator.OfLong s = LongStream.range(start, end).spliterator(); 271 272 assertEquals(s.estimateSize(), Long.MAX_VALUE); 273 assertNotSizedAndSubSized(s); 274 275 Spliterator.OfLong s1 = s.trySplit(); 276 assertSizedAndSubSized(s1); 277 assertSizedAndSubSized(s); 278 279 assertTrue(s.estimateSize() < Long.MAX_VALUE); 280 assertTrue(s1.estimateSize() < Long.MAX_VALUE); 281 282 assertEquals(s.estimateSize() + s1.estimateSize(), end - start); 283 } 284 } 285 286 public void testLongLongRangeClosed() { 287 // Test [Long.MIN_VALUE, Long.MAX_VALUE] 288 // This will concatenate streams of four ranges 289 // [Long.MIN_VALUE, x) [x, 0) [0, y) [y, Long.MAX_VALUE] 290 // where x = Long.divideUnsigned(0 - Long.MIN_VALUE, 2) + 1 291 // y = Long.divideUnsigned(Long.MAX_VALUE, 2) + 1 292 293 { 294 Spliterator.OfLong s = LongStream.rangeClosed(Long.MIN_VALUE, Long.MAX_VALUE).spliterator(); 295 296 assertEquals(s.estimateSize(), Long.MAX_VALUE); 297 assertNotSizedAndSubSized(s); 298 299 Spliterator.OfLong s1 = s.trySplit(); 300 assertNotSizedAndSubSized(s1); 301 assertNotSizedAndSubSized(s); 302 303 Spliterator.OfLong s2 = s1.trySplit(); 304 assertSizedAndSubSized(s1); 305 assertSizedAndSubSized(s2); 306 307 Spliterator.OfLong s3 = s.trySplit(); 308 assertSizedAndSubSized(s3); 309 assertSizedAndSubSized(s); 310 311 assertTrue(s.estimateSize() < Long.MAX_VALUE); 312 assertTrue(s3.estimateSize() < Long.MAX_VALUE); 313 assertTrue(s1.estimateSize() < Long.MAX_VALUE); 314 assertTrue(s2.estimateSize() < Long.MAX_VALUE); 315 316 assertEquals(s.estimateSize() + s3.estimateSize() + s1.estimateSize() + s2.estimateSize(), 317 Long.MAX_VALUE - Long.MIN_VALUE + 1); 318 } 319 320 long[][] ranges = { {Long.MIN_VALUE, 0}, {-1, Long.MAX_VALUE} }; 321 for (int i = 0; i < ranges.length; i++) { 322 long start = ranges[i][0]; 323 long end = ranges[i][1]; 324 325 Spliterator.OfLong s = LongStream.rangeClosed(start, end).spliterator(); 326 327 assertEquals(s.estimateSize(), Long.MAX_VALUE); 328 assertNotSizedAndSubSized(s); 329 330 Spliterator.OfLong s1 = s.trySplit(); 331 assertSizedAndSubSized(s1); 332 assertSizedAndSubSized(s); 333 334 assertTrue(s.estimateSize() < Long.MAX_VALUE); 335 assertTrue(s1.estimateSize() < Long.MAX_VALUE); 336 337 assertEquals(s.estimateSize() + s1.estimateSize(), end - start + 1); 338 } 339 } 340 } 341