Coverage Report - org.perfidix.socketadapter.IUpdater
 
Classes in this File Line Coverage Branch Coverage Complexity
IUpdater
N/A
N/A
1
 
 1  
 /**
 2  
  * Copyright (c) 2012, University of Konstanz, Distributed Systems Group
 3  
  * All rights reserved.
 4  
  * 
 5  
  * Redistribution and use in source and binary forms, with or without
 6  
  * modification, are permitted provided that the following conditions are met:
 7  
  * * Redistributions of source code must retain the above copyright
 8  
  * notice, this list of conditions and the following disclaimer.
 9  
  * * Redistributions in binary form must reproduce the above copyright
 10  
  * notice, this list of conditions and the following disclaimer in the
 11  
  * documentation and/or other materials provided with the distribution.
 12  
  * * Neither the name of the University of Konstanz nor the
 13  
  * names of its contributors may be used to endorse or promote products
 14  
  * derived from this software without specific prior written permission.
 15  
  * 
 16  
  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
 17  
  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
 18  
  * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
 19  
  * DISCLAIMED. IN NO EVENT SHALL <COPYRIGHT HOLDER> BE LIABLE FOR ANY
 20  
  * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
 21  
  * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
 22  
  * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
 23  
  * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
 24  
  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
 25  
  * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
 26  
  */
 27  
 package org.perfidix.socketadapter;
 28  
 
 29  
 import java.util.Map;
 30  
 
 31  
 import org.perfidix.element.BenchmarkMethod;
 32  
 import org.perfidix.exceptions.SocketViewException;
 33  
 import org.perfidix.meter.AbstractMeter;
 34  
 
 35  
 /**
 36  
  * This class creates the connection to the eclipse view via {@link SocketViewStub}. It contains the methods
 37  
  * which update the view to
 38  
  * inform about the bench process progress.
 39  
  * 
 40  
  * @author Nuray Guerler, University of Konstanz
 41  
  * 
 42  
  */
 43  
 public interface IUpdater {
 44  
 
 45  
     /**
 46  
      * This method initializes the values of the eclipse view and resets the
 47  
      * progress bar.
 48  
      * 
 49  
      * @param mapping
 50  
      *            a mapping with all methods to benchmark and the related runs
 51  
      * @throws SocketViewException
 52  
      */
 53  
     public boolean initProgressView(final Map<BenchmarkMethod, Integer> mapping) throws SocketViewException;
 54  
 
 55  
     /**
 56  
      * This method notifies the eclipse view which element is currently benched.
 57  
      * 
 58  
      * @param meter
 59  
      *            The current meter.
 60  
      * @param name
 61  
      *            This param represents the java element which is currently
 62  
      *            benched and which is fully qualified.
 63  
      * @throws SocketViewException
 64  
      */
 65  
     public boolean updateCurrentElement(final AbstractMeter meter, final String name)
 66  
         throws SocketViewException;
 67  
 
 68  
     /**
 69  
      * This method informs the view that an error occurred while benching the
 70  
      * current element.
 71  
      * 
 72  
      * @param name
 73  
      *            Element represents the java element which has not been
 74  
      *            executed successfully.
 75  
      * @param exception
 76  
      *            The exception caused by the element.
 77  
      * @throws SocketViewException
 78  
      */
 79  
     public boolean updateErrorInElement(final String name, final Exception exception)
 80  
         throws SocketViewException;
 81  
 
 82  
     /**
 83  
      * This method notifies the view that all benches have been executed and the
 84  
      * bench progress is finished.
 85  
      * 
 86  
      * @throws SocketViewException
 87  
      */
 88  
     public void finished() throws SocketViewException;
 89  
 
 90  
 }