Last active
June 5, 2023 16:58
-
-
Save fappel/8bcb2aea4b39ff9cfb6e to your computer and use it in GitHub Desktop.
JUnit 4 TestRule to run a test repeatedly for a specified amount of repititions
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
import java.lang.annotation.Retention; | |
import java.lang.annotation.RetentionPolicy; | |
import java.lang.annotation.Target; | |
@Retention( RetentionPolicy.RUNTIME ) | |
@Target( { | |
java.lang.annotation.ElementType.METHOD | |
} ) | |
public @interface Repeat { | |
public abstract int times(); | |
} |
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
import org.junit.rules.TestRule; | |
import org.junit.runner.Description; | |
import org.junit.runners.model.Statement; | |
public class RepeatRule implements TestRule { | |
private static class RepeatStatement extends Statement { | |
private final int times; | |
private final Statement statement; | |
private RepeatStatement( int times, Statement statement ) { | |
this.times = times; | |
this.statement = statement; | |
} | |
@Override | |
public void evaluate() throws Throwable { | |
for( int i = 0; i < times; i++ ) { | |
statement.evaluate(); | |
} | |
} | |
} | |
@Override | |
public Statement apply( Statement statement, Description description ) { | |
Statement result = statement; | |
Repeat repeat = description.getAnnotation( Repeat.class ); | |
if( repeat != null ) { | |
int times = repeat.times(); | |
result = new RepeatStatement( times, statement ); | |
} | |
return result; | |
} | |
} |
Thanks for sharing @fappel. I've documented and tidied it up as well as incorporated @bazi's comment.
See my fork https://gist.github.com/coolersport/b0c26c601c7739d1cbf5f6ded8210bae
Nice work 👍 thank you @fappel.
It could be interesting to add a random wait option between executions with a default value set to 0 ms.
Here is a proposal below.
https://gist.github.com/cbismuth/5f5315ccd8a8f4b1e4a129c40ee5edd3
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
How many times will
Before
andAfter
methods be called?