Migrate to JUnit5

This commit is contained in:
Artur Mogozov
2017-12-31 16:29:48 +09:00
parent a20e54d0a7
commit 6694d742a3
408 changed files with 2656 additions and 2165 deletions

View File

@ -22,7 +22,7 @@
*/
package com.iluwatar.interpreter;
import org.junit.Test;
import org.junit.jupiter.api.Test;
/**
*

View File

@ -22,15 +22,19 @@
*/
package com.iluwatar.interpreter;
import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertNotNull;
import org.junit.jupiter.api.Disabled;
import org.junit.jupiter.params.ParameterizedTest;
import org.junit.jupiter.params.provider.Arguments;
import org.junit.jupiter.params.provider.MethodSource;
import java.util.ArrayList;
import java.util.List;
import java.util.function.BiFunction;
import java.util.function.IntBinaryOperator;
import java.util.stream.Stream;
import org.junit.Test;
import static org.junit.jupiter.api.Assertions.assertEquals;
import static org.junit.jupiter.api.Assertions.assertNotNull;
/**
* Date: 12/14/15 - 11:48 AM
@ -45,37 +49,22 @@ public abstract class ExpressionTest<E extends Expression> {
* Generate inputs ranging from -10 to 10 for both input params and calculate the expected result
*
* @param resultCalc The function used to calculate the expected result
* @return A data set with test entries
* @return A stream with test entries
*/
static List<Object[]> prepareParameters(final IntBinaryOperator resultCalc) {
final List<Object[]> testData = new ArrayList<>();
static Stream<Arguments> prepareParameters(final IntBinaryOperator resultCalc) {
final List<Arguments> testData = new ArrayList<>();
for (int i = -10; i < 10; i++) {
for (int j = -10; j < 10; j++) {
testData.add(new Object[]{
new NumberExpression(i),
new NumberExpression(j),
resultCalc.applyAsInt(i, j)
});
testData.add(Arguments.of(
new NumberExpression(i),
new NumberExpression(j),
resultCalc.applyAsInt(i, j)
));
}
}
return testData;
return testData.stream();
}
/**
* The input used as first parameter during the test
*/
private final NumberExpression first;
/**
* The input used as second parameter during the test
*/
private final NumberExpression second;
/**
* The expected result of the calculation, taking the first and second parameter in account
*/
private final int result;
/**
* The expected {@link E#toString()} response
*/
@ -89,47 +78,34 @@ public abstract class ExpressionTest<E extends Expression> {
/**
* Create a new test instance with the given parameters and expected results
*
* @param first The input used as first parameter during the test
* @param second The input used as second parameter during the test
* @param result The expected result of the tested expression
* @param expectedToString The expected {@link E#toString()} response
* @param factory Factory, used to create a new test object instance
*/
ExpressionTest(final NumberExpression first, final NumberExpression second, final int result,
final String expectedToString, final BiFunction<NumberExpression, NumberExpression, E> factory) {
this.first = first;
this.second = second;
this.result = result;
ExpressionTest(final String expectedToString,
final BiFunction<NumberExpression, NumberExpression, E> factory
) {
this.expectedToString = expectedToString;
this.factory = factory;
}
/**
* Get the first parameter
*
* @return The first parameter
*/
final NumberExpression getFirst() {
return this.first;
}
/**
* Verify if the expression calculates the correct result when calling {@link E#interpret()}
*/
@Test
public void testInterpret() {
final E expression = this.factory.apply(this.first, this.second);
@ParameterizedTest
@MethodSource("expressionProvider")
public void testInterpret(NumberExpression first, NumberExpression second, int result) {
final E expression = factory.apply(first, second);
assertNotNull(expression);
assertEquals(this.result, expression.interpret());
assertEquals(result, expression.interpret());
}
/**
* Verify if the expression has the expected {@link E#toString()} value
*/
@Test
public void testToString() {
final E expression = this.factory.apply(this.first, this.second);
@ParameterizedTest
@MethodSource("expressionProvider")
public void testToString(NumberExpression first, NumberExpression second) {
final E expression = factory.apply(first, second);
assertNotNull(expression);
assertEquals(expectedToString, expression.toString());
}

View File

@ -22,18 +22,15 @@
*/
package com.iluwatar.interpreter;
import org.junit.runner.RunWith;
import org.junit.runners.Parameterized;
import org.junit.runners.Parameterized.Parameters;
import org.junit.jupiter.params.provider.Arguments;
import java.util.List;
import java.util.stream.Stream;
/**
* Date: 12/14/15 - 12:08 PM
*
* @author Jeroen Meulemeester
*/
@RunWith(Parameterized.class)
public class MinusExpressionTest extends ExpressionTest<MinusExpression> {
/**
@ -41,20 +38,15 @@ public class MinusExpressionTest extends ExpressionTest<MinusExpression> {
*
* @return The list of parameters used during this test
*/
@Parameters
public static List<Object[]> data() {
public static Stream<Arguments> expressionProvider() {
return prepareParameters((f, s) -> f - s);
}
/**
* Create a new test instance using the given test parameters and expected result
*
* @param first The first expression parameter
* @param second The second expression parameter
* @param result The expected result
*/
public MinusExpressionTest(final NumberExpression first, final NumberExpression second, final int result) {
super(first, second, result, "-", MinusExpression::new);
public MinusExpressionTest() {
super("-", MinusExpression::new);
}
}

View File

@ -22,18 +22,15 @@
*/
package com.iluwatar.interpreter;
import org.junit.runner.RunWith;
import org.junit.runners.Parameterized;
import org.junit.runners.Parameterized.Parameters;
import org.junit.jupiter.params.provider.Arguments;
import java.util.List;
import java.util.stream.Stream;
/**
* Date: 12/14/15 - 12:08 PM
*
* @author Jeroen Meulemeester
*/
@RunWith(Parameterized.class)
public class MultiplyExpressionTest extends ExpressionTest<MultiplyExpression> {
/**
@ -41,20 +38,16 @@ public class MultiplyExpressionTest extends ExpressionTest<MultiplyExpression> {
*
* @return The list of parameters used during this test
*/
@Parameters
public static List<Object[]> data() {
public static Stream<Arguments> expressionProvider() {
return prepareParameters((f, s) -> f * s);
}
/**
* Create a new test instance using the given test parameters and expected result
*
* @param first The first expression parameter
* @param second The second expression parameter
* @param result The expected result
*/
public MultiplyExpressionTest(final NumberExpression first, final NumberExpression second, final int result) {
super(first, second, result, "*", MultiplyExpression::new);
public MultiplyExpressionTest() {
super("*", MultiplyExpression::new);
}
}

View File

@ -22,21 +22,19 @@
*/
package com.iluwatar.interpreter;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.junit.runners.Parameterized;
import org.junit.runners.Parameterized.Parameters;
import org.junit.jupiter.params.ParameterizedTest;
import org.junit.jupiter.params.provider.Arguments;
import org.junit.jupiter.params.provider.MethodSource;
import java.util.List;
import java.util.stream.Stream;
import static org.junit.Assert.assertEquals;
import static org.junit.jupiter.api.Assertions.assertEquals;
/**
* Date: 12/14/15 - 12:08 PM
*
* @author Jeroen Meulemeester
*/
@RunWith(Parameterized.class)
public class NumberExpressionTest extends ExpressionTest<NumberExpression> {
/**
@ -44,30 +42,26 @@ public class NumberExpressionTest extends ExpressionTest<NumberExpression> {
*
* @return The list of parameters used during this test
*/
@Parameters
public static List<Object[]> data() {
public static Stream<Arguments> expressionProvider() {
return prepareParameters((f, s) -> f);
}
/**
* Create a new test instance using the given test parameters and expected result
*
* @param first The first expression parameter
* @param second The second expression parameter
* @param result The expected result
*/
public NumberExpressionTest(final NumberExpression first, final NumberExpression second, final int result) {
super(first, second, result, "number", (f, s) -> f);
public NumberExpressionTest() {
super("number", (f, s) -> f);
}
/**
* Verify if the {@link NumberExpression#NumberExpression(String)} constructor works as expected
*/
@Test
public void testFromString() throws Exception {
final int expectedValue = getFirst().interpret();
final String testStingValue = String.valueOf(expectedValue);
final NumberExpression numberExpression = new NumberExpression(testStingValue);
@ParameterizedTest
@MethodSource("expressionProvider")
public void testFromString(NumberExpression first) throws Exception {
final int expectedValue = first.interpret();
final String testStringValue = String.valueOf(expectedValue);
final NumberExpression numberExpression = new NumberExpression(testStringValue);
assertEquals(expectedValue, numberExpression.interpret());
}

View File

@ -22,18 +22,15 @@
*/
package com.iluwatar.interpreter;
import org.junit.runner.RunWith;
import org.junit.runners.Parameterized;
import org.junit.runners.Parameterized.Parameters;
import org.junit.jupiter.params.provider.Arguments;
import java.util.List;
import java.util.stream.Stream;
/**
* Date: 12/14/15 - 12:08 PM
*
* @author Jeroen Meulemeester
*/
@RunWith(Parameterized.class)
public class PlusExpressionTest extends ExpressionTest<PlusExpression> {
/**
@ -41,20 +38,15 @@ public class PlusExpressionTest extends ExpressionTest<PlusExpression> {
*
* @return The list of parameters used during this test
*/
@Parameters
public static List<Object[]> data() {
public static Stream<Arguments> expressionProvider() {
return prepareParameters((f, s) -> f + s);
}
/**
* Create a new test instance using the given test parameters and expected result
*
* @param first The first expression parameter
* @param second The second expression parameter
* @param result The expected result
*/
public PlusExpressionTest(final NumberExpression first, final NumberExpression second, final int result) {
super(first, second, result, "+", PlusExpression::new);
public PlusExpressionTest() {
super("+", PlusExpression::new);
}
}