blob: 09742d77710c666f81e3182a6366b0a776d719d0 [file] [log] [blame]
/*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to You 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 org.apache.harmony.luni.tests.java.util;
import java.io.Serializable;
import java.util.Collection;
import java.util.HashSet;
import java.util.IdentityHashMap;
import java.util.Iterator;
import java.util.Map;
import java.util.Set;
import java.util.TreeSet;
import org.apache.harmony.testframework.serialization.SerializationTest;
import org.apache.harmony.testframework.serialization.SerializationTest.SerializableAssert;
public class IdentityHashMapTest extends junit.framework.TestCase {
/**
* @tests java.util.IdentityHashMap#containsKey(java.lang.Object)
* @tests java.util.IdentityHashMap#containsValue(java.lang.Object)
* @tests java.util.IdentityHashMap#put(java.lang.Object, java.lang.Object)
* @tests java.util.IdentityHashMap#get(java.lang.Object)
*/
public void test_null_Keys_and_Values() {
// tests with null keys and values
IdentityHashMap map = new IdentityHashMap();
Object result;
// null key and null value
result = map.put(null, null);
assertTrue("testA can not find null key", map.containsKey(null));
assertTrue("testA can not find null value", map.containsValue(null));
assertNull("testA can not get null value for null key",
map.get(null));
assertNull("testA put returned wrong value", result);
// null value
String value = "a value";
result = map.put(null, value);
assertTrue("testB can not find null key", map.containsKey(null));
assertTrue("testB can not find a value with null key", map
.containsValue(value));
assertTrue("testB can not get value for null key",
map.get(null) == value);
assertNull("testB put returned wrong value", result);
// a null key
String key = "a key";
result = map.put(key, null);
assertTrue("testC can not find a key with null value", map
.containsKey(key));
assertTrue("testC can not find null value", map.containsValue(null));
assertNull("testC can not get null value for key", map.get(key));
assertNull("testC put returned wrong value", result);
// another null key
String anothervalue = "another value";
result = map.put(null, anothervalue);
assertTrue("testD can not find null key", map.containsKey(null));
assertTrue("testD can not find a value with null key", map
.containsValue(anothervalue));
assertTrue("testD can not get value for null key",
map.get(null) == anothervalue);
assertTrue("testD put returned wrong value", result == value);
// remove a null key
result = map.remove(null);
assertTrue("testE remove returned wrong value", result == anothervalue);
assertTrue("testE should not find null key", !map.containsKey(null));
assertTrue("testE should not find a value with null key", !map
.containsValue(anothervalue));
assertNull("testE should not get value for null key",
map.get(null));
}
/**
* @tests java.util.IdentityHashMap#put(java.lang.Object, java.lang.Object)
*/
public void test_putLjava_lang_ObjectLjava_lang_Object() {
IdentityHashMap<Object, Object> map = new IdentityHashMap<Object, Object>();
// Test null as a key.
Object value = "Some value";
map.put(null, value);
assertSame("Assert 0: Failure getting null key", value, map.get(null));
// Test null as a value
Object key = "Some key";
map.put(key, null);
assertNull("Assert 1: Failure getting null value", map.get(key));
}
/**
* @tests java.util.IdentityHashMap#remove(java.lang.Object)
* @tests java.util.IdentityHashMap#keySet()
*/
public void test_remove() {
IdentityHashMap map = new IdentityHashMap();
map.put(null, null);
map.put("key1", "value1");
map.put("key2", "value2");
map.remove("key1");
assertTrue("Did not remove key1", !map.containsKey("key1"));
assertTrue("Did not remove the value for key1", !map
.containsValue("value1"));
assertTrue("Modified key2", map.get("key2") != null
&& map.get("key2") == "value2");
assertNull("Modified null entry", map.get(null));
}
/**
* @tests java.util.IdentityHashMapTest#remove(java.lang.Object)
*/
public void test_removeLjava_lang_Object() {
// Regression for HARMONY-37
IdentityHashMap<String, String> hashMap = new IdentityHashMap<String, String>();
hashMap.remove("absent");
assertEquals("Assert 0: Size is incorrect", 0, hashMap.size());
hashMap.put("key", "value");
hashMap.remove("key");
assertEquals("Assert 1: After removing non-null element size is incorrect", 0, hashMap.size());
hashMap.put(null, null);
assertEquals("Assert 2: adding literal null failed", 1, hashMap.size());
hashMap.remove(null);
assertEquals("Assert 3: After removing null element size is incorrect", 0, hashMap.size());
}
/**
* @tests java.util.IdentityHashMap#entrySet()
* @tests java.util.IdentityHashMap#keySet()
* @tests java.util.IdentityHashMap#values()
*/
public void test_sets() {
// tests with null keys and values
IdentityHashMap map = new IdentityHashMap();
// null key and null value
map.put("key", "value");
map.put(null, null);
map.put("a key", null);
map.put("another key", null);
Set keyset = map.keySet();
Collection valueset = map.values();
Set entries = map.entrySet();
Iterator it = entries.iterator();
while (it.hasNext()) {
Map.Entry entry = (Map.Entry) it.next();
assertTrue("EntrySetIterator can not find entry ", entries
.contains(entry));
assertTrue("entry key not found in map", map.containsKey(entry
.getKey()));
assertTrue("entry value not found in map", map.containsValue(entry
.getValue()));
assertTrue("entry key not found in the keyset", keyset
.contains(entry.getKey()));
assertTrue("entry value not found in the valueset", valueset
.contains(entry.getValue()));
}
}
/**
* @tests java.util.IdentityHashMap#entrySet()
* @tests java.util.IdentityHashMap#remove(java.lang.Object)
*/
public void test_entrySet_removeAll() {
IdentityHashMap map = new IdentityHashMap();
for (int i = 0; i < 1000; i++) {
map.put(new Integer(i), new Integer(i));
}
Set set = map.entrySet();
set.removeAll(set);
assertEquals("did not remove all elements in the map", 0, map.size());
assertTrue("did not remove all elements in the entryset", set.isEmpty());
Iterator it = set.iterator();
assertTrue("entrySet iterator still has elements", !it.hasNext());
}
/**
* @tests java.util.IdentityHashMap#keySet()
* @tests java.util.IdentityHashMap#clear()
*/
public void test_keySet_clear() {
IdentityHashMap map = new IdentityHashMap();
for (int i = 0; i < 1000; i++) {
map.put(new Integer(i), new Integer(i));
}
Set set = map.keySet();
set.clear();
assertEquals("did not remove all elements in the map", 0, map.size());
assertTrue("did not remove all elements in the keyset", set.isEmpty());
Iterator it = set.iterator();
assertTrue("keySet iterator still has elements", !it.hasNext());
}
/**
* @tests java.util.IdentityHashMap#values()
*/
public void test_values() {
IdentityHashMap map = new IdentityHashMap();
for (int i = 0; i < 10; i++) {
map.put(new Integer(i), new Integer(i));
}
Integer key = new Integer(20);
Integer value = new Integer(40);
map.put(key, value);
Collection vals = map.values();
boolean result = vals.remove(key);
assertTrue("removed entries incorrectly", map.size() == 11 && !result);
assertTrue("removed key incorrectly", map.containsKey(key));
assertTrue("removed value incorrectly", map.containsValue(value));
result = vals.remove(value);
assertTrue("Did not remove entry as expected", map.size() == 10
&& result);
assertTrue("Did not remove key as expected", !map.containsKey(key));
assertTrue("Did not remove value as expected", !map
.containsValue(value));
// put an equivalent key to a value
key = new Integer(1);
value = new Integer(100);
map.put(key, value);
result = vals.remove(key);
assertTrue("TestB. removed entries incorrectly", map.size() == 11
&& !result);
assertTrue("TestB. removed key incorrectly", map.containsKey(key));
assertTrue("TestB. removed value incorrectly", map.containsValue(value));
result = vals.remove(value);
assertTrue("TestB. Did not remove entry as expected", map.size() == 10
&& result);
assertTrue("TestB. Did not remove key as expected", !map
.containsKey(key));
assertTrue("TestB. Did not remove value as expected", !map
.containsValue(value));
vals.clear();
assertEquals("Did not remove all entries as expected", 0, map.size());
}
/**
* @tests java.util.IdentityHashMap#keySet()
* @tests java.util.IdentityHashMap#remove(java.lang.Object)
*/
public void test_keySet_removeAll() {
IdentityHashMap map = new IdentityHashMap();
for (int i = 0; i < 1000; i++) {
map.put(new Integer(i), new Integer(i));
}
Set set = map.keySet();
set.removeAll(set);
assertEquals("did not remove all elements in the map", 0, map.size());
assertTrue("did not remove all elements in the keyset", set.isEmpty());
Iterator it = set.iterator();
assertTrue("keySet iterator still has elements", !it.hasNext());
}
/**
* @tests java.util.IdentityHashMap#keySet()
*/
public void test_keySet_retainAll() {
IdentityHashMap map = new IdentityHashMap();
for (int i = 0; i < 1000; i++) {
map.put(new Integer(i), new Integer(i));
}
Set set = map.keySet();
// retain all the elements
boolean result = set.retainAll(set);
assertTrue("retain all should return false", !result);
assertEquals("did not retain all", 1000, set.size());
// send empty set to retainAll
result = set.retainAll(new TreeSet());
assertTrue("retain all should return true", result);
assertEquals("did not remove all elements in the map", 0, map.size());
assertTrue("did not remove all elements in the keyset", set.isEmpty());
Iterator it = set.iterator();
assertTrue("keySet iterator still has elements", !it.hasNext());
}
/**
* @tests java.util.IdentityHashMap#keySet()
* @tests java.util.IdentityHashMap#remove(java.lang.Object)
*/
public void test_keyset_remove() {
IdentityHashMap map = new IdentityHashMap();
Integer key = new Integer(21);
map.put(new Integer(1), null);
map.put(new Integer(11), null);
map.put(key, null);
map.put(new Integer(31), null);
map.put(new Integer(41), null);
map.put(new Integer(51), null);
map.put(new Integer(61), null);
map.put(new Integer(71), null);
map.put(new Integer(81), null);
map.put(new Integer(91), null);
Set set = map.keySet();
Set newset = new HashSet();
Iterator it = set.iterator();
while (it.hasNext()) {
Object element = it.next();
if (element == key) {
it.remove();
} else
newset.add(element);
}
int size = newset.size();
assertTrue("keyset and newset don't have same size",
newset.size() == size);
assertTrue("element is in newset ", !newset.contains(key));
assertTrue("element not removed from keyset", !set.contains(key));
assertTrue("element not removed from map", !map.containsKey(key));
assertTrue("newset and keyset do not have same elements 1", newset
.equals(set));
assertTrue("newset and keyset do not have same elements 2", set
.equals(newset));
}
public void test_clone_scenario1() {
IdentityHashMap hashMap = new IdentityHashMap();
assertEquals(0, hashMap.hashCode());
Object cloneHashMap = hashMap.clone();
((IdentityHashMap) cloneHashMap).put("key", "value");
assertEquals(0, hashMap.hashCode());
assertTrue(0 != cloneHashMap.hashCode());
}
public void test_clone_scenario2() {
IdentityHashMap hashMap = new IdentityHashMap();
assertEquals(0, hashMap.hashCode());
Object cloneHashMap = hashMap.clone();
hashMap.put("key", "value");
assertEquals(1, hashMap.size());
assertEquals(0, ((IdentityHashMap) cloneHashMap).size());
assertEquals("value", hashMap.get("key"));
assertNull(((IdentityHashMap) cloneHashMap).get("key"));
assertTrue(0 != hashMap.hashCode());
assertEquals(0, cloneHashMap.hashCode());
}
public void test_clone_scenario3() {
IdentityHashMap hashMap = new IdentityHashMap();
assertEquals(0, hashMap.hashCode());
hashMap.put("key", "value");
Object cloneHashMap = hashMap.clone();
assertEquals(1, hashMap.size());
assertEquals(1, ((IdentityHashMap) cloneHashMap).size());
assertEquals("value", hashMap.get("key"));
assertEquals("value", ((IdentityHashMap) cloneHashMap).get("key"));
assertEquals(hashMap.hashCode(), cloneHashMap.hashCode());
}
public void test_clone_scenario4() {
IdentityHashMap hashMap = new IdentityHashMap();
Object cloneHashMap = hashMap.clone();
assertNull(((IdentityHashMap) cloneHashMap).get((Object) null));
hashMap.put((Object) null, cloneHashMap);
assertNull(((IdentityHashMap) cloneHashMap).get((Object) null));
assertEquals(cloneHashMap, hashMap.get((Object) null));
}
public void test_clone_scenario5() throws Exception {
IdentityHashMap hashMap = new IdentityHashMap();
Object cloneHashMap = hashMap.clone();
assertNull(hashMap.remove((Object) null));
((IdentityHashMap) cloneHashMap).put((Object) null, cloneHashMap);
assertNull(hashMap.remove((Object) null));
assertEquals(cloneHashMap, ((IdentityHashMap) cloneHashMap)
.get((Object) null));
}
// comparator for IdentityHashMap objects
private static final SerializableAssert COMPARATOR = new SerializableAssert() {
public void assertDeserialized(Serializable initial,
Serializable deserialized) {
IdentityHashMap init = (IdentityHashMap) initial;
IdentityHashMap desr = (IdentityHashMap) deserialized;
assertEquals("Size", init.size(), desr.size());
}
};
/**
* @tests serialization/deserialization compatibility with RI.
*/
public void testSerializationCompatibility() throws Exception {
IdentityHashMap<String, String> identityHashMap = new IdentityHashMap<String, String>();
identityHashMap.put("key1", "value1");
identityHashMap.put("key2", "value2");
identityHashMap.put("key3", "value3");
SerializationTest.verifyGolden(this, identityHashMap, COMPARATOR);
}
}