org.hibernate.testing.byteman.BytemanHelper Maven / Gradle / Ivy
/*
* SPDX-License-Identifier: LGPL-2.1-or-later
* Copyright Red Hat Inc. and Hibernate Authors
*/
package org.hibernate.testing.byteman;
import java.util.concurrent.atomic.AtomicInteger;
import org.jboss.byteman.rule.Rule;
import org.jboss.byteman.rule.helper.Helper;
import org.jboss.logging.Logger;
/**
* @author Sanne Grinovero (C) 2011 Red Hat Inc.
* @author Hardy Ferentschik
*/
public class BytemanHelper extends Helper {
private static final Logger log = Logger.getLogger( BytemanHelper.class );
public static final AtomicInteger COUNTER = new AtomicInteger();
protected BytemanHelper(Rule rule) {
super( rule );
}
public void sleepASecond() {
try {
log.info( "Byteman rule triggered: sleeping a second" );
Thread.sleep( 1000 );
}
catch ( InterruptedException e ) {
Thread.currentThread().interrupt();
log.error( "unexpected interruption", e );
}
}
public void throwNPE(String message) {
//Needed because of Bug BYTEMAN-173: can't simply inject a NPE from the rule
throw new NullPointerException( message );
}
public void countInvocation() {
log.debug( "Increment call count" );
COUNTER.incrementAndGet();
}
public static int getAndResetInvocationCount() {
return COUNTER.getAndSet( 0 );
}
}