File: ReferenceArraySetTest.java

package info (click to toggle)
libfastutil-java 8.5.16%2Bdfsg-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 4,208 kB
  • sloc: java: 19,706; sh: 1,188; makefile: 473; xml: 354
file content (103 lines) | stat: -rw-r--r-- 3,249 bytes parent folder | download | duplicates (3)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
/*
 * Copyright (C) 2017-2022 Sebastiano Vigna
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *     http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

package it.unimi.dsi.fastutil.objects;


import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertFalse;
import static org.junit.Assert.assertTrue;

import java.io.ByteArrayInputStream;
import java.io.ByteArrayOutputStream;
import java.io.IOException;
import java.io.ObjectOutputStream;

import org.junit.Test;

import it.unimi.dsi.fastutil.io.BinIO;

public class ReferenceArraySetTest {

	@Test
	public void testSet() {
		for(int i = 0; i <= 2; i++) {
			final ReferenceArraySet<Object> s = i == 0 ? new ReferenceArraySet<>() : new ReferenceArraySet<>(2);
			final Integer one = new Integer(1), two = new Integer(2), three = new Integer(3);
			assertTrue(s.add(one));
			assertEquals(1, s.size());
			assertTrue(s.contains(one));
			assertFalse(s.contains(new Integer(1)));
			assertTrue(s.add(two));
			assertTrue(s.contains(two));
			assertFalse(s.contains(new Integer(2)));
			assertEquals(2, s.size());
			assertFalse(s.add(one));
			assertFalse(s.remove(three));
			assertTrue(s.add(three));
			assertEquals(3, s.size());
			assertTrue(s.contains(one));
			assertTrue(s.contains(two));
			assertTrue(s.contains(three));
			assertEquals(new ReferenceOpenHashSet<>(new Object[] { one, two, three }), new ReferenceOpenHashSet<>(s.iterator()));
			assertTrue(s.remove(three));
			assertEquals(2, s.size());
			assertTrue(s.remove(one));
			assertEquals(1, s.size());
			assertFalse(s.contains(one));
			assertTrue(s.remove(two));
			assertEquals(0, s.size());
			assertFalse(s.contains(one));
		}
	}

	@Test
	public void testClone() {
		final ReferenceArraySet<Integer> s = new ReferenceArraySet<>();
		assertEquals(s, s.clone());
		Integer zero;
		s.add(zero = new Integer(0));
		assertEquals(s, s.clone());
		s.add(new Integer(0));
		assertEquals(s, s.clone());
		s.add(new Integer(1));
		assertEquals(s, s.clone());
		s.add(new Integer(2));
		assertEquals(s, s.clone());
		s.remove(zero);
		assertEquals(s, s.clone());
	}

	@Test
	public void testSerialisation() throws IOException, ClassNotFoundException {
		// We can't really test reference maps as equals() doesnt' work
		final ObjectArraySet<Integer> s = new ObjectArraySet<>();
		final ByteArrayOutputStream baos = new ByteArrayOutputStream();
		ObjectOutputStream oos = new ObjectOutputStream(baos);
		oos.writeObject(s);
		oos.close();
		assertEquals(s, BinIO.loadObject(new ByteArrayInputStream(baos.toByteArray())));

		s.add(new Integer(0));
		s.add(new Integer(1));

		baos.reset();
		oos = new ObjectOutputStream(baos);
		oos.writeObject(s);
		oos.close();
		assertEquals(s, BinIO.loadObject(new ByteArrayInputStream(baos.toByteArray())));
	}
}