001/* 002 * Copyright (C) 2015 The Guava Authors 003 * 004 * Licensed under the Apache License, Version 2.0 (the "License"); 005 * you may not use this file except in compliance with the License. 006 * You may obtain a copy of the License at 007 * 008 * http://www.apache.org/licenses/LICENSE-2.0 009 * 010 * Unless required by applicable law or agreed to in writing, software 011 * distributed under the License is distributed on an "AS IS" BASIS, 012 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 013 * See the License for the specific language governing permissions and 014 * limitations under the License. 015 */ 016 017package com.google.common.collect.testing.testers; 018 019import static com.google.common.collect.testing.features.CollectionSize.ZERO; 020import static com.google.common.collect.testing.features.MapFeature.ALLOWS_NULL_KEY_QUERIES; 021import static com.google.common.collect.testing.features.MapFeature.ALLOWS_NULL_VALUE_QUERIES; 022import static com.google.common.collect.testing.features.MapFeature.SUPPORTS_REMOVE; 023 024import com.google.common.annotations.GwtCompatible; 025import com.google.common.collect.testing.AbstractMapTester; 026import com.google.common.collect.testing.features.CollectionSize; 027import com.google.common.collect.testing.features.MapFeature; 028import java.util.concurrent.ConcurrentMap; 029import org.junit.Ignore; 030 031/** 032 * Tester for {@link ConcurrentMap#remove}. Can't be invoked directly; please see {@link 033 * com.google.common.collect.testing.ConcurrentMapTestSuiteBuilder}. 034 * 035 * @author Louis Wasserman 036 */ 037@GwtCompatible 038@Ignore // Affects only Android test runner, which respects JUnit 4 annotations on JUnit 3 tests. 039@SuppressWarnings("JUnit4ClassUsedInJUnit3") 040@ElementTypesAreNonnullByDefault 041public class ConcurrentMapRemoveTester<K, V> extends AbstractMapTester<K, V> { 042 @Override 043 protected ConcurrentMap<K, V> getMap() { 044 return (ConcurrentMap<K, V>) super.getMap(); 045 } 046 047 @MapFeature.Require(SUPPORTS_REMOVE) 048 @CollectionSize.Require(absent = ZERO) 049 public void testRemove_supportedPresent() { 050 assertTrue(getMap().remove(k0(), v0())); 051 expectMissing(e0()); 052 } 053 054 @MapFeature.Require(SUPPORTS_REMOVE) 055 public void testRemove_supportedPresentKeyWrongValue() { 056 assertFalse(getMap().remove(k0(), v3())); 057 expectUnchanged(); 058 } 059 060 @MapFeature.Require(SUPPORTS_REMOVE) 061 public void testRemove_supportedWrongKeyPresentValue() { 062 assertFalse(getMap().remove(k3(), v0())); 063 expectUnchanged(); 064 } 065 066 @MapFeature.Require(SUPPORTS_REMOVE) 067 public void testRemove_supportedAbsentKeyAbsentValue() { 068 assertFalse(getMap().remove(k3(), v3())); 069 expectUnchanged(); 070 } 071 072 @MapFeature.Require(value = SUPPORTS_REMOVE, absent = ALLOWS_NULL_KEY_QUERIES) 073 public void testRemove_nullKeyQueriesUnsupported() { 074 try { 075 assertFalse(getMap().remove(null, v3())); 076 } catch (NullPointerException tolerated) { 077 // since the operation would be a no-op, the exception is not required 078 } 079 expectUnchanged(); 080 } 081 082 @MapFeature.Require(value = SUPPORTS_REMOVE, absent = ALLOWS_NULL_VALUE_QUERIES) 083 public void testRemove_nullValueQueriesUnsupported() { 084 try { 085 assertFalse(getMap().remove(k3(), null)); 086 } catch (NullPointerException tolerated) { 087 // since the operation would be a no-op, the exception is not required 088 } 089 expectUnchanged(); 090 } 091 092 @MapFeature.Require(absent = SUPPORTS_REMOVE) 093 @CollectionSize.Require(absent = ZERO) 094 public void testRemove_unsupportedPresent() { 095 try { 096 getMap().remove(k0(), v0()); 097 fail("Expected UnsupportedOperationException"); 098 } catch (UnsupportedOperationException expected) { 099 } 100 expectUnchanged(); 101 } 102 103 @MapFeature.Require(absent = SUPPORTS_REMOVE) 104 public void testRemove_unsupportedAbsent() { 105 try { 106 assertFalse(getMap().remove(k0(), v3())); 107 } catch (UnsupportedOperationException tolerated) { 108 // since the operation would be a no-op, the exception is not required 109 } 110 expectUnchanged(); 111 } 112}