All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.google.testing.threadtester.Stepper Maven / Gradle / Ivy

/*
 * Copyright 2009 Weaver authors
 *
 * 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 com.google.testing.threadtester;


/**
 * Allows an instrumented class to be stepped through line by line. A Stepper is
 * created by calling {@link ObjectInstrumentation#step}. Typical useage is:
 * 
 *
 *  Breakpoint bp = ...
 *  bp.await();
 *  Stepper stepper = instrumentedObject.step(bp);
 *  while(stepper.hasNext()) {
 *    stepper.step();
 *  }
 *  stepper.resume();
 * 
* * @author [email protected] (Alasdair Mackintosh) */ public interface Stepper { /** * Returns true if this stepper can be stepped again. Typically, this method * will return false once the Stepper has advanced to the end of an * instrumented method, and is about to return into non-instrumented code. */ boolean hasNext(); /** * Advances a stepper a single line. If the stepper cannot be stepped again * (i.e. if {@link #hasNext} returns false) then this method is equivalent to * calling {@link #resume}. */ void step() throws TestTimeoutException; /** * Causes the Stepper's thread to continue running. Note that this method * should only be used when {@link #hasNext} has returned false. Otherwise, * use {@link #step}. * * @see Breakpoint#resume */ void resume() throws TestTimeoutException; }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy