Home | History | Annotate | Download | only in cache
      1 /*
      2  * Copyright (C) 2011 The Guava Authors
      3  *
      4  * Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except
      5  * in compliance with the License. You may obtain a copy of the License at
      6  *
      7  * http://www.apache.org/licenses/LICENSE-2.0
      8  *
      9  * Unless required by applicable law or agreed to in writing, software distributed under the License
     10  * is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express
     11  * or implied. See the License for the specific language governing permissions and limitations under
     12  * the License.
     13  */
     14 
     15 package com.google.common.cache;
     16 
     17 import com.google.common.annotations.GwtCompatible;
     18 import com.google.common.annotations.GwtIncompatible;
     19 
     20 import java.util.concurrent.ConcurrentLinkedQueue;
     21 import java.util.concurrent.atomic.AtomicInteger;
     22 
     23 /**
     24  * Utility {@link RemovalListener} implementations intended for use in testing.
     25  *
     26  * @author mike nonemacher
     27  */
     28 @GwtCompatible(emulated = true)
     29 class TestingRemovalListeners {
     30 
     31   /**
     32    * Returns a new no-op {@code RemovalListener}.
     33    */
     34   static <K, V> NullRemovalListener<K, V> nullRemovalListener() {
     35     return new NullRemovalListener<K, V>();
     36   }
     37 
     38   /**
     39    * Type-inferring factory method for creating a {@link QueuingRemovalListener}.
     40    */
     41   @GwtIncompatible("ConcurrentLinkedQueue")
     42   static <K, V> QueuingRemovalListener<K, V> queuingRemovalListener() {
     43     return new QueuingRemovalListener<K,V>();
     44   }
     45 
     46   /**
     47    * Type-inferring factory method for creating a {@link CountingRemovalListener}.
     48    */
     49   static <K, V> CountingRemovalListener<K, V> countingRemovalListener() {
     50     return new CountingRemovalListener<K,V>();
     51   }
     52 
     53   /**
     54    * {@link RemovalListener} that adds all {@link RemovalNotification} objects to a queue.
     55    */
     56   @GwtIncompatible("ConcurrentLinkedQueue")
     57   static class QueuingRemovalListener<K, V>
     58       extends ConcurrentLinkedQueue<RemovalNotification<K, V>> implements RemovalListener<K, V> {
     59 
     60     @Override
     61     public void onRemoval(RemovalNotification<K, V> notification) {
     62       add(notification);
     63     }
     64   }
     65 
     66   /**
     67    * {@link RemovalListener} that counts each {@link RemovalNotification} it receives, and provides
     68    * access to the most-recently received one.
     69    */
     70   static class CountingRemovalListener<K, V> implements RemovalListener<K, V> {
     71     private final AtomicInteger count = new AtomicInteger();
     72     private volatile RemovalNotification<K, V> lastNotification;
     73 
     74     @Override
     75     public void onRemoval(RemovalNotification<K, V> notification) {
     76       count.incrementAndGet();
     77       lastNotification = notification;
     78     }
     79 
     80     public int getCount() {
     81       return count.get();
     82     }
     83 
     84     public K getLastEvictedKey() {
     85       return lastNotification.getKey();
     86     }
     87 
     88     public V getLastEvictedValue() {
     89       return lastNotification.getValue();
     90     }
     91 
     92     public RemovalNotification<K, V> getLastNotification() {
     93       return lastNotification;
     94     }
     95   }
     96 
     97   /**
     98    * No-op {@link RemovalListener}.
     99    */
    100   static class NullRemovalListener<K, V> implements RemovalListener<K, V> {
    101     @Override
    102     public void onRemoval(RemovalNotification<K, V> notification) {}
    103   }
    104 }
    105