1 // Protocol Buffers - Google's data interchange format 2 // Copyright 2008 Google Inc. All rights reserved. 3 // https://developers.google.com/protocol-buffers/ 4 // 5 // Redistribution and use in source and binary forms, with or without 6 // modification, are permitted provided that the following conditions are 7 // met: 8 // 9 // * Redistributions of source code must retain the above copyright 10 // notice, this list of conditions and the following disclaimer. 11 // * Redistributions in binary form must reproduce the above 12 // copyright notice, this list of conditions and the following disclaimer 13 // in the documentation and/or other materials provided with the 14 // distribution. 15 // * Neither the name of Google Inc. nor the names of its 16 // contributors may be used to endorse or promote products derived from 17 // this software without specific prior written permission. 18 // 19 // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS 20 // "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT 21 // LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR 22 // A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT 23 // OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, 24 // SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT 25 // LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, 26 // DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY 27 // THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT 28 // (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE 29 // OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 30 31 package com.google.protobuf; 32 33 import static java.util.Arrays.asList; 34 35 import junit.framework.TestCase; 36 37 import java.util.Collections; 38 import java.util.ConcurrentModificationException; 39 import java.util.Iterator; 40 41 /** 42 * Tests for {@link IntArrayList}. 43 * 44 * @author dweis@google.com (Daniel Weis) 45 */ 46 public class IntArrayListTest extends TestCase { 47 48 private static final IntArrayList UNARY_LIST = newImmutableIntArrayList(1); 49 private static final IntArrayList TERTIARY_LIST = 50 newImmutableIntArrayList(1, 2, 3); 51 52 private IntArrayList list; 53 54 @Override setUp()55 protected void setUp() throws Exception { 56 list = new IntArrayList(); 57 } 58 testEmptyListReturnsSameInstance()59 public void testEmptyListReturnsSameInstance() { 60 assertSame(IntArrayList.emptyList(), IntArrayList.emptyList()); 61 } 62 testEmptyListIsImmutable()63 public void testEmptyListIsImmutable() { 64 assertImmutable(IntArrayList.emptyList()); 65 } 66 testMakeImmutable()67 public void testMakeImmutable() { 68 list.addInt(2); 69 list.addInt(4); 70 list.addInt(6); 71 list.addInt(8); 72 list.makeImmutable(); 73 assertImmutable(list); 74 } 75 testModificationWithIteration()76 public void testModificationWithIteration() { 77 list.addAll(asList(1, 2, 3, 4)); 78 Iterator<Integer> iterator = list.iterator(); 79 assertEquals(4, list.size()); 80 assertEquals(1, (int) list.get(0)); 81 assertEquals(1, (int) iterator.next()); 82 list.set(0, 1); 83 assertEquals(2, (int) iterator.next()); 84 85 list.remove(0); 86 try { 87 iterator.next(); 88 fail(); 89 } catch (ConcurrentModificationException e) { 90 // expected 91 } 92 93 iterator = list.iterator(); 94 list.add(0, 0); 95 try { 96 iterator.next(); 97 fail(); 98 } catch (ConcurrentModificationException e) { 99 // expected 100 } 101 } 102 testGet()103 public void testGet() { 104 assertEquals(1, (int) TERTIARY_LIST.get(0)); 105 assertEquals(2, (int) TERTIARY_LIST.get(1)); 106 assertEquals(3, (int) TERTIARY_LIST.get(2)); 107 108 try { 109 TERTIARY_LIST.get(-1); 110 fail(); 111 } catch (IndexOutOfBoundsException e) { 112 // expected 113 } 114 115 try { 116 TERTIARY_LIST.get(3); 117 fail(); 118 } catch (IndexOutOfBoundsException e) { 119 // expected 120 } 121 } 122 testGetInt()123 public void testGetInt() { 124 assertEquals(1, TERTIARY_LIST.getInt(0)); 125 assertEquals(2, TERTIARY_LIST.getInt(1)); 126 assertEquals(3, TERTIARY_LIST.getInt(2)); 127 128 try { 129 TERTIARY_LIST.get(-1); 130 fail(); 131 } catch (IndexOutOfBoundsException e) { 132 // expected 133 } 134 135 try { 136 TERTIARY_LIST.get(3); 137 fail(); 138 } catch (IndexOutOfBoundsException e) { 139 // expected 140 } 141 } 142 testSize()143 public void testSize() { 144 assertEquals(0, IntArrayList.emptyList().size()); 145 assertEquals(1, UNARY_LIST.size()); 146 assertEquals(3, TERTIARY_LIST.size()); 147 148 list.addInt(2); 149 list.addInt(4); 150 list.addInt(6); 151 list.addInt(8); 152 assertEquals(4, list.size()); 153 154 list.remove(0); 155 assertEquals(3, list.size()); 156 157 list.add(16); 158 assertEquals(4, list.size()); 159 } 160 testSet()161 public void testSet() { 162 list.addInt(2); 163 list.addInt(4); 164 165 assertEquals(2, (int) list.set(0, 0)); 166 assertEquals(0, list.getInt(0)); 167 168 assertEquals(4, (int) list.set(1, 0)); 169 assertEquals(0, list.getInt(1)); 170 171 try { 172 list.set(-1, 0); 173 fail(); 174 } catch (IndexOutOfBoundsException e) { 175 // expected 176 } 177 178 try { 179 list.set(2, 0); 180 fail(); 181 } catch (IndexOutOfBoundsException e) { 182 // expected 183 } 184 } 185 testSetInt()186 public void testSetInt() { 187 list.addInt(2); 188 list.addInt(4); 189 190 assertEquals(2, list.setInt(0, 0)); 191 assertEquals(0, list.getInt(0)); 192 193 assertEquals(4, list.setInt(1, 0)); 194 assertEquals(0, list.getInt(1)); 195 196 try { 197 list.setInt(-1, 0); 198 fail(); 199 } catch (IndexOutOfBoundsException e) { 200 // expected 201 } 202 203 try { 204 list.setInt(2, 0); 205 fail(); 206 } catch (IndexOutOfBoundsException e) { 207 // expected 208 } 209 } 210 testAdd()211 public void testAdd() { 212 assertEquals(0, list.size()); 213 214 assertTrue(list.add(2)); 215 assertEquals(asList(2), list); 216 217 assertTrue(list.add(3)); 218 list.add(0, 4); 219 assertEquals(asList(4, 2, 3), list); 220 221 list.add(0, 1); 222 list.add(0, 0); 223 // Force a resize by getting up to 11 elements. 224 for (int i = 0; i < 6; i++) { 225 list.add(5 + i); 226 } 227 assertEquals(asList(0, 1, 4, 2, 3, 5, 6, 7, 8, 9, 10), list); 228 229 try { 230 list.add(-1, 5); 231 } catch (IndexOutOfBoundsException e) { 232 // expected 233 } 234 235 try { 236 list.add(4, 5); 237 } catch (IndexOutOfBoundsException e) { 238 // expected 239 } 240 } 241 testAddInt()242 public void testAddInt() { 243 assertEquals(0, list.size()); 244 245 list.addInt(2); 246 assertEquals(asList(2), list); 247 248 list.addInt(3); 249 assertEquals(asList(2, 3), list); 250 } 251 testAddAll()252 public void testAddAll() { 253 assertEquals(0, list.size()); 254 255 assertTrue(list.addAll(Collections.singleton(1))); 256 assertEquals(1, list.size()); 257 assertEquals(1, (int) list.get(0)); 258 assertEquals(1, list.getInt(0)); 259 260 assertTrue(list.addAll(asList(2, 3, 4, 5, 6))); 261 assertEquals(asList(1, 2, 3, 4, 5, 6), list); 262 263 assertTrue(list.addAll(TERTIARY_LIST)); 264 assertEquals(asList(1, 2, 3, 4, 5, 6, 1, 2, 3), list); 265 266 assertFalse(list.addAll(Collections.<Integer>emptyList())); 267 assertFalse(list.addAll(IntArrayList.emptyList())); 268 } 269 testRemove()270 public void testRemove() { 271 list.addAll(TERTIARY_LIST); 272 assertEquals(1, (int) list.remove(0)); 273 assertEquals(asList(2, 3), list); 274 275 assertTrue(list.remove(Integer.valueOf(3))); 276 assertEquals(asList(2), list); 277 278 assertFalse(list.remove(Integer.valueOf(3))); 279 assertEquals(asList(2), list); 280 281 assertEquals(2, (int) list.remove(0)); 282 assertEquals(asList(), list); 283 284 try { 285 list.remove(-1); 286 fail(); 287 } catch (IndexOutOfBoundsException e) { 288 // expected 289 } 290 291 try { 292 list.remove(0); 293 } catch (IndexOutOfBoundsException e) { 294 // expected 295 } 296 } 297 assertImmutable(IntArrayList list)298 private void assertImmutable(IntArrayList list) { 299 if (list.contains(1)) { 300 throw new RuntimeException("Cannot test the immutability of lists that contain 1."); 301 } 302 303 try { 304 list.add(1); 305 fail(); 306 } catch (UnsupportedOperationException e) { 307 // expected 308 } 309 310 try { 311 list.add(0, 1); 312 fail(); 313 } catch (UnsupportedOperationException e) { 314 // expected 315 } 316 317 try { 318 list.addAll(Collections.<Integer>emptyList()); 319 fail(); 320 } catch (UnsupportedOperationException e) { 321 // expected 322 } 323 324 try { 325 list.addAll(Collections.singletonList(1)); 326 fail(); 327 } catch (UnsupportedOperationException e) { 328 // expected 329 } 330 331 try { 332 list.addAll(new IntArrayList()); 333 fail(); 334 } catch (UnsupportedOperationException e) { 335 // expected 336 } 337 338 try { 339 list.addAll(UNARY_LIST); 340 fail(); 341 } catch (UnsupportedOperationException e) { 342 // expected 343 } 344 345 try { 346 list.addAll(0, Collections.singleton(1)); 347 fail(); 348 } catch (UnsupportedOperationException e) { 349 // expected 350 } 351 352 try { 353 list.addAll(0, UNARY_LIST); 354 fail(); 355 } catch (UnsupportedOperationException e) { 356 // expected 357 } 358 359 try { 360 list.addAll(0, Collections.<Integer>emptyList()); 361 fail(); 362 } catch (UnsupportedOperationException e) { 363 // expected 364 } 365 366 try { 367 list.addInt(0); 368 fail(); 369 } catch (UnsupportedOperationException e) { 370 // expected 371 } 372 373 try { 374 list.clear(); 375 fail(); 376 } catch (UnsupportedOperationException e) { 377 // expected 378 } 379 380 try { 381 list.remove(1); 382 fail(); 383 } catch (UnsupportedOperationException e) { 384 // expected 385 } 386 387 try { 388 list.remove(new Object()); 389 fail(); 390 } catch (UnsupportedOperationException e) { 391 // expected 392 } 393 394 try { 395 list.removeAll(Collections.<Integer>emptyList()); 396 fail(); 397 } catch (UnsupportedOperationException e) { 398 // expected 399 } 400 401 try { 402 list.removeAll(Collections.singleton(1)); 403 fail(); 404 } catch (UnsupportedOperationException e) { 405 // expected 406 } 407 408 try { 409 list.removeAll(UNARY_LIST); 410 fail(); 411 } catch (UnsupportedOperationException e) { 412 // expected 413 } 414 415 try { 416 list.retainAll(Collections.<Integer>emptyList()); 417 fail(); 418 } catch (UnsupportedOperationException e) { 419 // expected 420 } 421 422 try { 423 list.retainAll(Collections.singleton(1)); 424 fail(); 425 } catch (UnsupportedOperationException e) { 426 // expected 427 } 428 429 try { 430 list.retainAll(UNARY_LIST); 431 fail(); 432 } catch (UnsupportedOperationException e) { 433 // expected 434 } 435 436 try { 437 list.set(0, 0); 438 fail(); 439 } catch (UnsupportedOperationException e) { 440 // expected 441 } 442 443 try { 444 list.setInt(0, 0); 445 fail(); 446 } catch (UnsupportedOperationException e) { 447 // expected 448 } 449 } 450 newImmutableIntArrayList(int... elements)451 private static IntArrayList newImmutableIntArrayList(int... elements) { 452 IntArrayList list = new IntArrayList(); 453 for (int element : elements) { 454 list.addInt(element); 455 } 456 list.makeImmutable(); 457 return list; 458 } 459 } 460