org.browsermob.proxy.jetty.util.LifeCycle Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of browsermob-proxy Show documentation
Show all versions of browsermob-proxy Show documentation
A programmatic HTTP/S designed for performance and functional testing
The newest version!
// ========================================================================
// $Id: LifeCycle.java,v 1.5 2004/05/09 20:32:49 gregwilkins Exp $
// Copyright 1999-2004 Mort Bay Consulting Pty. Ltd.
// ------------------------------------------------------------------------
// 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 org.browsermob.proxy.jetty.util;/* ------------------------------------------------------------ */
/** A component LifeCycle.
* Represents the life cycle interface for an abstract
* software component.
*
* @version $Id: LifeCycle.java,v 1.5 2004/05/09 20:32:49 gregwilkins Exp $
* @author Greg Wilkins (gregw)
*/
public interface LifeCycle
{
/* ------------------------------------------------------------ */
/** Start the LifeCycle.
* @exception Exception An arbitrary exception may be thrown.
*/
public void start()
throws Exception;
/* ------------------------------------------------------------ */
/** Stop the LifeCycle.
* The LifeCycle may wait for current activities to complete
* normally, but it can be interrupted.
* @exception InterruptedException Stopping a lifecycle is rarely atomic
* and may be interrupted by another thread. If this happens
* InterruptedException is throw and the component will be in an
* indeterminant state and should probably be discarded.
*/
public void stop()
throws InterruptedException;
/* ------------------------------------------------------------ */
/**
* @return True if the LifeCycle has been started.
*/
public boolean isStarted();
}