diff --git a/app/src/sharedTest/java/org/oppia/android/app/customview/interaction/MathExpressionInteractionsViewTest.kt b/app/src/sharedTest/java/org/oppia/android/app/customview/interaction/MathExpressionInteractionsViewTest.kt index 77e3a425a9e..6e808bb6414 100644 --- a/app/src/sharedTest/java/org/oppia/android/app/customview/interaction/MathExpressionInteractionsViewTest.kt +++ b/app/src/sharedTest/java/org/oppia/android/app/customview/interaction/MathExpressionInteractionsViewTest.kt @@ -83,7 +83,6 @@ import org.oppia.android.testing.junit.InitializeDefaultLocaleRule import org.oppia.android.testing.junit.OppiaParameterizedTestRunner import org.oppia.android.testing.junit.OppiaParameterizedTestRunner.Iteration import org.oppia.android.testing.junit.OppiaParameterizedTestRunner.Parameter -import org.oppia.android.testing.junit.OppiaParameterizedTestRunner.RunParameterized import org.oppia.android.testing.junit.OppiaParameterizedTestRunner.SelectRunnerPlatform import org.oppia.android.testing.junit.ParameterizedAutoAndroidTestRunner import org.oppia.android.testing.robolectric.RobolectricModule @@ -169,15 +168,13 @@ class MathExpressionInteractionsViewTest { } @Test - @RunParameterized( - Iteration( - "numeric_exp", - "type=NUMERIC_EXPRESSION", - "expHintText=Type an expression here, using only numbers." - ), - Iteration("alg_exp", "type=ALGEBRAIC_EXPRESSION", "expHintText=Type an expression here."), - Iteration("math_equation", "type=MATH_EQUATION", "expHintText=Type an equation here.") + @Iteration( + "numeric_exp", + "type=NUMERIC_EXPRESSION", + "expHintText=Type an expression here, using only numbers." ) + @Iteration("alg_exp", "type=ALGEBRAIC_EXPRESSION", "expHintText=Type an expression here.") + @Iteration("math_equation", "type=MATH_EQUATION", "expHintText=Type an equation here.") fun testView_allInteractions_withoutPlaceholder_hasCorrectDefaultHintText() { launch(interactionType = MathInteractionType.valueOf(type)).use { testCoroutineDispatchers.runCurrent() @@ -199,10 +196,8 @@ class MathExpressionInteractionsViewTest { } @Test - @RunParameterized( - Iteration("alg_exp", "type=ALGEBRAIC_EXPRESSION", "expHintText=Type an expression here."), - Iteration("math_equation", "type=MATH_EQUATION", "expHintText=Type an equation here.") - ) + @Iteration("alg_exp", "type=ALGEBRAIC_EXPRESSION", "expHintText=Type an expression here.") + @Iteration("math_equation", "type=MATH_EQUATION", "expHintText=Type an equation here.") fun testView_algebraicInteractions_withUnicodePlaceholder_hasDefaultHintText() { val interaction = createInteractionWithPlaceholder("test placeholder") launch(interactionType = MathInteractionType.valueOf(type), interaction).use { @@ -226,10 +221,8 @@ class MathExpressionInteractionsViewTest { } @Test - @RunParameterized( - Iteration("alg_exp", "type=ALGEBRAIC_EXPRESSION", "expHintText=Type an expression here."), - Iteration("math_equation", "type=MATH_EQUATION", "expHintText=Type an equation here.") - ) + @Iteration("alg_exp", "type=ALGEBRAIC_EXPRESSION", "expHintText=Type an expression here.") + @Iteration("math_equation", "type=MATH_EQUATION", "expHintText=Type an equation here.") fun testView_algebraicInteractions_withNestedUnicodePlaceholder_hasDefaultHintText() { val interaction = createInteractionWithNestedPlaceholder("test placeholder") launch(interactionType = MathInteractionType.valueOf(type), interaction).use { @@ -355,32 +348,30 @@ class MathExpressionInteractionsViewTest { } @Test - @RunParameterized( - Iteration("numeric_-1", "type=NUMERIC_EXPRESSION", "text= - 1 "), - Iteration("numeric_1+2", "type=NUMERIC_EXPRESSION", "text=1 + 2"), - Iteration("numeric_1-2", "type=NUMERIC_EXPRESSION", "text=1 − 2"), - Iteration("numeric_1*2", "type=NUMERIC_EXPRESSION", "text=1 × 2"), - Iteration("numeric_1/2", "type=NUMERIC_EXPRESSION", "text=1 ÷ 2"), - Iteration("numeric_long_exp", "type=NUMERIC_EXPRESSION", "text=3*2-3+4^3*8/3*2+7"), - Iteration("numeric_invalid_exp_extra_error", "type=NUMERIC_EXPRESSION", "text=3/0"), - Iteration("numeric_invalid_exp_syntax_error", "type=NUMERIC_EXPRESSION", "text=3!"), - Iteration("algebraic_-1", "type=ALGEBRAIC_EXPRESSION", "text= - x "), - Iteration("algebraic_1+2", "type=ALGEBRAIC_EXPRESSION", "text=x + 2"), - Iteration("algebraic_1-2", "type=ALGEBRAIC_EXPRESSION", "text=x − 2"), - Iteration("algebraic_1*2", "type=ALGEBRAIC_EXPRESSION", "text=x × 2"), - Iteration("algebraic_1/2", "type=ALGEBRAIC_EXPRESSION", "text=x c 2"), - Iteration("algebraic_long_exp", "type=ALGEBRAIC_EXPRESSION", "text=12x^2y^2-(yz^2+yzx)-731z"), - Iteration("algebraic_invalid_exp_extra_error", "type=ALGEBRAIC_EXPRESSION", "text=2^x"), - Iteration("algebraic_invalid_exp_syntax_error", "type=ALGEBRAIC_EXPRESSION", "text=2**x"), - Iteration("math_eq_-1", "type=MATH_EQUATION", "text= y= - x "), - Iteration("math_eq_1+2", "type=MATH_EQUATION", "text=y = x + 2"), - Iteration("math_eq_1-2", "type=MATH_EQUATION", "text=y = x − 2"), - Iteration("math_eq_1*2", "type=MATH_EQUATION", "text=y = x × 2"), - Iteration("math_eq_1/2", "type=MATH_EQUATION", "text=y = x ÷ 2"), - Iteration("math_eq_long_exp", "type=MATH_EQUATION", "text=(x^2-1)/(x+1)=y/2"), - Iteration("math_eq_invalid_exp_extra_error", "type=MATH_EQUATION", "text=y=+x"), - Iteration("math_eq_invalid_exp_syntax_error", "type=MATH_EQUATION", "text=y=x=z") - ) + @Iteration("numeric_-1", "type=NUMERIC_EXPRESSION", "text= - 1 ") + @Iteration("numeric_1+2", "type=NUMERIC_EXPRESSION", "text=1 + 2") + @Iteration("numeric_1-2", "type=NUMERIC_EXPRESSION", "text=1 − 2") + @Iteration("numeric_1*2", "type=NUMERIC_EXPRESSION", "text=1 × 2") + @Iteration("numeric_1/2", "type=NUMERIC_EXPRESSION", "text=1 ÷ 2") + @Iteration("numeric_long_exp", "type=NUMERIC_EXPRESSION", "text=3*2-3+4^3*8/3*2+7") + @Iteration("numeric_invalid_exp_extra_error", "type=NUMERIC_EXPRESSION", "text=3/0") + @Iteration("numeric_invalid_exp_syntax_error", "type=NUMERIC_EXPRESSION", "text=3!") + @Iteration("algebraic_-1", "type=ALGEBRAIC_EXPRESSION", "text= - x ") + @Iteration("algebraic_1+2", "type=ALGEBRAIC_EXPRESSION", "text=x + 2") + @Iteration("algebraic_1-2", "type=ALGEBRAIC_EXPRESSION", "text=x − 2") + @Iteration("algebraic_1*2", "type=ALGEBRAIC_EXPRESSION", "text=x × 2") + @Iteration("algebraic_1/2", "type=ALGEBRAIC_EXPRESSION", "text=x c 2") + @Iteration("algebraic_long_exp", "type=ALGEBRAIC_EXPRESSION", "text=12x^2y^2-(yz^2+yzx)-731z") + @Iteration("algebraic_invalid_exp_extra_error", "type=ALGEBRAIC_EXPRESSION", "text=2^x") + @Iteration("algebraic_invalid_exp_syntax_error", "type=ALGEBRAIC_EXPRESSION", "text=2**x") + @Iteration("math_eq_-1", "type=MATH_EQUATION", "text= y= - x ") + @Iteration("math_eq_1+2", "type=MATH_EQUATION", "text=y = x + 2") + @Iteration("math_eq_1-2", "type=MATH_EQUATION", "text=y = x − 2") + @Iteration("math_eq_1*2", "type=MATH_EQUATION", "text=y = x × 2") + @Iteration("math_eq_1/2", "type=MATH_EQUATION", "text=y = x ÷ 2") + @Iteration("math_eq_long_exp", "type=MATH_EQUATION", "text=(x^2-1)/(x+1)=y/2") + @Iteration("math_eq_invalid_exp_extra_error", "type=MATH_EQUATION", "text=y=+x") + @Iteration("math_eq_invalid_exp_syntax_error", "type=MATH_EQUATION", "text=y=x=z") fun testView_allInteractions_differentAnswers_producesAnswerWithOriginalMathExpression() { val interactionType = MathInteractionType.valueOf(type) val interaction = createInteraction() @@ -399,40 +390,38 @@ class MathExpressionInteractionsViewTest { } @Test - @RunParameterized( - Iteration("numeric_-1", "type=NUMERIC_EXPRESSION", "text= - 1 ", "expLatex=-1"), - Iteration("numeric_1+2", "type=NUMERIC_EXPRESSION", "text=1 + 2", "expLatex=1 + 2"), - Iteration("numeric_1-2", "type=NUMERIC_EXPRESSION", "text=1 − 2", "expLatex=1 - 2"), - Iteration("numeric_1*2", "type=NUMERIC_EXPRESSION", "text=1 × 2", "expLatex=1 \\times 2"), - Iteration("numeric_1/2", "type=NUMERIC_EXPRESSION", "text=1 ÷ 2", "expLatex=1 \\div 2"), - Iteration( - "numeric_long_exp", - "type=NUMERIC_EXPRESSION", - "text=3*2-3+4^3*8/3*2+7", - "expLatex=3 \\times 2 - 3 + 4 ^ {3} \\times 8 \\div 3 \\times 2 + 7" - ), - Iteration("algebraic_-x", "type=ALGEBRAIC_EXPRESSION", "text= - x ", "expLatex=-x"), - Iteration("algebraic_x+2", "type=ALGEBRAIC_EXPRESSION", "text=x + 2", "expLatex=x + 2"), - Iteration("algebraic_x-2", "type=ALGEBRAIC_EXPRESSION", "text=x − 2", "expLatex=x - 2"), - Iteration("algebraic_x*2", "type=ALGEBRAIC_EXPRESSION", "text=x × 2", "expLatex=x \\times 2"), - Iteration("algebraic_x/2", "type=ALGEBRAIC_EXPRESSION", "text=x ÷ 2", "expLatex=x \\div 2"), - Iteration( - "algebraic_long_exp", - "type=ALGEBRAIC_EXPRESSION", - "text=12x^2y^2-(yz^2+yzx)-731z", - "expLatex=12x ^ {2}y ^ {2} - (yz ^ {2} + yzx) - 731z" - ), - Iteration("math_eq_-x", "type=MATH_EQUATION", "text= y= - x ", "expLatex=y = -x"), - Iteration("math_eq_x+2", "type=MATH_EQUATION", "text=y = x + 2", "expLatex=y = x + 2"), - Iteration("math_eq_x-2", "type=MATH_EQUATION", "text=y = x − 2", "expLatex=y = x - 2"), - Iteration("math_eq_x*2", "type=MATH_EQUATION", "text=y = x × 2", "expLatex=y = x \\times 2"), - Iteration("math_eq_x/2", "type=MATH_EQUATION", "text=y = x ÷ 2", "expLatex=y = x \\div 2"), - Iteration( - "math_eq_long_exp", - "type=MATH_EQUATION", - "text=(x^2-1)/(x+1)=y/2", - "expLatex=(x ^ {2} - 1) \\div (x + 1) = y \\div 2" - ) + @Iteration("numeric_-1", "type=NUMERIC_EXPRESSION", "text= - 1 ", "expLatex=-1") + @Iteration("numeric_1+2", "type=NUMERIC_EXPRESSION", "text=1 + 2", "expLatex=1 + 2") + @Iteration("numeric_1-2", "type=NUMERIC_EXPRESSION", "text=1 − 2", "expLatex=1 - 2") + @Iteration("numeric_1*2", "type=NUMERIC_EXPRESSION", "text=1 × 2", "expLatex=1 \\times 2") + @Iteration("numeric_1/2", "type=NUMERIC_EXPRESSION", "text=1 ÷ 2", "expLatex=1 \\div 2") + @Iteration( + "numeric_long_exp", + "type=NUMERIC_EXPRESSION", + "text=3*2-3+4^3*8/3*2+7", + "expLatex=3 \\times 2 - 3 + 4 ^ {3} \\times 8 \\div 3 \\times 2 + 7" + ) + @Iteration("algebraic_-x", "type=ALGEBRAIC_EXPRESSION", "text= - x ", "expLatex=-x") + @Iteration("algebraic_x+2", "type=ALGEBRAIC_EXPRESSION", "text=x + 2", "expLatex=x + 2") + @Iteration("algebraic_x-2", "type=ALGEBRAIC_EXPRESSION", "text=x − 2", "expLatex=x - 2") + @Iteration("algebraic_x*2", "type=ALGEBRAIC_EXPRESSION", "text=x × 2", "expLatex=x \\times 2") + @Iteration("algebraic_x/2", "type=ALGEBRAIC_EXPRESSION", "text=x ÷ 2", "expLatex=x \\div 2") + @Iteration( + "algebraic_long_exp", + "type=ALGEBRAIC_EXPRESSION", + "text=12x^2y^2-(yz^2+yzx)-731z", + "expLatex=12x ^ {2}y ^ {2} - (yz ^ {2} + yzx) - 731z" + ) + @Iteration("math_eq_-x", "type=MATH_EQUATION", "text= y= - x ", "expLatex=y = -x") + @Iteration("math_eq_x+2", "type=MATH_EQUATION", "text=y = x + 2", "expLatex=y = x + 2") + @Iteration("math_eq_x-2", "type=MATH_EQUATION", "text=y = x − 2", "expLatex=y = x - 2") + @Iteration("math_eq_x*2", "type=MATH_EQUATION", "text=y = x × 2", "expLatex=y = x \\times 2") + @Iteration("math_eq_x/2", "type=MATH_EQUATION", "text=y = x ÷ 2", "expLatex=y = x \\div 2") + @Iteration( + "math_eq_long_exp", + "type=MATH_EQUATION", + "text=(x^2-1)/(x+1)=y/2", + "expLatex=(x ^ {2} - 1) \\div (x + 1) = y \\div 2" ) fun testView_allInteractions_differentAnswers_validAnswers_producesAnswerWithLatexHtml() { val interactionType = MathInteractionType.valueOf(type) @@ -454,37 +443,35 @@ class MathExpressionInteractionsViewTest { } @Test - @RunParameterized( - Iteration("numeric_1/2", "type=NUMERIC_EXPRESSION", "text=1/2", "expLatex=1 \\div 2"), - Iteration( - "numeric_1/2/3", "type=NUMERIC_EXPRESSION", "text=1/2/3", "expLatex=1 \\div 2 \\div 3" - ), - Iteration( - "numeric_1/(2+3)", "type=NUMERIC_EXPRESSION", "text=1/(2+3)", "expLatex=1 \\div (2 + 3)" - ), - Iteration("numeric_1/2+3", "type=NUMERIC_EXPRESSION", "text=1/2+3", "expLatex=1 \\div 2 + 3"), - Iteration("algebraic_x/2", "type=ALGEBRAIC_EXPRESSION", "text=x/2", "expLatex=x \\div 2"), - Iteration( - "algebraic_x/y/z", "type=ALGEBRAIC_EXPRESSION", "text=x/y/z", "expLatex=x \\div y \\div z" - ), - Iteration( - "algebraic_x/(2+y)", "type=ALGEBRAIC_EXPRESSION", "text=x/(2+y)", "expLatex=x \\div (2 + y)" - ), - Iteration( - "algebraic_x/2+y", "type=ALGEBRAIC_EXPRESSION", "text=x/2+y", "expLatex=x \\div 2 + y" - ), - Iteration("math_eq_x/2", "type=MATH_EQUATION", "text=y=x/2", "expLatex=y = x \\div 2"), - Iteration( - "math_eq_x/y/z", - "type=MATH_EQUATION", - "text=y/2=x/y/z", - "expLatex=y \\div 2 = x \\div y \\div z" - ), - Iteration( - "math_eq_x/(2+y)", "type=MATH_EQUATION", "text=x/(2+y)=y", "expLatex=x \\div (2 + y) = y" - ), - Iteration("math_eq_x/2+y", "type=MATH_EQUATION", "text=x/2+y=y", "expLatex=x \\div 2 + y = y") + @Iteration("numeric_1/2", "type=NUMERIC_EXPRESSION", "text=1/2", "expLatex=1 \\div 2") + @Iteration( + "numeric_1/2/3", "type=NUMERIC_EXPRESSION", "text=1/2/3", "expLatex=1 \\div 2 \\div 3" + ) + @Iteration( + "numeric_1/(2+3)", "type=NUMERIC_EXPRESSION", "text=1/(2+3)", "expLatex=1 \\div (2 + 3)" + ) + @Iteration("numeric_1/2+3", "type=NUMERIC_EXPRESSION", "text=1/2+3", "expLatex=1 \\div 2 + 3") + @Iteration("algebraic_x/2", "type=ALGEBRAIC_EXPRESSION", "text=x/2", "expLatex=x \\div 2") + @Iteration( + "algebraic_x/y/z", "type=ALGEBRAIC_EXPRESSION", "text=x/y/z", "expLatex=x \\div y \\div z" ) + @Iteration( + "algebraic_x/(2+y)", "type=ALGEBRAIC_EXPRESSION", "text=x/(2+y)", "expLatex=x \\div (2 + y)" + ) + @Iteration( + "algebraic_x/2+y", "type=ALGEBRAIC_EXPRESSION", "text=x/2+y", "expLatex=x \\div 2 + y" + ) + @Iteration("math_eq_x/2", "type=MATH_EQUATION", "text=y=x/2", "expLatex=y = x \\div 2") + @Iteration( + "math_eq_x/y/z", + "type=MATH_EQUATION", + "text=y/2=x/y/z", + "expLatex=y \\div 2 = x \\div y \\div z" + ) + @Iteration( + "math_eq_x/(2+y)", "type=MATH_EQUATION", "text=x/(2+y)=y", "expLatex=x \\div (2 + y) = y" + ) + @Iteration("math_eq_x/2+y", "type=MATH_EQUATION", "text=x/2+y=y", "expLatex=x \\div 2 + y = y") fun testView_allInteractions_differentValidAnswers_divNotAsFractions_producesLatexWithDivs() { val interactionType = MathInteractionType.valueOf(type) val interaction = createInteraction(divAsFractions = false) @@ -502,46 +489,44 @@ class MathExpressionInteractionsViewTest { } @Test - @RunParameterized( - Iteration("numeric_1/2", "type=NUMERIC_EXPRESSION", "text=1/2", "expLatex=\\frac{1}{2}"), - Iteration( - "numeric_1/2/3", "type=NUMERIC_EXPRESSION", "text=1/2/3", "expLatex=\\frac{\\frac{1}{2}}{3}" - ), - Iteration( - "numeric_1/(2+3)", "type=NUMERIC_EXPRESSION", "text=1/(2+3)", "expLatex=\\frac{1}{(2 + 3)}" - ), - Iteration( - "numeric_1/2+3", "type=NUMERIC_EXPRESSION", "text=1/2+3", "expLatex=\\frac{1}{2} + 3" - ), - Iteration("algebraic_x/2", "type=ALGEBRAIC_EXPRESSION", "text=x/2", "expLatex=\\frac{x}{2}"), - Iteration( - "algebraic_x/y/z", - "type=ALGEBRAIC_EXPRESSION", - "text=x/y/z", - "expLatex=\\frac{\\frac{x}{y}}{z}" - ), - Iteration( - "algebraic_x/(2+y)", - "type=ALGEBRAIC_EXPRESSION", - "text=x/(2+y)", - "expLatex=\\frac{x}{(2 + y)}" - ), - Iteration( - "algebraic_x/2+y", "type=ALGEBRAIC_EXPRESSION", "text=x/2+y", "expLatex=\\frac{x}{2} + y" - ), - Iteration("math_eq_x/2", "type=MATH_EQUATION", "text=y=x/2", "expLatex=y = \\frac{x}{2}"), - Iteration( - "math_eq_x/y/z", - "type=MATH_EQUATION", - "text=y/2=x/y/z", - "expLatex=\\frac{y}{2} = \\frac{\\frac{x}{y}}{z}" - ), - Iteration( - "math_eq_x/(2+y)", "type=MATH_EQUATION", "text=x/(2+y)=y", "expLatex=\\frac{x}{(2 + y)} = y" - ), - Iteration( - "math_eq_x/2+y", "type=MATH_EQUATION", "text=x/2+y=y", "expLatex=\\frac{x}{2} + y = y" - ) + @Iteration("numeric_1/2", "type=NUMERIC_EXPRESSION", "text=1/2", "expLatex=\\frac{1}{2}") + @Iteration( + "numeric_1/2/3", "type=NUMERIC_EXPRESSION", "text=1/2/3", "expLatex=\\frac{\\frac{1}{2}}{3}" + ) + @Iteration( + "numeric_1/(2+3)", "type=NUMERIC_EXPRESSION", "text=1/(2+3)", "expLatex=\\frac{1}{(2 + 3)}" + ) + @Iteration( + "numeric_1/2+3", "type=NUMERIC_EXPRESSION", "text=1/2+3", "expLatex=\\frac{1}{2} + 3" + ) + @Iteration("algebraic_x/2", "type=ALGEBRAIC_EXPRESSION", "text=x/2", "expLatex=\\frac{x}{2}") + @Iteration( + "algebraic_x/y/z", + "type=ALGEBRAIC_EXPRESSION", + "text=x/y/z", + "expLatex=\\frac{\\frac{x}{y}}{z}" + ) + @Iteration( + "algebraic_x/(2+y)", + "type=ALGEBRAIC_EXPRESSION", + "text=x/(2+y)", + "expLatex=\\frac{x}{(2 + y)}" + ) + @Iteration( + "algebraic_x/2+y", "type=ALGEBRAIC_EXPRESSION", "text=x/2+y", "expLatex=\\frac{x}{2} + y" + ) + @Iteration("math_eq_x/2", "type=MATH_EQUATION", "text=y=x/2", "expLatex=y = \\frac{x}{2}") + @Iteration( + "math_eq_x/y/z", + "type=MATH_EQUATION", + "text=y/2=x/y/z", + "expLatex=\\frac{y}{2} = \\frac{\\frac{x}{y}}{z}" + ) + @Iteration( + "math_eq_x/(2+y)", "type=MATH_EQUATION", "text=x/(2+y)=y", "expLatex=\\frac{x}{(2 + y)} = y" + ) + @Iteration( + "math_eq_x/2+y", "type=MATH_EQUATION", "text=x/2+y=y", "expLatex=\\frac{x}{2} + y = y" ) fun testView_allInteractions_differentValidAnswers_divAsFractions_producesLatexWithFractions() { val interactionType = MathInteractionType.valueOf(type) @@ -560,14 +545,12 @@ class MathExpressionInteractionsViewTest { } @Test - @RunParameterized( - Iteration("numeric_invalid_exp_extra_error", "type=NUMERIC_EXPRESSION", "text=3/0"), - Iteration("numeric_invalid_exp_syntax_error", "type=NUMERIC_EXPRESSION", "text=3!"), - Iteration("algebraic_invalid_exp_extra_error", "type=ALGEBRAIC_EXPRESSION", "text=2^x"), - Iteration("algebraic_invalid_exp_syntax_error", "type=ALGEBRAIC_EXPRESSION", "text=2**x"), - Iteration("math_eq_invalid_exp_extra_error", "type=MATH_EQUATION", "text=y=+x"), - Iteration("math_eq_invalid_exp_syntax_error", "type=MATH_EQUATION", "text=y=x=z") - ) + @Iteration("numeric_invalid_exp_extra_error", "type=NUMERIC_EXPRESSION", "text=3/0") + @Iteration("numeric_invalid_exp_syntax_error", "type=NUMERIC_EXPRESSION", "text=3!") + @Iteration("algebraic_invalid_exp_extra_error", "type=ALGEBRAIC_EXPRESSION", "text=2^x") + @Iteration("algebraic_invalid_exp_syntax_error", "type=ALGEBRAIC_EXPRESSION", "text=2**x") + @Iteration("math_eq_invalid_exp_extra_error", "type=MATH_EQUATION", "text=y=+x") + @Iteration("math_eq_invalid_exp_syntax_error", "type=MATH_EQUATION", "text=y=x=z") fun testView_allInteractions_differentAnswers_failingAns_producesAnswerWithOrigExpAsPlainText() { val interactionType = MathInteractionType.valueOf(type) val interaction = createInteraction() @@ -587,52 +570,50 @@ class MathExpressionInteractionsViewTest { } @Test - @RunParameterized( - Iteration( - "numeric_-1", "type=NUMERIC_EXPRESSION", "text= - 1 ", "expA11y=negative 1" - ), - Iteration("numeric_1+2", "type=NUMERIC_EXPRESSION", "text=1 + 2", "expA11y=1 plus 2"), - Iteration("numeric_1-2", "type=NUMERIC_EXPRESSION", "text=1 − 2", "expA11y=1 minus 2"), - Iteration("numeric_1*2", "type=NUMERIC_EXPRESSION", "text=1 × 2", "expA11y=1 times 2"), - Iteration("numeric_1/2", "type=NUMERIC_EXPRESSION", "text=1 ÷ 2", "expA11y=1 divided by 2"), - Iteration( - "numeric_long_exp", - "type=NUMERIC_EXPRESSION", - "text=3*2-3+4^3*8/3*2+7", - "expA11y=3 times 2 minus 3 plus 4 raised to the power of 3 times 8 divided by 3 times" + - " 2 plus 7" - ), - Iteration( - "algebraic_-x", "type=ALGEBRAIC_EXPRESSION", "text= - x ", "expA11y=negative x" - ), - Iteration("algebraic_x+2", "type=ALGEBRAIC_EXPRESSION", "text=x + 2", "expA11y=x plus 2"), - Iteration("algebraic_x-2", "type=ALGEBRAIC_EXPRESSION", "text=x − 2", "expA11y=x minus 2"), - Iteration("algebraic_x*2", "type=ALGEBRAIC_EXPRESSION", "text=x × 2", "expA11y=x times 2"), - Iteration("algebraic_x/2", "type=ALGEBRAIC_EXPRESSION", "text=x ÷ 2", "expA11y=x divided by 2"), - Iteration( - "algebraic_long_exp", - "type=ALGEBRAIC_EXPRESSION", - "text=12x^2y^2-(yz^2+yzx)-731z", - "expA11y=12 x raised to the power of 2 times y raised to the power of 2 minus open" + - " parenthesis y times zed raised to the power of 2 plus y times zed times x close" + - " parenthesis minus 731 zed" - ), - Iteration( - "math_eq_-x", "type=MATH_EQUATION", "text= y= - x ", "expA11y=y equals negative x" - ), - Iteration("math_eq_x+2", "type=MATH_EQUATION", "text=y = x + 2", "expA11y=y equals x plus 2"), - Iteration("math_eq_x-2", "type=MATH_EQUATION", "text=y = x − 2", "expA11y=y equals x minus 2"), - Iteration("math_eq_x*2", "type=MATH_EQUATION", "text=y = x × 2", "expA11y=y equals x times 2"), - Iteration( - "math_eq_x/2", "type=MATH_EQUATION", "text=y = x ÷ 2", "expA11y=y equals x divided by 2" - ), - Iteration( - "math_eq_long_exp", - "type=MATH_EQUATION", - "text=(x^2-1)/(x+1)=y/2", - "expA11y=open parenthesis x raised to the power of 2 minus 1 close parenthesis divided by" + - " open parenthesis x plus 1 close parenthesis equals y divided by 2" - ) + @Iteration( + "numeric_-1", "type=NUMERIC_EXPRESSION", "text= - 1 ", "expA11y=negative 1" + ) + @Iteration("numeric_1+2", "type=NUMERIC_EXPRESSION", "text=1 + 2", "expA11y=1 plus 2") + @Iteration("numeric_1-2", "type=NUMERIC_EXPRESSION", "text=1 − 2", "expA11y=1 minus 2") + @Iteration("numeric_1*2", "type=NUMERIC_EXPRESSION", "text=1 × 2", "expA11y=1 times 2") + @Iteration("numeric_1/2", "type=NUMERIC_EXPRESSION", "text=1 ÷ 2", "expA11y=1 divided by 2") + @Iteration( + "numeric_long_exp", + "type=NUMERIC_EXPRESSION", + "text=3*2-3+4^3*8/3*2+7", + "expA11y=3 times 2 minus 3 plus 4 raised to the power of 3 times 8 divided by 3 times" + + " 2 plus 7" + ) + @Iteration( + "algebraic_-x", "type=ALGEBRAIC_EXPRESSION", "text= - x ", "expA11y=negative x" + ) + @Iteration("algebraic_x+2", "type=ALGEBRAIC_EXPRESSION", "text=x + 2", "expA11y=x plus 2") + @Iteration("algebraic_x-2", "type=ALGEBRAIC_EXPRESSION", "text=x − 2", "expA11y=x minus 2") + @Iteration("algebraic_x*2", "type=ALGEBRAIC_EXPRESSION", "text=x × 2", "expA11y=x times 2") + @Iteration("algebraic_x/2", "type=ALGEBRAIC_EXPRESSION", "text=x ÷ 2", "expA11y=x divided by 2") + @Iteration( + "algebraic_long_exp", + "type=ALGEBRAIC_EXPRESSION", + "text=12x^2y^2-(yz^2+yzx)-731z", + "expA11y=12 x raised to the power of 2 times y raised to the power of 2 minus open" + + " parenthesis y times zed raised to the power of 2 plus y times zed times x close" + + " parenthesis minus 731 zed" + ) + @Iteration( + "math_eq_-x", "type=MATH_EQUATION", "text= y= - x ", "expA11y=y equals negative x" + ) + @Iteration("math_eq_x+2", "type=MATH_EQUATION", "text=y = x + 2", "expA11y=y equals x plus 2") + @Iteration("math_eq_x-2", "type=MATH_EQUATION", "text=y = x − 2", "expA11y=y equals x minus 2") + @Iteration("math_eq_x*2", "type=MATH_EQUATION", "text=y = x × 2", "expA11y=y equals x times 2") + @Iteration( + "math_eq_x/2", "type=MATH_EQUATION", "text=y = x ÷ 2", "expA11y=y equals x divided by 2" + ) + @Iteration( + "math_eq_long_exp", + "type=MATH_EQUATION", + "text=(x^2-1)/(x+1)=y/2", + "expA11y=open parenthesis x raised to the power of 2 minus 1 close parenthesis divided by" + + " open parenthesis x plus 1 close parenthesis equals y divided by 2" ) fun testView_allInteractions_diffAnswers_english_producesAnswerWithReadableContentDescription() { val interactionType = MathInteractionType.valueOf(type) @@ -652,61 +633,59 @@ class MathExpressionInteractionsViewTest { } @Test - @RunParameterized( - Iteration("numeric_1/2", "type=NUMERIC_EXPRESSION", "text=1/2", "expA11y=1 divided by 2"), - Iteration( - "numeric_1/2/3", - "type=NUMERIC_EXPRESSION", - "text=1/2/3", - "expA11y=1 divided by 2 divided by 3" - ), - Iteration( - "numeric_1/(2+3)", - "type=NUMERIC_EXPRESSION", - "text=1/(2+3)", - "expA11y=1 divided by open parenthesis 2 plus 3 close parenthesis" - ), - Iteration( - "numeric_1/2+3", "type=NUMERIC_EXPRESSION", "text=1/2+3", "expA11y=1 divided by 2 plus 3" - ), - Iteration( - "numeric_1/3+3", "type=NUMERIC_EXPRESSION", "text=1/3+3", "expA11y=1 divided by 3 plus 3" - ), - Iteration("algebraic_x/2", "type=ALGEBRAIC_EXPRESSION", "text=x/2", "expA11y=x divided by 2"), - Iteration( - "algebraic_x/y/z", - "type=ALGEBRAIC_EXPRESSION", - "text=x/y/z", - "expA11y=x divided by y divided by zed" - ), - Iteration( - "algebraic_x/(2+y)", - "type=ALGEBRAIC_EXPRESSION", - "text=x/(2+y)", - "expA11y=x divided by open parenthesis 2 plus y close parenthesis" - ), - Iteration( - "algebraic_x/2+y", "type=ALGEBRAIC_EXPRESSION", "text=x/2+y", "expA11y=x divided by 2 plus y" - ), - Iteration("math_eq_x/2", "type=MATH_EQUATION", "text=y=x/2", "expA11y=y equals x divided by 2"), - Iteration( - "math_eq_x/y/z", - "type=MATH_EQUATION", - "text=y/2=x/y/z", - "expA11y=y divided by 2 equals x divided by y divided by zed" - ), - Iteration( - "math_eq_x/(2+y)", - "type=MATH_EQUATION", - "text=x/(2+y)=y", - "expA11y=x divided by open parenthesis 2 plus y close parenthesis equals y" - ), - Iteration( - "math_eq_x/2+y", - "type=MATH_EQUATION", - "text=x/2+y=y", - "expA11y=x divided by 2 plus y equals y" - ) + @Iteration("numeric_1/2", "type=NUMERIC_EXPRESSION", "text=1/2", "expA11y=1 divided by 2") + @Iteration( + "numeric_1/2/3", + "type=NUMERIC_EXPRESSION", + "text=1/2/3", + "expA11y=1 divided by 2 divided by 3" + ) + @Iteration( + "numeric_1/(2+3)", + "type=NUMERIC_EXPRESSION", + "text=1/(2+3)", + "expA11y=1 divided by open parenthesis 2 plus 3 close parenthesis" + ) + @Iteration( + "numeric_1/2+3", "type=NUMERIC_EXPRESSION", "text=1/2+3", "expA11y=1 divided by 2 plus 3" + ) + @Iteration( + "numeric_1/3+3", "type=NUMERIC_EXPRESSION", "text=1/3+3", "expA11y=1 divided by 3 plus 3" + ) + @Iteration("algebraic_x/2", "type=ALGEBRAIC_EXPRESSION", "text=x/2", "expA11y=x divided by 2") + @Iteration( + "algebraic_x/y/z", + "type=ALGEBRAIC_EXPRESSION", + "text=x/y/z", + "expA11y=x divided by y divided by zed" + ) + @Iteration( + "algebraic_x/(2+y)", + "type=ALGEBRAIC_EXPRESSION", + "text=x/(2+y)", + "expA11y=x divided by open parenthesis 2 plus y close parenthesis" + ) + @Iteration( + "algebraic_x/2+y", "type=ALGEBRAIC_EXPRESSION", "text=x/2+y", "expA11y=x divided by 2 plus y" + ) + @Iteration("math_eq_x/2", "type=MATH_EQUATION", "text=y=x/2", "expA11y=y equals x divided by 2") + @Iteration( + "math_eq_x/y/z", + "type=MATH_EQUATION", + "text=y/2=x/y/z", + "expA11y=y divided by 2 equals x divided by y divided by zed" + ) + @Iteration( + "math_eq_x/(2+y)", + "type=MATH_EQUATION", + "text=x/(2+y)=y", + "expA11y=x divided by open parenthesis 2 plus y close parenthesis equals y" + ) + @Iteration( + "math_eq_x/2+y", + "type=MATH_EQUATION", + "text=x/2+y=y", + "expA11y=x divided by 2 plus y equals y" ) fun testView_allInteractions_diffAnswers_english_divNotAsFractions_producesReadableContentDesc() { val interactionType = MathInteractionType.valueOf(type) @@ -726,61 +705,59 @@ class MathExpressionInteractionsViewTest { } @Test - @RunParameterized( - Iteration("numeric_1/2", "type=NUMERIC_EXPRESSION", "text=1/2", "expA11y=one half"), - Iteration( - "numeric_1/2/3", - "type=NUMERIC_EXPRESSION", - "text=1/2/3", - "expA11y=the fraction with numerator one half and denominator 3" - ), - Iteration( - "numeric_1/(2+3)", - "type=NUMERIC_EXPRESSION", - "text=1/(2+3)", - "expA11y=the fraction with numerator 1 and denominator open parenthesis 2 plus 3 close" + - " parenthesis" - ), - Iteration( - "numeric_1/2+3", "type=NUMERIC_EXPRESSION", "text=1/2+3", "expA11y=one half plus 3" - ), - Iteration( - "numeric_1/3+3", "type=NUMERIC_EXPRESSION", "text=1/3+3", "expA11y=1 over 3 plus 3" - ), - Iteration("algebraic_x/2", "type=ALGEBRAIC_EXPRESSION", "text=x/2", "expA11y=x over 2"), - Iteration( - "algebraic_x/y/z", - "type=ALGEBRAIC_EXPRESSION", - "text=x/y/z", - "expA11y=the fraction with numerator x over y and denominator zed" - ), - Iteration( - "algebraic_x/(2+y)", - "type=ALGEBRAIC_EXPRESSION", - "text=x/(2+y)", - "expA11y=the fraction with numerator x and denominator open parenthesis 2 plus y close" + - " parenthesis" - ), - Iteration( - "algebraic_x/2+y", "type=ALGEBRAIC_EXPRESSION", "text=x/2+y", "expA11y=x over 2 plus y" - ), - Iteration("math_eq_x/2", "type=MATH_EQUATION", "text=y=x/2", "expA11y=y equals x over 2"), - Iteration( - "math_eq_x/y/z", - "type=MATH_EQUATION", - "text=y/2=x/y/z", - "expA11y=y over 2 equals the fraction with numerator x over y and denominator zed" - ), - Iteration( - "math_eq_x/(2+y)", - "type=MATH_EQUATION", - "text=x/(2+y)=y", - "expA11y=the fraction with numerator x and denominator open parenthesis 2 plus y close" + - " parenthesis equals y" - ), - Iteration( - "math_eq_x/2+y", "type=MATH_EQUATION", "text=x/2+y=y", "expA11y=x over 2 plus y equals y" - ) + @Iteration("numeric_1/2", "type=NUMERIC_EXPRESSION", "text=1/2", "expA11y=one half") + @Iteration( + "numeric_1/2/3", + "type=NUMERIC_EXPRESSION", + "text=1/2/3", + "expA11y=the fraction with numerator one half and denominator 3" + ) + @Iteration( + "numeric_1/(2+3)", + "type=NUMERIC_EXPRESSION", + "text=1/(2+3)", + "expA11y=the fraction with numerator 1 and denominator open parenthesis 2 plus 3 close" + + " parenthesis" + ) + @Iteration( + "numeric_1/2+3", "type=NUMERIC_EXPRESSION", "text=1/2+3", "expA11y=one half plus 3" + ) + @Iteration( + "numeric_1/3+3", "type=NUMERIC_EXPRESSION", "text=1/3+3", "expA11y=1 over 3 plus 3" + ) + @Iteration("algebraic_x/2", "type=ALGEBRAIC_EXPRESSION", "text=x/2", "expA11y=x over 2") + @Iteration( + "algebraic_x/y/z", + "type=ALGEBRAIC_EXPRESSION", + "text=x/y/z", + "expA11y=the fraction with numerator x over y and denominator zed" + ) + @Iteration( + "algebraic_x/(2+y)", + "type=ALGEBRAIC_EXPRESSION", + "text=x/(2+y)", + "expA11y=the fraction with numerator x and denominator open parenthesis 2 plus y close" + + " parenthesis" + ) + @Iteration( + "algebraic_x/2+y", "type=ALGEBRAIC_EXPRESSION", "text=x/2+y", "expA11y=x over 2 plus y" + ) + @Iteration("math_eq_x/2", "type=MATH_EQUATION", "text=y=x/2", "expA11y=y equals x over 2") + @Iteration( + "math_eq_x/y/z", + "type=MATH_EQUATION", + "text=y/2=x/y/z", + "expA11y=y over 2 equals the fraction with numerator x over y and denominator zed" + ) + @Iteration( + "math_eq_x/(2+y)", + "type=MATH_EQUATION", + "text=x/(2+y)=y", + "expA11y=the fraction with numerator x and denominator open parenthesis 2 plus y close" + + " parenthesis equals y" + ) + @Iteration( + "math_eq_x/2+y", "type=MATH_EQUATION", "text=x/2+y=y", "expA11y=x over 2 plus y equals y" ) fun testView_allInteractions_diffAnswers_english_divAsFractions_producesReadableContentDesc() { val interactionType = MathInteractionType.valueOf(type) @@ -800,14 +777,12 @@ class MathExpressionInteractionsViewTest { } @Test - @RunParameterized( - Iteration("numeric_invalid_exp_extra_error", "type=NUMERIC_EXPRESSION", "text=3/0"), - Iteration("numeric_invalid_exp_syntax_error", "type=NUMERIC_EXPRESSION", "text=3!"), - Iteration("algebraic_invalid_exp_extra_error", "type=ALGEBRAIC_EXPRESSION", "text=2^x"), - Iteration("algebraic_invalid_exp_syntax_error", "type=ALGEBRAIC_EXPRESSION", "text=2**x"), - Iteration("math_eq_invalid_exp_extra_error", "type=MATH_EQUATION", "text=y=+x"), - Iteration("math_eq_invalid_exp_syntax_error", "type=MATH_EQUATION", "text=y=x=z") - ) + @Iteration("numeric_invalid_exp_extra_error", "type=NUMERIC_EXPRESSION", "text=3/0") + @Iteration("numeric_invalid_exp_syntax_error", "type=NUMERIC_EXPRESSION", "text=3!") + @Iteration("algebraic_invalid_exp_extra_error", "type=ALGEBRAIC_EXPRESSION", "text=2^x") + @Iteration("algebraic_invalid_exp_syntax_error", "type=ALGEBRAIC_EXPRESSION", "text=2**x") + @Iteration("math_eq_invalid_exp_extra_error", "type=MATH_EQUATION", "text=y=+x") + @Iteration("math_eq_invalid_exp_syntax_error", "type=MATH_EQUATION", "text=y=x=z") fun testView_allInteractions_invalidAnswers_english_producesAnswerOriginalExpAsDescription() { val interactionType = MathInteractionType.valueOf(type) val interaction = createInteraction() @@ -827,26 +802,24 @@ class MathExpressionInteractionsViewTest { } @Test - @RunParameterized( - Iteration("numexp_unsp", "type=NUMERIC_EXPRESSION", "lang=LANGUAGE_UNSPECIFIED", "text=3*2"), - Iteration("numexp_ar", "type=NUMERIC_EXPRESSION", "lang=ARABIC", "text=3*2"), - Iteration("numexp_hi", "type=NUMERIC_EXPRESSION", "lang=HINDI", "text=3*2"), - Iteration("numexp_hi-EN", "type=NUMERIC_EXPRESSION", "lang=HINGLISH", "text=3*2"), - Iteration("numexp_pt", "type=NUMERIC_EXPRESSION", "lang=PORTUGUESE", "text=3*2"), - Iteration("numexp_pt-BR", "type=NUMERIC_EXPRESSION", "lang=BRAZILIAN_PORTUGUESE", "text=3*2"), - Iteration("algexp_unsp", "type=ALGEBRAIC_EXPRESSION", "lang=LANGUAGE_UNSPECIFIED", "text=x*2"), - Iteration("algexp_ar", "type=ALGEBRAIC_EXPRESSION", "lang=ARABIC", "text=x*2"), - Iteration("algexp_hi", "type=ALGEBRAIC_EXPRESSION", "lang=HINDI", "text=x*2"), - Iteration("algexp_hi-EN", "type=ALGEBRAIC_EXPRESSION", "lang=HINGLISH", "text=x*2"), - Iteration("algexp_pt", "type=ALGEBRAIC_EXPRESSION", "lang=PORTUGUESE", "text=x*2"), - Iteration("algexp_pt-BR", "type=ALGEBRAIC_EXPRESSION", "lang=BRAZILIAN_PORTUGUESE", "text=x*2"), - Iteration("matheq_unsp", "type=MATH_EQUATION", "lang=LANGUAGE_UNSPECIFIED", "text=y=x"), - Iteration("matheq_ar", "type=MATH_EQUATION", "lang=ARABIC", "text=y=x"), - Iteration("matheq_hi", "type=MATH_EQUATION", "lang=HINDI", "text=y=x"), - Iteration("matheq_hi-EN", "type=MATH_EQUATION", "lang=HINGLISH", "text=y=x"), - Iteration("matheq_pt", "type=MATH_EQUATION", "lang=PORTUGUESE", "text=y=x"), - Iteration("matheq_pt-BR", "type=MATH_EQUATION", "lang=BRAZILIAN_PORTUGUESE", "text=y=x") - ) + @Iteration("numexp_unsp", "type=NUMERIC_EXPRESSION", "lang=LANGUAGE_UNSPECIFIED", "text=3*2") + @Iteration("numexp_ar", "type=NUMERIC_EXPRESSION", "lang=ARABIC", "text=3*2") + @Iteration("numexp_hi", "type=NUMERIC_EXPRESSION", "lang=HINDI", "text=3*2") + @Iteration("numexp_hi-EN", "type=NUMERIC_EXPRESSION", "lang=HINGLISH", "text=3*2") + @Iteration("numexp_pt", "type=NUMERIC_EXPRESSION", "lang=PORTUGUESE", "text=3*2") + @Iteration("numexp_pt-BR", "type=NUMERIC_EXPRESSION", "lang=BRAZILIAN_PORTUGUESE", "text=3*2") + @Iteration("algexp_unsp", "type=ALGEBRAIC_EXPRESSION", "lang=LANGUAGE_UNSPECIFIED", "text=x*2") + @Iteration("algexp_ar", "type=ALGEBRAIC_EXPRESSION", "lang=ARABIC", "text=x*2") + @Iteration("algexp_hi", "type=ALGEBRAIC_EXPRESSION", "lang=HINDI", "text=x*2") + @Iteration("algexp_hi-EN", "type=ALGEBRAIC_EXPRESSION", "lang=HINGLISH", "text=x*2") + @Iteration("algexp_pt", "type=ALGEBRAIC_EXPRESSION", "lang=PORTUGUESE", "text=x*2") + @Iteration("algexp_pt-BR", "type=ALGEBRAIC_EXPRESSION", "lang=BRAZILIAN_PORTUGUESE", "text=x*2") + @Iteration("matheq_unsp", "type=MATH_EQUATION", "lang=LANGUAGE_UNSPECIFIED", "text=y=x") + @Iteration("matheq_ar", "type=MATH_EQUATION", "lang=ARABIC", "text=y=x") + @Iteration("matheq_hi", "type=MATH_EQUATION", "lang=HINDI", "text=y=x") + @Iteration("matheq_hi-EN", "type=MATH_EQUATION", "lang=HINGLISH", "text=y=x") + @Iteration("matheq_pt", "type=MATH_EQUATION", "lang=PORTUGUESE", "text=y=x") + @Iteration("matheq_pt-BR", "type=MATH_EQUATION", "lang=BRAZILIAN_PORTUGUESE", "text=y=x") fun testView_allInteractions_unsupportedLang_producesAnswerOriginalExpAsDescription() { val interactionType = MathInteractionType.valueOf(type) val interaction = createInteraction() @@ -870,175 +843,173 @@ class MathExpressionInteractionsViewTest { // they're the same for all possible expressions/equations that can produce that error), and // aren't tied to specific interaction types. @Test - @RunParameterized( - Iteration( - "numexp_exp_too_large", - "type=NUMERIC_EXPRESSION", - "text=2^10", - "expErr=Sorry, powers higher than 5 are not supported by the app. Please revise your answer." - ), - Iteration( - "numexp_exp_incomplete_func_name", - "type=NUMERIC_EXPRESSION", - "text=sqr(2)", - "expErr=Did you mean sqrt? If not, please separate the variables with multiplication symbols." - ), - Iteration( - "numexp_exp_hanging_square_root", - "type=NUMERIC_EXPRESSION", - "text=√", - "expErr=Missing input for square root." - ), - Iteration( - "numexp_exp_nested_exponent", - "type=NUMERIC_EXPRESSION", - "text=2^3^4", - "expErr=Sorry, repeated powers/exponents are not supported by the app. Please limit your" + - " answer to one power." - ), - Iteration( - "numexp_exp_spaces_in_number_input", - "type=NUMERIC_EXPRESSION", - "text=3.14 1", - "expErr=Please remove the spaces between numbers in your answer." - ), - Iteration( - "numexp_exp_consecutive_unary", - "type=NUMERIC_EXPRESSION", - "text=--2", - "expErr=Please remove the extra symbols in your answer." - ), - Iteration( - "numexp_exp_divide_by_zero", - "type=NUMERIC_EXPRESSION", - "text=2/0", - "expErr=Dividing by zero is invalid. Please revise your answer." - ), - Iteration( - "numexp_exp_hanging_parenthesis", - "type=NUMERIC_EXPRESSION", - "text=2+(3-1", - "expErr=Please close or remove parentheses." - ), - Iteration( - "numexp_exp_generic_error", - "type=NUMERIC_EXPRESSION", - "text=sqrt 2", - "expErr=Sorry, we couldn't understand your answer. Please check it to make sure there" + - " aren't any errors." - ), - Iteration( - "algexp_exp_too_large", - "type=ALGEBRAIC_EXPRESSION", - "text=x^10", - "expErr=Sorry, powers higher than 5 are not supported by the app. Please revise your answer." - ), - Iteration( - "algexp_exp_incomplete_func_name", - "type=ALGEBRAIC_EXPRESSION", - "text=sqr(x)", - "expErr=Did you mean sqrt? If not, please separate the variables with multiplication symbols." - ), - Iteration( - "algexp_exp_hanging_square_root", - "type=ALGEBRAIC_EXPRESSION", - "text=√", - "expErr=Missing input for square root." - ), - Iteration( - "algexp_exp_nested_exponent", - "type=ALGEBRAIC_EXPRESSION", - "text=x^3^4", - "expErr=Sorry, repeated powers/exponents are not supported by the app. Please limit your" + - " answer to one power." - ), - Iteration( - "algexp_exp_spaces_in_number_input", - "type=ALGEBRAIC_EXPRESSION", - "text=3.14 1", - "expErr=Please remove the spaces between numbers in your answer." - ), - Iteration( - "algexp_exp_consecutive_unary", - "type=ALGEBRAIC_EXPRESSION", - "text=--x", - "expErr=Please remove the extra symbols in your answer." - ), - Iteration( - "algexp_exp_divide_by_zero", - "type=ALGEBRAIC_EXPRESSION", - "text=x/0", - "expErr=Dividing by zero is invalid. Please revise your answer." - ), - Iteration( - "algexp_exp_hanging_parenthesis", - "type=ALGEBRAIC_EXPRESSION", - "text=x+(y-z", - "expErr=Please close or remove parentheses." - ), - Iteration( - "algexp_exp_generic_error", - "type=ALGEBRAIC_EXPRESSION", - "text=sqrt x", - "expErr=Sorry, we couldn't understand your answer. Please check it to make sure there" + - " aren't any errors." - ), - Iteration( - "matheq_exp_too_large", - "type=MATH_EQUATION", - "text=y=x^10", - "expErr=Sorry, powers higher than 5 are not supported by the app. Please revise your answer." - ), - Iteration( - "matheq_exp_incomplete_func_name", - "type=MATH_EQUATION", - "text=y=sqr(x)", - "expErr=Did you mean sqrt? If not, please separate the variables with multiplication symbols." - ), - Iteration( - "matheq_exp_hanging_square_root", - "type=MATH_EQUATION", - "text=y=√", - "expErr=Missing input for square root." - ), - Iteration( - "matheq_exp_nested_exponent", - "type=MATH_EQUATION", - "text=y=x^3^4", - "expErr=Sorry, repeated powers/exponents are not supported by the app. Please limit your" + - " answer to one power." - ), - Iteration( - "matheq_exp_spaces_in_number_input", - "type=MATH_EQUATION", - "text=y=3.14 1", - "expErr=Please remove the spaces between numbers in your answer." - ), - Iteration( - "matheq_exp_consecutive_unary", - "type=MATH_EQUATION", - "text=y=--x", - "expErr=Please remove the extra symbols in your answer." - ), - Iteration( - "matheq_exp_divide_by_zero", - "type=MATH_EQUATION", - "text=y=x/0", - "expErr=Dividing by zero is invalid. Please revise your answer." - ), - Iteration( - "matheq_exp_hanging_parenthesis", - "type=MATH_EQUATION", - "text=y=x+(y-z", - "expErr=Please close or remove parentheses." - ), - Iteration( - "matheq_exp_generic_error", - "type=MATH_EQUATION", - "text=y=sqrt x", - "expErr=Sorry, we couldn't understand your answer. Please check it to make sure there" + - " aren't any errors." - ) + @Iteration( + "numexp_exp_too_large", + "type=NUMERIC_EXPRESSION", + "text=2^10", + "expErr=Sorry, powers higher than 5 are not supported by the app. Please revise your answer." + ) + @Iteration( + "numexp_exp_incomplete_func_name", + "type=NUMERIC_EXPRESSION", + "text=sqr(2)", + "expErr=Did you mean sqrt? If not, please separate the variables with multiplication symbols." + ) + @Iteration( + "numexp_exp_hanging_square_root", + "type=NUMERIC_EXPRESSION", + "text=√", + "expErr=Missing input for square root." + ) + @Iteration( + "numexp_exp_nested_exponent", + "type=NUMERIC_EXPRESSION", + "text=2^3^4", + "expErr=Sorry, repeated powers/exponents are not supported by the app. Please limit your" + + " answer to one power." + ) + @Iteration( + "numexp_exp_spaces_in_number_input", + "type=NUMERIC_EXPRESSION", + "text=3.14 1", + "expErr=Please remove the spaces between numbers in your answer." + ) + @Iteration( + "numexp_exp_consecutive_unary", + "type=NUMERIC_EXPRESSION", + "text=--2", + "expErr=Please remove the extra symbols in your answer." + ) + @Iteration( + "numexp_exp_divide_by_zero", + "type=NUMERIC_EXPRESSION", + "text=2/0", + "expErr=Dividing by zero is invalid. Please revise your answer." + ) + @Iteration( + "numexp_exp_hanging_parenthesis", + "type=NUMERIC_EXPRESSION", + "text=2+(3-1", + "expErr=Please close or remove parentheses." + ) + @Iteration( + "numexp_exp_generic_error", + "type=NUMERIC_EXPRESSION", + "text=sqrt 2", + "expErr=Sorry, we couldn't understand your answer. Please check it to make sure there" + + " aren't any errors." + ) + @Iteration( + "algexp_exp_too_large", + "type=ALGEBRAIC_EXPRESSION", + "text=x^10", + "expErr=Sorry, powers higher than 5 are not supported by the app. Please revise your answer." + ) + @Iteration( + "algexp_exp_incomplete_func_name", + "type=ALGEBRAIC_EXPRESSION", + "text=sqr(x)", + "expErr=Did you mean sqrt? If not, please separate the variables with multiplication symbols." + ) + @Iteration( + "algexp_exp_hanging_square_root", + "type=ALGEBRAIC_EXPRESSION", + "text=√", + "expErr=Missing input for square root." + ) + @Iteration( + "algexp_exp_nested_exponent", + "type=ALGEBRAIC_EXPRESSION", + "text=x^3^4", + "expErr=Sorry, repeated powers/exponents are not supported by the app. Please limit your" + + " answer to one power." + ) + @Iteration( + "algexp_exp_spaces_in_number_input", + "type=ALGEBRAIC_EXPRESSION", + "text=3.14 1", + "expErr=Please remove the spaces between numbers in your answer." + ) + @Iteration( + "algexp_exp_consecutive_unary", + "type=ALGEBRAIC_EXPRESSION", + "text=--x", + "expErr=Please remove the extra symbols in your answer." + ) + @Iteration( + "algexp_exp_divide_by_zero", + "type=ALGEBRAIC_EXPRESSION", + "text=x/0", + "expErr=Dividing by zero is invalid. Please revise your answer." + ) + @Iteration( + "algexp_exp_hanging_parenthesis", + "type=ALGEBRAIC_EXPRESSION", + "text=x+(y-z", + "expErr=Please close or remove parentheses." + ) + @Iteration( + "algexp_exp_generic_error", + "type=ALGEBRAIC_EXPRESSION", + "text=sqrt x", + "expErr=Sorry, we couldn't understand your answer. Please check it to make sure there" + + " aren't any errors." + ) + @Iteration( + "matheq_exp_too_large", + "type=MATH_EQUATION", + "text=y=x^10", + "expErr=Sorry, powers higher than 5 are not supported by the app. Please revise your answer." + ) + @Iteration( + "matheq_exp_incomplete_func_name", + "type=MATH_EQUATION", + "text=y=sqr(x)", + "expErr=Did you mean sqrt? If not, please separate the variables with multiplication symbols." + ) + @Iteration( + "matheq_exp_hanging_square_root", + "type=MATH_EQUATION", + "text=y=√", + "expErr=Missing input for square root." + ) + @Iteration( + "matheq_exp_nested_exponent", + "type=MATH_EQUATION", + "text=y=x^3^4", + "expErr=Sorry, repeated powers/exponents are not supported by the app. Please limit your" + + " answer to one power." + ) + @Iteration( + "matheq_exp_spaces_in_number_input", + "type=MATH_EQUATION", + "text=y=3.14 1", + "expErr=Please remove the spaces between numbers in your answer." + ) + @Iteration( + "matheq_exp_consecutive_unary", + "type=MATH_EQUATION", + "text=y=--x", + "expErr=Please remove the extra symbols in your answer." + ) + @Iteration( + "matheq_exp_divide_by_zero", + "type=MATH_EQUATION", + "text=y=x/0", + "expErr=Dividing by zero is invalid. Please revise your answer." + ) + @Iteration( + "matheq_exp_hanging_parenthesis", + "type=MATH_EQUATION", + "text=y=x+(y-z", + "expErr=Please close or remove parentheses." + ) + @Iteration( + "matheq_exp_generic_error", + "type=MATH_EQUATION", + "text=y=sqrt x", + "expErr=Sorry, we couldn't understand your answer. Please check it to make sure there" + + " aren't any errors." ) fun testView_allInteractions_invalidAnswer_casesWithNoCustomization_producesError() { val interactionType = MathInteractionType.valueOf(type) @@ -1075,10 +1046,8 @@ class MathExpressionInteractionsViewTest { } @Test - @RunParameterized( - Iteration("alg_exp", "type=ALGEBRAIC_EXPRESSION", "text=2^x"), - Iteration("math_equation", "type=MATH_EQUATION", "text=y=2^x") - ) + @Iteration("alg_exp", "type=ALGEBRAIC_EXPRESSION", "text=2^x") + @Iteration("math_equation", "type=MATH_EQUATION", "text=y=2^x") fun testView_algebraicInteractions_variableInExponent_producesError() { val interactionType = MathInteractionType.valueOf(type) val interaction = createInteraction() @@ -1098,22 +1067,20 @@ class MathExpressionInteractionsViewTest { } @Test - @RunParameterized( - Iteration("y", "text=y", "expErr=Your equation is missing an '=' sign."), - Iteration("2y", "text=2y", "expErr=Your equation is missing an '=' sign."), - Iteration( - "y==x", - "text=y==x", - "expErr=Your equation contains too many '=' signs. It should have only one." - ), - Iteration("y=", "text=y=", "expErr=One of the sides of '=' in your equation is empty."), - Iteration("=x", "text==x", "expErr=One of the sides of '=' in your equation is empty."), - Iteration("=y=x", "text==y=x", "expErr=One of the sides of '=' in your equation is empty."), - Iteration( - "y=x=", - "text=y=x=", - "expErr=Your equation contains too many '=' signs. It should have only one." - ) + @Iteration("y", "text=y", "expErr=Your equation is missing an '=' sign.") + @Iteration("2y", "text=2y", "expErr=Your equation is missing an '=' sign.") + @Iteration( + "y==x", + "text=y==x", + "expErr=Your equation contains too many '=' signs. It should have only one." + ) + @Iteration("y=", "text=y=", "expErr=One of the sides of '=' in your equation is empty.") + @Iteration("=x", "text==x", "expErr=One of the sides of '=' in your equation is empty.") + @Iteration("=y=x", "text==y=x", "expErr=One of the sides of '=' in your equation is empty.") + @Iteration( + "y=x=", + "text=y=x=", + "expErr=Your equation contains too many '=' signs. It should have only one." ) fun testView_mathEquationInput_incorrectEqualsUsage_producesError() { launchForMathEquations(interaction = createInteraction()).use { scenario -> @@ -1129,11 +1096,9 @@ class MathExpressionInteractionsViewTest { } @Test - @RunParameterized( - Iteration("num_exp", "type=NUMERIC_EXPRESSION", "text=abs(2)"), - Iteration("alg_exp", "type=ALGEBRAIC_EXPRESSION", "text=abs(x)"), - Iteration("math_equation", "type=MATH_EQUATION", "text=y=abs(x)") - ) + @Iteration("num_exp", "type=NUMERIC_EXPRESSION", "text=abs(2)") + @Iteration("alg_exp", "type=ALGEBRAIC_EXPRESSION", "text=abs(x)") + @Iteration("math_equation", "type=MATH_EQUATION", "text=y=abs(x)") fun testView_allInteractions_invalidFunctionAnswer_producesError() { val interactionType = MathInteractionType.valueOf(type) val interaction = createInteraction() @@ -1152,25 +1117,23 @@ class MathExpressionInteractionsViewTest { } @Test - @RunParameterized( - Iteration( - "num_exp", - "type=NUMERIC_EXPRESSION", - "text=1+((2* 3))", - "expErr=Please remove extra parentheses around the '((2* 3))', for example: '(2* 3)'." - ), - Iteration( - "alg_exp", - "type=ALGEBRAIC_EXPRESSION", - "text=x+((y* z))", - "expErr=Please remove extra parentheses around the '((y* z))', for example: '(y* z)'." - ), - Iteration( - "math_equation", - "type=MATH_EQUATION", - "text=y=x+((y* z))", - "expErr=Please remove extra parentheses around the '((y* z))', for example: '(y* z)'." - ) + @Iteration( + "num_exp", + "type=NUMERIC_EXPRESSION", + "text=1+((2* 3))", + "expErr=Please remove extra parentheses around the '((2* 3))', for example: '(2* 3)'." + ) + @Iteration( + "alg_exp", + "type=ALGEBRAIC_EXPRESSION", + "text=x+((y* z))", + "expErr=Please remove extra parentheses around the '((y* z))', for example: '(y* z)'." + ) + @Iteration( + "math_equation", + "type=MATH_EQUATION", + "text=y=x+((y* z))", + "expErr=Please remove extra parentheses around the '((y* z))', for example: '(y* z)'." ) fun testView_allInteractions_multipleRedundantParentheses_producesError() { val interactionType = MathInteractionType.valueOf(type) @@ -1189,25 +1152,23 @@ class MathExpressionInteractionsViewTest { } @Test - @RunParameterized( - Iteration( - "num_exp", - "type=NUMERIC_EXPRESSION", - "text=1+(2 )", - "expErr=Please remove the extra parentheses around '(2)', for example: '2'." - ), - Iteration( - "alg_exp", - "type=ALGEBRAIC_EXPRESSION", - "text=x+(y )", - "expErr=Please remove the extra parentheses around '(y)', for example: 'y'." - ), - Iteration( - "math_equation", - "type=MATH_EQUATION", - "text=y=x+(y )", - "expErr=Please remove the extra parentheses around '(y)', for example: 'y'." - ) + @Iteration( + "num_exp", + "type=NUMERIC_EXPRESSION", + "text=1+(2 )", + "expErr=Please remove the extra parentheses around '(2)', for example: '2'." + ) + @Iteration( + "alg_exp", + "type=ALGEBRAIC_EXPRESSION", + "text=x+(y )", + "expErr=Please remove the extra parentheses around '(y)', for example: 'y'." + ) + @Iteration( + "math_equation", + "type=MATH_EQUATION", + "text=y=x+(y )", + "expErr=Please remove the extra parentheses around '(y)', for example: 'y'." ) fun testView_allInteractions_individualRedundantParentheses_producesError() { val interactionType = MathInteractionType.valueOf(type) @@ -1226,25 +1187,23 @@ class MathExpressionInteractionsViewTest { } @Test - @RunParameterized( - Iteration( - "num_exp", - "type=NUMERIC_EXPRESSION", - "text=(1+2 )", - "expErr=Please remove the parentheses around the whole answer: '(1+2 )'." - ), - Iteration( - "alg_exp", - "type=ALGEBRAIC_EXPRESSION", - "text=(x+y )", - "expErr=Please remove the parentheses around the whole answer: '(x+y )'." - ), - Iteration( - "math_equation", - "type=MATH_EQUATION", - "text=y=(x+y )", - "expErr=Please remove the parentheses around the whole answer: '(x+y )'." - ) + @Iteration( + "num_exp", + "type=NUMERIC_EXPRESSION", + "text=(1+2 )", + "expErr=Please remove the parentheses around the whole answer: '(1+2 )'." + ) + @Iteration( + "alg_exp", + "type=ALGEBRAIC_EXPRESSION", + "text=(x+y )", + "expErr=Please remove the parentheses around the whole answer: '(x+y )'." + ) + @Iteration( + "math_equation", + "type=MATH_EQUATION", + "text=y=(x+y )", + "expErr=Please remove the parentheses around the whole answer: '(x+y )'." ) fun testView_allInteractions_singleRedundantParentheses_producesError() { val interactionType = MathInteractionType.valueOf(type) @@ -1263,97 +1222,95 @@ class MathExpressionInteractionsViewTest { } @Test - @RunParameterized( - Iteration( - "numeric_expression_add", - "type=NUMERIC_EXPRESSION", - "text=1+", - "expErr=There seems to be a number or a variable missing after the addition symbol '+'." - ), - Iteration( - "numeric_expression_subtract", - "type=NUMERIC_EXPRESSION", - "text=1−", - "expErr=There seems to be a number or a variable missing after the subtraction symbol '−'." - ), - Iteration( - "numeric_expression_multiply", - "type=NUMERIC_EXPRESSION", - "text=1×", - "expErr=There seems to be a number or a variable missing after the multiplication symbol '×'." - ), - Iteration( - "numeric_expression_divide", - "type=NUMERIC_EXPRESSION", - "text=1÷", - "expErr=There seems to be a number or a variable missing after the division symbol '÷'." - ), - Iteration( - "numeric_expression_exponentiate", - "type=NUMERIC_EXPRESSION", - "text=1^", - "expErr=There seems to be a number or a variable missing after the exponentiation symbol '^'." - ), - Iteration( - "algebraic_expression_add", - "type=ALGEBRAIC_EXPRESSION", - "text=x+", - "expErr=There seems to be a number or a variable missing after the addition symbol '+'." - ), - Iteration( - "algebraic_expression_subtract", - "type=ALGEBRAIC_EXPRESSION", - "text=x−", - "expErr=There seems to be a number or a variable missing after the subtraction symbol '−'." - ), - Iteration( - "algebraic_expression_multiply", - "type=ALGEBRAIC_EXPRESSION", - "text=x×", - "expErr=There seems to be a number or a variable missing after the multiplication symbol '×'." - ), - Iteration( - "algebraic_expression_divide", - "type=ALGEBRAIC_EXPRESSION", - "text=x÷", - "expErr=There seems to be a number or a variable missing after the division symbol '÷'." - ), - Iteration( - "algebraic_expression_exponentiate", - "type=ALGEBRAIC_EXPRESSION", - "text=x^", - "expErr=There seems to be a number or a variable missing after the exponentiation symbol '^'." - ), - Iteration( - "math_equation_add", - "type=MATH_EQUATION", - "text=y=x+", - "expErr=There seems to be a number or a variable missing after the addition symbol '+'." - ), - Iteration( - "math_equation_subtract", - "type=MATH_EQUATION", - "text=y=x−", - "expErr=There seems to be a number or a variable missing after the subtraction symbol '−'." - ), - Iteration( - "math_equation_multiply", - "type=MATH_EQUATION", - "text=y=x×", - "expErr=There seems to be a number or a variable missing after the multiplication symbol '×'." - ), - Iteration( - "math_equation_divide", - "type=MATH_EQUATION", - "text=y=x÷", - "expErr=There seems to be a number or a variable missing after the division symbol '÷'." - ), - Iteration( - "math_equation_exponentiate", - "type=MATH_EQUATION", - "text=y=x^", - "expErr=There seems to be a number or a variable missing after the exponentiation symbol '^'." - ) + @Iteration( + "numeric_expression_add", + "type=NUMERIC_EXPRESSION", + "text=1+", + "expErr=There seems to be a number or a variable missing after the addition symbol '+'." + ) + @Iteration( + "numeric_expression_subtract", + "type=NUMERIC_EXPRESSION", + "text=1−", + "expErr=There seems to be a number or a variable missing after the subtraction symbol '−'." + ) + @Iteration( + "numeric_expression_multiply", + "type=NUMERIC_EXPRESSION", + "text=1×", + "expErr=There seems to be a number or a variable missing after the multiplication symbol '×'." + ) + @Iteration( + "numeric_expression_divide", + "type=NUMERIC_EXPRESSION", + "text=1÷", + "expErr=There seems to be a number or a variable missing after the division symbol '÷'." + ) + @Iteration( + "numeric_expression_exponentiate", + "type=NUMERIC_EXPRESSION", + "text=1^", + "expErr=There seems to be a number or a variable missing after the exponentiation symbol '^'." + ) + @Iteration( + "algebraic_expression_add", + "type=ALGEBRAIC_EXPRESSION", + "text=x+", + "expErr=There seems to be a number or a variable missing after the addition symbol '+'." + ) + @Iteration( + "algebraic_expression_subtract", + "type=ALGEBRAIC_EXPRESSION", + "text=x−", + "expErr=There seems to be a number or a variable missing after the subtraction symbol '−'." + ) + @Iteration( + "algebraic_expression_multiply", + "type=ALGEBRAIC_EXPRESSION", + "text=x×", + "expErr=There seems to be a number or a variable missing after the multiplication symbol '×'." + ) + @Iteration( + "algebraic_expression_divide", + "type=ALGEBRAIC_EXPRESSION", + "text=x÷", + "expErr=There seems to be a number or a variable missing after the division symbol '÷'." + ) + @Iteration( + "algebraic_expression_exponentiate", + "type=ALGEBRAIC_EXPRESSION", + "text=x^", + "expErr=There seems to be a number or a variable missing after the exponentiation symbol '^'." + ) + @Iteration( + "math_equation_add", + "type=MATH_EQUATION", + "text=y=x+", + "expErr=There seems to be a number or a variable missing after the addition symbol '+'." + ) + @Iteration( + "math_equation_subtract", + "type=MATH_EQUATION", + "text=y=x−", + "expErr=There seems to be a number or a variable missing after the subtraction symbol '−'." + ) + @Iteration( + "math_equation_multiply", + "type=MATH_EQUATION", + "text=y=x×", + "expErr=There seems to be a number or a variable missing after the multiplication symbol '×'." + ) + @Iteration( + "math_equation_divide", + "type=MATH_EQUATION", + "text=y=x÷", + "expErr=There seems to be a number or a variable missing after the division symbol '÷'." + ) + @Iteration( + "math_equation_exponentiate", + "type=MATH_EQUATION", + "text=y=x^", + "expErr=There seems to be a number or a variable missing after the exponentiation symbol '^'." ) fun testView_allInteractions_noVarOrNumberAfterBinaryOpted_producesError() { val interactionType = MathInteractionType.valueOf(type) @@ -1374,91 +1331,89 @@ class MathExpressionInteractionsViewTest { // Note that subtraction is omitted here since expressions like '-2' would be treated as negative // 2 rather than a subtraction being assumed. @Test - @RunParameterized( - Iteration( - "numeric_expression_add", - "type=NUMERIC_EXPRESSION", - "text=+1", - "expErr=Is there a number or a variable missing before or after the addition symbol '+'? If" + - " not, please remove the extra '+'." - ), - Iteration( - "numeric_expression_multiply", - "type=NUMERIC_EXPRESSION", - "text=×1", - "expErr=Is there a number or a variable missing before or after the multiplication symbol" + - " '×'? If not, please remove the extra '×'." - ), - Iteration( - "numeric_expression_divide", - "type=NUMERIC_EXPRESSION", - "text=÷1", - "expErr=Is there a number or a variable missing before or after the division symbol '÷'? If" + - " not, please remove the extra '÷'." - ), - Iteration( - "numeric_expression_exponentiate", - "type=NUMERIC_EXPRESSION", - "text=^1", - "expErr=Is there a number or a variable missing before or after the exponentiation symbol" + - " '^'? If not, please remove the extra '^'." - ), - Iteration( - "algebraic_expression_add", - "type=ALGEBRAIC_EXPRESSION", - "text=+x", - "expErr=Is there a number or a variable missing before or after the addition symbol '+'? If" + - " not, please remove the extra '+'." - ), - Iteration( - "algebraic_expression_multiply", - "type=ALGEBRAIC_EXPRESSION", - "text=×x", - "expErr=Is there a number or a variable missing before or after the multiplication symbol" + - " '×'? If not, please remove the extra '×'." - ), - Iteration( - "algebraic_expression_divide", - "type=ALGEBRAIC_EXPRESSION", - "text=÷x", - "expErr=Is there a number or a variable missing before or after the division symbol '÷'? If" + - " not, please remove the extra '÷'." - ), - Iteration( - "algebraic_expression_exponentiate", - "type=ALGEBRAIC_EXPRESSION", - "text=^x", - "expErr=Is there a number or a variable missing before or after the exponentiation symbol" + - " '^'? If not, please remove the extra '^'." - ), - Iteration( - "math_equation_add", - "type=MATH_EQUATION", - "text=y=+x", - "expErr=Is there a number or a variable missing before or after the addition symbol '+'? If" + - " not, please remove the extra '+'." - ), - Iteration( - "math_equation_multiply", - "type=MATH_EQUATION", - "text=y=×x", - "expErr=Is there a number or a variable missing before or after the multiplication symbol" + - " '×'? If not, please remove the extra '×'." - ), - Iteration( - "math_equation_divide", - "type=MATH_EQUATION", - "text=y=÷x", - "expErr=Is there a number or a variable missing before or after the division symbol '÷'? If" + - " not, please remove the extra '÷'." - ), - Iteration( - "math_equation_exponentiate", - "type=MATH_EQUATION", - "text=y=^x", - "expErr=Is there a number or a variable missing before or after the exponentiation symbol" + - " '^'? If not, please remove the extra '^'." - ) + @Iteration( + "numeric_expression_add", + "type=NUMERIC_EXPRESSION", + "text=+1", + "expErr=Is there a number or a variable missing before or after the addition symbol '+'? If" + + " not, please remove the extra '+'." + ) + @Iteration( + "numeric_expression_multiply", + "type=NUMERIC_EXPRESSION", + "text=×1", + "expErr=Is there a number or a variable missing before or after the multiplication symbol" + + " '×'? If not, please remove the extra '×'." + ) + @Iteration( + "numeric_expression_divide", + "type=NUMERIC_EXPRESSION", + "text=÷1", + "expErr=Is there a number or a variable missing before or after the division symbol '÷'? If" + + " not, please remove the extra '÷'." + ) + @Iteration( + "numeric_expression_exponentiate", + "type=NUMERIC_EXPRESSION", + "text=^1", + "expErr=Is there a number or a variable missing before or after the exponentiation symbol" + + " '^'? If not, please remove the extra '^'." + ) + @Iteration( + "algebraic_expression_add", + "type=ALGEBRAIC_EXPRESSION", + "text=+x", + "expErr=Is there a number or a variable missing before or after the addition symbol '+'? If" + + " not, please remove the extra '+'." + ) + @Iteration( + "algebraic_expression_multiply", + "type=ALGEBRAIC_EXPRESSION", + "text=×x", + "expErr=Is there a number or a variable missing before or after the multiplication symbol" + + " '×'? If not, please remove the extra '×'." + ) + @Iteration( + "algebraic_expression_divide", + "type=ALGEBRAIC_EXPRESSION", + "text=÷x", + "expErr=Is there a number or a variable missing before or after the division symbol '÷'? If" + + " not, please remove the extra '÷'." + ) + @Iteration( + "algebraic_expression_exponentiate", + "type=ALGEBRAIC_EXPRESSION", + "text=^x", + "expErr=Is there a number or a variable missing before or after the exponentiation symbol" + + " '^'? If not, please remove the extra '^'." + ) + @Iteration( + "math_equation_add", + "type=MATH_EQUATION", + "text=y=+x", + "expErr=Is there a number or a variable missing before or after the addition symbol '+'? If" + + " not, please remove the extra '+'." + ) + @Iteration( + "math_equation_multiply", + "type=MATH_EQUATION", + "text=y=×x", + "expErr=Is there a number or a variable missing before or after the multiplication symbol" + + " '×'? If not, please remove the extra '×'." + ) + @Iteration( + "math_equation_divide", + "type=MATH_EQUATION", + "text=y=÷x", + "expErr=Is there a number or a variable missing before or after the division symbol '÷'? If" + + " not, please remove the extra '÷'." + ) + @Iteration( + "math_equation_exponentiate", + "type=MATH_EQUATION", + "text=y=^x", + "expErr=Is there a number or a variable missing before or after the exponentiation symbol" + + " '^'? If not, please remove the extra '^'." ) fun testView_allInteractions_noVarOrNumberBeforeBinaryOpted_producesError() { val interactionType = MathInteractionType.valueOf(type) @@ -1477,10 +1432,8 @@ class MathExpressionInteractionsViewTest { } @Test - @RunParameterized( - Iteration("algebraic_expression", "type=ALGEBRAIC_EXPRESSION", "text=x2"), - Iteration("math_equation", "type=MATH_EQUATION", "text=y=x2") - ) + @Iteration("algebraic_expression", "type=ALGEBRAIC_EXPRESSION", "text=x2") + @Iteration("math_equation", "type=MATH_EQUATION", "text=y=x2") fun testView_algebraicInteractions_numberAfterVariable_producesError() { val interactionType = MathInteractionType.valueOf(type) val interaction = createInteraction() @@ -1498,11 +1451,9 @@ class MathExpressionInteractionsViewTest { } @Test - @RunParameterized( - Iteration("numeric_expression", "type=NUMERIC_EXPRESSION", "text=1×÷2"), - Iteration("algebraic_expression", "type=ALGEBRAIC_EXPRESSION", "text=x×÷y"), - Iteration("math_equation", "type=MATH_EQUATION", "text=z=x×÷y") - ) + @Iteration("numeric_expression", "type=NUMERIC_EXPRESSION", "text=1×÷2") + @Iteration("algebraic_expression", "type=ALGEBRAIC_EXPRESSION", "text=x×÷y") + @Iteration("math_equation", "type=MATH_EQUATION", "text=z=x×÷y") fun testView_allInteractions_consecutiveBinaryOperators_producesError() { val interactionType = MathInteractionType.valueOf(type) val interaction = createInteraction() @@ -1520,11 +1471,9 @@ class MathExpressionInteractionsViewTest { } @Test - @RunParameterized( - Iteration("numeric_expression", "type=NUMERIC_EXPRESSION", "text=2!"), - Iteration("algebraic_expression", "type=ALGEBRAIC_EXPRESSION", "text=x!"), - Iteration("math_equation", "type=MATH_EQUATION", "text=z=x!") - ) + @Iteration("numeric_expression", "type=NUMERIC_EXPRESSION", "text=2!") + @Iteration("algebraic_expression", "type=ALGEBRAIC_EXPRESSION", "text=x!") + @Iteration("math_equation", "type=MATH_EQUATION", "text=z=x!") fun testView_allInteractions_invalidSymbol_producesError() { val interactionType = MathInteractionType.valueOf(type) val interaction = createInteraction() @@ -1543,25 +1492,23 @@ class MathExpressionInteractionsViewTest { } @Test - @RunParameterized( - Iteration( - "algebraic_expression", - "type=ALGEBRAIC_EXPRESSION", - "text=x+y", - "expErr=Please use the variables specified in the question and not x, y." - ), - Iteration( - "math_equation_single_var_lhs", - "type=MATH_EQUATION", - "text=z=x+y", - "expErr=Please use the variables specified in the question and not z." - ), - Iteration( - "math_equation_single_var_rhs", - "type=MATH_EQUATION", - "text=x+y=z", - "expErr=Please use the variables specified in the question and not x, y." - ) + @Iteration( + "algebraic_expression", + "type=ALGEBRAIC_EXPRESSION", + "text=x+y", + "expErr=Please use the variables specified in the question and not x, y." + ) + @Iteration( + "math_equation_single_var_lhs", + "type=MATH_EQUATION", + "text=z=x+y", + "expErr=Please use the variables specified in the question and not z." + ) + @Iteration( + "math_equation_single_var_rhs", + "type=MATH_EQUATION", + "text=x+y=z", + "expErr=Please use the variables specified in the question and not x, y." ) fun testView_algebraicInteractions_missingVariables_producesError() { val interactionType = MathInteractionType.valueOf(type) @@ -1579,11 +1526,9 @@ class MathExpressionInteractionsViewTest { } @Test - @RunParameterized( - Iteration("numeric_expression", "type=NUMERIC_EXPRESSION", "text=1+2"), - Iteration("algebraic_expression", "type=ALGEBRAIC_EXPRESSION", "text=x+y"), - Iteration("math_equation", "type=MATH_EQUATION", "text=z=x+y") - ) + @Iteration("numeric_expression", "type=NUMERIC_EXPRESSION", "text=1+2") + @Iteration("algebraic_expression", "type=ALGEBRAIC_EXPRESSION", "text=x+y") + @Iteration("math_equation", "type=MATH_EQUATION", "text=z=x+y") fun testView_allInteractions_validExpression_doesNotProduceSubmitTimeErrorError() { val interactionType = MathInteractionType.valueOf(type) val interaction = createInteraction() @@ -1601,14 +1546,12 @@ class MathExpressionInteractionsViewTest { } @Test - @RunParameterized( - Iteration("numeric_expression_valid", "type=NUMERIC_EXPRESSION", "text=0/1"), - Iteration("numeric_expression_invalid", "type=NUMERIC_EXPRESSION", "text=1/0"), - Iteration("algebraic_expression_valid", "type=ALGEBRAIC_EXPRESSION", "text=x^2"), - Iteration("algebraic_expression_invalid", "type=ALGEBRAIC_EXPRESSION", "text=2^x"), - Iteration("math_equation_valid", "type=MATH_EQUATION", "text=z=x^2"), - Iteration("math_equation_invalid", "type=MATH_EQUATION", "text=z=2^x") - ) + @Iteration("numeric_expression_valid", "type=NUMERIC_EXPRESSION", "text=0/1") + @Iteration("numeric_expression_invalid", "type=NUMERIC_EXPRESSION", "text=1/0") + @Iteration("algebraic_expression_valid", "type=ALGEBRAIC_EXPRESSION", "text=x^2") + @Iteration("algebraic_expression_invalid", "type=ALGEBRAIC_EXPRESSION", "text=2^x") + @Iteration("math_equation_valid", "type=MATH_EQUATION", "text=z=x^2") + @Iteration("math_equation_invalid", "type=MATH_EQUATION", "text=z=2^x") fun testView_allInteractions_validAndInvalidExpressions_doNotProduceRealTimeError() { val interactionType = MathInteractionType.valueOf(type) val interaction = createInteraction() diff --git a/app/src/sharedTest/java/org/oppia/android/app/splash/SplashActivityTest.kt b/app/src/sharedTest/java/org/oppia/android/app/splash/SplashActivityTest.kt index aec2ab09efb..42feaef5968 100644 --- a/app/src/sharedTest/java/org/oppia/android/app/splash/SplashActivityTest.kt +++ b/app/src/sharedTest/java/org/oppia/android/app/splash/SplashActivityTest.kt @@ -99,7 +99,6 @@ import org.oppia.android.testing.data.DataProviderTestMonitor import org.oppia.android.testing.junit.OppiaParameterizedTestRunner import org.oppia.android.testing.junit.OppiaParameterizedTestRunner.Iteration import org.oppia.android.testing.junit.OppiaParameterizedTestRunner.Parameter -import org.oppia.android.testing.junit.OppiaParameterizedTestRunner.RunParameterized import org.oppia.android.testing.junit.OppiaParameterizedTestRunner.SelectRunnerPlatform import org.oppia.android.testing.junit.ParameterizedAutoAndroidTestRunner import org.oppia.android.testing.robolectric.RobolectricModule @@ -400,12 +399,10 @@ class SplashActivityTest { } @Test - @RunParameterized( - Iteration("testing_to_beta", "firstOpen=TESTING", "secondOpen=BETA"), - Iteration("dev_to_beta", "firstOpen=DEVELOPER", "secondOpen=BETA"), - Iteration("alpha_to_beta", "firstOpen=ALPHA", "secondOpen=BETA"), - Iteration("ga_to_beta", "firstOpen=GENERAL_AVAILABILITY", "secondOpen=BETA") - ) + @Iteration("testing_to_beta", "firstOpen=TESTING", "secondOpen=BETA") + @Iteration("dev_to_beta", "firstOpen=DEVELOPER", "secondOpen=BETA") + @Iteration("alpha_to_beta", "firstOpen=ALPHA", "secondOpen=BETA") + @Iteration("ga_to_beta", "firstOpen=GENERAL_AVAILABILITY", "secondOpen=BETA") fun testSplashActivity_newUser_betaFlavorTransitions_showsBetaNotice() { simulateAppAlreadyOpenedWithFlavor(firstOpenFlavor) @@ -418,12 +415,10 @@ class SplashActivityTest { } @Test - @RunParameterized( - Iteration("testing_to_beta", "firstOpen=TESTING", "secondOpen=BETA"), - Iteration("dev_to_beta", "firstOpen=DEVELOPER", "secondOpen=BETA"), - Iteration("alpha_to_beta", "firstOpen=ALPHA", "secondOpen=BETA"), - Iteration("ga_to_beta", "firstOpen=GENERAL_AVAILABILITY", "secondOpen=BETA") - ) + @Iteration("testing_to_beta", "firstOpen=TESTING", "secondOpen=BETA") + @Iteration("dev_to_beta", "firstOpen=DEVELOPER", "secondOpen=BETA") + @Iteration("alpha_to_beta", "firstOpen=ALPHA", "secondOpen=BETA") + @Iteration("ga_to_beta", "firstOpen=GENERAL_AVAILABILITY", "secondOpen=BETA") fun testSplashActivity_newUser_betaFlavorTransitions_closeNotice_routesToOnboardingFlow() { simulateAppAlreadyOpenedWithFlavor(firstOpenFlavor) initializeTestApplicationWithFlavor(secondOpenFlavor) @@ -439,12 +434,10 @@ class SplashActivityTest { } @Test - @RunParameterized( - Iteration("testing_to_beta", "firstOpen=TESTING", "secondOpen=BETA"), - Iteration("dev_to_beta", "firstOpen=DEVELOPER", "secondOpen=BETA"), - Iteration("alpha_to_beta", "firstOpen=ALPHA", "secondOpen=BETA"), - Iteration("ga_to_beta", "firstOpen=GENERAL_AVAILABILITY", "secondOpen=BETA") - ) + @Iteration("testing_to_beta", "firstOpen=TESTING", "secondOpen=BETA") + @Iteration("dev_to_beta", "firstOpen=DEVELOPER", "secondOpen=BETA") + @Iteration("alpha_to_beta", "firstOpen=ALPHA", "secondOpen=BETA") + @Iteration("ga_to_beta", "firstOpen=GENERAL_AVAILABILITY", "secondOpen=BETA") fun testSplashActivity_newUser_betaFlavorTransitions_doNotShowAgain_routesToOnboardingFlow() { simulateAppAlreadyOpenedWithFlavor(firstOpenFlavor) initializeTestApplicationWithFlavor(secondOpenFlavor) @@ -539,10 +532,8 @@ class SplashActivityTest { } @Test - @RunParameterized( - Iteration("alpha_to_ga", "firstOpen=ALPHA", "secondOpen=GENERAL_AVAILABILITY"), - Iteration("beta_to_ga", "firstOpen=BETA", "secondOpen=GENERAL_AVAILABILITY") - ) + @Iteration("alpha_to_ga", "firstOpen=ALPHA", "secondOpen=GENERAL_AVAILABILITY") + @Iteration("beta_to_ga", "firstOpen=BETA", "secondOpen=GENERAL_AVAILABILITY") fun testSplashActivity_onboarded_gaFlavorTransitions_showsGaUpgradeNotice() { simulateAppAlreadyOnboardedWithFlavor(firstOpenFlavor) @@ -556,10 +547,8 @@ class SplashActivityTest { } @Test - @RunParameterized( - Iteration("alpha_to_ga", "firstOpen=ALPHA", "secondOpen=GENERAL_AVAILABILITY"), - Iteration("beta_to_ga", "firstOpen=BETA", "secondOpen=GENERAL_AVAILABILITY") - ) + @Iteration("alpha_to_ga", "firstOpen=ALPHA", "secondOpen=GENERAL_AVAILABILITY") + @Iteration("beta_to_ga", "firstOpen=BETA", "secondOpen=GENERAL_AVAILABILITY") fun testSplashActivity_onboarded_gaFlavorTransitions_closeNotice_routesToProfileChooser() { simulateAppAlreadyOnboardedWithFlavor(firstOpenFlavor) initializeTestApplicationWithFlavor(secondOpenFlavor) @@ -576,10 +565,8 @@ class SplashActivityTest { } @Test - @RunParameterized( - Iteration("alpha_to_ga", "firstOpen=ALPHA", "secondOpen=GENERAL_AVAILABILITY"), - Iteration("beta_to_ga", "firstOpen=BETA", "secondOpen=GENERAL_AVAILABILITY") - ) + @Iteration("alpha_to_ga", "firstOpen=ALPHA", "secondOpen=GENERAL_AVAILABILITY") + @Iteration("beta_to_ga", "firstOpen=BETA", "secondOpen=GENERAL_AVAILABILITY") fun testSplashActivity_onboarded_gaFlavorTransitions_doNotShowAgain_routesToProfileChooser() { simulateAppAlreadyOnboardedWithFlavor(firstOpenFlavor) initializeTestApplicationWithFlavor(secondOpenFlavor) @@ -749,27 +736,25 @@ class SplashActivityTest { } @Test - @RunParameterized( - Iteration("testing_to_testing", "firstOpen=TESTING", "secondOpen=TESTING"), - Iteration("testing_to_dev", "firstOpen=TESTING", "secondOpen=DEVELOPER"), - Iteration("testing_to_alpha", "firstOpen=TESTING", "secondOpen=ALPHA"), - Iteration("testing_to_ga", "firstOpen=TESTING", "secondOpen=GENERAL_AVAILABILITY"), - Iteration("dev_to_testing", "firstOpen=DEVELOPER", "secondOpen=TESTING"), - Iteration("dev_to_dev", "firstOpen=DEVELOPER", "secondOpen=DEVELOPER"), - Iteration("dev_to_alpha", "firstOpen=DEVELOPER", "secondOpen=ALPHA"), - Iteration("dev_to_ga", "firstOpen=DEVELOPER", "secondOpen=GENERAL_AVAILABILITY"), - Iteration("alpha_to_testing", "firstOpen=ALPHA", "secondOpen=TESTING"), - Iteration("alpha_to_dev", "firstOpen=ALPHA", "secondOpen=DEVELOPER"), - Iteration("alpha_to_alpha", "firstOpen=ALPHA", "secondOpen=ALPHA"), - Iteration("beta_to_testing", "firstOpen=BETA", "secondOpen=TESTING"), - Iteration("beta_to_dev", "firstOpen=BETA", "secondOpen=DEVELOPER"), - Iteration("beta_to_alpha", "firstOpen=BETA", "secondOpen=ALPHA"), - Iteration("beta_to_beta", "firstOpen=BETA", "secondOpen=BETA"), - Iteration("ga_to_testing", "firstOpen=GENERAL_AVAILABILITY", "secondOpen=TESTING"), - Iteration("ga_to_dev", "firstOpen=GENERAL_AVAILABILITY", "secondOpen=DEVELOPER"), - Iteration("ga_to_alpha", "firstOpen=GENERAL_AVAILABILITY", "secondOpen=ALPHA"), - Iteration("ga_to_ga", "firstOpen=GENERAL_AVAILABILITY", "secondOpen=GENERAL_AVAILABILITY") - ) + @Iteration("testing_to_testing", "firstOpen=TESTING", "secondOpen=TESTING") + @Iteration("testing_to_dev", "firstOpen=TESTING", "secondOpen=DEVELOPER") + @Iteration("testing_to_alpha", "firstOpen=TESTING", "secondOpen=ALPHA") + @Iteration("testing_to_ga", "firstOpen=TESTING", "secondOpen=GENERAL_AVAILABILITY") + @Iteration("dev_to_testing", "firstOpen=DEVELOPER", "secondOpen=TESTING") + @Iteration("dev_to_dev", "firstOpen=DEVELOPER", "secondOpen=DEVELOPER") + @Iteration("dev_to_alpha", "firstOpen=DEVELOPER", "secondOpen=ALPHA") + @Iteration("dev_to_ga", "firstOpen=DEVELOPER", "secondOpen=GENERAL_AVAILABILITY") + @Iteration("alpha_to_testing", "firstOpen=ALPHA", "secondOpen=TESTING") + @Iteration("alpha_to_dev", "firstOpen=ALPHA", "secondOpen=DEVELOPER") + @Iteration("alpha_to_alpha", "firstOpen=ALPHA", "secondOpen=ALPHA") + @Iteration("beta_to_testing", "firstOpen=BETA", "secondOpen=TESTING") + @Iteration("beta_to_dev", "firstOpen=BETA", "secondOpen=DEVELOPER") + @Iteration("beta_to_alpha", "firstOpen=BETA", "secondOpen=ALPHA") + @Iteration("beta_to_beta", "firstOpen=BETA", "secondOpen=BETA") + @Iteration("ga_to_testing", "firstOpen=GENERAL_AVAILABILITY", "secondOpen=TESTING") + @Iteration("ga_to_dev", "firstOpen=GENERAL_AVAILABILITY", "secondOpen=DEVELOPER") + @Iteration("ga_to_alpha", "firstOpen=GENERAL_AVAILABILITY", "secondOpen=ALPHA") + @Iteration("ga_to_ga", "firstOpen=GENERAL_AVAILABILITY", "secondOpen=GENERAL_AVAILABILITY") fun testSplashActivity_newUser_ignoredFlavorTransitions_routesToOnboardingFlow() { simulateAppAlreadyOpenedWithFlavor(firstOpenFlavor) @@ -783,27 +768,25 @@ class SplashActivityTest { } @Test - @RunParameterized( - Iteration("testing_to_testing", "firstOpen=TESTING", "secondOpen=TESTING"), - Iteration("testing_to_dev", "firstOpen=TESTING", "secondOpen=DEVELOPER"), - Iteration("testing_to_alpha", "firstOpen=TESTING", "secondOpen=ALPHA"), - Iteration("testing_to_ga", "firstOpen=TESTING", "secondOpen=GENERAL_AVAILABILITY"), - Iteration("dev_to_testing", "firstOpen=DEVELOPER", "secondOpen=TESTING"), - Iteration("dev_to_dev", "firstOpen=DEVELOPER", "secondOpen=DEVELOPER"), - Iteration("dev_to_alpha", "firstOpen=DEVELOPER", "secondOpen=ALPHA"), - Iteration("dev_to_ga", "firstOpen=DEVELOPER", "secondOpen=GENERAL_AVAILABILITY"), - Iteration("alpha_to_testing", "firstOpen=ALPHA", "secondOpen=TESTING"), - Iteration("alpha_to_dev", "firstOpen=ALPHA", "secondOpen=DEVELOPER"), - Iteration("alpha_to_alpha", "firstOpen=ALPHA", "secondOpen=ALPHA"), - Iteration("beta_to_testing", "firstOpen=BETA", "secondOpen=TESTING"), - Iteration("beta_to_dev", "firstOpen=BETA", "secondOpen=DEVELOPER"), - Iteration("beta_to_alpha", "firstOpen=BETA", "secondOpen=ALPHA"), - Iteration("beta_to_beta", "firstOpen=BETA", "secondOpen=BETA"), - Iteration("ga_to_testing", "firstOpen=GENERAL_AVAILABILITY", "secondOpen=TESTING"), - Iteration("ga_to_dev", "firstOpen=GENERAL_AVAILABILITY", "secondOpen=DEVELOPER"), - Iteration("ga_to_alpha", "firstOpen=GENERAL_AVAILABILITY", "secondOpen=ALPHA"), - Iteration("ga_to_ga", "firstOpen=GENERAL_AVAILABILITY", "secondOpen=GENERAL_AVAILABILITY") - ) + @Iteration("testing_to_testing", "firstOpen=TESTING", "secondOpen=TESTING") + @Iteration("testing_to_dev", "firstOpen=TESTING", "secondOpen=DEVELOPER") + @Iteration("testing_to_alpha", "firstOpen=TESTING", "secondOpen=ALPHA") + @Iteration("testing_to_ga", "firstOpen=TESTING", "secondOpen=GENERAL_AVAILABILITY") + @Iteration("dev_to_testing", "firstOpen=DEVELOPER", "secondOpen=TESTING") + @Iteration("dev_to_dev", "firstOpen=DEVELOPER", "secondOpen=DEVELOPER") + @Iteration("dev_to_alpha", "firstOpen=DEVELOPER", "secondOpen=ALPHA") + @Iteration("dev_to_ga", "firstOpen=DEVELOPER", "secondOpen=GENERAL_AVAILABILITY") + @Iteration("alpha_to_testing", "firstOpen=ALPHA", "secondOpen=TESTING") + @Iteration("alpha_to_dev", "firstOpen=ALPHA", "secondOpen=DEVELOPER") + @Iteration("alpha_to_alpha", "firstOpen=ALPHA", "secondOpen=ALPHA") + @Iteration("beta_to_testing", "firstOpen=BETA", "secondOpen=TESTING") + @Iteration("beta_to_dev", "firstOpen=BETA", "secondOpen=DEVELOPER") + @Iteration("beta_to_alpha", "firstOpen=BETA", "secondOpen=ALPHA") + @Iteration("beta_to_beta", "firstOpen=BETA", "secondOpen=BETA") + @Iteration("ga_to_testing", "firstOpen=GENERAL_AVAILABILITY", "secondOpen=TESTING") + @Iteration("ga_to_dev", "firstOpen=GENERAL_AVAILABILITY", "secondOpen=DEVELOPER") + @Iteration("ga_to_alpha", "firstOpen=GENERAL_AVAILABILITY", "secondOpen=ALPHA") + @Iteration("ga_to_ga", "firstOpen=GENERAL_AVAILABILITY", "secondOpen=GENERAL_AVAILABILITY") fun testSplashActivity_onboarded_ignoredFlavorTransitions_routesToProfileChooser() { simulateAppAlreadyOnboardedWithFlavor(firstOpenFlavor) @@ -817,33 +800,31 @@ class SplashActivityTest { } @Test - @RunParameterized( - Iteration("testing_to_testing", "firstOpen=TESTING", "secondOpen=TESTING"), - Iteration("testing_to_dev", "firstOpen=TESTING", "secondOpen=DEVELOPER"), - Iteration("testing_to_alpha", "firstOpen=TESTING", "secondOpen=ALPHA"), - Iteration("testing_to_beta", "firstOpen=TESTING", "secondOpen=BETA"), - Iteration("testing_to_ga", "firstOpen=TESTING", "secondOpen=GENERAL_AVAILABILITY"), - Iteration("dev_to_testing", "firstOpen=DEVELOPER", "secondOpen=TESTING"), - Iteration("dev_to_dev", "firstOpen=DEVELOPER", "secondOpen=DEVELOPER"), - Iteration("dev_to_alpha", "firstOpen=DEVELOPER", "secondOpen=ALPHA"), - Iteration("dev_to_beta", "firstOpen=DEVELOPER", "secondOpen=BETA"), - Iteration("dev_to_ga", "firstOpen=DEVELOPER", "secondOpen=GENERAL_AVAILABILITY"), - Iteration("alpha_to_testing", "firstOpen=ALPHA", "secondOpen=TESTING"), - Iteration("alpha_to_dev", "firstOpen=ALPHA", "secondOpen=DEVELOPER"), - Iteration("alpha_to_alpha", "firstOpen=ALPHA", "secondOpen=ALPHA"), - Iteration("alpha_to_beta", "firstOpen=ALPHA", "secondOpen=BETA"), - Iteration("alpha_to_ga", "firstOpen=ALPHA", "secondOpen=GENERAL_AVAILABILITY"), - Iteration("beta_to_testing", "firstOpen=BETA", "secondOpen=TESTING"), - Iteration("beta_to_dev", "firstOpen=BETA", "secondOpen=DEVELOPER"), - Iteration("beta_to_alpha", "firstOpen=BETA", "secondOpen=ALPHA"), - Iteration("beta_to_beta", "firstOpen=BETA", "secondOpen=BETA"), - Iteration("beta_to_ga", "firstOpen=BETA", "secondOpen=GENERAL_AVAILABILITY"), - Iteration("ga_to_testing", "firstOpen=GENERAL_AVAILABILITY", "secondOpen=TESTING"), - Iteration("ga_to_dev", "firstOpen=GENERAL_AVAILABILITY", "secondOpen=DEVELOPER"), - Iteration("ga_to_alpha", "firstOpen=GENERAL_AVAILABILITY", "secondOpen=ALPHA"), - Iteration("ga_to_beta", "firstOpen=GENERAL_AVAILABILITY", "secondOpen=BETA"), - Iteration("ga_to_ga", "firstOpen=GENERAL_AVAILABILITY", "secondOpen=GENERAL_AVAILABILITY") - ) + @Iteration("testing_to_testing", "firstOpen=TESTING", "secondOpen=TESTING") + @Iteration("testing_to_dev", "firstOpen=TESTING", "secondOpen=DEVELOPER") + @Iteration("testing_to_alpha", "firstOpen=TESTING", "secondOpen=ALPHA") + @Iteration("testing_to_beta", "firstOpen=TESTING", "secondOpen=BETA") + @Iteration("testing_to_ga", "firstOpen=TESTING", "secondOpen=GENERAL_AVAILABILITY") + @Iteration("dev_to_testing", "firstOpen=DEVELOPER", "secondOpen=TESTING") + @Iteration("dev_to_dev", "firstOpen=DEVELOPER", "secondOpen=DEVELOPER") + @Iteration("dev_to_alpha", "firstOpen=DEVELOPER", "secondOpen=ALPHA") + @Iteration("dev_to_beta", "firstOpen=DEVELOPER", "secondOpen=BETA") + @Iteration("dev_to_ga", "firstOpen=DEVELOPER", "secondOpen=GENERAL_AVAILABILITY") + @Iteration("alpha_to_testing", "firstOpen=ALPHA", "secondOpen=TESTING") + @Iteration("alpha_to_dev", "firstOpen=ALPHA", "secondOpen=DEVELOPER") + @Iteration("alpha_to_alpha", "firstOpen=ALPHA", "secondOpen=ALPHA") + @Iteration("alpha_to_beta", "firstOpen=ALPHA", "secondOpen=BETA") + @Iteration("alpha_to_ga", "firstOpen=ALPHA", "secondOpen=GENERAL_AVAILABILITY") + @Iteration("beta_to_testing", "firstOpen=BETA", "secondOpen=TESTING") + @Iteration("beta_to_dev", "firstOpen=BETA", "secondOpen=DEVELOPER") + @Iteration("beta_to_alpha", "firstOpen=BETA", "secondOpen=ALPHA") + @Iteration("beta_to_beta", "firstOpen=BETA", "secondOpen=BETA") + @Iteration("beta_to_ga", "firstOpen=BETA", "secondOpen=GENERAL_AVAILABILITY") + @Iteration("ga_to_testing", "firstOpen=GENERAL_AVAILABILITY", "secondOpen=TESTING") + @Iteration("ga_to_dev", "firstOpen=GENERAL_AVAILABILITY", "secondOpen=DEVELOPER") + @Iteration("ga_to_alpha", "firstOpen=GENERAL_AVAILABILITY", "secondOpen=ALPHA") + @Iteration("ga_to_beta", "firstOpen=GENERAL_AVAILABILITY", "secondOpen=BETA") + @Iteration("ga_to_ga", "firstOpen=GENERAL_AVAILABILITY", "secondOpen=GENERAL_AVAILABILITY") fun testSplashActivity_appDeprecated_allFlavorTransitions_showsDeprecationNotice() { simulateAppAlreadyOnboardedWithFlavor(firstOpenFlavor) diff --git a/app/src/test/java/org/oppia/android/app/translation/AppLanguageResourceHandlerTest.kt b/app/src/test/java/org/oppia/android/app/translation/AppLanguageResourceHandlerTest.kt index 1ed42145790..b77ae423034 100644 --- a/app/src/test/java/org/oppia/android/app/translation/AppLanguageResourceHandlerTest.kt +++ b/app/src/test/java/org/oppia/android/app/translation/AppLanguageResourceHandlerTest.kt @@ -72,7 +72,6 @@ import org.oppia.android.testing.junit.InitializeDefaultLocaleRule import org.oppia.android.testing.junit.OppiaParameterizedTestRunner import org.oppia.android.testing.junit.OppiaParameterizedTestRunner.Iteration import org.oppia.android.testing.junit.OppiaParameterizedTestRunner.Parameter -import org.oppia.android.testing.junit.OppiaParameterizedTestRunner.RunParameterized import org.oppia.android.testing.junit.OppiaParameterizedTestRunner.SelectRunnerPlatform import org.oppia.android.testing.junit.ParameterizedRobolectricTestRunner import org.oppia.android.testing.robolectric.RobolectricModule @@ -492,16 +491,14 @@ class AppLanguageResourceHandlerTest { // testing functionality that's expected to go away with later language selection work. // TODO(#3793): Remove this once OppiaLanguage is used as the source of truth. @Test - @RunParameterized( - Iteration("hi", "lang=HINDI_AUDIO_LANGUAGE", "expectedDisplayText=हिन्दी"), - Iteration("fr", "lang=FRENCH_AUDIO_LANGUAGE", "expectedDisplayText=Français"), - Iteration("zh", "lang=CHINESE_AUDIO_LANGUAGE", "expectedDisplayText=中文"), - Iteration("pr-pt", "lang=BRAZILIAN_PORTUGUESE_LANGUAGE", "expectedDisplayText=Português"), - Iteration("unsp", "lang=AUDIO_LANGUAGE_UNSPECIFIED", "expectedDisplayText=English"), - Iteration("none", "lang=NO_AUDIO", "expectedDisplayText=English"), - Iteration("unknown", "lang=UNRECOGNIZED", "expectedDisplayText=English"), - Iteration("en", "lang=ENGLISH_AUDIO_LANGUAGE", "expectedDisplayText=English") - ) + @Iteration("hi", "lang=HINDI_AUDIO_LANGUAGE", "expectedDisplayText=हिन्दी") + @Iteration("fr", "lang=FRENCH_AUDIO_LANGUAGE", "expectedDisplayText=Français") + @Iteration("zh", "lang=CHINESE_AUDIO_LANGUAGE", "expectedDisplayText=中文") + @Iteration("pr-pt", "lang=BRAZILIAN_PORTUGUESE_LANGUAGE", "expectedDisplayText=Português") + @Iteration("unsp", "lang=AUDIO_LANGUAGE_UNSPECIFIED", "expectedDisplayText=English") + @Iteration("none", "lang=NO_AUDIO", "expectedDisplayText=English") + @Iteration("unknown", "lang=UNRECOGNIZED", "expectedDisplayText=English") + @Iteration("en", "lang=ENGLISH_AUDIO_LANGUAGE", "expectedDisplayText=English") fun testComputeLocalizedDisplayName_englishLocale_forAllLanguages_hasTheExpectedOutput() { updateAppLanguageTo(OppiaLanguage.ENGLISH) val handler = retrieveAppLanguageResourceHandler() diff --git a/app/src/test/java/org/oppia/android/app/utility/math/MathExpressionAccessibilityUtilTest.kt b/app/src/test/java/org/oppia/android/app/utility/math/MathExpressionAccessibilityUtilTest.kt index 323ab88e166..82330290ce7 100644 --- a/app/src/test/java/org/oppia/android/app/utility/math/MathExpressionAccessibilityUtilTest.kt +++ b/app/src/test/java/org/oppia/android/app/utility/math/MathExpressionAccessibilityUtilTest.kt @@ -81,7 +81,6 @@ import org.oppia.android.testing.junit.InitializeDefaultLocaleRule import org.oppia.android.testing.junit.OppiaParameterizedTestRunner import org.oppia.android.testing.junit.OppiaParameterizedTestRunner.Iteration import org.oppia.android.testing.junit.OppiaParameterizedTestRunner.Parameter -import org.oppia.android.testing.junit.OppiaParameterizedTestRunner.RunParameterized import org.oppia.android.testing.junit.OppiaParameterizedTestRunner.SelectRunnerPlatform import org.oppia.android.testing.junit.ParameterizedRobolectricTestRunner import org.oppia.android.testing.math.MathEquationSubject @@ -167,16 +166,14 @@ class MathExpressionAccessibilityUtilTest { } @Test - @RunParameterized( - Iteration("LANGUAGE_UNSPECIFIED", "language=LANGUAGE_UNSPECIFIED"), - Iteration("ARABIC", "language=ARABIC"), - Iteration("HINDI", "language=HINDI"), - Iteration("HINGLISH", "language=HINGLISH"), - Iteration("PORTUGUESE", "language=PORTUGUESE"), - Iteration("BRAZILIAN_PORTUGUESE", "language=BRAZILIAN_PORTUGUESE"), - Iteration("SWAHILI", "language=SWAHILI"), - Iteration("UNRECOGNIZED", "language=UNRECOGNIZED") - ) + @Iteration("LANGUAGE_UNSPECIFIED", "language=LANGUAGE_UNSPECIFIED") + @Iteration("ARABIC", "language=ARABIC") + @Iteration("HINDI", "language=HINDI") + @Iteration("HINGLISH", "language=HINGLISH") + @Iteration("PORTUGUESE", "language=PORTUGUESE") + @Iteration("BRAZILIAN_PORTUGUESE", "language=BRAZILIAN_PORTUGUESE") + @Iteration("SWAHILI", "language=SWAHILI") + @Iteration("UNRECOGNIZED", "language=UNRECOGNIZED") fun testConvertToString_constExp_unsupportedLanguage_returnsNull() { val exp = parseAlgebraicExpression("2") val language = OppiaLanguage.valueOf(language) @@ -185,16 +182,14 @@ class MathExpressionAccessibilityUtilTest { } @Test - @RunParameterized( - Iteration("LANGUAGE_UNSPECIFIED", "language=LANGUAGE_UNSPECIFIED"), - Iteration("ARABIC", "language=ARABIC"), - Iteration("HINDI", "language=HINDI"), - Iteration("HINGLISH", "language=HINGLISH"), - Iteration("PORTUGUESE", "language=PORTUGUESE"), - Iteration("BRAZILIAN_PORTUGUESE", "language=BRAZILIAN_PORTUGUESE"), - Iteration("SWAHILI", "language=SWAHILI"), - Iteration("UNRECOGNIZED", "language=UNRECOGNIZED") - ) + @Iteration("LANGUAGE_UNSPECIFIED", "language=LANGUAGE_UNSPECIFIED") + @Iteration("ARABIC", "language=ARABIC") + @Iteration("HINDI", "language=HINDI") + @Iteration("HINGLISH", "language=HINGLISH") + @Iteration("PORTUGUESE", "language=PORTUGUESE") + @Iteration("BRAZILIAN_PORTUGUESE", "language=BRAZILIAN_PORTUGUESE") + @Iteration("SWAHILI", "language=SWAHILI") + @Iteration("UNRECOGNIZED", "language=UNRECOGNIZED") fun testConvertToString_constEq_unsupportedLanguage_returnsNull() { val eq = parseAlgebraicEquation("x=2") val language = OppiaLanguage.valueOf(language) @@ -216,14 +211,12 @@ class MathExpressionAccessibilityUtilTest { } @Test - @RunParameterized( - Iteration("2", "expression=2", "a11yStr=2"), - Iteration("123", "expression=123", "a11yStr=123"), - Iteration("1234", "expression=1234", "a11yStr=1,234"), - Iteration("12345", "expression=12345", "a11yStr=12,345"), - Iteration("123456", "expression=123456", "a11yStr=123,456"), - Iteration("1234567", "expression=1234567", "a11yStr=1,234,567") - ) + @Iteration("2", "expression=2", "a11yStr=2") + @Iteration("123", "expression=123", "a11yStr=123") + @Iteration("1234", "expression=1234", "a11yStr=1,234") + @Iteration("12345", "expression=12345", "a11yStr=12,345") + @Iteration("123456", "expression=123456", "a11yStr=123,456") + @Iteration("1234567", "expression=1234567", "a11yStr=1,234,567") fun testConvertToString_eng_constIntExp_returnsIntegerConvertedString() { val exp = parseAlgebraicExpression(expression) @@ -231,23 +224,21 @@ class MathExpressionAccessibilityUtilTest { } @Test - @RunParameterized( - // Note that some rounding occurs when formatting doubles with decimals. - Iteration("2.0", "expression=2.0", "a11yStr=2"), - Iteration("3.14", "expression=3.14", "a11yStr=3.14"), - Iteration( - "long_pi", "expression=3.14159265358979323846264338327950288419716939937510", "a11yStr=3.142" - ), - Iteration("1234.0", "expression=1234.0", "a11yStr=1,234"), - Iteration("12345.0", "expression=12345.0", "a11yStr=12,345"), - Iteration("123456.0", "expression=123456.0", "a11yStr=123,456"), - Iteration("1234567.0", "expression=1234567.0", "a11yStr=1,234,567"), - Iteration("1234567.987654321", "expression=1234567.987654321", "a11yStr=1,234,567.988"), - // Verify that scientific notation isn't used. - Iteration("small_number", "expression=0.000000000000000000001", "a11yStr=0"), - Iteration( - "large_number", "expression=123456789101112131415.0", "a11yStr=123,456,789,101,112,130,000" - ) + // Note that some rounding occurs when formatting doubles with decimals. + @Iteration("2.0", "expression=2.0", "a11yStr=2") + @Iteration("3.14", "expression=3.14", "a11yStr=3.14") + @Iteration( + "long_pi", "expression=3.14159265358979323846264338327950288419716939937510", "a11yStr=3.142" + ) + @Iteration("1234.0", "expression=1234.0", "a11yStr=1,234") + @Iteration("12345.0", "expression=12345.0", "a11yStr=12,345") + @Iteration("123456.0", "expression=123456.0", "a11yStr=123,456") + @Iteration("1234567.0", "expression=1234567.0", "a11yStr=1,234,567") + @Iteration("1234567.987654321", "expression=1234567.987654321", "a11yStr=1,234,567.988") + // Verify that scientific notation isn't used. + @Iteration("small_number", "expression=0.000000000000000000001", "a11yStr=0") + @Iteration( + "large_number", "expression=123456789101112131415.0", "a11yStr=123,456,789,101,112,130,000" ) fun testConvertToString_eng_constDoubleExp_returnsDoubleConvertedString() { val exp = parseAlgebraicExpression(expression) @@ -256,15 +247,13 @@ class MathExpressionAccessibilityUtilTest { } @Test - @RunParameterized( - Iteration("x", "expression=x", "a11yStr=x"), - Iteration("y", "expression=y", "a11yStr=y"), - Iteration("z", "expression=z", "a11yStr=zed"), - Iteration("X", "expression=X", "a11yStr=X"), - Iteration("Y", "expression=Y", "a11yStr=Y"), - Iteration("Z", "expression=Z", "a11yStr=Zed"), - Iteration("a", "expression=a", "a11yStr=a") - ) + @Iteration("x", "expression=x", "a11yStr=x") + @Iteration("y", "expression=y", "a11yStr=y") + @Iteration("z", "expression=z", "a11yStr=zed") + @Iteration("X", "expression=X", "a11yStr=X") + @Iteration("Y", "expression=Y", "a11yStr=Y") + @Iteration("Z", "expression=Z", "a11yStr=Zed") + @Iteration("a", "expression=a", "a11yStr=a") fun testConvertToString_eng_variableExp_returnsVariableNameWithZed() { val allowedVariables = listOf("a", "x", "y", "z", "X", "Y", "Z") val exp = parseAlgebraicExpression(expression, allowedVariables) @@ -273,13 +262,11 @@ class MathExpressionAccessibilityUtilTest { } @Test - @RunParameterized( - Iteration("1+2", "expression=1+2", "a11yStr=1 plus 2"), - Iteration("1+x", "expression=1+x", "a11yStr=1 plus x"), - Iteration("z+1234", "expression=z+1234", "a11yStr=zed plus 1,234"), - Iteration("z+3.14", "expression=z+3.14", "a11yStr=zed plus 3.14"), - Iteration("x+z", "expression=x+z", "a11yStr=x plus zed") - ) + @Iteration("1+2", "expression=1+2", "a11yStr=1 plus 2") + @Iteration("1+x", "expression=1+x", "a11yStr=1 plus x") + @Iteration("z+1234", "expression=z+1234", "a11yStr=zed plus 1,234") + @Iteration("z+3.14", "expression=z+3.14", "a11yStr=zed plus 3.14") + @Iteration("x+z", "expression=x+z", "a11yStr=x plus zed") fun testConvertToString_eng_addition_returnsLeftPlusRightString() { val exp = parseAlgebraicExpression(expression) @@ -287,13 +274,11 @@ class MathExpressionAccessibilityUtilTest { } @Test - @RunParameterized( - Iteration("1-2", "expression=1-2", "a11yStr=1 minus 2"), - Iteration("1-x", "expression=1-x", "a11yStr=1 minus x"), - Iteration("z-1234", "expression=z-1234", "a11yStr=zed minus 1,234"), - Iteration("z-3.14", "expression=z-3.14", "a11yStr=zed minus 3.14"), - Iteration("x-z", "expression=x-z", "a11yStr=x minus zed") - ) + @Iteration("1-2", "expression=1-2", "a11yStr=1 minus 2") + @Iteration("1-x", "expression=1-x", "a11yStr=1 minus x") + @Iteration("z-1234", "expression=z-1234", "a11yStr=zed minus 1,234") + @Iteration("z-3.14", "expression=z-3.14", "a11yStr=zed minus 3.14") + @Iteration("x-z", "expression=x-z", "a11yStr=x minus zed") fun testConvertToString_eng_subtraction_returnsLeftMinusRightString() { val exp = parseAlgebraicExpression(expression) @@ -301,13 +286,11 @@ class MathExpressionAccessibilityUtilTest { } @Test - @RunParameterized( - Iteration("1*2", "expression=1*2", "a11yStr=1 times 2"), - Iteration("1*x", "expression=1*x", "a11yStr=1 times x"), - Iteration("z*1234", "expression=z*1234", "a11yStr=zed times 1,234"), - Iteration("z*3.14", "expression=z*3.14", "a11yStr=zed times 3.14"), - Iteration("x*z", "expression=x*z", "a11yStr=x times zed") - ) + @Iteration("1*2", "expression=1*2", "a11yStr=1 times 2") + @Iteration("1*x", "expression=1*x", "a11yStr=1 times x") + @Iteration("z*1234", "expression=z*1234", "a11yStr=zed times 1,234") + @Iteration("z*3.14", "expression=z*3.14", "a11yStr=zed times 3.14") + @Iteration("x*z", "expression=x*z", "a11yStr=x times zed") fun testConvertToString_eng_multiplication_returnsLeftTimesRightString() { val exp = parseAlgebraicExpression(expression) @@ -315,13 +298,11 @@ class MathExpressionAccessibilityUtilTest { } @Test - @RunParameterized( - Iteration("1/2", "expression=1/2", "a11yStr=1 divided by 2"), - Iteration("1/x", "expression=1/x", "a11yStr=1 divided by x"), - Iteration("z/1234", "expression=z/1234", "a11yStr=zed divided by 1,234"), - Iteration("z/3.14", "expression=z/3.14", "a11yStr=zed divided by 3.14"), - Iteration("x/z", "expression=x/z", "a11yStr=x divided by zed") - ) + @Iteration("1/2", "expression=1/2", "a11yStr=1 divided by 2") + @Iteration("1/x", "expression=1/x", "a11yStr=1 divided by x") + @Iteration("z/1234", "expression=z/1234", "a11yStr=zed divided by 1,234") + @Iteration("z/3.14", "expression=z/3.14", "a11yStr=zed divided by 3.14") + @Iteration("x/z", "expression=x/z", "a11yStr=x divided by zed") fun testConvertToString_eng_division_returnsLeftDividedByRightString() { val exp = parseAlgebraicExpression(expression) @@ -329,13 +310,11 @@ class MathExpressionAccessibilityUtilTest { } @Test - @RunParameterized( - Iteration("1^2", "expression=1^2", "a11yStr=1 raised to the power of 2"), - Iteration("1^x", "expression=1^x", "a11yStr=1 raised to the power of x"), - Iteration("z^1234", "expression=z^1234", "a11yStr=zed raised to the power of 1,234"), - Iteration("z^3.14", "expression=z^3.14", "a11yStr=zed raised to the power of 3.14"), - Iteration("x^z", "expression=x^z", "a11yStr=x raised to the power of zed") - ) + @Iteration("1^2", "expression=1^2", "a11yStr=1 raised to the power of 2") + @Iteration("1^x", "expression=1^x", "a11yStr=1 raised to the power of x") + @Iteration("z^1234", "expression=z^1234", "a11yStr=zed raised to the power of 1,234") + @Iteration("z^3.14", "expression=z^3.14", "a11yStr=zed raised to the power of 3.14") + @Iteration("x^z", "expression=x^z", "a11yStr=x raised to the power of zed") fun testConvertToString_eng_exponentiation_returnsLeftRaisedToThePowerOfRightString() { // Some expressions may include variable terms as exponents (which normally isn't allowed). val exp = parseAlgebraicExpression(expression, errorCheckingMode = REQUIRED_ONLY) @@ -344,13 +323,11 @@ class MathExpressionAccessibilityUtilTest { } @Test - @RunParameterized( - Iteration("-2", "expression=-2", "a11yStr=negative 2"), - Iteration("-x", "expression=-x", "a11yStr=negative x"), - Iteration("-1234", "expression=-1234", "a11yStr=negative 1,234"), - Iteration("-3.14", "expression=-3.14", "a11yStr=negative 3.14"), - Iteration("-z", "expression=-z", "a11yStr=negative zed") - ) + @Iteration("-2", "expression=-2", "a11yStr=negative 2") + @Iteration("-x", "expression=-x", "a11yStr=negative x") + @Iteration("-1234", "expression=-1234", "a11yStr=negative 1,234") + @Iteration("-3.14", "expression=-3.14", "a11yStr=negative 3.14") + @Iteration("-z", "expression=-z", "a11yStr=negative zed") fun testConvertToString_eng_negation_returnsNegativeOperandString() { val exp = parseAlgebraicExpression(expression) @@ -358,13 +335,11 @@ class MathExpressionAccessibilityUtilTest { } @Test - @RunParameterized( - Iteration("+2", "expression=+2", "a11yStr=positive 2"), - Iteration("+x", "expression=+x", "a11yStr=positive x"), - Iteration("+1234", "expression=+1234", "a11yStr=positive 1,234"), - Iteration("+3.14", "expression=+3.14", "a11yStr=positive 3.14"), - Iteration("+z", "expression=+z", "a11yStr=positive zed") - ) + @Iteration("+2", "expression=+2", "a11yStr=positive 2") + @Iteration("+x", "expression=+x", "a11yStr=positive x") + @Iteration("+1234", "expression=+1234", "a11yStr=positive 1,234") + @Iteration("+3.14", "expression=+3.14", "a11yStr=positive 3.14") + @Iteration("+z", "expression=+z", "a11yStr=positive zed") fun testConvertToString_eng_positiveUnary_returnsPositiveOperandString() { // Allow positive unary operations to verify this case. val exp = parseAlgebraicExpression(expression, errorCheckingMode = REQUIRED_ONLY) @@ -373,18 +348,16 @@ class MathExpressionAccessibilityUtilTest { } @Test - @RunParameterized( - Iteration("√2", "expression=√2", "a11yStr=square root of 2"), - Iteration("√x", "expression=√x", "a11yStr=square root of x"), - Iteration("√z", "expression=√z", "a11yStr=square root of zed"), - Iteration("√1234", "expression=√1234", "a11yStr=square root of 1,234"), - Iteration("√3.14", "expression=√3.14", "a11yStr=square root of 3.14"), - Iteration("√(2)", "expression=√(2)", "a11yStr=square root of 2"), - Iteration("√(x)", "expression=√(x)", "a11yStr=square root of x"), - Iteration("√(z)", "expression=√(z)", "a11yStr=square root of zed"), - Iteration("√(1234)", "expression=√(1234)", "a11yStr=square root of 1,234"), - Iteration("√(3.14)", "expression=√(3.14)", "a11yStr=square root of 3.14") - ) + @Iteration("√2", "expression=√2", "a11yStr=square root of 2") + @Iteration("√x", "expression=√x", "a11yStr=square root of x") + @Iteration("√z", "expression=√z", "a11yStr=square root of zed") + @Iteration("√1234", "expression=√1234", "a11yStr=square root of 1,234") + @Iteration("√3.14", "expression=√3.14", "a11yStr=square root of 3.14") + @Iteration("√(2)", "expression=√(2)", "a11yStr=square root of 2") + @Iteration("√(x)", "expression=√(x)", "a11yStr=square root of x") + @Iteration("√(z)", "expression=√(z)", "a11yStr=square root of zed") + @Iteration("√(1234)", "expression=√(1234)", "a11yStr=square root of 1,234") + @Iteration("√(3.14)", "expression=√(3.14)", "a11yStr=square root of 3.14") fun testConvertToString_eng_inlineSqrt_returnsSquareRootOfArgumentString() { // Allow for single-term parentheses for testing (even though these cases would normally result // in errors). @@ -394,13 +367,11 @@ class MathExpressionAccessibilityUtilTest { } @Test - @RunParameterized( - Iteration("sqrt(2)", "expression=sqrt(2)", "a11yStr=square root of 2"), - Iteration("sqrt(x)", "expression=sqrt(x)", "a11yStr=square root of x"), - Iteration("sqrt(z)", "expression=sqrt(z)", "a11yStr=square root of zed"), - Iteration("sqrt(1234)", "expression=sqrt(1234)", "a11yStr=square root of 1,234"), - Iteration("sqrt(3.14)", "expression=sqrt(3.14)", "a11yStr=square root of 3.14") - ) + @Iteration("sqrt(2)", "expression=sqrt(2)", "a11yStr=square root of 2") + @Iteration("sqrt(x)", "expression=sqrt(x)", "a11yStr=square root of x") + @Iteration("sqrt(z)", "expression=sqrt(z)", "a11yStr=square root of zed") + @Iteration("sqrt(1234)", "expression=sqrt(1234)", "a11yStr=square root of 1,234") + @Iteration("sqrt(3.14)", "expression=sqrt(3.14)", "a11yStr=square root of 3.14") fun testConvertToString_eng_sqrt_returnsSquareRootOfArgumentString() { val exp = parseAlgebraicExpression(expression) @@ -408,22 +379,20 @@ class MathExpressionAccessibilityUtilTest { } @Test - @RunParameterized( - Iteration("(2)", "expression=(2)", "a11yStr=2"), - Iteration("(x)", "expression=(x)", "a11yStr=x"), - Iteration("(z)", "expression=(z)", "a11yStr=zed"), - Iteration("(1234)", "expression=(1234)", "a11yStr=1,234"), - Iteration("(3.14)", "expression=(3.14)", "a11yStr=3.14"), - Iteration("((2))", "expression=((2))", "a11yStr=2"), - Iteration("((x))", "expression=((x))", "a11yStr=x"), - Iteration("((z))", "expression=((z))", "a11yStr=zed"), - Iteration("((1234))", "expression=((1234))", "a11yStr=1,234"), - Iteration("((3.14))", "expression=((3.14))", "a11yStr=3.14"), - Iteration("(√2)", "expression=(√2)", "a11yStr=square root of 2"), - Iteration("(√x)", "expression=(√x)", "a11yStr=square root of x"), - Iteration("(sqrt(2))", "expression=(sqrt(2))", "a11yStr=square root of 2"), - Iteration("(sqrt(x))", "expression=(sqrt(x))", "a11yStr=square root of x") - ) + @Iteration("(2)", "expression=(2)", "a11yStr=2") + @Iteration("(x)", "expression=(x)", "a11yStr=x") + @Iteration("(z)", "expression=(z)", "a11yStr=zed") + @Iteration("(1234)", "expression=(1234)", "a11yStr=1,234") + @Iteration("(3.14)", "expression=(3.14)", "a11yStr=3.14") + @Iteration("((2))", "expression=((2))", "a11yStr=2") + @Iteration("((x))", "expression=((x))", "a11yStr=x") + @Iteration("((z))", "expression=((z))", "a11yStr=zed") + @Iteration("((1234))", "expression=((1234))", "a11yStr=1,234") + @Iteration("((3.14))", "expression=((3.14))", "a11yStr=3.14") + @Iteration("(√2)", "expression=(√2)", "a11yStr=square root of 2") + @Iteration("(√x)", "expression=(√x)", "a11yStr=square root of x") + @Iteration("(sqrt(2))", "expression=(sqrt(2))", "a11yStr=square root of 2") + @Iteration("(sqrt(x))", "expression=(sqrt(x))", "a11yStr=square root of x") fun testConvertToString_eng_group_singleTermOrNestedSingleTerm_returnsDirectString() { // Allow for single-term parentheses for testing (even though these cases would normally result // in errors). @@ -435,41 +404,39 @@ class MathExpressionAccessibilityUtilTest { } @Test - @RunParameterized( - Iteration("(1+2)", "expression=(1+2)", "a11yStr=open parenthesis 1 plus 2 close parenthesis"), - Iteration("(1+x)", "expression=(1+x)", "a11yStr=open parenthesis 1 plus x close parenthesis"), - Iteration("(1+z)", "expression=(1+z)", "a11yStr=open parenthesis 1 plus zed close parenthesis"), - Iteration( - "(1+1234)", "expression=(1+1234)", "a11yStr=open parenthesis 1 plus 1,234 close parenthesis" - ), - Iteration( - "(1+3.14)", "expression=(1+3.14)", "a11yStr=open parenthesis 1 plus 3.14 close parenthesis" - ), - Iteration("(1-2)", "expression=(1-2)", "a11yStr=open parenthesis 1 minus 2 close parenthesis"), - Iteration("(x-2)", "expression=(x-2)", "a11yStr=open parenthesis x minus 2 close parenthesis"), - Iteration("(1*2)", "expression=(1*2)", "a11yStr=open parenthesis 1 times 2 close parenthesis"), - Iteration("(x*2)", "expression=(x*2)", "a11yStr=open parenthesis x times 2 close parenthesis"), - Iteration( - "(1/2)", "expression=(1/2)", "a11yStr=open parenthesis 1 divided by 2 close parenthesis" - ), - Iteration( - "(x/2)", "expression=(x/2)", "a11yStr=open parenthesis x divided by 2 close parenthesis" - ), - Iteration( - "(1^2)", - "expression=(1^2)", - "a11yStr=open parenthesis 1 raised to the power of 2 close parenthesis" - ), - Iteration( - "(x^2)", - "expression=(x^2)", - "a11yStr=open parenthesis x raised to the power of 2 close parenthesis" - ), - Iteration("(-2)", "expression=(-2)", "a11yStr=open parenthesis negative 2 close parenthesis"), - Iteration("(-x)", "expression=(-x)", "a11yStr=open parenthesis negative x close parenthesis"), - Iteration("(+2)", "expression=(+2)", "a11yStr=open parenthesis positive 2 close parenthesis"), - Iteration("(+x)", "expression=(+x)", "a11yStr=open parenthesis positive x close parenthesis") + @Iteration("(1+2)", "expression=(1+2)", "a11yStr=open parenthesis 1 plus 2 close parenthesis") + @Iteration("(1+x)", "expression=(1+x)", "a11yStr=open parenthesis 1 plus x close parenthesis") + @Iteration("(1+z)", "expression=(1+z)", "a11yStr=open parenthesis 1 plus zed close parenthesis") + @Iteration( + "(1+1234)", "expression=(1+1234)", "a11yStr=open parenthesis 1 plus 1,234 close parenthesis" + ) + @Iteration( + "(1+3.14)", "expression=(1+3.14)", "a11yStr=open parenthesis 1 plus 3.14 close parenthesis" + ) + @Iteration("(1-2)", "expression=(1-2)", "a11yStr=open parenthesis 1 minus 2 close parenthesis") + @Iteration("(x-2)", "expression=(x-2)", "a11yStr=open parenthesis x minus 2 close parenthesis") + @Iteration("(1*2)", "expression=(1*2)", "a11yStr=open parenthesis 1 times 2 close parenthesis") + @Iteration("(x*2)", "expression=(x*2)", "a11yStr=open parenthesis x times 2 close parenthesis") + @Iteration( + "(1/2)", "expression=(1/2)", "a11yStr=open parenthesis 1 divided by 2 close parenthesis" + ) + @Iteration( + "(x/2)", "expression=(x/2)", "a11yStr=open parenthesis x divided by 2 close parenthesis" + ) + @Iteration( + "(1^2)", + "expression=(1^2)", + "a11yStr=open parenthesis 1 raised to the power of 2 close parenthesis" + ) + @Iteration( + "(x^2)", + "expression=(x^2)", + "a11yStr=open parenthesis x raised to the power of 2 close parenthesis" ) + @Iteration("(-2)", "expression=(-2)", "a11yStr=open parenthesis negative 2 close parenthesis") + @Iteration("(-x)", "expression=(-x)", "a11yStr=open parenthesis negative x close parenthesis") + @Iteration("(+2)", "expression=(+2)", "a11yStr=open parenthesis positive 2 close parenthesis") + @Iteration("(+x)", "expression=(+x)", "a11yStr=open parenthesis positive x close parenthesis") fun testConvertToString_eng_group_nestedOps_returnOpenParensOpCloseParensString() { // Allow for the outer expression to have redundant parentheses to test cases when groups are // announced (even though these exact cases would normally result in an error). @@ -479,85 +446,83 @@ class MathExpressionAccessibilityUtilTest { } @Test - @RunParameterized( - Iteration("√-2", "expression=√-2", "a11yStr=start square root negative 2 end square root"), - Iteration("√-x", "expression=√-x", "a11yStr=start square root negative x end square root"), - Iteration("√+2", "expression=√+2", "a11yStr=start square root positive 2 end square root"), - Iteration("√+x", "expression=√+x", "a11yStr=start square root positive x end square root"), - // Note that these cases compose with the group cases since √ only "attached" to the immediate - // next terms rather than being able to encapsulate a whole operation (like sqrt()). - Iteration( - "√(1+2)", - "expression=√(1+2)", - "a11yStr=start square root open parenthesis 1 plus 2 close parenthesis end square root" - ), - Iteration( - "√(1+x)", - "expression=√(1+x)", - "a11yStr=start square root open parenthesis 1 plus x close parenthesis end square root" - ), - Iteration( - "√(1-2)", - "expression=√(1-2)", - "a11yStr=start square root open parenthesis 1 minus 2 close parenthesis end square root" - ), - Iteration( - "√(1-x)", - "expression=√(1-x)", - "a11yStr=start square root open parenthesis 1 minus x close parenthesis end square root" - ), - Iteration( - "√(1*2)", - "expression=√(1*2)", - "a11yStr=start square root open parenthesis 1 times 2 close parenthesis end square root" - ), - Iteration( - "√(1*x)", - "expression=√(1*x)", - "a11yStr=start square root open parenthesis 1 times x close parenthesis end square root" - ), - Iteration( - "√(1/2)", - "expression=√(1/2)", - "a11yStr=start square root open parenthesis 1 divided by 2 close parenthesis end square root" - ), - Iteration( - "√(1/x)", - "expression=√(1/x)", - "a11yStr=start square root open parenthesis 1 divided by x close parenthesis end square root" - ), - Iteration( - "√(1^2)", - "expression=√(1^2)", - "a11yStr=start square root open parenthesis 1 raised to the power of 2 close parenthesis" + - " end square root" - ), - Iteration( - "√(1^x)", - "expression=√(1^x)", - "a11yStr=start square root open parenthesis 1 raised to the power of x close parenthesis" + - " end square root" - ), - Iteration( - "√(-2)", - "expression=√(-2)", - "a11yStr=start square root open parenthesis negative 2 close parenthesis end square root" - ), - Iteration( - "√(-x)", - "expression=√(-x)", - "a11yStr=start square root open parenthesis negative x close parenthesis end square root" - ), - Iteration( - "√(+2)", - "expression=√(+2)", - "a11yStr=start square root open parenthesis positive 2 close parenthesis end square root" - ), - Iteration( - "√(+x)", - "expression=√(+x)", - "a11yStr=start square root open parenthesis positive x close parenthesis end square root" - ) + @Iteration("√-2", "expression=√-2", "a11yStr=start square root negative 2 end square root") + @Iteration("√-x", "expression=√-x", "a11yStr=start square root negative x end square root") + @Iteration("√+2", "expression=√+2", "a11yStr=start square root positive 2 end square root") + @Iteration("√+x", "expression=√+x", "a11yStr=start square root positive x end square root") + // Note that these cases compose with the group cases since √ only "attached" to the immediate + // next terms rather than being able to encapsulate a whole operation (like sqrt()). + @Iteration( + "√(1+2)", + "expression=√(1+2)", + "a11yStr=start square root open parenthesis 1 plus 2 close parenthesis end square root" + ) + @Iteration( + "√(1+x)", + "expression=√(1+x)", + "a11yStr=start square root open parenthesis 1 plus x close parenthesis end square root" + ) + @Iteration( + "√(1-2)", + "expression=√(1-2)", + "a11yStr=start square root open parenthesis 1 minus 2 close parenthesis end square root" + ) + @Iteration( + "√(1-x)", + "expression=√(1-x)", + "a11yStr=start square root open parenthesis 1 minus x close parenthesis end square root" + ) + @Iteration( + "√(1*2)", + "expression=√(1*2)", + "a11yStr=start square root open parenthesis 1 times 2 close parenthesis end square root" + ) + @Iteration( + "√(1*x)", + "expression=√(1*x)", + "a11yStr=start square root open parenthesis 1 times x close parenthesis end square root" + ) + @Iteration( + "√(1/2)", + "expression=√(1/2)", + "a11yStr=start square root open parenthesis 1 divided by 2 close parenthesis end square root" + ) + @Iteration( + "√(1/x)", + "expression=√(1/x)", + "a11yStr=start square root open parenthesis 1 divided by x close parenthesis end square root" + ) + @Iteration( + "√(1^2)", + "expression=√(1^2)", + "a11yStr=start square root open parenthesis 1 raised to the power of 2 close parenthesis" + + " end square root" + ) + @Iteration( + "√(1^x)", + "expression=√(1^x)", + "a11yStr=start square root open parenthesis 1 raised to the power of x close parenthesis" + + " end square root" + ) + @Iteration( + "√(-2)", + "expression=√(-2)", + "a11yStr=start square root open parenthesis negative 2 close parenthesis end square root" + ) + @Iteration( + "√(-x)", + "expression=√(-x)", + "a11yStr=start square root open parenthesis negative x close parenthesis end square root" + ) + @Iteration( + "√(+2)", + "expression=√(+2)", + "a11yStr=start square root open parenthesis positive 2 close parenthesis end square root" + ) + @Iteration( + "√(+x)", + "expression=√(+x)", + "a11yStr=start square root open parenthesis positive x close parenthesis end square root" ) fun testConvertToString_eng_inlineSqrt_nestedOp_returnsStartSquareRootConstructString() { // Allow for positive unary expressions. @@ -567,57 +532,55 @@ class MathExpressionAccessibilityUtilTest { } @Test - @RunParameterized( - Iteration( - "sqrt(1+2)", "expression=sqrt(1+2)", "a11yStr=start square root 1 plus 2 end square root" - ), - Iteration( - "sqrt(1+x)", "expression=sqrt(1+x)", "a11yStr=start square root 1 plus x end square root" - ), - Iteration( - "sqrt(1-2)", "expression=sqrt(1-2)", "a11yStr=start square root 1 minus 2 end square root" - ), - Iteration( - "sqrt(1-x)", "expression=sqrt(1-x)", "a11yStr=start square root 1 minus x end square root" - ), - Iteration( - "sqrt(1*2)", "expression=sqrt(1*2)", "a11yStr=start square root 1 times 2 end square root" - ), - Iteration( - "sqrt(1*x)", "expression=sqrt(1*x)", "a11yStr=start square root 1 times x end square root" - ), - Iteration( - "sqrt(1/2)", - "expression=sqrt(1/2)", - "a11yStr=start square root 1 divided by 2 end square root" - ), - Iteration( - "sqrt(1/x)", - "expression=sqrt(1/x)", - "a11yStr=start square root 1 divided by x end square root" - ), - Iteration( - "sqrt(1^2)", - "expression=sqrt(1^2)", - "a11yStr=start square root 1 raised to the power of 2 end square root" - ), - Iteration( - "sqrt(1^x)", - "expression=sqrt(1^x)", - "a11yStr=start square root 1 raised to the power of x end square root" - ), - Iteration( - "sqrt(-2)", "expression=sqrt(-2)", "a11yStr=start square root negative 2 end square root" - ), - Iteration( - "sqrt(-x)", "expression=sqrt(-x)", "a11yStr=start square root negative x end square root" - ), - Iteration( - "sqrt(+2)", "expression=sqrt(+2)", "a11yStr=start square root positive 2 end square root" - ), - Iteration( - "sqrt(+x)", "expression=sqrt(+x)", "a11yStr=start square root positive x end square root" - ) + @Iteration( + "sqrt(1+2)", "expression=sqrt(1+2)", "a11yStr=start square root 1 plus 2 end square root" + ) + @Iteration( + "sqrt(1+x)", "expression=sqrt(1+x)", "a11yStr=start square root 1 plus x end square root" + ) + @Iteration( + "sqrt(1-2)", "expression=sqrt(1-2)", "a11yStr=start square root 1 minus 2 end square root" + ) + @Iteration( + "sqrt(1-x)", "expression=sqrt(1-x)", "a11yStr=start square root 1 minus x end square root" + ) + @Iteration( + "sqrt(1*2)", "expression=sqrt(1*2)", "a11yStr=start square root 1 times 2 end square root" + ) + @Iteration( + "sqrt(1*x)", "expression=sqrt(1*x)", "a11yStr=start square root 1 times x end square root" + ) + @Iteration( + "sqrt(1/2)", + "expression=sqrt(1/2)", + "a11yStr=start square root 1 divided by 2 end square root" + ) + @Iteration( + "sqrt(1/x)", + "expression=sqrt(1/x)", + "a11yStr=start square root 1 divided by x end square root" + ) + @Iteration( + "sqrt(1^2)", + "expression=sqrt(1^2)", + "a11yStr=start square root 1 raised to the power of 2 end square root" + ) + @Iteration( + "sqrt(1^x)", + "expression=sqrt(1^x)", + "a11yStr=start square root 1 raised to the power of x end square root" + ) + @Iteration( + "sqrt(-2)", "expression=sqrt(-2)", "a11yStr=start square root negative 2 end square root" + ) + @Iteration( + "sqrt(-x)", "expression=sqrt(-x)", "a11yStr=start square root negative x end square root" + ) + @Iteration( + "sqrt(+2)", "expression=sqrt(+2)", "a11yStr=start square root positive 2 end square root" + ) + @Iteration( + "sqrt(+x)", "expression=sqrt(+x)", "a11yStr=start square root positive x end square root" ) fun testConvertToString_eng_sqrt_nestedOp_returnsStartSquareRootConstructString() { // Allow for positive unary expressions. @@ -627,15 +590,13 @@ class MathExpressionAccessibilityUtilTest { } @Test - @RunParameterized( - // Note that numeric exponentiations must be explicitly multiplied next to a constant. They - // otherwise result in a grammatical error that cannot be resolved. - Iteration("2x", "expression=2x", "a11yStr=2 x"), - Iteration("2z", "expression=2z", "a11yStr=2 zed"), - Iteration("2x^3", "expression=2x^3", "a11yStr=2 x raised to the power of 3"), - Iteration("2z^3", "expression=2z^3", "a11yStr=2 zed raised to the power of 3"), - Iteration("1234x^3.14", "expression=1234x^3.14", "a11yStr=1,234 x raised to the power of 3.14") - ) + // Note that numeric exponentiations must be explicitly multiplied next to a constant. They + // otherwise result in a grammatical error that cannot be resolved. + @Iteration("2x", "expression=2x", "a11yStr=2 x") + @Iteration("2z", "expression=2z", "a11yStr=2 zed") + @Iteration("2x^3", "expression=2x^3", "a11yStr=2 x raised to the power of 3") + @Iteration("2z^3", "expression=2z^3", "a11yStr=2 zed raised to the power of 3") + @Iteration("1234x^3.14", "expression=1234x^3.14", "a11yStr=1,234 x raised to the power of 3.14") fun testConvertToString_eng_implicitMult_leftConst_rightVarOrExp_returnsLeftRightString() { val exp = parseAlgebraicExpression(expression) @@ -645,18 +606,16 @@ class MathExpressionAccessibilityUtilTest { } @Test - @RunParameterized( - Iteration("xz", "expression=xz", "a11yStr=x times zed"), - Iteration("2xy", "expression=2yx", "a11yStr=2 y times x"), - Iteration("2√x", "expression=2√x", "a11yStr=2 times square root of x"), - Iteration("2sqrt(x)", "expression=2sqrt(x)", "a11yStr=2 times square root of x"), - Iteration("2(3)", "expression=2(3)", "a11yStr=2 times 3"), - Iteration("2(x)", "expression=2(x)", "a11yStr=2 times x"), - Iteration( - "2(x^3)", - "expression=2(x^3)", - "a11yStr=2 times open parenthesis x raised to the power of 3 close parenthesis" - ) + @Iteration("xz", "expression=xz", "a11yStr=x times zed") + @Iteration("2xy", "expression=2yx", "a11yStr=2 y times x") + @Iteration("2√x", "expression=2√x", "a11yStr=2 times square root of x") + @Iteration("2sqrt(x)", "expression=2sqrt(x)", "a11yStr=2 times square root of x") + @Iteration("2(3)", "expression=2(3)", "a11yStr=2 times 3") + @Iteration("2(x)", "expression=2(x)", "a11yStr=2 times x") + @Iteration( + "2(x^3)", + "expression=2(x^3)", + "a11yStr=2 times open parenthesis x raised to the power of 3 close parenthesis" ) fun testConvertToString_eng_impMult_nonLeftConst_orRightIsNotVarOrExp_returnsLeftTimesRightStr() { // Allow for redundant single-term parentheses. @@ -678,22 +637,20 @@ class MathExpressionAccessibilityUtilTest { } @Test - @RunParameterized( - Iteration("0/1", "expression=0/1", "a11yStr=0 over 1"), - Iteration("1/1", "expression=1/1", "a11yStr=1 over 1"), - Iteration("0/2", "expression=0/2", "a11yStr=0 over 2"), - Iteration("2/2", "expression=2/2", "a11yStr=2 over 2"), - Iteration("0/3", "expression=0/3", "a11yStr=0 over 3"), - Iteration("1/3", "expression=1/3", "a11yStr=1 over 3"), - Iteration("2/3", "expression=2/3", "a11yStr=2 over 3"), - Iteration("3/3", "expression=3/3", "a11yStr=3 over 3"), - Iteration("4/3", "expression=4/3", "a11yStr=4 over 3"), - Iteration("5/3", "expression=5/3", "a11yStr=5 over 3"), - Iteration("6/3", "expression=6/3", "a11yStr=6 over 3"), - Iteration("5/9", "expression=5/9", "a11yStr=5 over 9"), - Iteration("19/3", "expression=19/3", "a11yStr=19 over 3"), - Iteration("2/17", "expression=2/17", "a11yStr=2 over 17") - ) + @Iteration("0/1", "expression=0/1", "a11yStr=0 over 1") + @Iteration("1/1", "expression=1/1", "a11yStr=1 over 1") + @Iteration("0/2", "expression=0/2", "a11yStr=0 over 2") + @Iteration("2/2", "expression=2/2", "a11yStr=2 over 2") + @Iteration("0/3", "expression=0/3", "a11yStr=0 over 3") + @Iteration("1/3", "expression=1/3", "a11yStr=1 over 3") + @Iteration("2/3", "expression=2/3", "a11yStr=2 over 3") + @Iteration("3/3", "expression=3/3", "a11yStr=3 over 3") + @Iteration("4/3", "expression=4/3", "a11yStr=4 over 3") + @Iteration("5/3", "expression=5/3", "a11yStr=5 over 3") + @Iteration("6/3", "expression=6/3", "a11yStr=6 over 3") + @Iteration("5/9", "expression=5/9", "a11yStr=5 over 9") + @Iteration("19/3", "expression=19/3", "a11yStr=19 over 3") + @Iteration("2/17", "expression=2/17", "a11yStr=2 over 17") fun testConvertToString_eng_divisionAsFractions_smallIntegerFracs_returnsNumOverDenomString() { val exp = parseAlgebraicExpression(expression) @@ -701,11 +658,9 @@ class MathExpressionAccessibilityUtilTest { } @Test - @RunParameterized( - Iteration("1/1234", "expression=1/1234", "a11yStr=1 over 1,234"), - Iteration("1234/1", "expression=1234/1", "a11yStr=1,234 over 1"), - Iteration("1234/987654", "expression=1234/987654", "a11yStr=1,234 over 987,654") - ) + @Iteration("1/1234", "expression=1/1234", "a11yStr=1 over 1,234") + @Iteration("1234/1", "expression=1234/1", "a11yStr=1,234 over 1") + @Iteration("1234/987654", "expression=1234/987654", "a11yStr=1,234 over 987,654") fun testConvertToString_eng_divisionAsFractions_largeIntegerFracs_returnsNumOverDenomString() { val exp = parseAlgebraicExpression(expression) @@ -714,13 +669,11 @@ class MathExpressionAccessibilityUtilTest { } @Test - @RunParameterized( - Iteration("1/x", "expression=1/x", "a11yStr=1 over x"), - Iteration("1/z", "expression=1/z", "a11yStr=1 over zed"), - Iteration("x/2", "expression=x/2", "a11yStr=x over 2"), - Iteration("z/3", "expression=z/3", "a11yStr=zed over 3"), - Iteration("x/z", "expression=x/z", "a11yStr=x over zed") - ) + @Iteration("1/x", "expression=1/x", "a11yStr=1 over x") + @Iteration("1/z", "expression=1/z", "a11yStr=1 over zed") + @Iteration("x/2", "expression=x/2", "a11yStr=x over 2") + @Iteration("z/3", "expression=z/3", "a11yStr=zed over 3") + @Iteration("x/z", "expression=x/z", "a11yStr=x over zed") fun testConvertToString_eng_divisionAsFractions_fracsWithVariables_returnsNumOverDenomString() { val exp = parseAlgebraicExpression(expression) @@ -729,48 +682,46 @@ class MathExpressionAccessibilityUtilTest { } @Test - @RunParameterized( - Iteration( - "x/√2", - "expression=x/√2", - "a11yStr=the fraction with numerator x and denominator square root of 2" - ), - Iteration( - "x/-2", - "expression=x/-2", - "a11yStr=the fraction with numerator x and denominator negative 2" - ), - Iteration( - "2/(1+2)", - "expression=2/(1+2)", - "a11yStr=the fraction with numerator 2 and denominator open parenthesis 1 plus 2 close" + - " parenthesis" - ), - // Nested fractions still cause the outer fraction to be read out the long way. - Iteration( - "2/(1/2)", - "expression=2/(1/2)", - "a11yStr=the fraction with numerator 2 and denominator open parenthesis one half close" + - " parenthesis" - ), - Iteration( - "2/(1/3)", - "expression=2/(1/3)", - "a11yStr=the fraction with numerator 2 and denominator open parenthesis 1 over 3 close" + - " parenthesis" - ), - Iteration( - "x/sqrt(y/3)", - "expression=x/sqrt(y/3)", - "a11yStr=the fraction with numerator x and denominator start square root y over 3 end" + - " square root" - ), - Iteration( - "3.14/x", "expression=3.14/x", "a11yStr=the fraction with numerator 3.14 and denominator x" - ), - Iteration( - "x/3.14", "expression=x/3.14", "a11yStr=the fraction with numerator x and denominator 3.14" - ) + @Iteration( + "x/√2", + "expression=x/√2", + "a11yStr=the fraction with numerator x and denominator square root of 2" + ) + @Iteration( + "x/-2", + "expression=x/-2", + "a11yStr=the fraction with numerator x and denominator negative 2" + ) + @Iteration( + "2/(1+2)", + "expression=2/(1+2)", + "a11yStr=the fraction with numerator 2 and denominator open parenthesis 1 plus 2 close" + + " parenthesis" + ) + // Nested fractions still cause the outer fraction to be read out the long way. + @Iteration( + "2/(1/2)", + "expression=2/(1/2)", + "a11yStr=the fraction with numerator 2 and denominator open parenthesis one half close" + + " parenthesis" + ) + @Iteration( + "2/(1/3)", + "expression=2/(1/3)", + "a11yStr=the fraction with numerator 2 and denominator open parenthesis 1 over 3 close" + + " parenthesis" + ) + @Iteration( + "x/sqrt(y/3)", + "expression=x/sqrt(y/3)", + "a11yStr=the fraction with numerator x and denominator start square root y over 3 end" + + " square root" + ) + @Iteration( + "3.14/x", "expression=3.14/x", "a11yStr=the fraction with numerator 3.14 and denominator x" + ) + @Iteration( + "x/3.14", "expression=x/3.14", "a11yStr=the fraction with numerator x and denominator 3.14" ) fun testConvertToString_eng_divisionAsFractions_fracWithComplexParts_returnsFracConstructStr() { val exp = parseAlgebraicExpression(expression) @@ -780,14 +731,12 @@ class MathExpressionAccessibilityUtilTest { } @Test - @RunParameterized( - Iteration("1=2", "expression=1=2", "a11yStr=1 equals 2"), - Iteration("x=1", "expression=x=1", "a11yStr=x equals 1"), - Iteration("z=1", "expression=z=1", "a11yStr=zed equals 1"), - Iteration("2=x", "expression=2=x", "a11yStr=2 equals x"), - Iteration("2=z", "expression=2=z", "a11yStr=2 equals zed"), - Iteration("x=z", "expression=x=z", "a11yStr=x equals zed") - ) + @Iteration("1=2", "expression=1=2", "a11yStr=1 equals 2") + @Iteration("x=1", "expression=x=1", "a11yStr=x equals 1") + @Iteration("z=1", "expression=z=1", "a11yStr=zed equals 1") + @Iteration("2=x", "expression=2=x", "a11yStr=2 equals x") + @Iteration("2=z", "expression=2=z", "a11yStr=2 equals zed") + @Iteration("x=z", "expression=x=z", "a11yStr=x equals zed") fun testConvertToString_eng_simpleEquation_returnsLeftEqualsRightString() { val eq = parseAlgebraicEquation(expression) @@ -795,19 +744,17 @@ class MathExpressionAccessibilityUtilTest { } @Test - @RunParameterized( - Iteration("xyz", "expression=xyz", "a11yStr=x times y times zed"), - Iteration("1+x+x^2", "expression=1+x+x^2", "a11yStr=1 plus x plus x raised to the power of 2"), - Iteration( - "-3x^2+23x-14", - "expression=-3x^2+23x-14", - "a11yStr=negative 3 times x raised to the power of 2 plus 23 x minus 14" - ), - Iteration( - "y^2+xy+x^2", - "expression=y^2+xy+x^2", - "a11yStr=y raised to the power of 2 plus x times y plus x raised to the power of 2" - ) + @Iteration("xyz", "expression=xyz", "a11yStr=x times y times zed") + @Iteration("1+x+x^2", "expression=1+x+x^2", "a11yStr=1 plus x plus x raised to the power of 2") + @Iteration( + "-3x^2+23x-14", + "expression=-3x^2+23x-14", + "a11yStr=negative 3 times x raised to the power of 2 plus 23 x minus 14" + ) + @Iteration( + "y^2+xy+x^2", + "expression=y^2+xy+x^2", + "a11yStr=y raised to the power of 2 plus x times y plus x raised to the power of 2" ) fun testConvertToString_eng_polynomialExpressions_returnsCorrectlyBuiltString() { val exp = parseAlgebraicExpression(expression) @@ -817,25 +764,23 @@ class MathExpressionAccessibilityUtilTest { } @Test - @RunParameterized( - Iteration("z=xyz", "expression=z=xyz", "a11yStr=zed equals x times y times zed"), - Iteration( - "y=1+x+x^2", - "expression=y=1+x+x^2", - "a11yStr=y equals 1 plus x plus x raised to the power of 2" - ), - Iteration( - "-3x^2+23x-14=7y^3", - "expression=-3x^2+23x-14=7y^3", - "a11yStr=negative 3 times x raised to the power of 2 plus 23 x minus 14 equals 7 y raised" + - " to the power of 3" - ), - Iteration( - "sqrt(z)=y^2+xy+x^2", - "expression=sqrt(z)=y^2+xy+x^2", - "a11yStr=square root of zed equals y raised to the power of 2 plus x times y plus x raised" + - " to the power of 2" - ) + @Iteration("z=xyz", "expression=z=xyz", "a11yStr=zed equals x times y times zed") + @Iteration( + "y=1+x+x^2", + "expression=y=1+x+x^2", + "a11yStr=y equals 1 plus x plus x raised to the power of 2" + ) + @Iteration( + "-3x^2+23x-14=7y^3", + "expression=-3x^2+23x-14=7y^3", + "a11yStr=negative 3 times x raised to the power of 2 plus 23 x minus 14 equals 7 y raised" + + " to the power of 3" + ) + @Iteration( + "sqrt(z)=y^2+xy+x^2", + "expression=sqrt(z)=y^2+xy+x^2", + "a11yStr=square root of zed equals y raised to the power of 2 plus x times y plus x raised" + + " to the power of 2" ) fun testConvertToString_eng_polynomialEquations_returnsCorrectlyBuiltString() { val eq = parseAlgebraicEquation(expression) @@ -845,50 +790,48 @@ class MathExpressionAccessibilityUtilTest { } @Test - @RunParameterized( - Iteration( - "(x^2+2x+1)/(x+1)", - "expression= ( x^2 + 2x + 1 ) /( x + 1)", - "a11yStr=open parenthesis x raised to the power of 2 plus 2 x plus 1 close parenthesis" + - " divided by open parenthesis x plus 1 close parenthesis" - ), - Iteration( - "(1/2)x", - "expression=(1/2) x", - "a11yStr=open parenthesis 1 divided by 2 close parenthesis times x" - ), - Iteration( - "(-27x^3)^(1/3)", - "expression=(\t-27x\n^3\r)^(1 / 3) ", - "a11yStr=open parenthesis negative 27 times x raised to the power of 3 close parenthesis" + - " raised to the power of open parenthesis 1 divided by 3 close parenthesis" - ), - Iteration( - "(4x^2)^(-1/2)", - "expression=( 4x ^ 2) ^ ( - 1 / 2 ) ", - "a11yStr=open parenthesis 4 x raised to the power of 2 close parenthesis raised to the" + - " power of open parenthesis negative 1 divided by 2 close parenthesis" - ), - Iteration( - "sqrt(sqrt(sqrt(x)+1))", - "expression=sqrt( sqrt( sqrt( x ) + 1 ) )", - "a11yStr=square root of start square root square root of x plus 1 end square root" - ), - Iteration( - "x-(1+(y-(2+z)))", - "expression= x - ( 1 + ( y - ( 2 + z )))", - "a11yStr=x minus open parenthesis 1 plus open parenthesis y minus open parenthesis 2 plus" + - " zed close parenthesis close parenthesis close parenthesis" - ), - Iteration( - "1/(2/(y+3/z))", - "expression=1 / ( 2 / ( y + 3/z ) )", - "a11yStr=1 divided by open parenthesis 2 divided by open parenthesis y plus 3 divided by" + - " zed close parenthesis close parenthesis" - ), - Iteration( - "x/y/z/2", "expression= x/ y/ z/ 2", "a11yStr=x divided by y divided by zed divided by 2" - ) + @Iteration( + "(x^2+2x+1)/(x+1)", + "expression= ( x^2 + 2x + 1 ) /( x + 1)", + "a11yStr=open parenthesis x raised to the power of 2 plus 2 x plus 1 close parenthesis" + + " divided by open parenthesis x plus 1 close parenthesis" + ) + @Iteration( + "(1/2)x", + "expression=(1/2) x", + "a11yStr=open parenthesis 1 divided by 2 close parenthesis times x" + ) + @Iteration( + "(-27x^3)^(1/3)", + "expression=(\t-27x\n^3\r)^(1 / 3) ", + "a11yStr=open parenthesis negative 27 times x raised to the power of 3 close parenthesis" + + " raised to the power of open parenthesis 1 divided by 3 close parenthesis" + ) + @Iteration( + "(4x^2)^(-1/2)", + "expression=( 4x ^ 2) ^ ( - 1 / 2 ) ", + "a11yStr=open parenthesis 4 x raised to the power of 2 close parenthesis raised to the" + + " power of open parenthesis negative 1 divided by 2 close parenthesis" + ) + @Iteration( + "sqrt(sqrt(sqrt(x)+1))", + "expression=sqrt( sqrt( sqrt( x ) + 1 ) )", + "a11yStr=square root of start square root square root of x plus 1 end square root" + ) + @Iteration( + "x-(1+(y-(2+z)))", + "expression= x - ( 1 + ( y - ( 2 + z )))", + "a11yStr=x minus open parenthesis 1 plus open parenthesis y minus open parenthesis 2 plus" + + " zed close parenthesis close parenthesis close parenthesis" + ) + @Iteration( + "1/(2/(y+3/z))", + "expression=1 / ( 2 / ( y + 3/z ) )", + "a11yStr=1 divided by open parenthesis 2 divided by open parenthesis y plus 3 divided by" + + " zed close parenthesis close parenthesis" + ) + @Iteration( + "x/y/z/2", "expression= x/ y/ z/ 2", "a11yStr=x divided by y divided by zed divided by 2" ) fun testConvertToString_eng_complexNestedExpression_returnsCorrectlyBuiltString() { val exp = parseAlgebraicExpression(expression) @@ -899,53 +842,51 @@ class MathExpressionAccessibilityUtilTest { } @Test - @RunParameterized( - Iteration( - "(x^2+2x+1)/(x+1)", - "expression= ( x^2 + 2x + 1 ) /( x + 1)", - "a11yStr=the fraction with numerator open parenthesis x raised to the power of 2 plus 2 x" + - " plus 1 close parenthesis and denominator open parenthesis x plus 1 close parenthesis" - ), - Iteration( - "(1/2)x", "expression=(1/2) x", "a11yStr=open parenthesis one half close parenthesis times x" - ), - Iteration( - "(-27x^3)^(1/3)", - "expression=(\t-27x\n^3\r)^(1 / 3) ", - "a11yStr=open parenthesis negative 27 times x raised to the power of 3 close parenthesis" + - " raised to the power of open parenthesis 1 over 3 close parenthesis" - ), - Iteration( - "(4x^2)^(-1/2)", - "expression=( 4x ^ 2) ^ ( - 1 / 2 ) ", - "a11yStr=open parenthesis 4 x raised to the power of 2 close parenthesis raised to the" + - " power of open parenthesis the fraction with numerator negative 1 and denominator 2" + - " close parenthesis" - ), - Iteration( - "sqrt(sqrt(sqrt(x)+1))", - "expression=sqrt( sqrt( sqrt( x ) + 1 ) )", - "a11yStr=square root of start square root square root of x plus 1 end square root" - ), - Iteration( - "x-(1+(y-(2+z)))", - "expression= x - ( 1 + ( y - ( 2 + z )))", - "a11yStr=x minus open parenthesis 1 plus open parenthesis y minus open parenthesis 2 plus" + - " zed close parenthesis close parenthesis close parenthesis" - ), - Iteration( - "1/(2/(y+3/z))", - "expression=1 / ( 2 / ( y + 3/z ) )", - "a11yStr=the fraction with numerator 1 and denominator open parenthesis the fraction with" + - " numerator 2 and denominator open parenthesis y plus 3 over zed close parenthesis" + - " close parenthesis" - ), - Iteration( - "x/y/z/2", - "expression= x/ y/ z/ 2", - "a11yStr=the fraction with numerator the fraction with numerator x over y and denominator" + - " zed and denominator 2" - ) + @Iteration( + "(x^2+2x+1)/(x+1)", + "expression= ( x^2 + 2x + 1 ) /( x + 1)", + "a11yStr=the fraction with numerator open parenthesis x raised to the power of 2 plus 2 x" + + " plus 1 close parenthesis and denominator open parenthesis x plus 1 close parenthesis" + ) + @Iteration( + "(1/2)x", "expression=(1/2) x", "a11yStr=open parenthesis one half close parenthesis times x" + ) + @Iteration( + "(-27x^3)^(1/3)", + "expression=(\t-27x\n^3\r)^(1 / 3) ", + "a11yStr=open parenthesis negative 27 times x raised to the power of 3 close parenthesis" + + " raised to the power of open parenthesis 1 over 3 close parenthesis" + ) + @Iteration( + "(4x^2)^(-1/2)", + "expression=( 4x ^ 2) ^ ( - 1 / 2 ) ", + "a11yStr=open parenthesis 4 x raised to the power of 2 close parenthesis raised to the" + + " power of open parenthesis the fraction with numerator negative 1 and denominator 2" + + " close parenthesis" + ) + @Iteration( + "sqrt(sqrt(sqrt(x)+1))", + "expression=sqrt( sqrt( sqrt( x ) + 1 ) )", + "a11yStr=square root of start square root square root of x plus 1 end square root" + ) + @Iteration( + "x-(1+(y-(2+z)))", + "expression= x - ( 1 + ( y - ( 2 + z )))", + "a11yStr=x minus open parenthesis 1 plus open parenthesis y minus open parenthesis 2 plus" + + " zed close parenthesis close parenthesis close parenthesis" + ) + @Iteration( + "1/(2/(y+3/z))", + "expression=1 / ( 2 / ( y + 3/z ) )", + "a11yStr=the fraction with numerator 1 and denominator open parenthesis the fraction with" + + " numerator 2 and denominator open parenthesis y plus 3 over zed close parenthesis" + + " close parenthesis" + ) + @Iteration( + "x/y/z/2", + "expression= x/ y/ z/ 2", + "a11yStr=the fraction with numerator the fraction with numerator x over y and denominator" + + " zed and denominator 2" ) fun testConvertToString_eng_complexNestedExpression_divAsFracs_returnsCorrectlyBuiltString() { val exp = parseAlgebraicExpression(expression) @@ -956,54 +897,52 @@ class MathExpressionAccessibilityUtilTest { } @Test - @RunParameterized( - Iteration( - "y=(x^2+2x+1)/(x+1)", - "expression= y = ( x^2 + 2x + 1 ) /( x + 1)", - "a11yStr=y equals open parenthesis x raised to the power of 2 plus 2 x plus 1 close" + - " parenthesis divided by open parenthesis x plus 1 close parenthesis" - ), - Iteration( - "(1/2)x=sqrt(x)", - "expression=(1/2) x =sqrt (x)", - "a11yStr=open parenthesis 1 divided by 2 close parenthesis times x equals square root of x" - ), - Iteration( - "-3x=(-27x^3)^(1/3)", - "expression=\n-\n3\nx\n=\n(\t-27x\n^3\r)^(1 / 3) ", - "a11yStr=negative 3 times x equals open parenthesis negative 27 times x raised to the power" + - " of 3 close parenthesis raised to the power of open parenthesis 1 divided by 3 close" + - " parenthesis" - ), - Iteration( - "(4x^2)^(-1/2)=1+x", - "expression=( 4x ^ 2) ^ ( - 1 / 2 ) =1 + x ", - "a11yStr=open parenthesis 4 x raised to the power of 2 close parenthesis raised to the" + - " power of open parenthesis negative 1 divided by 2 close parenthesis equals 1 plus x" - ), - Iteration( - "sqrt(sqrt(sqrt(x)+1))=1/2", - "expression=sqrt( sqrt( sqrt( x ) + 1 ) ) = 1 / 2", - "a11yStr=square root of start square root square root of x plus 1 end square root equals 1" + - " divided by 2" - ), - Iteration( - "xy+x+y=x-(1+(y-(2+z)))", - "expression=xy+x+y=x - ( 1 + ( y - ( 2 + z )))", - "a11yStr=x times y plus x plus y equals x minus open parenthesis 1 plus open parenthesis y" + - " minus open parenthesis 2 plus zed close parenthesis close parenthesis close parenthesis" - ), - Iteration( - "x=1/(2/(y+3/z))", - "expression= x = 1 / ( 2 / ( y + 3/z ) )", - "a11yStr=x equals 1 divided by open parenthesis 2 divided by open parenthesis y plus 3" + - " divided by zed close parenthesis close parenthesis" - ), - Iteration( - "x/y/z/2=z", - "expression= x/ y/ z/ 2=z", - "a11yStr=x divided by y divided by zed divided by 2 equals zed" - ) + @Iteration( + "y=(x^2+2x+1)/(x+1)", + "expression= y = ( x^2 + 2x + 1 ) /( x + 1)", + "a11yStr=y equals open parenthesis x raised to the power of 2 plus 2 x plus 1 close" + + " parenthesis divided by open parenthesis x plus 1 close parenthesis" + ) + @Iteration( + "(1/2)x=sqrt(x)", + "expression=(1/2) x =sqrt (x)", + "a11yStr=open parenthesis 1 divided by 2 close parenthesis times x equals square root of x" + ) + @Iteration( + "-3x=(-27x^3)^(1/3)", + "expression=\n-\n3\nx\n=\n(\t-27x\n^3\r)^(1 / 3) ", + "a11yStr=negative 3 times x equals open parenthesis negative 27 times x raised to the power" + + " of 3 close parenthesis raised to the power of open parenthesis 1 divided by 3 close" + + " parenthesis" + ) + @Iteration( + "(4x^2)^(-1/2)=1+x", + "expression=( 4x ^ 2) ^ ( - 1 / 2 ) =1 + x ", + "a11yStr=open parenthesis 4 x raised to the power of 2 close parenthesis raised to the" + + " power of open parenthesis negative 1 divided by 2 close parenthesis equals 1 plus x" + ) + @Iteration( + "sqrt(sqrt(sqrt(x)+1))=1/2", + "expression=sqrt( sqrt( sqrt( x ) + 1 ) ) = 1 / 2", + "a11yStr=square root of start square root square root of x plus 1 end square root equals 1" + + " divided by 2" + ) + @Iteration( + "xy+x+y=x-(1+(y-(2+z)))", + "expression=xy+x+y=x - ( 1 + ( y - ( 2 + z )))", + "a11yStr=x times y plus x plus y equals x minus open parenthesis 1 plus open parenthesis y" + + " minus open parenthesis 2 plus zed close parenthesis close parenthesis close parenthesis" + ) + @Iteration( + "x=1/(2/(y+3/z))", + "expression= x = 1 / ( 2 / ( y + 3/z ) )", + "a11yStr=x equals 1 divided by open parenthesis 2 divided by open parenthesis y plus 3" + + " divided by zed close parenthesis close parenthesis" + ) + @Iteration( + "x/y/z/2=z", + "expression= x/ y/ z/ 2=z", + "a11yStr=x divided by y divided by zed divided by 2 equals zed" ) fun testConvertToString_eng_complexNestedEquations_returnsCorrectlyBuiltString() { val eq = parseAlgebraicEquation(expression) @@ -1014,57 +953,55 @@ class MathExpressionAccessibilityUtilTest { } @Test - @RunParameterized( - Iteration( - "y=(x^2+2x+1)/(x+1)", - "expression= y = ( x^2 + 2x + 1 ) /( x + 1)", - "a11yStr=y equals the fraction with numerator open parenthesis x raised to the power of 2" + - " plus 2 x plus 1 close parenthesis and denominator open parenthesis x plus 1 close" + - " parenthesis" - ), - Iteration( - "(1/2)x=sqrt(x)", - "expression=(1/2) x =sqrt (x)", - "a11yStr=open parenthesis one half close parenthesis times x equals square root of x" - ), - Iteration( - "-3x=(-27x^3)^(1/3)", - "expression=\n-\n3\nx\n=\n(\t-27x\n^3\r)^(1 / 3) ", - "a11yStr=negative 3 times x equals open parenthesis negative 27 times x raised to the power" + - " of 3 close parenthesis raised to the power of open parenthesis 1 over 3 close parenthesis" - ), - Iteration( - "(4x^2)^(-1/2)=1+x", - "expression=( 4x ^ 2) ^ ( - 1 / 2 ) =1 + x ", - "a11yStr=open parenthesis 4 x raised to the power of 2 close parenthesis raised to the" + - " power of open parenthesis the fraction with numerator negative 1 and denominator 2" + - " close parenthesis equals 1 plus x" - ), - Iteration( - "sqrt(sqrt(sqrt(x)+1))=1/2", - "expression=sqrt( sqrt( sqrt( x ) + 1 ) ) = 1 / 2", - "a11yStr=square root of start square root square root of x plus 1 end square root equals" + - " one half" - ), - Iteration( - "xy+x+y=x-(1+(y-(2+z)))", - "expression=xy+x+y=x - ( 1 + ( y - ( 2 + z )))", - "a11yStr=x times y plus x plus y equals x minus open parenthesis 1 plus open parenthesis y" + - " minus open parenthesis 2 plus zed close parenthesis close parenthesis close parenthesis" - ), - Iteration( - "x=1/(2/(y+3/z))", - "expression= x = 1 / ( 2 / ( y + 3/z ) )", - "a11yStr=x equals the fraction with numerator 1 and denominator open parenthesis the" + - " fraction with numerator 2 and denominator open parenthesis y plus 3 over zed close" + - " parenthesis close parenthesis" - ), - Iteration( - "x/y/z/2=z", - "expression= x/ y/ z/ 2=z", - "a11yStr=the fraction with numerator the fraction with numerator x over y and denominator" + - " zed and denominator 2 equals zed" - ) + @Iteration( + "y=(x^2+2x+1)/(x+1)", + "expression= y = ( x^2 + 2x + 1 ) /( x + 1)", + "a11yStr=y equals the fraction with numerator open parenthesis x raised to the power of 2" + + " plus 2 x plus 1 close parenthesis and denominator open parenthesis x plus 1 close" + + " parenthesis" + ) + @Iteration( + "(1/2)x=sqrt(x)", + "expression=(1/2) x =sqrt (x)", + "a11yStr=open parenthesis one half close parenthesis times x equals square root of x" + ) + @Iteration( + "-3x=(-27x^3)^(1/3)", + "expression=\n-\n3\nx\n=\n(\t-27x\n^3\r)^(1 / 3) ", + "a11yStr=negative 3 times x equals open parenthesis negative 27 times x raised to the power" + + " of 3 close parenthesis raised to the power of open parenthesis 1 over 3 close parenthesis" + ) + @Iteration( + "(4x^2)^(-1/2)=1+x", + "expression=( 4x ^ 2) ^ ( - 1 / 2 ) =1 + x ", + "a11yStr=open parenthesis 4 x raised to the power of 2 close parenthesis raised to the" + + " power of open parenthesis the fraction with numerator negative 1 and denominator 2" + + " close parenthesis equals 1 plus x" + ) + @Iteration( + "sqrt(sqrt(sqrt(x)+1))=1/2", + "expression=sqrt( sqrt( sqrt( x ) + 1 ) ) = 1 / 2", + "a11yStr=square root of start square root square root of x plus 1 end square root equals" + + " one half" + ) + @Iteration( + "xy+x+y=x-(1+(y-(2+z)))", + "expression=xy+x+y=x - ( 1 + ( y - ( 2 + z )))", + "a11yStr=x times y plus x plus y equals x minus open parenthesis 1 plus open parenthesis y" + + " minus open parenthesis 2 plus zed close parenthesis close parenthesis close parenthesis" + ) + @Iteration( + "x=1/(2/(y+3/z))", + "expression= x = 1 / ( 2 / ( y + 3/z ) )", + "a11yStr=x equals the fraction with numerator 1 and denominator open parenthesis the" + + " fraction with numerator 2 and denominator open parenthesis y plus 3 over zed close" + + " parenthesis close parenthesis" + ) + @Iteration( + "x/y/z/2=z", + "expression= x/ y/ z/ 2=z", + "a11yStr=the fraction with numerator the fraction with numerator x over y and denominator" + + " zed and denominator 2 equals zed" ) fun testConvertToString_eng_complexNestedEquations_divAsFracs_returnsCorrectlyBuiltString() { val eq = parseAlgebraicEquation(expression) @@ -1077,43 +1014,41 @@ class MathExpressionAccessibilityUtilTest { // This & the next test are implementing cases defined in the doc: // https://docs.google.com/document/d/1P-dldXQ08O-02ZRG978paiWOSz0dsvcKpDgiV_rKH_Y/edit#. @Test - @RunParameterized( - Iteration( - "(x + 6)/(x - 4)", - "expression=(x + 6)/(x - 4)", - "a11yStr=the fraction with numerator open parenthesis x plus 6 close parenthesis and" + - " denominator open parenthesis x minus 4 close parenthesis" - ), - Iteration( - "4*(x)^(2)+20x", - "expression=4*(x)^(2)+20x", - "a11yStr=4 times x raised to the power of 2 plus 20 x" - ), - Iteration("3+x-5", "expression=3+x-5", "a11yStr=3 plus x minus 5"), - Iteration("Z+A-Z", "expression=Z+A-Z", "a11yStr=Zed plus A minus Zed"), - Iteration("6C - 5A -1", "expression=6C - 5A -1", "a11yStr=6 C minus 5 A minus 1"), - Iteration("5*Z-w", "expression=5*Z-w", "a11yStr=5 times Zed minus w"), - Iteration("L*S-3S+L", "expression=L*S-3S+L", "a11yStr=L times S minus 3 S plus L"), - Iteration( - "2*(2+6+3+4)", - "expression=2*(2+6+3+4)", - "a11yStr=2 times open parenthesis 2 plus 6 plus 3 plus 4 close parenthesis" - ), - Iteration("sqrt(64)", "expression=sqrt(64)", "a11yStr=square root of 64"), - Iteration( - "√(a+b)", - "expression=√(a+b)", - "a11yStr=start square root open parenthesis a plus b close parenthesis end square root" - ), - Iteration( - "3 * 10^-5", "expression=3 * 10^-5", "a11yStr=3 times 10 raised to the power of negative 5" - ), - Iteration( - "((x+2y) + 5*(a - 2b) + z)", - "expression=((x+2y) + 5*(a - 2b) + z)", - "a11yStr=open parenthesis open parenthesis x plus 2 y close parenthesis plus 5 times open" + - " parenthesis a minus 2 b close parenthesis plus zed close parenthesis" - ) + @Iteration( + "(x + 6)/(x - 4)", + "expression=(x + 6)/(x - 4)", + "a11yStr=the fraction with numerator open parenthesis x plus 6 close parenthesis and" + + " denominator open parenthesis x minus 4 close parenthesis" + ) + @Iteration( + "4*(x)^(2)+20x", + "expression=4*(x)^(2)+20x", + "a11yStr=4 times x raised to the power of 2 plus 20 x" + ) + @Iteration("3+x-5", "expression=3+x-5", "a11yStr=3 plus x minus 5") + @Iteration("Z+A-Z", "expression=Z+A-Z", "a11yStr=Zed plus A minus Zed") + @Iteration("6C - 5A -1", "expression=6C - 5A -1", "a11yStr=6 C minus 5 A minus 1") + @Iteration("5*Z-w", "expression=5*Z-w", "a11yStr=5 times Zed minus w") + @Iteration("L*S-3S+L", "expression=L*S-3S+L", "a11yStr=L times S minus 3 S plus L") + @Iteration( + "2*(2+6+3+4)", + "expression=2*(2+6+3+4)", + "a11yStr=2 times open parenthesis 2 plus 6 plus 3 plus 4 close parenthesis" + ) + @Iteration("sqrt(64)", "expression=sqrt(64)", "a11yStr=square root of 64") + @Iteration( + "√(a+b)", + "expression=√(a+b)", + "a11yStr=start square root open parenthesis a plus b close parenthesis end square root" + ) + @Iteration( + "3 * 10^-5", "expression=3 * 10^-5", "a11yStr=3 times 10 raised to the power of negative 5" + ) + @Iteration( + "((x+2y) + 5*(a - 2b) + z)", + "expression=((x+2y) + 5*(a - 2b) + z)", + "a11yStr=open parenthesis open parenthesis x plus 2 y close parenthesis plus 5 times open" + + " parenthesis a minus 2 b close parenthesis plus zed close parenthesis" ) fun testConvertToString_eng_assortedExpressionsFromPrd_returnsCorrectlyComputedString() { // Some of the expressions include cases that would normally result in errors. @@ -1123,12 +1058,10 @@ class MathExpressionAccessibilityUtilTest { } @Test - @RunParameterized( - Iteration( - "3x^2 + 4y = 62", - "expression=3x^2 + 4y = 62", - "a11yStr=3 x raised to the power of 2 plus 4 y equals 62" - ) + @Iteration( + "3x^2 + 4y = 62", + "expression=3x^2 + 4y = 62", + "a11yStr=3 x raised to the power of 2 plus 4 y equals 62" ) fun testConvertToString_eng_assortedEquationsFromPrd_returnsCorrectlyComputedString() { val eq = parseAlgebraicEquation(expression) diff --git a/domain/src/main/java/org/oppia/android/domain/exploration/ExplorationProgressController.kt b/domain/src/main/java/org/oppia/android/domain/exploration/ExplorationProgressController.kt index 23314c02f59..9fc218d9858 100644 --- a/domain/src/main/java/org/oppia/android/domain/exploration/ExplorationProgressController.kt +++ b/domain/src/main/java/org/oppia/android/domain/exploration/ExplorationProgressController.kt @@ -520,20 +520,16 @@ class ExplorationProgressController @Inject constructor( message: ControllerMessage, lazyFailureMessage: () -> String ) { - // TODO(#4119): Switch this to use trySend(), instead, which is much cleaner and doesn't require - // catching an exception. - val flowResult: AsyncResult = try { - val commandQueue = mostRecentCommandQueue - when { - commandQueue == null -> - AsyncResult.Failure(IllegalStateException("Session isn't initialized yet.")) - !commandQueue.trySend(message).isSuccess -> - AsyncResult.Failure(IllegalStateException(lazyFailureMessage())) - // Ensure that the result is first reset since there will be a delay before the message is - // processed (if there's a flow). - else -> AsyncResult.Pending() - } - } catch (e: Exception) { AsyncResult.Failure(e) } + val commandQueue = mostRecentCommandQueue + val flowResult: AsyncResult = when { + commandQueue == null -> + AsyncResult.Failure(IllegalStateException("Session isn't initialized yet.")) + !commandQueue.trySend(message).isSuccess -> + AsyncResult.Failure(IllegalStateException(lazyFailureMessage())) + // Ensure that the result is first reset since there will be a delay before the message is + // processed (if there's a flow). + else -> AsyncResult.Pending() + } // This must be assigned separately since flowResult should always be calculated, even if // there's no callbackFlow to report it. diff --git a/domain/src/main/java/org/oppia/android/domain/oppialogger/analytics/AnalyticsController.kt b/domain/src/main/java/org/oppia/android/domain/oppialogger/analytics/AnalyticsController.kt index 383252ee7d7..214e0f22796 100644 --- a/domain/src/main/java/org/oppia/android/domain/oppialogger/analytics/AnalyticsController.kt +++ b/domain/src/main/java/org/oppia/android/domain/oppialogger/analytics/AnalyticsController.kt @@ -6,9 +6,9 @@ import kotlinx.coroutines.Deferred import kotlinx.coroutines.async import kotlinx.coroutines.flow.Flow import kotlinx.coroutines.flow.SharingStarted -import kotlinx.coroutines.flow.collect import kotlinx.coroutines.flow.emitAll import kotlinx.coroutines.flow.flow +import kotlinx.coroutines.flow.lastOrNull import kotlinx.coroutines.flow.map import kotlinx.coroutines.flow.onCompletion import kotlinx.coroutines.flow.stateIn @@ -319,17 +319,6 @@ class AnalyticsController @Inject constructor( } } - // TODO(#4119): Migrate this to Flow.lastOrNull() once Kotlin 1.5 is available. - private suspend fun Flow.lastOrNull(): T? { - return CoroutineScope(backgroundDispatcher).async { - var lastValue: T? = null - this@lastOrNull.collect { - lastValue = it - } - return@async lastValue - }.await() - } - private companion object { private suspend fun resolveProfileOperation( profileId: ProfileId?, diff --git a/domain/src/main/java/org/oppia/android/domain/oppialogger/logscheduler/MetricLogSchedulingWorker.kt b/domain/src/main/java/org/oppia/android/domain/oppialogger/logscheduler/MetricLogSchedulingWorker.kt index 8d4b595b252..3902ebb74d0 100644 --- a/domain/src/main/java/org/oppia/android/domain/oppialogger/logscheduler/MetricLogSchedulingWorker.kt +++ b/domain/src/main/java/org/oppia/android/domain/oppialogger/logscheduler/MetricLogSchedulingWorker.kt @@ -56,7 +56,7 @@ class MetricLogSchedulingWorker private constructor( override fun startWork(): ListenableFuture { val backgroundScope = CoroutineScope(backgroundDispatcher) - // TODO(#3715): Add withTimeout() to avoid potential hanging. + // TODO(#4463): Add withTimeout() to avoid potential hanging. return backgroundScope.async { when (inputData.getStringFromData(WORKER_CASE_KEY)) { PERIODIC_BACKGROUND_METRIC_WORKER -> schedulePeriodicBackgroundMetricLogging() diff --git a/domain/src/main/java/org/oppia/android/domain/oppialogger/loguploader/LogUploadWorker.kt b/domain/src/main/java/org/oppia/android/domain/oppialogger/loguploader/LogUploadWorker.kt index 4c1bd1026f5..f30e00b1ef2 100644 --- a/domain/src/main/java/org/oppia/android/domain/oppialogger/loguploader/LogUploadWorker.kt +++ b/domain/src/main/java/org/oppia/android/domain/oppialogger/loguploader/LogUploadWorker.kt @@ -44,7 +44,7 @@ class LogUploadWorker private constructor( override fun startWork(): ListenableFuture { val backgroundScope = CoroutineScope(backgroundDispatcher) - // TODO(#3715): Add withTimeout() to avoid potential hanging. + // TODO(#4463): Add withTimeout() to avoid potential hanging. return backgroundScope.async { when (inputData.getStringFromData(WORKER_CASE_KEY)) { EVENT_WORKER -> uploadEvents() diff --git a/domain/src/main/java/org/oppia/android/domain/platformparameter/syncup/PlatformParameterSyncUpWorker.kt b/domain/src/main/java/org/oppia/android/domain/platformparameter/syncup/PlatformParameterSyncUpWorker.kt index ed106bb9a7b..06bd9250360 100644 --- a/domain/src/main/java/org/oppia/android/domain/platformparameter/syncup/PlatformParameterSyncUpWorker.kt +++ b/domain/src/main/java/org/oppia/android/domain/platformparameter/syncup/PlatformParameterSyncUpWorker.kt @@ -54,7 +54,7 @@ class PlatformParameterSyncUpWorker private constructor( override fun startWork(): ListenableFuture { val backgroundScope = CoroutineScope(backgroundDispatcher) - // TODO(#3715): Add withTimeout() to avoid potential hanging. + // TODO(#4463): Add withTimeout() to avoid potential hanging. return backgroundScope.async { when (inputData.getStringFromData(WORKER_TYPE_KEY)) { PLATFORM_PARAMETER_WORKER -> refreshPlatformParameters() diff --git a/domain/src/main/java/org/oppia/android/domain/question/QuestionAssessmentProgressController.kt b/domain/src/main/java/org/oppia/android/domain/question/QuestionAssessmentProgressController.kt index e7bdba6a8f0..583ef085ce0 100644 --- a/domain/src/main/java/org/oppia/android/domain/question/QuestionAssessmentProgressController.kt +++ b/domain/src/main/java/org/oppia/android/domain/question/QuestionAssessmentProgressController.kt @@ -432,21 +432,15 @@ class QuestionAssessmentProgressController @Inject constructor( message: ControllerMessage, lazyFailureMessage: () -> String ) { - // TODO(#4119): Switch this to use trySend(), instead, which is much cleaner and doesn't require - // catching an exception. - val flowResult: AsyncResult = try { - val commandQueue = mostRecentCommandQueue - when { - commandQueue == null -> - AsyncResult.Failure(IllegalStateException("Session isn't initialized yet.")) - !commandQueue.trySend(message).isSuccess -> - AsyncResult.Failure(IllegalStateException(lazyFailureMessage())) - // Ensure that the result is first reset since there will be a delay before the message is - // processed (if there's a flow). - else -> AsyncResult.Pending() - } - } catch (e: Exception) { - AsyncResult.Failure(e) + val commandQueue = mostRecentCommandQueue + val flowResult: AsyncResult = when { + commandQueue == null -> + AsyncResult.Failure(IllegalStateException("Session isn't initialized yet.")) + !commandQueue.trySend(message).isSuccess -> + AsyncResult.Failure(IllegalStateException(lazyFailureMessage())) + // Ensure that the result is first reset since there will be a delay before the message is + // processed (if there's a flow). + else -> AsyncResult.Pending() } // This must be assigned separately since flowResult should always be calculated, even if diff --git a/domain/src/test/java/org/oppia/android/domain/classify/rules/algebraicexpressioninput/AlgebraicExpressionInputIsEquivalentToRuleClassifierProviderTest.kt b/domain/src/test/java/org/oppia/android/domain/classify/rules/algebraicexpressioninput/AlgebraicExpressionInputIsEquivalentToRuleClassifierProviderTest.kt index c64a5fc7640..c233180629e 100644 --- a/domain/src/test/java/org/oppia/android/domain/classify/rules/algebraicexpressioninput/AlgebraicExpressionInputIsEquivalentToRuleClassifierProviderTest.kt +++ b/domain/src/test/java/org/oppia/android/domain/classify/rules/algebraicexpressioninput/AlgebraicExpressionInputIsEquivalentToRuleClassifierProviderTest.kt @@ -19,7 +19,6 @@ import org.oppia.android.domain.classify.RuleClassifier import org.oppia.android.testing.junit.OppiaParameterizedTestRunner import org.oppia.android.testing.junit.OppiaParameterizedTestRunner.Iteration import org.oppia.android.testing.junit.OppiaParameterizedTestRunner.Parameter -import org.oppia.android.testing.junit.OppiaParameterizedTestRunner.RunParameterized import org.oppia.android.testing.junit.OppiaParameterizedTestRunner.SelectRunnerPlatform import org.oppia.android.testing.junit.ParameterizedRobolectricTestRunner import org.oppia.android.testing.robolectric.RobolectricModule @@ -75,13 +74,11 @@ class AlgebraicExpressionInputIsEquivalentToRuleClassifierProviderTest { } @Test - @RunParameterized( - Iteration("0==0", "answer=0", "input=0"), - Iteration("1==1", "answer=1", "input=1"), - Iteration("2==2", "answer=2", "input=2"), - Iteration("x==x", "answer=x", "input=x"), - Iteration("y==y", "answer=y", "input=y") - ) + @Iteration("0==0", "answer=0", "input=0") + @Iteration("1==1", "answer=1", "input=1") + @Iteration("2==2", "answer=2", "input=2") + @Iteration("x==x", "answer=x", "input=x") + @Iteration("y==y", "answer=y", "input=y") fun testMatches_sameSingleTerms_returnsTrue() { val answerExpression = createMathExpression(answer) val inputExpression = createMathExpression(input) @@ -93,24 +90,22 @@ class AlgebraicExpressionInputIsEquivalentToRuleClassifierProviderTest { } @Test - @RunParameterized( - Iteration("-2==-2", "answer=-2", "input=-2"), - Iteration("1+3.14==1+3.14", "answer=1+3.14", "input=1+3.14"), - Iteration(" 1 + 3.14 ==1+3.14", "answer= 1 + 3.14 ", "input=1+3.14"), - Iteration("1+2+3==1+2+3", "answer=1+2+3", "input=1+2+3"), - Iteration("1-3.14==1-3.14", "answer=1-3.14", "input=1-3.14"), - Iteration("2*3.14==2*3.14", "answer=2*3.14", "input=2*3.14"), - Iteration("2/3==2/3", "answer=2/3", "input=2/3"), - Iteration("2/3.14==2/3.14", "answer=2/3.14", "input=2/3.14"), - Iteration("2^3==2^3", "answer=2^3", "input=2^3"), - Iteration("2^3.14==2^3.14", "answer=2^3.14", "input=2^3.14"), - Iteration("sqrt(2)==sqrt(2)", "answer=sqrt(2)", "input=sqrt(2)"), - Iteration("-x==-x", "answer=-x", "input=-x"), - Iteration("x+3.14==x+3.14", "answer=x+3.14", "input=x+3.14"), - Iteration("x-3.14==x-3.14", "answer=x-3.14", "input=x-3.14"), - Iteration("x*3.14==x*3.14", "answer=x*3.14", "input=x*3.14"), - Iteration("x/3==x/3", "answer=x/3", "input=x/3") - ) + @Iteration("-2==-2", "answer=-2", "input=-2") + @Iteration("1+3.14==1+3.14", "answer=1+3.14", "input=1+3.14") + @Iteration(" 1 + 3.14 ==1+3.14", "answer= 1 + 3.14 ", "input=1+3.14") + @Iteration("1+2+3==1+2+3", "answer=1+2+3", "input=1+2+3") + @Iteration("1-3.14==1-3.14", "answer=1-3.14", "input=1-3.14") + @Iteration("2*3.14==2*3.14", "answer=2*3.14", "input=2*3.14") + @Iteration("2/3==2/3", "answer=2/3", "input=2/3") + @Iteration("2/3.14==2/3.14", "answer=2/3.14", "input=2/3.14") + @Iteration("2^3==2^3", "answer=2^3", "input=2^3") + @Iteration("2^3.14==2^3.14", "answer=2^3.14", "input=2^3.14") + @Iteration("sqrt(2)==sqrt(2)", "answer=sqrt(2)", "input=sqrt(2)") + @Iteration("-x==-x", "answer=-x", "input=-x") + @Iteration("x+3.14==x+3.14", "answer=x+3.14", "input=x+3.14") + @Iteration("x-3.14==x-3.14", "answer=x-3.14", "input=x-3.14") + @Iteration("x*3.14==x*3.14", "answer=x*3.14", "input=x*3.14") + @Iteration("x/3==x/3", "answer=x/3", "input=x/3") fun testMatches_sameSingleOperations_returnsTrue() { val answerExpression = createMathExpression(answer) val inputExpression = createMathExpression(input) @@ -122,9 +117,7 @@ class AlgebraicExpressionInputIsEquivalentToRuleClassifierProviderTest { } @Test - @RunParameterized( - Iteration("sqrt(x)!=sqrt(x)", "answer=sqrt(x)", "input=sqrt(x)") - ) + @Iteration("sqrt(x)!=sqrt(x)", "answer=sqrt(x)", "input=sqrt(x)") fun testMatches_sameSingleOperations_thatCannotBecomePolynomials_returnsFalse() { val answerExpression = createMathExpression(answer) val inputExpression = createMathExpression(input) @@ -137,15 +130,13 @@ class AlgebraicExpressionInputIsEquivalentToRuleClassifierProviderTest { } @Test - @RunParameterized( - Iteration("1!=0", "answer=1", "input=0"), - Iteration("0!=1", "answer=0", "input=1"), - Iteration("3.14!=1", "answer=3.14", "input=1"), - Iteration("1!=3.14", "answer=1", "input=3.14"), - Iteration("x!=3.14", "answer=x", "input=3.14"), - Iteration("y!=x", "answer=y", "input=x"), - Iteration("3.14!=x", "answer=3.14", "input=x") - ) + @Iteration("1!=0", "answer=1", "input=0") + @Iteration("0!=1", "answer=0", "input=1") + @Iteration("3.14!=1", "answer=3.14", "input=1") + @Iteration("1!=3.14", "answer=1", "input=3.14") + @Iteration("x!=3.14", "answer=x", "input=3.14") + @Iteration("y!=x", "answer=y", "input=x") + @Iteration("3.14!=x", "answer=3.14", "input=x") fun testMatches_differentSingleTerms_returnsFalse() { val answerExpression = createMathExpression(answer) val inputExpression = createMathExpression(input) @@ -157,16 +148,14 @@ class AlgebraicExpressionInputIsEquivalentToRuleClassifierProviderTest { } @Test - @RunParameterized( - Iteration("3.14+1==1+3.14", "answer=3.14+1", "input=1+3.14"), - Iteration("3+2+1==1+2+3", "answer=3+2+1", "input=1+2+3"), - Iteration("-3.14+1==1-3.14", "answer=-3.14+1", "input=1-3.14"), - Iteration("3.14*2==2*3.14", "answer=3.14*2", "input=2*3.14"), - Iteration("2+x==x+2", "answer=2+x", "input=x+2"), - Iteration("y+x==x+y", "answer=y+x", "input=x+y"), - Iteration("x*2==2x", "answer=x*2", "input=2x"), - Iteration("yx==xy", "answer=yx", "input=xy") - ) + @Iteration("3.14+1==1+3.14", "answer=3.14+1", "input=1+3.14") + @Iteration("3+2+1==1+2+3", "answer=3+2+1", "input=1+2+3") + @Iteration("-3.14+1==1-3.14", "answer=-3.14+1", "input=1-3.14") + @Iteration("3.14*2==2*3.14", "answer=3.14*2", "input=2*3.14") + @Iteration("2+x==x+2", "answer=2+x", "input=x+2") + @Iteration("y+x==x+y", "answer=y+x", "input=x+y") + @Iteration("x*2==2x", "answer=x*2", "input=2x") + @Iteration("yx==xy", "answer=yx", "input=xy") fun testMatches_operationsDiffer_byCommutativity_returnsTrue() { val answerExpression = createMathExpression(answer) val inputExpression = createMathExpression(input) @@ -178,14 +167,12 @@ class AlgebraicExpressionInputIsEquivalentToRuleClassifierProviderTest { } @Test - @RunParameterized( - Iteration("1+(2+3)==(1+2)+3", "answer=1+(2+3)", "input=(1+2)+3"), - Iteration("2*(3*4)==(2*3)*4", "answer=2*(3*4)", "input=(2*3)*4"), - Iteration("x+(2+3)==(x+2)+3", "answer=x+(2+3)", "input=(x+2)+3"), - Iteration("x+(y+z)==(x+y)+z", "answer=x+(y+z)", "input=(x+y)+z"), - Iteration("2*(3x)==(2x)*3", "answer=2*(3x)", "input=(2x)*3"), - Iteration("x(yz)==(xy)z", "answer=x(yz)", "input=(xy)z") - ) + @Iteration("1+(2+3)==(1+2)+3", "answer=1+(2+3)", "input=(1+2)+3") + @Iteration("2*(3*4)==(2*3)*4", "answer=2*(3*4)", "input=(2*3)*4") + @Iteration("x+(2+3)==(x+2)+3", "answer=x+(2+3)", "input=(x+2)+3") + @Iteration("x+(y+z)==(x+y)+z", "answer=x+(y+z)", "input=(x+y)+z") + @Iteration("2*(3x)==(2x)*3", "answer=2*(3x)", "input=(2x)*3") + @Iteration("x(yz)==(xy)z", "answer=x(yz)", "input=(xy)z") fun testMatches_operationsDiffer_byAssociativity_returnsTrue() { val answerExpression = createMathExpression(answer) val inputExpression = createMathExpression(input) @@ -197,17 +184,15 @@ class AlgebraicExpressionInputIsEquivalentToRuleClassifierProviderTest { } @Test - @RunParameterized( - Iteration("3.14-1!=1-3.14", "answer=3.14-1", "input=1-3.14"), - Iteration("1-(2-3)!=(1-2)-3", "answer=1-(2-3)", "input=(1-2)-3"), - Iteration("3.14/2!=2/3.14", "answer=3.14/2", "input=2/3.14"), - Iteration("2/(3/4)!=(2/3)/4", "answer=2/(3/4)", "input=(2/3)/4"), - Iteration("3.14^2!=2^3.14", "answer=3.14^2", "input=2^3.14"), - Iteration("3.14-x!=x-3.14", "answer=3.14-x", "input=x-3.14"), - Iteration("x-(y-z)!=(x-y)-z", "answer=x-(y-z)", "input=(x-y)-z"), - Iteration("3.14/x!=x/3.14", "answer=3.14/x", "input=x/3.14"), - Iteration("x/(y/z)!=(x/y)/z", "answer=x/(y/z)", "input=(x/y)/z") - ) + @Iteration("3.14-1!=1-3.14", "answer=3.14-1", "input=1-3.14") + @Iteration("1-(2-3)!=(1-2)-3", "answer=1-(2-3)", "input=(1-2)-3") + @Iteration("3.14/2!=2/3.14", "answer=3.14/2", "input=2/3.14") + @Iteration("2/(3/4)!=(2/3)/4", "answer=2/(3/4)", "input=(2/3)/4") + @Iteration("3.14^2!=2^3.14", "answer=3.14^2", "input=2^3.14") + @Iteration("3.14-x!=x-3.14", "answer=3.14-x", "input=x-3.14") + @Iteration("x-(y-z)!=(x-y)-z", "answer=x-(y-z)", "input=(x-y)-z") + @Iteration("3.14/x!=x/3.14", "answer=3.14/x", "input=x/3.14") + @Iteration("x/(y/z)!=(x/y)/z", "answer=x/(y/z)", "input=(x/y)/z") fun testMatches_operationsDiffer_byNonCommutativeOrAssociativeReordering_returnsFalse() { val answerExpression = createMathExpression(answer) val inputExpression = createMathExpression(input) @@ -220,26 +205,24 @@ class AlgebraicExpressionInputIsEquivalentToRuleClassifierProviderTest { } @Test - @RunParameterized( - Iteration("1-2==-(2-1)", "answer=1-2", "input=-(2-1)"), - Iteration("1+2==1+1+1", "answer=1+2", "input=1+1+1"), - Iteration("1+2==1-(-2)", "answer=1+2", "input=1-(-2)"), - Iteration("4-6==1-2-1", "answer=4-6", "input=1-2-1"), - Iteration("2*3*2*2==2*3*4", "answer=2*3*2*2", "input=2*3*4"), - Iteration("-6-2==2*-(3+1)", "answer=-6-2", "input=2*-(3+1)"), - Iteration("2/3/2/2==2/3/4", "answer=2/3/2/2", "input=2/3/4"), - Iteration("2^(2+1)==2^3", "answer=2^(2+1)", "input=2^3"), - Iteration("2^(-1)==1/2", "answer=2^(-1)", "input=1/2"), - Iteration("x-y==-(y-x)", "answer=x-y", "input=-(y-x)"), - Iteration("2+x==1+x+1", "answer=2+x", "input=1+x+1"), - Iteration("1+x==1-(-x)", "answer=1+x", "input=1-(-x)"), - Iteration("-x==1-x-1", "answer=-x", "input=1-x-1"), - Iteration("4x==2*2*x", "answer=4x", "input=2*2*x"), - Iteration("2-6x==2*(-3x+1)", "answer=2-6x", "input=2*(-3x+1)"), - Iteration("x/4==x/2/2", "answer=x/4", "input=x/2/2"), - Iteration("x^(2+1)==x^3", "answer=x^(2+1)", "input=x^3"), - Iteration("x*(2^(-1))==x/2", "answer=x*(2^(-1))", "input=x/2") - ) + @Iteration("1-2==-(2-1)", "answer=1-2", "input=-(2-1)") + @Iteration("1+2==1+1+1", "answer=1+2", "input=1+1+1") + @Iteration("1+2==1-(-2)", "answer=1+2", "input=1-(-2)") + @Iteration("4-6==1-2-1", "answer=4-6", "input=1-2-1") + @Iteration("2*3*2*2==2*3*4", "answer=2*3*2*2", "input=2*3*4") + @Iteration("-6-2==2*-(3+1)", "answer=-6-2", "input=2*-(3+1)") + @Iteration("2/3/2/2==2/3/4", "answer=2/3/2/2", "input=2/3/4") + @Iteration("2^(2+1)==2^3", "answer=2^(2+1)", "input=2^3") + @Iteration("2^(-1)==1/2", "answer=2^(-1)", "input=1/2") + @Iteration("x-y==-(y-x)", "answer=x-y", "input=-(y-x)") + @Iteration("2+x==1+x+1", "answer=2+x", "input=1+x+1") + @Iteration("1+x==1-(-x)", "answer=1+x", "input=1-(-x)") + @Iteration("-x==1-x-1", "answer=-x", "input=1-x-1") + @Iteration("4x==2*2*x", "answer=4x", "input=2*2*x") + @Iteration("2-6x==2*(-3x+1)", "answer=2-6x", "input=2*(-3x+1)") + @Iteration("x/4==x/2/2", "answer=x/4", "input=x/2/2") + @Iteration("x^(2+1)==x^3", "answer=x^(2+1)", "input=x^3") + @Iteration("x*(2^(-1))==x/2", "answer=x*(2^(-1))", "input=x/2") fun testMatches_operationsDiffer_byDistributionAndCombining_returnTrue() { val answerExpression = createMathExpression(answer) val inputExpression = createMathExpression(input) @@ -251,268 +234,266 @@ class AlgebraicExpressionInputIsEquivalentToRuleClassifierProviderTest { } @Test - @RunParameterized( - Iteration("3x(3x - 2) + 1==(3x-1)^2", "answer=3x(3x - 2) + 1", "input=(3x-1)^2"), - Iteration("3(3x^2) - 6x +1==(3x-1)^2", "answer=3(3x^2) - 6x +1", "input=(3x-1)^2"), - Iteration("(1 - 3x)^2!=(3x-1)^2", "answer=(1 - 3x)^2", "input=(3x-1)^2"), - Iteration("2x==sqrt(4x^2)", "answer=2x", "input=sqrt(4x^2)"), - Iteration("x^2+2x+1==(x+1)^2", "answer=x^2+2x+1", "input=(x+1)^2"), - Iteration("x^2-1==(x+1)(x-1)", "answer=x^2-1", "input=(x+1)(x-1)"), - Iteration("x+1==(x^2+2x+1)/(x+1)", "answer=x+1", "input=(x^2+2x+1)/(x+1)"), - Iteration("x-1==(x^2-1)/(x+1)", "answer=x-1", "input=(x^2-1)/(x+1)"), - Iteration("x+1==(x^2-1)/(x-1)", "answer=x+1", "input=(x^2-1)/(x-1)"), - Iteration("-3x==(-27x^3)^(1/3)", "answer=-3x", "input=(-27x^3)^(1/3)"), - Iteration("1==(x^2-1)/(x^2-1)", "answer=1", "input=(x^2-1)/(x^2-1)"), - Iteration("2*(2+6+3+4)==2*(2+6+3+4)", "answer=2*(2+6+3+4)", "input=2*(2+6+3+4)"), - Iteration("2 × (2+6+3+4)==2*(2+6+3+4)", "answer=2 × (2+6+3+4)", "input=2*(2+6+3+4)"), - Iteration( - "15 - (6 × 2) + 3==15 - (6 × 2) + 3", "answer=15 - (6 × 2) + 3", "input=15 - (6 × 2) + 3" - ), - Iteration( - "2 × (50 + 150 + 100 + 25) ==(50 + 150 + 100 + 25) × 2", - "answer=2 × (50 + 150 + 100 + 25) ", - "input=(50 + 150 + 100 + 25) × 2" - ), - Iteration( - "2 * (50 + 150 + 100 + 25) ==2 × (50 + 150 + 100 + 25)", - "answer=2 * (50 + 150 + 100 + 25) ", - "input=2 × (50 + 150 + 100 + 25)" - ), - Iteration("2+5==5+2", "answer=2+5", "input=5+2"), - Iteration("5+2==5+2", "answer=5+2", "input=5+2"), - Iteration("6 − (− 4)==6 − (− 4)", "answer=6 − (− 4)", "input=6 − (− 4)"), - Iteration("6-(-4)==6 − (− 4)", "answer=6-(-4)", "input=6 − (− 4)"), - Iteration("− (− 4) + 6==6 − (− 4)", "answer=− (− 4) + 6", "input=6 − (− 4)"), - Iteration("10==6 − (− 4)", "answer=10", "input=6 − (− 4)"), - Iteration("6 + 4==6 − (− 4)", "answer=6 + 4", "input=6 − (− 4)"), - Iteration("6 + 2^2==6 − (− 4)", "answer=6 + 2^2", "input=6 − (− 4)"), - Iteration("3 * 2 − (− 4)==6 − (− 4)", "answer=3 * 2 − (− 4)", "input=6 − (− 4)"), - Iteration("100/10==6 − (− 4)", "answer=100/10", "input=6 − (− 4)"), - Iteration("3 * 10^-5==3 * 10^-5", "answer=3 * 10^-5", "input=3 * 10^-5"), - Iteration("3/(10 * 10^4)==3 * 10^-5", "answer=3/(10 * 10^4)", "input=3 * 10^-5"), - Iteration( - "1000 + 200 + 30 + 4 + 0.5 + 0.06==1000 + 200 + 30 + 4 + 0.5 + 0.06", - "answer=1000 + 200 + 30 + 4 + 0.5 + 0.06", - "input=1000 + 200 + 30 + 4 + 0.5 + 0.06" - ), - Iteration( - "200 + 30 + 4 + 0.5 + 0.06 + 1000==1000 + 200 + 30 + 4 + 0.5 + 0.06", - "answer=200 + 30 + 4 + 0.5 + 0.06 + 1000", - "input=1000 + 200 + 30 + 4 + 0.5 + 0.06" - ), - Iteration( - "0.06 + 0.5 + 4 + 30 + 200 + 1000==1000 + 200 + 30 + 4 + 0.5 + 0.06", - "answer=0.06 + 0.5 + 4 + 30 + 200 + 1000", - "input=1000 + 200 + 30 + 4 + 0.5 + 0.06" - ), - Iteration( - "1234.56==1000 + 200 + 30 + 4 + 0.5 + 0.06", - "answer=1234.56", - "input=1000 + 200 + 30 + 4 + 0.5 + 0.06" - ), - Iteration( - "123456/100==1000 + 200 + 30 + 4 + 0.5 + 0.06", - "answer=123456/100", - "input=1000 + 200 + 30 + 4 + 0.5 + 0.06" - ), - Iteration( - "61728/50==1000 + 200 + 30 + 4 + 0.5 + 0.06", - "answer=61728/50", - "input=1000 + 200 + 30 + 4 + 0.5 + 0.06" - ), - Iteration( - "1234 + 56/100==1000 + 200 + 30 + 4 + 0.5 + 0.06", - "answer=1234 + 56/100", - "input=1000 + 200 + 30 + 4 + 0.5 + 0.06" - ), - Iteration( - "1230 + 4.56==1000 + 200 + 30 + 4 + 0.5 + 0.06", - "answer=1230 + 4.56", - "input=1000 + 200 + 30 + 4 + 0.5 + 0.06" - ), - Iteration("2 * 2 * 3 * 3==2 * 2 * 3 * 3", "answer=2 * 2 * 3 * 3", "input=2 * 2 * 3 * 3"), - Iteration( - "2 * 2 * 3 * 3 * 1==2 * 2 * 3 * 3", "answer=2 * 2 * 3 * 3 * 1", "input=2 * 2 * 3 * 3" - ), - Iteration("2 * 2 * 9==2 * 2 * 3 * 3", "answer=2 * 2 * 9", "input=2 * 2 * 3 * 3"), - Iteration("4 * 3^2==2 * 2 * 3 * 3", "answer=4 * 3^2", "input=2 * 2 * 3 * 3"), - Iteration("8/2 * 3 * 3==2 * 2 * 3 * 3", "answer=8/2 * 3 * 3", "input=2 * 2 * 3 * 3"), - Iteration("36==2 * 2 * 3 * 3", "answer=36", "input=2 * 2 * 3 * 3"), - Iteration("sqrt(4-2)==sqrt(2)", "answer=sqrt(4-2)", "input=sqrt(2)"), - Iteration("4x^2+20x==4*x^2+20x", "answer=4x^2+20x", "input=4*x^2+20x"), - Iteration("3+x-5==3+x-5", "answer=3+x-5", "input=3+x-5"), - Iteration("Z+A-Z==Z+A-Z", "answer=Z+A-Z", "input=Z+A-Z"), - Iteration("6C - 5A -1==6C - 5A -1", "answer=6C - 5A -1", "input=6C - 5A -1"), - Iteration("5Z-w==5*Z-w", "answer=5Z-w", "input=5*Z-w"), - Iteration("5*Z-w==5*Z-w", "answer=5*Z-w", "input=5*Z-w"), - Iteration("LS-3S+L==L*S-3S+L", "answer=LS-3S+L", "input=L*S-3S+L"), - Iteration("L*S-3S+L==L*S-3S+L", "answer=L*S-3S+L", "input=L*S-3S+L"), - Iteration("L*S-3*S+L==L*S-3S+L", "answer=L*S-3*S+L", "input=L*S-3S+L"), - Iteration("LS-3*S+L==L*S-3S+L", "answer=LS-3*S+L", "input=L*S-3S+L"), - Iteration("9x^2 − 6x + 1==9x^2 − 6x + 1", "answer=9x^2 − 6x + 1", "input=9x^2 − 6x + 1"), - Iteration("c*b-c==c*b-c", "answer=c*b-c", "input=c*b-c"), - Iteration("bc-c==c*b-c", "answer=bc-c", "input=c*b-c"), - Iteration("cb-c==c*b-c", "answer=cb-c", "input=c*b-c"), - Iteration("-c+bc==c*b-c", "answer=-c+bc", "input=c*b-c"), - Iteration("-c+cb==c*b-c", "answer=-c+cb", "input=c*b-c"), - Iteration("x^2+y+4x==x^2+y+4x", "answer=x^2+y+4x", "input=x^2+y+4x"), - Iteration("y+4x+x^2==x^2+y+4x", "answer=y+4x+x^2", "input=x^2+y+4x"), - Iteration("x^2+4x+y==x^2+y+4x", "answer=x^2+4x+y", "input=x^2+y+4x"), - Iteration("Y+5==Y+5", "answer=Y+5", "input=Y+5"), - Iteration("5+Y==Y+5", "answer=5+Y", "input=Y+5"), - Iteration( - "a^2 + b^2 + c^2+ 2a*b + 2a*c + 2bc==a^2+b^2+c^2+2a*b+2a*c+2bc", - "answer=a^2 + b^2 + c^2+ 2a*b + 2a*c + 2bc", - "input=a^2+b^2+c^2+2a*b+2a*c+2bc" - ), - Iteration( - "a^2 + b^2 + c^2+ 2a*b + 2bc + 2a*c==a^2+b^2+c^2+2a*b+2a*c+2bc", - "answer=a^2 + b^2 + c^2+ 2a*b + 2bc + 2a*c", - "input=a^2+b^2+c^2+2a*b+2a*c+2bc" - ), - Iteration( - "2a*b + 2bc + 2a*c + a^2 + b^2 + c^2==a^2+b^2+c^2+2a*b+2a*c+2bc", - "answer=2a*b + 2bc + 2a*c + a^2 + b^2 + c^2", - "input=a^2+b^2+c^2+2a*b+2a*c+2bc" - ), - Iteration( - "2a*b + b^2 + c^2+ a^2 + 2bc + 2a*c==a^2+b^2+c^2+2a*b+2a*c+2bc", - "answer=2a*b + b^2 + c^2+ a^2 + 2bc + 2a*c", - "input=a^2+b^2+c^2+2a*b+2a*c+2bc" - ), - Iteration( - "a*a + b*b + c*c + 2*a*b + 2*a*c + 2*b*c==a^2+b^2+c^2+2a*b+2a*c+2bc", - "answer=a*a + b*b + c*c + 2*a*b + 2*a*c + 2*b*c", - "input=a^2+b^2+c^2+2a*b+2a*c+2bc" - ), - Iteration( - "(a+ b)^2 + c^2 + 2bc + 2a*c==a^2+b^2+c^2+2a*b+2a*c+2bc", - "answer=(a+ b)^2 + c^2 + 2bc + 2a*c", - "input=a^2+b^2+c^2+2a*b+2a*c+2bc" - ), - Iteration( - "(a+b+c)^2==a^2+b^2+c^2+2a*b+2a*c+2bc", "answer=(a+b+c)^2", "input=a^2+b^2+c^2+2a*b+2a*c+2bc" - ), - Iteration( - "(-a -b -c)^2==a^2+b^2+c^2+2a*b+2a*c+2bc", - "answer=(-a -b -c)^2", - "input=a^2+b^2+c^2+2a*b+2a*c+2bc" - ), - Iteration("1 - 6x + 9x^2==9x^2 − 6x + 1", "answer=1 - 6x + 9x^2", "input=9x^2 − 6x + 1"), - Iteration("9x^2 + 1 - 6x==9x^2 − 6x + 1", "answer=9x^2 + 1 - 6x", "input=9x^2 − 6x + 1"), - Iteration("2+1+x==x+1+2", "answer=2+1+x", "input=x+1+2"), - Iteration("1+2+x==x+1+2", "answer=1+2+x", "input=x+1+2"), - Iteration("1+x+2==x+1+2", "answer=1+x+2", "input=x+1+2"), - Iteration("2+x+1==x+1+2", "answer=2+x+1", "input=x+1+2"), - Iteration("(x+1)+2==x+1+2", "answer=(x+1)+2", "input=x+1+2"), - Iteration("x + (1+2)==x+1+2", "answer=x + (1+2)", "input=x+1+2"), - Iteration( - "y+1+ 9x(x − 6)==9x(x − 6) + 1+ y", "answer=y+1+ 9x(x − 6)", "input=9x(x − 6) + 1+ y" - ), - Iteration("1+y+9x(x − 6)==9x(x − 6) + 1+ y", "answer=1+y+9x(x − 6)", "input=9x(x − 6) + 1+ y"), - Iteration( - "1 + 9x(x − 6) + y==9x(x − 6) + 1+ y", "answer=1 + 9x(x − 6) + y", "input=9x(x − 6) + 1+ y" - ), - Iteration( - "(y+1)+9x(x − 6)==9x(x − 6) + 1+ y", "answer=(y+1)+9x(x − 6)", "input=9x(x − 6) + 1+ y" - ), - Iteration( - "(x^2 − x)/3 − 4y==(x^2 − x)/3 − 4y", "answer=(x^2 − x)/3 − 4y", "input=(x^2 − x)/3 − 4y" - ), - Iteration( - "-4y + (x^2 − x)/3==(x^2 − x)/3 − 4y", "answer=-4y + (x^2 − x)/3", "input=(x^2 − x)/3 − 4y" - ), - Iteration( - "x(x − 1)/3 −4y==(x^2 − x)/3 − 4y", "answer=x(x − 1)/3 −4y", "input=(x^2 − x)/3 − 4y" - ), - Iteration( - "x^2/3 − x/3 − 4y==(x^2 − x)/3 − 4y", "answer=x^2/3 − x/3 − 4y", "input=(x^2 − x)/3 − 4y" - ), - Iteration( - "x^2/3 − (x/3 + 4y)==(x^2 − x)/3 − 4y", "answer=x^2/3 − (x/3 + 4y)", "input=(x^2 − x)/3 − 4y" - ), - Iteration("(3x -1)^2==(3x-1)^2", "answer=(3x -1)^2", "input=(3x-1)^2"), - Iteration("2*(6+3+4) + 4==2*(2+6+3+4)", "answer=2*(6+3+4) + 4", "input=2*(2+6+3+4)"), - Iteration("2*(2+6+3) + 8==2*(2+6+3+4)", "answer=2*(2+6+3) + 8", "input=2*(2+6+3+4)"), - Iteration("(2+6+3+4)*2==2*(2+6+3+4)", "answer=(2+6+3+4)*2", "input=2*(2+6+3+4)"), - Iteration("(2+6+3+4) × 2==2*(2+6+3+4)", "answer=(2+6+3+4) × 2", "input=2*(2+6+3+4)"), - Iteration("15 - 12 + 3==15 - (6 × 2) + 3", "answer=15 - 12 + 3", "input=15 - (6 × 2) + 3"), - Iteration( - "3 - (6 * 2) + 15==15 - (6 × 2) + 3", "answer=3 - (6 * 2) + 15", "input=15 - (6 × 2) + 3" - ), - Iteration( - "15 - (2 × 6) + 3==15 - (6 × 2) + 3", "answer=15 - (2 × 6) + 3", "input=15 - (6 × 2) + 3" - ), - Iteration( - "2 *(50 + 150) + 2*(100 + 25)==(50 + 150 + 100 + 25) × 2", - "answer=2 *(50 + 150) + 2*(100 + 25)", - "input=(50 + 150 + 100 + 25) × 2" - ), - Iteration( - "2* ( 25+50+100+150)==(50 + 150 + 100 + 25) × 2", - "answer=2* ( 25+50+100+150)", - "input=(50 + 150 + 100 + 25) × 2" - ), - Iteration("10^−5 * 3==3 * 10^-5", "answer=10^−5 * 3", "input=3 * 10^-5"), - Iteration("30 * 10^−6==3 * 10^-5", "answer=30 * 10^−6", "input=3 * 10^-5"), - Iteration("0.00003==3 * 10^-5", "answer=0.00003", "input=3 * 10^-5"), - Iteration("3/10^5==3 * 10^-5", "answer=3/10^5", "input=3 * 10^-5"), - Iteration("3 *2 – (− 4)==6 − (− 4)", "answer=3 *2 – (− 4)", "input=6 − (− 4)"), - Iteration("7==5+2", "answer=7", "input=5+2"), - Iteration("3+4==5+2", "answer=3+4", "input=5+2"), - Iteration("20x+4x^2==4*x^2+20x", "answer=20x+4x^2", "input=4*x^2+20x"), - Iteration("x-5+3==3+x-5", "answer=x-5+3", "input=3+x-5"), - Iteration("-5+3+x==3+x-5", "answer=-5+3+x", "input=3+x-5"), - Iteration("-5+x+3==3+x-5", "answer=-5+x+3", "input=3+x-5"), - Iteration("3+(x-5)==3+x-5", "answer=3+(x-5)", "input=3+x-5"), - Iteration("A==Z+A-Z", "answer=A", "input=Z+A-Z"), - Iteration("A+Z-Z==Z+A-Z", "answer=A+Z-Z", "input=Z+A-Z"), - Iteration("Z+(A-Z)==Z+A-Z", "answer=Z+(A-Z)", "input=Z+A-Z"), - Iteration("6C - (5A+1)==6C - 5A -1", "answer=6C - (5A+1)", "input=6C - 5A -1"), - Iteration("-5A-1+6C==6C - 5A -1", "answer=-5A-1+6C", "input=6C - 5A -1"), - Iteration("-W+5Z==5*Z-W", "answer=-W+5Z", "input=5*Z-W"), - Iteration("L(1+S)-3S==L*S-3S+L", "answer=L(1+S)-3S", "input=L*S-3S+L"), - Iteration("S(L-3)+L==L*S-3S+L", "answer=S(L-3)+L", "input=L*S-3S+L"), - Iteration("L+LS-3S==L*S-3S+L", "answer=L+LS-3S", "input=L*S-3S+L"), - Iteration( - "x(x − 1)/3 − 4y==(x^2 − x)/3 − 4y", "answer=x(x − 1)/3 − 4y", "input=(x^2 − x)/3 − 4y" - ), - Iteration( - "- 4y + (x^2 − x)/3==(x^2 − x)/3 − 4y", "answer=- 4y + (x^2 − x)/3", "input=(x^2 − x)/3 − 4y" - ), - Iteration( - "(x^2 − x) * 3^-1 − 4y==(x^2 − x)/3 − 4y", - "answer=(x^2 − x) * 3^-1 − 4y", - "input=(x^2 − x)/3 − 4y" - ), - Iteration( - "a^2 + b^2 + c^2 + 2(a*b + a*c + bc)==a^2+b^2+c^2+2a*b+2a*c+2bc", - "answer=a^2 + b^2 + c^2 + 2(a*b + a*c + bc)", - "input=a^2+b^2+c^2+2a*b+2a*c+2bc" - ), - Iteration( - "(a + b)^2 + c^2 + 2a*c + 2bc==a^2+b^2+c^2+2a*b+2a*c+2bc", - "answer=(a + b)^2 + c^2 + 2a*c + 2bc", - "input=a^2+b^2+c^2+2a*b+2a*c+2bc" - ), - Iteration( - "a * a + b * b + c^3/c + 2a*b + 2a*c + 2bc==a^2+b^2+c^2+2a*b+2a*c+2bc", - "answer=a * a + b * b + c^3/c + 2a*b + 2a*c + 2bc", - "input=a^2+b^2+c^2+2a*b+2a*c+2bc" - ), - Iteration( - "a^2+ b^2 + c^2 + 2bc + 2a*c + 2a*b==a^2+b^2+c^2+2a*b+2a*c+2bc", - "answer=a^2+ b^2 + c^2 + 2bc + 2a*c + 2a*b", - "input=a^2+b^2+c^2+2a*b+2a*c+2bc" - ), - Iteration("(3x − 1)^2==9x^2 − 6x + 1", "answer=(3x − 1)^2", "input=9x^2 − 6x + 1"), - Iteration("3x(3x − 2) + 1==9x^2 − 6x + 1", "answer=3x(3x − 2) + 1", "input=9x^2 − 6x + 1"), - Iteration("3(3x^2 − 2x) + 1==9x^2 − 6x + 1", "answer=3(3x^2 − 2x) + 1", "input=9x^2 − 6x + 1"), - Iteration("(3x)^2 − 6x + 1==9x^2 − 6x + 1", "answer=(3x)^2 − 6x + 1", "input=9x^2 − 6x + 1"), - Iteration("c(b-1)==c*b-c", "answer=c(b-1)", "input=c*b-c"), - Iteration("x(x+4)+y==x^2+y+4x", "answer=x(x+4)+y", "input=x^2+y+4x"), - Iteration("x+3==x+1+2", "answer=x+3", "input=x+1+2") + @Iteration("3x(3x - 2) + 1==(3x-1)^2", "answer=3x(3x - 2) + 1", "input=(3x-1)^2") + @Iteration("3(3x^2) - 6x +1==(3x-1)^2", "answer=3(3x^2) - 6x +1", "input=(3x-1)^2") + @Iteration("(1 - 3x)^2!=(3x-1)^2", "answer=(1 - 3x)^2", "input=(3x-1)^2") + @Iteration("2x==sqrt(4x^2)", "answer=2x", "input=sqrt(4x^2)") + @Iteration("x^2+2x+1==(x+1)^2", "answer=x^2+2x+1", "input=(x+1)^2") + @Iteration("x^2-1==(x+1)(x-1)", "answer=x^2-1", "input=(x+1)(x-1)") + @Iteration("x+1==(x^2+2x+1)/(x+1)", "answer=x+1", "input=(x^2+2x+1)/(x+1)") + @Iteration("x-1==(x^2-1)/(x+1)", "answer=x-1", "input=(x^2-1)/(x+1)") + @Iteration("x+1==(x^2-1)/(x-1)", "answer=x+1", "input=(x^2-1)/(x-1)") + @Iteration("-3x==(-27x^3)^(1/3)", "answer=-3x", "input=(-27x^3)^(1/3)") + @Iteration("1==(x^2-1)/(x^2-1)", "answer=1", "input=(x^2-1)/(x^2-1)") + @Iteration("2*(2+6+3+4)==2*(2+6+3+4)", "answer=2*(2+6+3+4)", "input=2*(2+6+3+4)") + @Iteration("2 × (2+6+3+4)==2*(2+6+3+4)", "answer=2 × (2+6+3+4)", "input=2*(2+6+3+4)") + @Iteration( + "15 - (6 × 2) + 3==15 - (6 × 2) + 3", "answer=15 - (6 × 2) + 3", "input=15 - (6 × 2) + 3" + ) + @Iteration( + "2 × (50 + 150 + 100 + 25) ==(50 + 150 + 100 + 25) × 2", + "answer=2 × (50 + 150 + 100 + 25) ", + "input=(50 + 150 + 100 + 25) × 2" + ) + @Iteration( + "2 * (50 + 150 + 100 + 25) ==2 × (50 + 150 + 100 + 25)", + "answer=2 * (50 + 150 + 100 + 25) ", + "input=2 × (50 + 150 + 100 + 25)" + ) + @Iteration("2+5==5+2", "answer=2+5", "input=5+2") + @Iteration("5+2==5+2", "answer=5+2", "input=5+2") + @Iteration("6 − (− 4)==6 − (− 4)", "answer=6 − (− 4)", "input=6 − (− 4)") + @Iteration("6-(-4)==6 − (− 4)", "answer=6-(-4)", "input=6 − (− 4)") + @Iteration("− (− 4) + 6==6 − (− 4)", "answer=− (− 4) + 6", "input=6 − (− 4)") + @Iteration("10==6 − (− 4)", "answer=10", "input=6 − (− 4)") + @Iteration("6 + 4==6 − (− 4)", "answer=6 + 4", "input=6 − (− 4)") + @Iteration("6 + 2^2==6 − (− 4)", "answer=6 + 2^2", "input=6 − (− 4)") + @Iteration("3 * 2 − (− 4)==6 − (− 4)", "answer=3 * 2 − (− 4)", "input=6 − (− 4)") + @Iteration("100/10==6 − (− 4)", "answer=100/10", "input=6 − (− 4)") + @Iteration("3 * 10^-5==3 * 10^-5", "answer=3 * 10^-5", "input=3 * 10^-5") + @Iteration("3/(10 * 10^4)==3 * 10^-5", "answer=3/(10 * 10^4)", "input=3 * 10^-5") + @Iteration( + "1000 + 200 + 30 + 4 + 0.5 + 0.06==1000 + 200 + 30 + 4 + 0.5 + 0.06", + "answer=1000 + 200 + 30 + 4 + 0.5 + 0.06", + "input=1000 + 200 + 30 + 4 + 0.5 + 0.06" + ) + @Iteration( + "200 + 30 + 4 + 0.5 + 0.06 + 1000==1000 + 200 + 30 + 4 + 0.5 + 0.06", + "answer=200 + 30 + 4 + 0.5 + 0.06 + 1000", + "input=1000 + 200 + 30 + 4 + 0.5 + 0.06" + ) + @Iteration( + "0.06 + 0.5 + 4 + 30 + 200 + 1000==1000 + 200 + 30 + 4 + 0.5 + 0.06", + "answer=0.06 + 0.5 + 4 + 30 + 200 + 1000", + "input=1000 + 200 + 30 + 4 + 0.5 + 0.06" + ) + @Iteration( + "1234.56==1000 + 200 + 30 + 4 + 0.5 + 0.06", + "answer=1234.56", + "input=1000 + 200 + 30 + 4 + 0.5 + 0.06" + ) + @Iteration( + "123456/100==1000 + 200 + 30 + 4 + 0.5 + 0.06", + "answer=123456/100", + "input=1000 + 200 + 30 + 4 + 0.5 + 0.06" + ) + @Iteration( + "61728/50==1000 + 200 + 30 + 4 + 0.5 + 0.06", + "answer=61728/50", + "input=1000 + 200 + 30 + 4 + 0.5 + 0.06" + ) + @Iteration( + "1234 + 56/100==1000 + 200 + 30 + 4 + 0.5 + 0.06", + "answer=1234 + 56/100", + "input=1000 + 200 + 30 + 4 + 0.5 + 0.06" + ) + @Iteration( + "1230 + 4.56==1000 + 200 + 30 + 4 + 0.5 + 0.06", + "answer=1230 + 4.56", + "input=1000 + 200 + 30 + 4 + 0.5 + 0.06" + ) + @Iteration("2 * 2 * 3 * 3==2 * 2 * 3 * 3", "answer=2 * 2 * 3 * 3", "input=2 * 2 * 3 * 3") + @Iteration( + "2 * 2 * 3 * 3 * 1==2 * 2 * 3 * 3", "answer=2 * 2 * 3 * 3 * 1", "input=2 * 2 * 3 * 3" + ) + @Iteration("2 * 2 * 9==2 * 2 * 3 * 3", "answer=2 * 2 * 9", "input=2 * 2 * 3 * 3") + @Iteration("4 * 3^2==2 * 2 * 3 * 3", "answer=4 * 3^2", "input=2 * 2 * 3 * 3") + @Iteration("8/2 * 3 * 3==2 * 2 * 3 * 3", "answer=8/2 * 3 * 3", "input=2 * 2 * 3 * 3") + @Iteration("36==2 * 2 * 3 * 3", "answer=36", "input=2 * 2 * 3 * 3") + @Iteration("sqrt(4-2)==sqrt(2)", "answer=sqrt(4-2)", "input=sqrt(2)") + @Iteration("4x^2+20x==4*x^2+20x", "answer=4x^2+20x", "input=4*x^2+20x") + @Iteration("3+x-5==3+x-5", "answer=3+x-5", "input=3+x-5") + @Iteration("Z+A-Z==Z+A-Z", "answer=Z+A-Z", "input=Z+A-Z") + @Iteration("6C - 5A -1==6C - 5A -1", "answer=6C - 5A -1", "input=6C - 5A -1") + @Iteration("5Z-w==5*Z-w", "answer=5Z-w", "input=5*Z-w") + @Iteration("5*Z-w==5*Z-w", "answer=5*Z-w", "input=5*Z-w") + @Iteration("LS-3S+L==L*S-3S+L", "answer=LS-3S+L", "input=L*S-3S+L") + @Iteration("L*S-3S+L==L*S-3S+L", "answer=L*S-3S+L", "input=L*S-3S+L") + @Iteration("L*S-3*S+L==L*S-3S+L", "answer=L*S-3*S+L", "input=L*S-3S+L") + @Iteration("LS-3*S+L==L*S-3S+L", "answer=LS-3*S+L", "input=L*S-3S+L") + @Iteration("9x^2 − 6x + 1==9x^2 − 6x + 1", "answer=9x^2 − 6x + 1", "input=9x^2 − 6x + 1") + @Iteration("c*b-c==c*b-c", "answer=c*b-c", "input=c*b-c") + @Iteration("bc-c==c*b-c", "answer=bc-c", "input=c*b-c") + @Iteration("cb-c==c*b-c", "answer=cb-c", "input=c*b-c") + @Iteration("-c+bc==c*b-c", "answer=-c+bc", "input=c*b-c") + @Iteration("-c+cb==c*b-c", "answer=-c+cb", "input=c*b-c") + @Iteration("x^2+y+4x==x^2+y+4x", "answer=x^2+y+4x", "input=x^2+y+4x") + @Iteration("y+4x+x^2==x^2+y+4x", "answer=y+4x+x^2", "input=x^2+y+4x") + @Iteration("x^2+4x+y==x^2+y+4x", "answer=x^2+4x+y", "input=x^2+y+4x") + @Iteration("Y+5==Y+5", "answer=Y+5", "input=Y+5") + @Iteration("5+Y==Y+5", "answer=5+Y", "input=Y+5") + @Iteration( + "a^2 + b^2 + c^2+ 2a*b + 2a*c + 2bc==a^2+b^2+c^2+2a*b+2a*c+2bc", + "answer=a^2 + b^2 + c^2+ 2a*b + 2a*c + 2bc", + "input=a^2+b^2+c^2+2a*b+2a*c+2bc" + ) + @Iteration( + "a^2 + b^2 + c^2+ 2a*b + 2bc + 2a*c==a^2+b^2+c^2+2a*b+2a*c+2bc", + "answer=a^2 + b^2 + c^2+ 2a*b + 2bc + 2a*c", + "input=a^2+b^2+c^2+2a*b+2a*c+2bc" + ) + @Iteration( + "2a*b + 2bc + 2a*c + a^2 + b^2 + c^2==a^2+b^2+c^2+2a*b+2a*c+2bc", + "answer=2a*b + 2bc + 2a*c + a^2 + b^2 + c^2", + "input=a^2+b^2+c^2+2a*b+2a*c+2bc" + ) + @Iteration( + "2a*b + b^2 + c^2+ a^2 + 2bc + 2a*c==a^2+b^2+c^2+2a*b+2a*c+2bc", + "answer=2a*b + b^2 + c^2+ a^2 + 2bc + 2a*c", + "input=a^2+b^2+c^2+2a*b+2a*c+2bc" + ) + @Iteration( + "a*a + b*b + c*c + 2*a*b + 2*a*c + 2*b*c==a^2+b^2+c^2+2a*b+2a*c+2bc", + "answer=a*a + b*b + c*c + 2*a*b + 2*a*c + 2*b*c", + "input=a^2+b^2+c^2+2a*b+2a*c+2bc" + ) + @Iteration( + "(a+ b)^2 + c^2 + 2bc + 2a*c==a^2+b^2+c^2+2a*b+2a*c+2bc", + "answer=(a+ b)^2 + c^2 + 2bc + 2a*c", + "input=a^2+b^2+c^2+2a*b+2a*c+2bc" + ) + @Iteration( + "(a+b+c)^2==a^2+b^2+c^2+2a*b+2a*c+2bc", "answer=(a+b+c)^2", "input=a^2+b^2+c^2+2a*b+2a*c+2bc" + ) + @Iteration( + "(-a -b -c)^2==a^2+b^2+c^2+2a*b+2a*c+2bc", + "answer=(-a -b -c)^2", + "input=a^2+b^2+c^2+2a*b+2a*c+2bc" ) + @Iteration("1 - 6x + 9x^2==9x^2 − 6x + 1", "answer=1 - 6x + 9x^2", "input=9x^2 − 6x + 1") + @Iteration("9x^2 + 1 - 6x==9x^2 − 6x + 1", "answer=9x^2 + 1 - 6x", "input=9x^2 − 6x + 1") + @Iteration("2+1+x==x+1+2", "answer=2+1+x", "input=x+1+2") + @Iteration("1+2+x==x+1+2", "answer=1+2+x", "input=x+1+2") + @Iteration("1+x+2==x+1+2", "answer=1+x+2", "input=x+1+2") + @Iteration("2+x+1==x+1+2", "answer=2+x+1", "input=x+1+2") + @Iteration("(x+1)+2==x+1+2", "answer=(x+1)+2", "input=x+1+2") + @Iteration("x + (1+2)==x+1+2", "answer=x + (1+2)", "input=x+1+2") + @Iteration( + "y+1+ 9x(x − 6)==9x(x − 6) + 1+ y", "answer=y+1+ 9x(x − 6)", "input=9x(x − 6) + 1+ y" + ) + @Iteration("1+y+9x(x − 6)==9x(x − 6) + 1+ y", "answer=1+y+9x(x − 6)", "input=9x(x − 6) + 1+ y") + @Iteration( + "1 + 9x(x − 6) + y==9x(x − 6) + 1+ y", "answer=1 + 9x(x − 6) + y", "input=9x(x − 6) + 1+ y" + ) + @Iteration( + "(y+1)+9x(x − 6)==9x(x − 6) + 1+ y", "answer=(y+1)+9x(x − 6)", "input=9x(x − 6) + 1+ y" + ) + @Iteration( + "(x^2 − x)/3 − 4y==(x^2 − x)/3 − 4y", "answer=(x^2 − x)/3 − 4y", "input=(x^2 − x)/3 − 4y" + ) + @Iteration( + "-4y + (x^2 − x)/3==(x^2 − x)/3 − 4y", "answer=-4y + (x^2 − x)/3", "input=(x^2 − x)/3 − 4y" + ) + @Iteration( + "x(x − 1)/3 −4y==(x^2 − x)/3 − 4y", "answer=x(x − 1)/3 −4y", "input=(x^2 − x)/3 − 4y" + ) + @Iteration( + "x^2/3 − x/3 − 4y==(x^2 − x)/3 − 4y", "answer=x^2/3 − x/3 − 4y", "input=(x^2 − x)/3 − 4y" + ) + @Iteration( + "x^2/3 − (x/3 + 4y)==(x^2 − x)/3 − 4y", "answer=x^2/3 − (x/3 + 4y)", "input=(x^2 − x)/3 − 4y" + ) + @Iteration("(3x -1)^2==(3x-1)^2", "answer=(3x -1)^2", "input=(3x-1)^2") + @Iteration("2*(6+3+4) + 4==2*(2+6+3+4)", "answer=2*(6+3+4) + 4", "input=2*(2+6+3+4)") + @Iteration("2*(2+6+3) + 8==2*(2+6+3+4)", "answer=2*(2+6+3) + 8", "input=2*(2+6+3+4)") + @Iteration("(2+6+3+4)*2==2*(2+6+3+4)", "answer=(2+6+3+4)*2", "input=2*(2+6+3+4)") + @Iteration("(2+6+3+4) × 2==2*(2+6+3+4)", "answer=(2+6+3+4) × 2", "input=2*(2+6+3+4)") + @Iteration("15 - 12 + 3==15 - (6 × 2) + 3", "answer=15 - 12 + 3", "input=15 - (6 × 2) + 3") + @Iteration( + "3 - (6 * 2) + 15==15 - (6 × 2) + 3", "answer=3 - (6 * 2) + 15", "input=15 - (6 × 2) + 3" + ) + @Iteration( + "15 - (2 × 6) + 3==15 - (6 × 2) + 3", "answer=15 - (2 × 6) + 3", "input=15 - (6 × 2) + 3" + ) + @Iteration( + "2 *(50 + 150) + 2*(100 + 25)==(50 + 150 + 100 + 25) × 2", + "answer=2 *(50 + 150) + 2*(100 + 25)", + "input=(50 + 150 + 100 + 25) × 2" + ) + @Iteration( + "2* ( 25+50+100+150)==(50 + 150 + 100 + 25) × 2", + "answer=2* ( 25+50+100+150)", + "input=(50 + 150 + 100 + 25) × 2" + ) + @Iteration("10^−5 * 3==3 * 10^-5", "answer=10^−5 * 3", "input=3 * 10^-5") + @Iteration("30 * 10^−6==3 * 10^-5", "answer=30 * 10^−6", "input=3 * 10^-5") + @Iteration("0.00003==3 * 10^-5", "answer=0.00003", "input=3 * 10^-5") + @Iteration("3/10^5==3 * 10^-5", "answer=3/10^5", "input=3 * 10^-5") + @Iteration("3 *2 – (− 4)==6 − (− 4)", "answer=3 *2 – (− 4)", "input=6 − (− 4)") + @Iteration("7==5+2", "answer=7", "input=5+2") + @Iteration("3+4==5+2", "answer=3+4", "input=5+2") + @Iteration("20x+4x^2==4*x^2+20x", "answer=20x+4x^2", "input=4*x^2+20x") + @Iteration("x-5+3==3+x-5", "answer=x-5+3", "input=3+x-5") + @Iteration("-5+3+x==3+x-5", "answer=-5+3+x", "input=3+x-5") + @Iteration("-5+x+3==3+x-5", "answer=-5+x+3", "input=3+x-5") + @Iteration("3+(x-5)==3+x-5", "answer=3+(x-5)", "input=3+x-5") + @Iteration("A==Z+A-Z", "answer=A", "input=Z+A-Z") + @Iteration("A+Z-Z==Z+A-Z", "answer=A+Z-Z", "input=Z+A-Z") + @Iteration("Z+(A-Z)==Z+A-Z", "answer=Z+(A-Z)", "input=Z+A-Z") + @Iteration("6C - (5A+1)==6C - 5A -1", "answer=6C - (5A+1)", "input=6C - 5A -1") + @Iteration("-5A-1+6C==6C - 5A -1", "answer=-5A-1+6C", "input=6C - 5A -1") + @Iteration("-W+5Z==5*Z-W", "answer=-W+5Z", "input=5*Z-W") + @Iteration("L(1+S)-3S==L*S-3S+L", "answer=L(1+S)-3S", "input=L*S-3S+L") + @Iteration("S(L-3)+L==L*S-3S+L", "answer=S(L-3)+L", "input=L*S-3S+L") + @Iteration("L+LS-3S==L*S-3S+L", "answer=L+LS-3S", "input=L*S-3S+L") + @Iteration( + "x(x − 1)/3 − 4y==(x^2 − x)/3 − 4y", "answer=x(x − 1)/3 − 4y", "input=(x^2 − x)/3 − 4y" + ) + @Iteration( + "- 4y + (x^2 − x)/3==(x^2 − x)/3 − 4y", "answer=- 4y + (x^2 − x)/3", "input=(x^2 − x)/3 − 4y" + ) + @Iteration( + "(x^2 − x) * 3^-1 − 4y==(x^2 − x)/3 − 4y", + "answer=(x^2 − x) * 3^-1 − 4y", + "input=(x^2 − x)/3 − 4y" + ) + @Iteration( + "a^2 + b^2 + c^2 + 2(a*b + a*c + bc)==a^2+b^2+c^2+2a*b+2a*c+2bc", + "answer=a^2 + b^2 + c^2 + 2(a*b + a*c + bc)", + "input=a^2+b^2+c^2+2a*b+2a*c+2bc" + ) + @Iteration( + "(a + b)^2 + c^2 + 2a*c + 2bc==a^2+b^2+c^2+2a*b+2a*c+2bc", + "answer=(a + b)^2 + c^2 + 2a*c + 2bc", + "input=a^2+b^2+c^2+2a*b+2a*c+2bc" + ) + @Iteration( + "a * a + b * b + c^3/c + 2a*b + 2a*c + 2bc==a^2+b^2+c^2+2a*b+2a*c+2bc", + "answer=a * a + b * b + c^3/c + 2a*b + 2a*c + 2bc", + "input=a^2+b^2+c^2+2a*b+2a*c+2bc" + ) + @Iteration( + "a^2+ b^2 + c^2 + 2bc + 2a*c + 2a*b==a^2+b^2+c^2+2a*b+2a*c+2bc", + "answer=a^2+ b^2 + c^2 + 2bc + 2a*c + 2a*b", + "input=a^2+b^2+c^2+2a*b+2a*c+2bc" + ) + @Iteration("(3x − 1)^2==9x^2 − 6x + 1", "answer=(3x − 1)^2", "input=9x^2 − 6x + 1") + @Iteration("3x(3x − 2) + 1==9x^2 − 6x + 1", "answer=3x(3x − 2) + 1", "input=9x^2 − 6x + 1") + @Iteration("3(3x^2 − 2x) + 1==9x^2 − 6x + 1", "answer=3(3x^2 − 2x) + 1", "input=9x^2 − 6x + 1") + @Iteration("(3x)^2 − 6x + 1==9x^2 − 6x + 1", "answer=(3x)^2 − 6x + 1", "input=9x^2 − 6x + 1") + @Iteration("c(b-1)==c*b-c", "answer=c(b-1)", "input=c*b-c") + @Iteration("x(x+4)+y==x^2+y+4x", "answer=x(x+4)+y", "input=x^2+y+4x") + @Iteration("x+3==x+1+2", "answer=x+3", "input=x+1+2") fun testMatches_assortedExpressions_withMatchingCharacteristics_returnsTrue() { val answerExpression = createMathExpression(answer) val inputExpression = createMathExpression(input) @@ -525,68 +506,66 @@ class AlgebraicExpressionInputIsEquivalentToRuleClassifierProviderTest { } @Test - @RunParameterized( - Iteration("√(3x −1)4!=(3x-1)^2", "answer=√(3x −1)4", "input=(3x-1)^2"), - Iteration("3 * 10^5!=3 * 10^-5", "answer=3 * 10^5", "input=3 * 10^-5"), - Iteration("2 * 10^−5!=3 * 10^-5", "answer=2 * 10^−5", "input=3 * 10^-5"), - Iteration("5 * 10^−3!=3 * 10^-5", "answer=5 * 10^−3", "input=3 * 10^-5"), - Iteration( - "123456!=1000 + 200 + 30 + 4 + 0.5 + 0.06", - "answer=123456", - "input=1000 + 200 + 30 + 4 + 0.5 + 0.06" - ), - Iteration( - "1000 + 200 + 30!=1000 + 200 + 30 + 4 + 0.5 + 0.06", - "answer=1000 + 200 + 30", - "input=1000 + 200 + 30 + 4 + 0.5 + 0.06" - ), - Iteration("6 − 4!=6 − (− 4)", "answer=6 − 4", "input=6 − (− 4)"), - Iteration("6 + (− 4)!=6 − (− 4)", "answer=6 + (− 4)", "input=6 − (− 4)"), - Iteration("100!=6 − (− 4)", "answer=100", "input=6 − (− 4)"), - Iteration("2 * 2 * 3!=2 * 2 * 3 * 3", "answer=2 * 2 * 3", "input=2 * 2 * 3 * 3"), - Iteration("2 * 3 * 3 * 3!=2 * 2 * 3 * 3", "answer=2 * 3 * 3 * 3", "input=2 * 2 * 3 * 3"), - Iteration( - "x(x^2 − x)/3 − 4y!=(x^2 − x)/3 − 4y", "answer=x(x^2 − x)/3 − 4y", "input=(x^2 − x)/3 − 4y" - ), - Iteration( - "(x^2 − x)/3 + 4y!=(x^2 − x)/3 − 4y", "answer=(x^2 − x)/3 + 4y", "input=(x^2 − x)/3 − 4y" - ), - Iteration( - "(x^2 + x)/3 - 4y!=(x^2 − x)/3 − 4y", "answer=(x^2 + x)/3 - 4y", "input=(x^2 − x)/3 − 4y" - ), - Iteration( - "(x^2 − x)*0.33 - 4y!=(x^2 − x)/3 − 4y", - "answer=(x^2 − x)*0.33 - 4y", - "input=(x^2 − x)/3 − 4y" - ), - Iteration( - "(a + b + c)^3!=a^2+b^2+c^2+2a*b+2a*c+2bc", - "answer=(a + b + c)^3", - "input=a^2+b^2+c^2+2a*b+2a*c+2bc" - ), - Iteration( - "a^2 + b^2 + c^2!=a^2+b^2+c^2+2a*b+2a*c+2bc", - "answer=a^2 + b^2 + c^2", - "input=a^2+b^2+c^2+2a*b+2a*c+2bc" - ), - Iteration( - "a^2 + b^2 + c^2- 2a*b - 2a*c - 2bc!=a^2+b^2+c^2+2a*b+2a*c+2bc", - "answer=a^2 + b^2 + c^2- 2a*b - 2a*c - 2bc", - "input=a^2+b^2+c^2+2a*b+2a*c+2bc" - ), - Iteration("9x^2 - 6x - 1!=(3x-1)^2", "answer=9x^2 - 6x - 1", "input=(3x-1)^2"), - Iteration("(3x −1)!=(3x-1)^2", "answer=(3x −1)", "input=(3x-1)^2"), - Iteration("2x!=sqrt(2x)^2", "answer=2x", "input=sqrt(2x)^2"), - Iteration("2x!=sqrt(-4x^2)", "answer=2x", "input=sqrt(-4x^2)"), - Iteration("x^2+2x+1!=(x+2)^2", "answer=x^2+2x+1", "input=(x+2)^2"), - Iteration("x^2-1!=(x+1)(1-x)", "answer=x^2-1", "input=(x+1)(1-x)"), - Iteration("x+1!=(x^2+2x+1)/(x-1)", "answer=x+1", "input=(x^2+2x+1)/(x-1)"), - Iteration("x-1!=(x^2-1)/x", "answer=x-1", "input=(x^2-1)/x"), - Iteration("x+1!=(x^2-1)/(x-2)", "answer=x+1", "input=(x^2-1)/(x-2)"), - Iteration("-3x!=(9x^3)^(1/3)", "answer=-3x", "input=(9x^3)^(1/3)"), - Iteration("Y==Y+5", "answer=Y", "input=Y+5"), - Iteration("5==Y+5", "answer=5", "input=Y+5") + @Iteration("√(3x −1)4!=(3x-1)^2", "answer=√(3x −1)4", "input=(3x-1)^2") + @Iteration("3 * 10^5!=3 * 10^-5", "answer=3 * 10^5", "input=3 * 10^-5") + @Iteration("2 * 10^−5!=3 * 10^-5", "answer=2 * 10^−5", "input=3 * 10^-5") + @Iteration("5 * 10^−3!=3 * 10^-5", "answer=5 * 10^−3", "input=3 * 10^-5") + @Iteration( + "123456!=1000 + 200 + 30 + 4 + 0.5 + 0.06", + "answer=123456", + "input=1000 + 200 + 30 + 4 + 0.5 + 0.06" + ) + @Iteration( + "1000 + 200 + 30!=1000 + 200 + 30 + 4 + 0.5 + 0.06", + "answer=1000 + 200 + 30", + "input=1000 + 200 + 30 + 4 + 0.5 + 0.06" + ) + @Iteration("6 − 4!=6 − (− 4)", "answer=6 − 4", "input=6 − (− 4)") + @Iteration("6 + (− 4)!=6 − (− 4)", "answer=6 + (− 4)", "input=6 − (− 4)") + @Iteration("100!=6 − (− 4)", "answer=100", "input=6 − (− 4)") + @Iteration("2 * 2 * 3!=2 * 2 * 3 * 3", "answer=2 * 2 * 3", "input=2 * 2 * 3 * 3") + @Iteration("2 * 3 * 3 * 3!=2 * 2 * 3 * 3", "answer=2 * 3 * 3 * 3", "input=2 * 2 * 3 * 3") + @Iteration( + "x(x^2 − x)/3 − 4y!=(x^2 − x)/3 − 4y", "answer=x(x^2 − x)/3 − 4y", "input=(x^2 − x)/3 − 4y" + ) + @Iteration( + "(x^2 − x)/3 + 4y!=(x^2 − x)/3 − 4y", "answer=(x^2 − x)/3 + 4y", "input=(x^2 − x)/3 − 4y" + ) + @Iteration( + "(x^2 + x)/3 - 4y!=(x^2 − x)/3 − 4y", "answer=(x^2 + x)/3 - 4y", "input=(x^2 − x)/3 − 4y" + ) + @Iteration( + "(x^2 − x)*0.33 - 4y!=(x^2 − x)/3 − 4y", + "answer=(x^2 − x)*0.33 - 4y", + "input=(x^2 − x)/3 − 4y" + ) + @Iteration( + "(a + b + c)^3!=a^2+b^2+c^2+2a*b+2a*c+2bc", + "answer=(a + b + c)^3", + "input=a^2+b^2+c^2+2a*b+2a*c+2bc" + ) + @Iteration( + "a^2 + b^2 + c^2!=a^2+b^2+c^2+2a*b+2a*c+2bc", + "answer=a^2 + b^2 + c^2", + "input=a^2+b^2+c^2+2a*b+2a*c+2bc" + ) + @Iteration( + "a^2 + b^2 + c^2- 2a*b - 2a*c - 2bc!=a^2+b^2+c^2+2a*b+2a*c+2bc", + "answer=a^2 + b^2 + c^2- 2a*b - 2a*c - 2bc", + "input=a^2+b^2+c^2+2a*b+2a*c+2bc" ) + @Iteration("9x^2 - 6x - 1!=(3x-1)^2", "answer=9x^2 - 6x - 1", "input=(3x-1)^2") + @Iteration("(3x −1)!=(3x-1)^2", "answer=(3x −1)", "input=(3x-1)^2") + @Iteration("2x!=sqrt(2x)^2", "answer=2x", "input=sqrt(2x)^2") + @Iteration("2x!=sqrt(-4x^2)", "answer=2x", "input=sqrt(-4x^2)") + @Iteration("x^2+2x+1!=(x+2)^2", "answer=x^2+2x+1", "input=(x+2)^2") + @Iteration("x^2-1!=(x+1)(1-x)", "answer=x^2-1", "input=(x+1)(1-x)") + @Iteration("x+1!=(x^2+2x+1)/(x-1)", "answer=x+1", "input=(x^2+2x+1)/(x-1)") + @Iteration("x-1!=(x^2-1)/x", "answer=x-1", "input=(x^2-1)/x") + @Iteration("x+1!=(x^2-1)/(x-2)", "answer=x+1", "input=(x^2-1)/(x-2)") + @Iteration("-3x!=(9x^3)^(1/3)", "answer=-3x", "input=(9x^3)^(1/3)") + @Iteration("Y==Y+5", "answer=Y", "input=Y+5") + @Iteration("5==Y+5", "answer=5", "input=Y+5") fun testMatches_assortedExpressions_withoutMatchingCharacteristics_returnsFalse() { val answerExpression = createMathExpression(answer) val inputExpression = createMathExpression(input) diff --git a/domain/src/test/java/org/oppia/android/domain/classify/rules/algebraicexpressioninput/AlgebraicExpressionInputMatchesExactlyWithRuleClassifierProviderTest.kt b/domain/src/test/java/org/oppia/android/domain/classify/rules/algebraicexpressioninput/AlgebraicExpressionInputMatchesExactlyWithRuleClassifierProviderTest.kt index 0511f4c6d0a..624d16d2a0a 100644 --- a/domain/src/test/java/org/oppia/android/domain/classify/rules/algebraicexpressioninput/AlgebraicExpressionInputMatchesExactlyWithRuleClassifierProviderTest.kt +++ b/domain/src/test/java/org/oppia/android/domain/classify/rules/algebraicexpressioninput/AlgebraicExpressionInputMatchesExactlyWithRuleClassifierProviderTest.kt @@ -19,7 +19,6 @@ import org.oppia.android.domain.classify.RuleClassifier import org.oppia.android.testing.junit.OppiaParameterizedTestRunner import org.oppia.android.testing.junit.OppiaParameterizedTestRunner.Iteration import org.oppia.android.testing.junit.OppiaParameterizedTestRunner.Parameter -import org.oppia.android.testing.junit.OppiaParameterizedTestRunner.RunParameterized import org.oppia.android.testing.junit.OppiaParameterizedTestRunner.SelectRunnerPlatform import org.oppia.android.testing.junit.ParameterizedRobolectricTestRunner import org.oppia.android.testing.robolectric.RobolectricModule @@ -76,13 +75,11 @@ class AlgebraicExpressionInputMatchesExactlyWithRuleClassifierProviderTest { } @Test - @RunParameterized( - Iteration("0==0", "answer=0", "input=0"), - Iteration("1==1", "answer=1", "input=1"), - Iteration("2==2", "answer=2", "input=2"), - Iteration("x==x", "answer=x", "input=x"), - Iteration("y==y", "answer=y", "input=y") - ) + @Iteration("0==0", "answer=0", "input=0") + @Iteration("1==1", "answer=1", "input=1") + @Iteration("2==2", "answer=2", "input=2") + @Iteration("x==x", "answer=x", "input=x") + @Iteration("y==y", "answer=y", "input=y") fun testMatches_sameSingleTerms_returnsTrue() { val answerExpression = createMathExpression(answer) val inputExpression = createMathExpression(input) @@ -94,25 +91,23 @@ class AlgebraicExpressionInputMatchesExactlyWithRuleClassifierProviderTest { } @Test - @RunParameterized( - Iteration("-2==-2", "answer=-2", "input=-2"), - Iteration("1+3.14==1+3.14", "answer=1+3.14", "input=1+3.14"), - Iteration(" 1 + 3.14 ==1+3.14", "answer= 1 + 3.14 ", "input=1+3.14"), - Iteration("1+2+3==1+2+3", "answer=1+2+3", "input=1+2+3"), - Iteration("1-3.14==1-3.14", "answer=1-3.14", "input=1-3.14"), - Iteration("2*3.14==2*3.14", "answer=2*3.14", "input=2*3.14"), - Iteration("2/3==2/3", "answer=2/3", "input=2/3"), - Iteration("2/3.14==2/3.14", "answer=2/3.14", "input=2/3.14"), - Iteration("2^3==2^3", "answer=2^3", "input=2^3"), - Iteration("2^3.14==2^3.14", "answer=2^3.14", "input=2^3.14"), - Iteration("sqrt(2)==sqrt(2)", "answer=sqrt(2)", "input=sqrt(2)"), - Iteration("-x==-x", "answer=-x", "input=-x"), - Iteration("x+3.14==x+3.14", "answer=x+3.14", "input=x+3.14"), - Iteration("x-3.14==x-3.14", "answer=x-3.14", "input=x-3.14"), - Iteration("x*3.14==x*3.14", "answer=x*3.14", "input=x*3.14"), - Iteration("x/3==x/3", "answer=x/3", "input=x/3"), - Iteration("sqrt(x)==sqrt(x)", "answer=sqrt(x)", "input=sqrt(x)") - ) + @Iteration("-2==-2", "answer=-2", "input=-2") + @Iteration("1+3.14==1+3.14", "answer=1+3.14", "input=1+3.14") + @Iteration(" 1 + 3.14 ==1+3.14", "answer= 1 + 3.14 ", "input=1+3.14") + @Iteration("1+2+3==1+2+3", "answer=1+2+3", "input=1+2+3") + @Iteration("1-3.14==1-3.14", "answer=1-3.14", "input=1-3.14") + @Iteration("2*3.14==2*3.14", "answer=2*3.14", "input=2*3.14") + @Iteration("2/3==2/3", "answer=2/3", "input=2/3") + @Iteration("2/3.14==2/3.14", "answer=2/3.14", "input=2/3.14") + @Iteration("2^3==2^3", "answer=2^3", "input=2^3") + @Iteration("2^3.14==2^3.14", "answer=2^3.14", "input=2^3.14") + @Iteration("sqrt(2)==sqrt(2)", "answer=sqrt(2)", "input=sqrt(2)") + @Iteration("-x==-x", "answer=-x", "input=-x") + @Iteration("x+3.14==x+3.14", "answer=x+3.14", "input=x+3.14") + @Iteration("x-3.14==x-3.14", "answer=x-3.14", "input=x-3.14") + @Iteration("x*3.14==x*3.14", "answer=x*3.14", "input=x*3.14") + @Iteration("x/3==x/3", "answer=x/3", "input=x/3") + @Iteration("sqrt(x)==sqrt(x)", "answer=sqrt(x)", "input=sqrt(x)") fun testMatches_sameSingleOperations_returnsTrue() { val answerExpression = createMathExpression(answer) val inputExpression = createMathExpression(input) @@ -124,15 +119,13 @@ class AlgebraicExpressionInputMatchesExactlyWithRuleClassifierProviderTest { } @Test - @RunParameterized( - Iteration("1!=0", "answer=1", "input=0"), - Iteration("0!=1", "answer=0", "input=1"), - Iteration("3.14!=1", "answer=3.14", "input=1"), - Iteration("1!=3.14", "answer=1", "input=3.14"), - Iteration("x!=3.14", "answer=x", "input=3.14"), - Iteration("y!=x", "answer=y", "input=x"), - Iteration("3.14!=x", "answer=3.14", "input=x") - ) + @Iteration("1!=0", "answer=1", "input=0") + @Iteration("0!=1", "answer=0", "input=1") + @Iteration("3.14!=1", "answer=3.14", "input=1") + @Iteration("1!=3.14", "answer=1", "input=3.14") + @Iteration("x!=3.14", "answer=x", "input=3.14") + @Iteration("y!=x", "answer=y", "input=x") + @Iteration("3.14!=x", "answer=3.14", "input=x") fun testMatches_differentSingleTerms_returnsFalse() { val answerExpression = createMathExpression(answer) val inputExpression = createMathExpression(input) @@ -144,16 +137,14 @@ class AlgebraicExpressionInputMatchesExactlyWithRuleClassifierProviderTest { } @Test - @RunParameterized( - Iteration("3.14+1!=1+3.14", "answer=3.14+1", "input=1+3.14"), - Iteration("3+2+1!=1+2+3", "answer=3+2+1", "input=1+2+3"), - Iteration("-3.14+1!=1-3.14", "answer=-3.14+1", "input=1-3.14"), - Iteration("3.14*2!=2*3.14", "answer=3.14*2", "input=2*3.14"), - Iteration("2+x!=x+2", "answer=2+x", "input=x+2"), - Iteration("y+x!=x+y", "answer=y+x", "input=x+y"), - Iteration("x*2!=2x", "answer=x*2", "input=2x"), - Iteration("yx!=xy", "answer=yx", "input=xy") - ) + @Iteration("3.14+1!=1+3.14", "answer=3.14+1", "input=1+3.14") + @Iteration("3+2+1!=1+2+3", "answer=3+2+1", "input=1+2+3") + @Iteration("-3.14+1!=1-3.14", "answer=-3.14+1", "input=1-3.14") + @Iteration("3.14*2!=2*3.14", "answer=3.14*2", "input=2*3.14") + @Iteration("2+x!=x+2", "answer=2+x", "input=x+2") + @Iteration("y+x!=x+y", "answer=y+x", "input=x+y") + @Iteration("x*2!=2x", "answer=x*2", "input=2x") + @Iteration("yx!=xy", "answer=yx", "input=xy") fun testMatches_operationsDiffer_byCommutativity_returnsFalse() { val answerExpression = createMathExpression(answer) val inputExpression = createMathExpression(input) @@ -165,14 +156,12 @@ class AlgebraicExpressionInputMatchesExactlyWithRuleClassifierProviderTest { } @Test - @RunParameterized( - Iteration("1+(2+3)!=(1+2)+3", "answer=1+(2+3)", "input=(1+2)+3"), - Iteration("2*(3*4)!=(2*3)*4", "answer=2*(3*4)", "input=(2*3)*4"), - Iteration("x+(2+3)!=(x+2)+3", "answer=x+(2+3)", "input=(x+2)+3"), - Iteration("x+(y+z)!=(x+y)+z", "answer=x+(y+z)", "input=(x+y)+z"), - Iteration("2*(3x)!=(2x)*3", "answer=2*(3x)", "input=(2x)*3"), - Iteration("x(yz)!=(xy)z", "answer=x(yz)", "input=(xy)z") - ) + @Iteration("1+(2+3)!=(1+2)+3", "answer=1+(2+3)", "input=(1+2)+3") + @Iteration("2*(3*4)!=(2*3)*4", "answer=2*(3*4)", "input=(2*3)*4") + @Iteration("x+(2+3)!=(x+2)+3", "answer=x+(2+3)", "input=(x+2)+3") + @Iteration("x+(y+z)!=(x+y)+z", "answer=x+(y+z)", "input=(x+y)+z") + @Iteration("2*(3x)!=(2x)*3", "answer=2*(3x)", "input=(2x)*3") + @Iteration("x(yz)!=(xy)z", "answer=x(yz)", "input=(xy)z") fun testMatches_operationsDiffer_byAssociativity_returnsFalse() { val answerExpression = createMathExpression(answer) val inputExpression = createMathExpression(input) @@ -184,17 +173,15 @@ class AlgebraicExpressionInputMatchesExactlyWithRuleClassifierProviderTest { } @Test - @RunParameterized( - Iteration("3.14-1!=1-3.14", "answer=3.14-1", "input=1-3.14"), - Iteration("1-(2-3)!=(1-2)-3", "answer=1-(2-3)", "input=(1-2)-3"), - Iteration("3.14/2!=2/3.14", "answer=3.14/2", "input=2/3.14"), - Iteration("2/(3/4)!=(2/3)/4", "answer=2/(3/4)", "input=(2/3)/4"), - Iteration("3.14^2!=2^3.14", "answer=3.14^2", "input=2^3.14"), - Iteration("3.14-x!=x-3.14", "answer=3.14-x", "input=x-3.14"), - Iteration("x-(y-z)!=(x-y)-z", "answer=x-(y-z)", "input=(x-y)-z"), - Iteration("3.14/x!=x/3.14", "answer=3.14/x", "input=x/3.14"), - Iteration("x/(y/z)!=(x/y)/z", "answer=x/(y/z)", "input=(x/y)/z") - ) + @Iteration("3.14-1!=1-3.14", "answer=3.14-1", "input=1-3.14") + @Iteration("1-(2-3)!=(1-2)-3", "answer=1-(2-3)", "input=(1-2)-3") + @Iteration("3.14/2!=2/3.14", "answer=3.14/2", "input=2/3.14") + @Iteration("2/(3/4)!=(2/3)/4", "answer=2/(3/4)", "input=(2/3)/4") + @Iteration("3.14^2!=2^3.14", "answer=3.14^2", "input=2^3.14") + @Iteration("3.14-x!=x-3.14", "answer=3.14-x", "input=x-3.14") + @Iteration("x-(y-z)!=(x-y)-z", "answer=x-(y-z)", "input=(x-y)-z") + @Iteration("3.14/x!=x/3.14", "answer=3.14/x", "input=x/3.14") + @Iteration("x/(y/z)!=(x/y)/z", "answer=x/(y/z)", "input=(x/y)/z") fun testMatches_operationsDiffer_byNonCommutativeOrAssociativeReordering_returnsFalse() { val answerExpression = createMathExpression(answer) val inputExpression = createMathExpression(input) @@ -207,26 +194,24 @@ class AlgebraicExpressionInputMatchesExactlyWithRuleClassifierProviderTest { } @Test - @RunParameterized( - Iteration("1-2!=-(2-1)", "answer=1-2", "input=-(2-1)"), - Iteration("1+2!=1+1+1", "answer=1+2", "input=1+1+1"), - Iteration("1+2!=1-(-2)", "answer=1+2", "input=1-(-2)"), - Iteration("4-6!=1-2-1", "answer=4-6", "input=1-2-1"), - Iteration("2*3*2*2!=2*3*4", "answer=2*3*2*2", "input=2*3*4"), - Iteration("-6-2!=2*-(3+1)", "answer=-6-2", "input=2*-(3+1)"), - Iteration("2/3/2/2!=2/3/4", "answer=2/3/2/2", "input=2/3/4"), - Iteration("2^(2+1)!=2^3", "answer=2^(2+1)", "input=2^3"), - Iteration("2^(-1)!=1/2", "answer=2^(-1)", "input=1/2"), - Iteration("x-y!=-(y-x)", "answer=x-y", "input=-(y-x)"), - Iteration("2+x!=1+x+1", "answer=2+x", "input=1+x+1"), - Iteration("1+x!=1-(-x)", "answer=1+x", "input=1-(-x)"), - Iteration("x!=1-x-1", "answer=x", "input=1-x-1"), - Iteration("4x!=2*2*x", "answer=4x", "input=2*2*x"), - Iteration("2-6x!=2*(-3x+1)", "answer=2-6x", "input=2*(-3x+1)"), - Iteration("x/4!=x/2/2", "answer=x/4", "input=x/2/2"), - Iteration("x^(2+1)!=x^3", "answer=x^(2+1)", "input=x^3"), - Iteration("x*(2^(-1))!=x/2", "answer=x*(2^(-1))", "input=x/2") - ) + @Iteration("1-2!=-(2-1)", "answer=1-2", "input=-(2-1)") + @Iteration("1+2!=1+1+1", "answer=1+2", "input=1+1+1") + @Iteration("1+2!=1-(-2)", "answer=1+2", "input=1-(-2)") + @Iteration("4-6!=1-2-1", "answer=4-6", "input=1-2-1") + @Iteration("2*3*2*2!=2*3*4", "answer=2*3*2*2", "input=2*3*4") + @Iteration("-6-2!=2*-(3+1)", "answer=-6-2", "input=2*-(3+1)") + @Iteration("2/3/2/2!=2/3/4", "answer=2/3/2/2", "input=2/3/4") + @Iteration("2^(2+1)!=2^3", "answer=2^(2+1)", "input=2^3") + @Iteration("2^(-1)!=1/2", "answer=2^(-1)", "input=1/2") + @Iteration("x-y!=-(y-x)", "answer=x-y", "input=-(y-x)") + @Iteration("2+x!=1+x+1", "answer=2+x", "input=1+x+1") + @Iteration("1+x!=1-(-x)", "answer=1+x", "input=1-(-x)") + @Iteration("x!=1-x-1", "answer=x", "input=1-x-1") + @Iteration("4x!=2*2*x", "answer=4x", "input=2*2*x") + @Iteration("2-6x!=2*(-3x+1)", "answer=2-6x", "input=2*(-3x+1)") + @Iteration("x/4!=x/2/2", "answer=x/4", "input=x/2/2") + @Iteration("x^(2+1)!=x^3", "answer=x^(2+1)", "input=x^3") + @Iteration("x*(2^(-1))!=x/2", "answer=x*(2^(-1))", "input=x/2") fun testMatches_operationsDiffer_byDistributionAndCombining_returnsFalse() { val answerExpression = createMathExpression(answer) val inputExpression = createMathExpression(input) @@ -238,52 +223,50 @@ class AlgebraicExpressionInputMatchesExactlyWithRuleClassifierProviderTest { } @Test - @RunParameterized( - Iteration("2*(2+6+3+4)==2*(2+6+3+4)", "answer=2*(2+6+3+4)", "input=2*(2+6+3+4)"), - Iteration("2 × (2+6+3+4)==2*(2+6+3+4)", "answer=2 × (2+6+3+4)", "input=2*(2+6+3+4)"), - Iteration( - "15 - (6 × 2) + 3==15 - (6 × 2) + 3", "answer=15 - (6 × 2) + 3", "input=15 - (6 × 2) + 3" - ), - Iteration( - "2 * (50 + 150 + 100 + 25) ==2 × (50 + 150 + 100 + 25)", - "answer=2 * (50 + 150 + 100 + 25) ", - "input=2 × (50 + 150 + 100 + 25)" - ), - Iteration("5+2==5+2", "answer=5+2", "input=5+2"), - Iteration("6 − (− 4)==6 − (− 4)", "answer=6 − (− 4)", "input=6 − (− 4)"), - Iteration("6-(-4)==6 − (− 4)", "answer=6-(-4)", "input=6 − (− 4)"), - Iteration("3 * 10^-5==3 * 10^-5", "answer=3 * 10^-5", "input=3 * 10^-5"), - Iteration( - "1000 + 200 + 30 + 4 + 0.5 + 0.06==1000 + 200 + 30 + 4 + 0.5 + 0.06", - "answer=1000 + 200 + 30 + 4 + 0.5 + 0.06", - "input=1000 + 200 + 30 + 4 + 0.5 + 0.06" - ), - Iteration("2 * 2 * 3 * 3==2 * 2 * 3 * 3", "answer=2 * 2 * 3 * 3", "input=2 * 2 * 3 * 3"), - Iteration("4x^2+20x==4*x^2+20x", "answer=4x^2+20x", "input=4*x^2+20x"), - Iteration("3+x-5==3+x-5", "answer=3+x-5", "input=3+x-5"), - Iteration("Z+A-Z==Z+A-Z", "answer=Z+A-Z", "input=Z+A-Z"), - Iteration("6C - 5A -1==6C - 5A -1", "answer=6C - 5A -1", "input=6C - 5A -1"), - Iteration("5Z-w==5*Z-w", "answer=5Z-w", "input=5*Z-w"), - Iteration("5*Z-w==5*Z-w", "answer=5*Z-w", "input=5*Z-w"), - Iteration("LS-3S+L==L*S-3S+L", "answer=LS-3S+L", "input=L*S-3S+L"), - Iteration("L*S-3S+L==L*S-3S+L", "answer=L*S-3S+L", "input=L*S-3S+L"), - Iteration("L*S-3*S+L==L*S-3S+L", "answer=L*S-3*S+L", "input=L*S-3S+L"), - Iteration("LS-3*S+L==L*S-3S+L", "answer=LS-3*S+L", "input=L*S-3S+L"), - Iteration("9x^2 − 6x + 1==9x^2 − 6x + 1", "answer=9x^2 − 6x + 1", "input=9x^2 − 6x + 1"), - Iteration("c*b-c==c*b-c", "answer=c*b-c", "input=c*b-c"), - Iteration("cb-c==c*b-c", "answer=cb-c", "input=c*b-c"), - Iteration("x^2+y+4x==x^2+y+4x", "answer=x^2+y+4x", "input=x^2+y+4x"), - Iteration("Y+5==Y+5", "answer=Y+5", "input=Y+5"), - Iteration( - "a^2 + b^2 + c^2+ 2a*b + 2a*c + 2bc==a^2+b^2+c^2+2a*b+2a*c+2bc", - "answer=a^2 + b^2 + c^2+ 2a*b + 2a*c + 2bc", - "input=a^2+b^2+c^2+2a*b+2a*c+2bc" - ), - Iteration( - "(x^2 − x)/3 − 4y==(x^2 − x)/3 − 4y", "answer=(x^2 − x)/3 − 4y", "input=(x^2 − x)/3 − 4y" - ), - Iteration("(3x -1)^2==(3x-1)^2", "answer=(3x -1)^2", "input=(3x-1)^2") + @Iteration("2*(2+6+3+4)==2*(2+6+3+4)", "answer=2*(2+6+3+4)", "input=2*(2+6+3+4)") + @Iteration("2 × (2+6+3+4)==2*(2+6+3+4)", "answer=2 × (2+6+3+4)", "input=2*(2+6+3+4)") + @Iteration( + "15 - (6 × 2) + 3==15 - (6 × 2) + 3", "answer=15 - (6 × 2) + 3", "input=15 - (6 × 2) + 3" ) + @Iteration( + "2 * (50 + 150 + 100 + 25) ==2 × (50 + 150 + 100 + 25)", + "answer=2 * (50 + 150 + 100 + 25) ", + "input=2 × (50 + 150 + 100 + 25)" + ) + @Iteration("5+2==5+2", "answer=5+2", "input=5+2") + @Iteration("6 − (− 4)==6 − (− 4)", "answer=6 − (− 4)", "input=6 − (− 4)") + @Iteration("6-(-4)==6 − (− 4)", "answer=6-(-4)", "input=6 − (− 4)") + @Iteration("3 * 10^-5==3 * 10^-5", "answer=3 * 10^-5", "input=3 * 10^-5") + @Iteration( + "1000 + 200 + 30 + 4 + 0.5 + 0.06==1000 + 200 + 30 + 4 + 0.5 + 0.06", + "answer=1000 + 200 + 30 + 4 + 0.5 + 0.06", + "input=1000 + 200 + 30 + 4 + 0.5 + 0.06" + ) + @Iteration("2 * 2 * 3 * 3==2 * 2 * 3 * 3", "answer=2 * 2 * 3 * 3", "input=2 * 2 * 3 * 3") + @Iteration("4x^2+20x==4*x^2+20x", "answer=4x^2+20x", "input=4*x^2+20x") + @Iteration("3+x-5==3+x-5", "answer=3+x-5", "input=3+x-5") + @Iteration("Z+A-Z==Z+A-Z", "answer=Z+A-Z", "input=Z+A-Z") + @Iteration("6C - 5A -1==6C - 5A -1", "answer=6C - 5A -1", "input=6C - 5A -1") + @Iteration("5Z-w==5*Z-w", "answer=5Z-w", "input=5*Z-w") + @Iteration("5*Z-w==5*Z-w", "answer=5*Z-w", "input=5*Z-w") + @Iteration("LS-3S+L==L*S-3S+L", "answer=LS-3S+L", "input=L*S-3S+L") + @Iteration("L*S-3S+L==L*S-3S+L", "answer=L*S-3S+L", "input=L*S-3S+L") + @Iteration("L*S-3*S+L==L*S-3S+L", "answer=L*S-3*S+L", "input=L*S-3S+L") + @Iteration("LS-3*S+L==L*S-3S+L", "answer=LS-3*S+L", "input=L*S-3S+L") + @Iteration("9x^2 − 6x + 1==9x^2 − 6x + 1", "answer=9x^2 − 6x + 1", "input=9x^2 − 6x + 1") + @Iteration("c*b-c==c*b-c", "answer=c*b-c", "input=c*b-c") + @Iteration("cb-c==c*b-c", "answer=cb-c", "input=c*b-c") + @Iteration("x^2+y+4x==x^2+y+4x", "answer=x^2+y+4x", "input=x^2+y+4x") + @Iteration("Y+5==Y+5", "answer=Y+5", "input=Y+5") + @Iteration( + "a^2 + b^2 + c^2+ 2a*b + 2a*c + 2bc==a^2+b^2+c^2+2a*b+2a*c+2bc", + "answer=a^2 + b^2 + c^2+ 2a*b + 2a*c + 2bc", + "input=a^2+b^2+c^2+2a*b+2a*c+2bc" + ) + @Iteration( + "(x^2 − x)/3 − 4y==(x^2 − x)/3 − 4y", "answer=(x^2 − x)/3 − 4y", "input=(x^2 − x)/3 − 4y" + ) + @Iteration("(3x -1)^2==(3x-1)^2", "answer=(3x -1)^2", "input=(3x-1)^2") fun testMatches_assortedExpressions_withMatchingCharacteristics_returnsTrue() { val answerExpression = createMathExpression(answer) val inputExpression = createMathExpression(input) @@ -296,284 +279,282 @@ class AlgebraicExpressionInputMatchesExactlyWithRuleClassifierProviderTest { } @Test - @RunParameterized( - Iteration( - "2 × (50 + 150 + 100 + 25) ==(50 + 150 + 100 + 25) × 2", - "answer=2 × (50 + 150 + 100 + 25) ", - "input=(50 + 150 + 100 + 25) × 2" - ), - Iteration("2+5!=5+2", "answer=2+5", "input=5+2"), - Iteration("− (− 4) + 6!=6 − (− 4)", "answer=− (− 4) + 6", "input=6 − (− 4)"), - Iteration("10!=6 − (− 4)", "answer=10", "input=6 − (− 4)"), - Iteration("6 + 4!=6 − (− 4)", "answer=6 + 4", "input=6 − (− 4)"), - Iteration("6 + 2^2!=6 − (− 4)", "answer=6 + 2^2", "input=6 − (− 4)"), - Iteration("3 * 2 − (− 4)!=6 − (− 4)", "answer=3 * 2 − (− 4)", "input=6 − (− 4)"), - Iteration("100/10!=6 − (− 4)", "answer=100/10", "input=6 − (− 4)"), - Iteration("3/(10 * 10^4)!=3 * 10^-5", "answer=3/(10 * 10^4)", "input=3 * 10^-5"), - Iteration( - "200 + 30 + 4 + 0.5 + 0.06 + 1000!=1000 + 200 + 30 + 4 + 0.5 + 0.06", - "answer=200 + 30 + 4 + 0.5 + 0.06 + 1000", - "input=1000 + 200 + 30 + 4 + 0.5 + 0.06" - ), - Iteration( - "0.06 + 0.5 + 4 + 30 + 200 + 1000!=1000 + 200 + 30 + 4 + 0.5 + 0.06", - "answer=0.06 + 0.5 + 4 + 30 + 200 + 1000", - "input=1000 + 200 + 30 + 4 + 0.5 + 0.06" - ), - Iteration( - "1234.56!=1000 + 200 + 30 + 4 + 0.5 + 0.06", - "answer=1234.56", - "input=1000 + 200 + 30 + 4 + 0.5 + 0.06" - ), - Iteration( - "123456/100!=1000 + 200 + 30 + 4 + 0.5 + 0.06", - "answer=123456/100", - "input=1000 + 200 + 30 + 4 + 0.5 + 0.06" - ), - Iteration( - "61728/50!=1000 + 200 + 30 + 4 + 0.5 + 0.06", - "answer=61728/50", - "input=1000 + 200 + 30 + 4 + 0.5 + 0.06" - ), - Iteration( - "1234 + 56/100!=1000 + 200 + 30 + 4 + 0.5 + 0.06", - "answer=1234 + 56/100", - "input=1000 + 200 + 30 + 4 + 0.5 + 0.06" - ), - Iteration( - "1230 + 4.56!=1000 + 200 + 30 + 4 + 0.5 + 0.06", - "answer=1230 + 4.56", - "input=1000 + 200 + 30 + 4 + 0.5 + 0.06" - ), - Iteration( - "2 * 2 * 3 * 3 * 1!=2 * 2 * 3 * 3", "answer=2 * 2 * 3 * 3 * 1", "input=2 * 2 * 3 * 3" - ), - Iteration("2 * 2 * 9!=2 * 2 * 3 * 3", "answer=2 * 2 * 9", "input=2 * 2 * 3 * 3"), - Iteration("4 * 3^2!=2 * 2 * 3 * 3", "answer=4 * 3^2", "input=2 * 2 * 3 * 3"), - Iteration("8/2 * 3 * 3!=2 * 2 * 3 * 3", "answer=8/2 * 3 * 3", "input=2 * 2 * 3 * 3"), - Iteration("36!=2 * 2 * 3 * 3", "answer=36", "input=2 * 2 * 3 * 3"), - Iteration("sqrt(4-2)!=sqrt(2)", "answer=sqrt(4-2)", "input=sqrt(2)"), - Iteration("bc-c!=c*b-c", "answer=bc-c", "input=c*b-c"), - Iteration("-c+bc!=c*b-c", "answer=-c+bc", "input=c*b-c"), - Iteration("-c+cb!=c*b-c", "answer=-c+cb", "input=c*b-c"), - Iteration("y+4x+x^2!=x^2+y+4x", "answer=y+4x+x^2", "input=x^2+y+4x"), - Iteration("x^2+4x+y!=x^2+y+4x", "answer=x^2+4x+y", "input=x^2+y+4x"), - Iteration("5+Y!=Y+5", "answer=5+Y", "input=Y+5"), - Iteration( - "a^2 + b^2 + c^2+ 2a*b + 2bc + 2a*c!=a^2+b^2+c^2+2a*b+2a*c+2bc", - "answer=a^2 + b^2 + c^2+ 2a*b + 2bc + 2a*c", - "input=a^2+b^2+c^2+2a*b+2a*c+2bc" - ), - Iteration( - "2a*b + 2bc + 2a*c + a^2 + b^2 + c^2!=a^2+b^2+c^2+2a*b+2a*c+2bc", - "answer=2a*b + 2bc + 2a*c + a^2 + b^2 + c^2", - "input=a^2+b^2+c^2+2a*b+2a*c+2bc" - ), - Iteration( - "2a*b + b^2 + c^2+ a^2 + 2bc + 2a*c!=a^2+b^2+c^2+2a*b+2a*c+2bc", - "answer=2a*b + b^2 + c^2+ a^2 + 2bc + 2a*c", - "input=a^2+b^2+c^2+2a*b+2a*c+2bc" - ), - Iteration( - "a*a + b*b + c*c + 2*a*b + 2*a*c + 2*b*c!=a^2+b^2+c^2+2a*b+2a*c+2bc", - "answer=a*a + b*b + c*c + 2*a*b + 2*a*c + 2*b*c", - "input=a^2+b^2+c^2+2a*b+2a*c+2bc" - ), - Iteration( - "(a+ b)^2 + c^2 + 2bc + 2a*c!=a^2+b^2+c^2+2a*b+2a*c+2bc", - "answer=(a+ b)^2 + c^2 + 2bc + 2a*c", - "input=a^2+b^2+c^2+2a*b+2a*c+2bc" - ), - Iteration( - "(a+b+c)^2!=a^2+b^2+c^2+2a*b+2a*c+2bc", "answer=(a+b+c)^2", "input=a^2+b^2+c^2+2a*b+2a*c+2bc" - ), - Iteration( - "(-a -b -c)^2!=a^2+b^2+c^2+2a*b+2a*c+2bc", - "answer=(-a -b -c)^2", - "input=a^2+b^2+c^2+2a*b+2a*c+2bc" - ), - Iteration("1 - 6x + 9x^2!=9x^2 − 6x + 1", "answer=1 - 6x + 9x^2", "input=9x^2 − 6x + 1"), - Iteration("9x^2 + 1 - 6x!=9x^2 − 6x + 1", "answer=9x^2 + 1 - 6x", "input=9x^2 − 6x + 1"), - Iteration("2+1+x!=x+1+2", "answer=2+1+x", "input=x+1+2"), - Iteration("1+2+x!=x+1+2", "answer=1+2+x", "input=x+1+2"), - Iteration("1+x+2!=x+1+2", "answer=1+x+2", "input=x+1+2"), - Iteration("2+x+1!=x+1+2", "answer=2+x+1", "input=x+1+2"), - Iteration("(x+1)+2!=x+1+2", "answer=(x+1)+2", "input=x+1+2"), - Iteration("x + (1+2)!=x+1+2", "answer=x + (1+2)", "input=x+1+2"), - Iteration( - "y+1+ 9x(x − 6)!=9x(x − 6) + 1+ y", "answer=y+1+ 9x(x − 6)", "input=9x(x − 6) + 1+ y" - ), - Iteration("1+y+9x(x − 6)!=9x(x − 6) + 1+ y", "answer=1+y+9x(x − 6)", "input=9x(x − 6) + 1+ y"), - Iteration( - "1 + 9x(x − 6) + y!=9x(x − 6) + 1+ y", "answer=1 + 9x(x − 6) + y", "input=9x(x − 6) + 1+ y" - ), - Iteration( - "(y+1)+9x(x − 6)!=9x(x − 6) + 1+ y", "answer=(y+1)+9x(x − 6)", "input=9x(x − 6) + 1+ y" - ), - Iteration( - "-4y + (x^2 − x)/3!=(x^2 − x)/3 − 4y", "answer=-4y + (x^2 − x)/3", "input=(x^2 − x)/3 − 4y" - ), - Iteration( - "x(x − 1)/3 −4y!=(x^2 − x)/3 − 4y", "answer=x(x − 1)/3 −4y", "input=(x^2 − x)/3 − 4y" - ), - Iteration( - "x^2/3 − x/3 − 4y!=(x^2 − x)/3 − 4y", "answer=x^2/3 − x/3 − 4y", "input=(x^2 − x)/3 − 4y" - ), - Iteration( - "x^2/3 − (x/3 + 4y)!=(x^2 − x)/3 − 4y", "answer=x^2/3 − (x/3 + 4y)", "input=(x^2 − x)/3 − 4y" - ), - Iteration("√(3x −1)4!=(3x-1)^2", "answer=√(3x −1)4", "input=(3x-1)^2"), - Iteration("3x(3x - 2) + 1!=(3x-1)^2", "answer=3x(3x - 2) + 1", "input=(3x-1)^2"), - Iteration("3(3x^2) - 6x +1!=(3x-1)^2", "answer=3(3x^2) - 6x +1", "input=(3x-1)^2"), - Iteration("2x!=sqrt(4x^2)", "answer=2x", "input=sqrt(4x^2)"), - Iteration("x^2+2x+1!=(x+1)^2", "answer=x^2+2x+1", "input=(x+1)^2"), - Iteration("x^2-1!=(x+1)(x-1)", "answer=x^2-1", "input=(x+1)(x-1)"), - Iteration("x+1!=(x^2+2x+1)/(x+1)", "answer=x+1", "input=(x^2+2x+1)/(x+1)"), - Iteration("x-1!=(x^2-1)/(x+1)", "answer=x-1", "input=(x^2-1)/(x+1)"), - Iteration("x+1!=(x^2-1)/(x-1)", "answer=x+1", "input=(x^2-1)/(x-1)"), - Iteration("-3x!=(-27x^3)^(1/3)", "answer=-3x", "input=(-27x^3)^(1/3)"), - Iteration("1!=(x^2-1)/(x^2-1)", "answer=1", "input=(x^2-1)/(x^2-1)"), - Iteration("2*(6+3+4) + 4!=2*(2+6+3+4)", "answer=2*(6+3+4) + 4", "input=2*(2+6+3+4)"), - Iteration("2*(2+6+3) + 8!=2*(2+6+3+4)", "answer=2*(2+6+3) + 8", "input=2*(2+6+3+4)"), - Iteration("(2+6+3+4)*2!=2*(2+6+3+4)", "answer=(2+6+3+4)*2", "input=2*(2+6+3+4)"), - Iteration("(2+6+3+4) × 2!=2*(2+6+3+4)", "answer=(2+6+3+4) × 2", "input=2*(2+6+3+4)"), - Iteration("15 - 12 + 3!=15 - (6 × 2) + 3", "answer=15 - 12 + 3", "input=15 - (6 × 2) + 3"), - Iteration( - "3 - (6 * 2) + 15!=15 - (6 × 2) + 3", "answer=3 - (6 * 2) + 15", "input=15 - (6 × 2) + 3" - ), - Iteration( - "15 - (2 × 6) + 3!=15 - (6 × 2) + 3", "answer=15 - (2 × 6) + 3", "input=15 - (6 × 2) + 3" - ), - Iteration( - "2 *(50 + 150) + 2*(100 + 25)!=(50 + 150 + 100 + 25) × 2", - "answer=2 *(50 + 150) + 2*(100 + 25)", - "input=(50 + 150 + 100 + 25) × 2" - ), - Iteration( - "2* ( 25+50+100+150)!=(50 + 150 + 100 + 25) × 2", - "answer=2* ( 25+50+100+150)", - "input=(50 + 150 + 100 + 25) × 2" - ), - Iteration("10^−5 * 3!=3 * 10^-5", "answer=10^−5 * 3", "input=3 * 10^-5"), - Iteration("3 * 10^5!=3 * 10^-5", "answer=3 * 10^5", "input=3 * 10^-5"), - Iteration("2 * 10^−5!=3 * 10^-5", "answer=2 * 10^−5", "input=3 * 10^-5"), - Iteration("5 * 10^−3!=3 * 10^-5", "answer=5 * 10^−3", "input=3 * 10^-5"), - Iteration("30 * 10^−6!=3 * 10^-5", "answer=30 * 10^−6", "input=3 * 10^-5"), - Iteration("0.00003!=3 * 10^-5", "answer=0.00003", "input=3 * 10^-5"), - Iteration("3/10^5!=3 * 10^-5", "answer=3/10^5", "input=3 * 10^-5"), - Iteration( - "123456!=1000 + 200 + 30 + 4 + 0.5 + 0.06", - "answer=123456", - "input=1000 + 200 + 30 + 4 + 0.5 + 0.06" - ), - Iteration( - "1000 + 200 + 30!=1000 + 200 + 30 + 4 + 0.5 + 0.06", - "answer=1000 + 200 + 30", - "input=1000 + 200 + 30 + 4 + 0.5 + 0.06" - ), - Iteration("3 *2 – (− 4)!=6 − (− 4)", "answer=3 *2 – (− 4)", "input=6 − (− 4)"), - Iteration("6 − 4!=6 − (− 4)", "answer=6 − 4", "input=6 − (− 4)"), - Iteration("6 + (− 4)!=6 − (− 4)", "answer=6 + (− 4)", "input=6 − (− 4)"), - Iteration("100!=6 − (− 4)", "answer=100", "input=6 − (− 4)"), - Iteration("7!=5+2", "answer=7", "input=5+2"), - Iteration("3+4!=5+2", "answer=3+4", "input=5+2"), - Iteration("2 * 2 * 3!=2 * 2 * 3 * 3", "answer=2 * 2 * 3", "input=2 * 2 * 3 * 3"), - Iteration("2 * 3 * 3 * 3!=2 * 2 * 3 * 3", "answer=2 * 3 * 3 * 3", "input=2 * 2 * 3 * 3"), - Iteration("20x+4x^2!=4*x^2+20x", "answer=20x+4x^2", "input=4*x^2+20x"), - Iteration("x-5+3!=3+x-5", "answer=x-5+3", "input=3+x-5"), - Iteration("-5+3+x!=3+x-5", "answer=-5+3+x", "input=3+x-5"), - Iteration("-5+x+3!=3+x-5", "answer=-5+x+3", "input=3+x-5"), - Iteration("3+(x-5)!=3+x-5", "answer=3+(x-5)", "input=3+x-5"), - Iteration("A!=Z+A-Z", "answer=A", "input=Z+A-Z"), - Iteration("A+Z-Z!=Z+A-Z", "answer=A+Z-Z", "input=Z+A-Z"), - Iteration("Z+(A-Z)!=Z+A-Z", "answer=Z+(A-Z)", "input=Z+A-Z"), - Iteration("6C - (5A+1)!=6C - 5A -1", "answer=6C - (5A+1)", "input=6C - 5A -1"), - Iteration("-5A-1+6C!=6C - 5A -1", "answer=-5A-1+6C", "input=6C - 5A -1"), - Iteration("-W+5Z!=5*Z-W", "answer=-W+5Z", "input=5*Z-W"), - Iteration("L(1+S)-3S!=L*S-3S+L", "answer=L(1+S)-3S", "input=L*S-3S+L"), - Iteration("S(L-3)+L!=L*S-3S+L", "answer=S(L-3)+L", "input=L*S-3S+L"), - Iteration("L+LS-3S!=L*S-3S+L", "answer=L+LS-3S", "input=L*S-3S+L"), - Iteration( - "x(x − 1)/3 − 4y!=(x^2 − x)/3 − 4y", "answer=x(x − 1)/3 − 4y", "input=(x^2 − x)/3 − 4y" - ), - Iteration( - "- 4y + (x^2 − x)/3!=(x^2 − x)/3 − 4y", "answer=- 4y + (x^2 − x)/3", "input=(x^2 − x)/3 − 4y" - ), - Iteration( - "(x^2 − x) * 3^-1 − 4y!=(x^2 − x)/3 − 4y", - "answer=(x^2 − x) * 3^-1 − 4y", - "input=(x^2 − x)/3 − 4y" - ), - Iteration( - "x(x^2 − x)/3 − 4y!=(x^2 − x)/3 − 4y", "answer=x(x^2 − x)/3 − 4y", "input=(x^2 − x)/3 − 4y" - ), - Iteration( - "(x^2 − x)/3 + 4y!=(x^2 − x)/3 − 4y", "answer=(x^2 − x)/3 + 4y", "input=(x^2 − x)/3 − 4y" - ), - Iteration( - "(x^2 + x)/3 - 4y!=(x^2 − x)/3 − 4y", "answer=(x^2 + x)/3 - 4y", "input=(x^2 − x)/3 − 4y" - ), - Iteration( - "(x^2 − x)*0.33 - 4y!=(x^2 − x)/3 − 4y", - "answer=(x^2 − x)*0.33 - 4y", - "input=(x^2 − x)/3 − 4y" - ), - Iteration( - "a^2 + b^2 + c^2 + 2(a*b + a*c + bc)!=a^2+b^2+c^2+2a*b+2a*c+2bc", - "answer=a^2 + b^2 + c^2 + 2(a*b + a*c + bc)", - "input=a^2+b^2+c^2+2a*b+2a*c+2bc" - ), - Iteration( - "(a + b)^2 + c^2 + 2a*c + 2bc!=a^2+b^2+c^2+2a*b+2a*c+2bc", - "answer=(a + b)^2 + c^2 + 2a*c + 2bc", - "input=a^2+b^2+c^2+2a*b+2a*c+2bc" - ), - Iteration( - "a * a + b * b + c^3/c + 2a*b + 2a*c + 2bc!=a^2+b^2+c^2+2a*b+2a*c+2bc", - "answer=a * a + b * b + c^3/c + 2a*b + 2a*c + 2bc", - "input=a^2+b^2+c^2+2a*b+2a*c+2bc" - ), - Iteration( - "a^2+ b^2 + c^2 + 2bc + 2a*c + 2a*b!=a^2+b^2+c^2+2a*b+2a*c+2bc", - "answer=a^2+ b^2 + c^2 + 2bc + 2a*c + 2a*b", - "input=a^2+b^2+c^2+2a*b+2a*c+2bc" - ), - Iteration( - "(a + b + c)^3!=a^2+b^2+c^2+2a*b+2a*c+2bc", - "answer=(a + b + c)^3", - "input=a^2+b^2+c^2+2a*b+2a*c+2bc" - ), - Iteration( - "a^2 + b^2 + c^2!=a^2+b^2+c^2+2a*b+2a*c+2bc", - "answer=a^2 + b^2 + c^2", - "input=a^2+b^2+c^2+2a*b+2a*c+2bc" - ), - Iteration( - "a^2 + b^2 + c^2- 2a*b - 2a*c - 2bc!=a^2+b^2+c^2+2a*b+2a*c+2bc", - "answer=a^2 + b^2 + c^2- 2a*b - 2a*c - 2bc", - "input=a^2+b^2+c^2+2a*b+2a*c+2bc" - ), - Iteration("(3x − 1)^2!=9x^2 − 6x + 1", "answer=(3x − 1)^2", "input=9x^2 − 6x + 1"), - Iteration("3x(3x − 2) + 1!=9x^2 − 6x + 1", "answer=3x(3x − 2) + 1", "input=9x^2 − 6x + 1"), - Iteration("3(3x^2 − 2x) + 1!=9x^2 − 6x + 1", "answer=3(3x^2 − 2x) + 1", "input=9x^2 − 6x + 1"), - Iteration("(3x)^2 − 6x + 1!=9x^2 − 6x + 1", "answer=(3x)^2 − 6x + 1", "input=9x^2 − 6x + 1"), - Iteration("c(b-1)!=c*b-c", "answer=c(b-1)", "input=c*b-c"), - Iteration("x(x+4)+y!=x^2+y+4x", "answer=x(x+4)+y", "input=x^2+y+4x"), - Iteration("Y!=Y+5", "answer=Y", "input=Y+5"), - Iteration("5!=Y+5", "answer=5", "input=Y+5"), - Iteration("x+3!=x+1+2", "answer=x+3", "input=x+1+2"), - Iteration("(1 - 3x)^2!=(3x-1)^2", "answer=(1 - 3x)^2", "input=(3x-1)^2"), - Iteration("9x^2 - 6x - 1!=(3x-1)^2", "answer=9x^2 - 6x - 1", "input=(3x-1)^2"), - Iteration("(3x −1)!=(3x-1)^2", "answer=(3x −1)", "input=(3x-1)^2"), - Iteration("2x!=sqrt(2x)^2", "answer=2x", "input=sqrt(2x)^2"), - Iteration("2x!=sqrt(-4x^2)", "answer=2x", "input=sqrt(-4x^2)"), - Iteration("x^2+2x+1!=(x+2)^2", "answer=x^2+2x+1", "input=(x+2)^2"), - Iteration("x^2-1!=(x+1)(1-x)", "answer=x^2-1", "input=(x+1)(1-x)"), - Iteration("x+1!=(x^2+2x+1)/(x-1)", "answer=x+1", "input=(x^2+2x+1)/(x-1)"), - Iteration("x-1!=(x^2-1)/x", "answer=x-1", "input=(x^2-1)/x"), - Iteration("x+1!=(x^2-1)/(x-2)", "answer=x+1", "input=(x^2-1)/(x-2)"), - Iteration("-3x!=(9x^3)^(1/3)", "answer=-3x", "input=(9x^3)^(1/3)") + @Iteration( + "2 × (50 + 150 + 100 + 25) ==(50 + 150 + 100 + 25) × 2", + "answer=2 × (50 + 150 + 100 + 25) ", + "input=(50 + 150 + 100 + 25) × 2" + ) + @Iteration("2+5!=5+2", "answer=2+5", "input=5+2") + @Iteration("− (− 4) + 6!=6 − (− 4)", "answer=− (− 4) + 6", "input=6 − (− 4)") + @Iteration("10!=6 − (− 4)", "answer=10", "input=6 − (− 4)") + @Iteration("6 + 4!=6 − (− 4)", "answer=6 + 4", "input=6 − (− 4)") + @Iteration("6 + 2^2!=6 − (− 4)", "answer=6 + 2^2", "input=6 − (− 4)") + @Iteration("3 * 2 − (− 4)!=6 − (− 4)", "answer=3 * 2 − (− 4)", "input=6 − (− 4)") + @Iteration("100/10!=6 − (− 4)", "answer=100/10", "input=6 − (− 4)") + @Iteration("3/(10 * 10^4)!=3 * 10^-5", "answer=3/(10 * 10^4)", "input=3 * 10^-5") + @Iteration( + "200 + 30 + 4 + 0.5 + 0.06 + 1000!=1000 + 200 + 30 + 4 + 0.5 + 0.06", + "answer=200 + 30 + 4 + 0.5 + 0.06 + 1000", + "input=1000 + 200 + 30 + 4 + 0.5 + 0.06" + ) + @Iteration( + "0.06 + 0.5 + 4 + 30 + 200 + 1000!=1000 + 200 + 30 + 4 + 0.5 + 0.06", + "answer=0.06 + 0.5 + 4 + 30 + 200 + 1000", + "input=1000 + 200 + 30 + 4 + 0.5 + 0.06" + ) + @Iteration( + "1234.56!=1000 + 200 + 30 + 4 + 0.5 + 0.06", + "answer=1234.56", + "input=1000 + 200 + 30 + 4 + 0.5 + 0.06" + ) + @Iteration( + "123456/100!=1000 + 200 + 30 + 4 + 0.5 + 0.06", + "answer=123456/100", + "input=1000 + 200 + 30 + 4 + 0.5 + 0.06" + ) + @Iteration( + "61728/50!=1000 + 200 + 30 + 4 + 0.5 + 0.06", + "answer=61728/50", + "input=1000 + 200 + 30 + 4 + 0.5 + 0.06" + ) + @Iteration( + "1234 + 56/100!=1000 + 200 + 30 + 4 + 0.5 + 0.06", + "answer=1234 + 56/100", + "input=1000 + 200 + 30 + 4 + 0.5 + 0.06" + ) + @Iteration( + "1230 + 4.56!=1000 + 200 + 30 + 4 + 0.5 + 0.06", + "answer=1230 + 4.56", + "input=1000 + 200 + 30 + 4 + 0.5 + 0.06" + ) + @Iteration( + "2 * 2 * 3 * 3 * 1!=2 * 2 * 3 * 3", "answer=2 * 2 * 3 * 3 * 1", "input=2 * 2 * 3 * 3" + ) + @Iteration("2 * 2 * 9!=2 * 2 * 3 * 3", "answer=2 * 2 * 9", "input=2 * 2 * 3 * 3") + @Iteration("4 * 3^2!=2 * 2 * 3 * 3", "answer=4 * 3^2", "input=2 * 2 * 3 * 3") + @Iteration("8/2 * 3 * 3!=2 * 2 * 3 * 3", "answer=8/2 * 3 * 3", "input=2 * 2 * 3 * 3") + @Iteration("36!=2 * 2 * 3 * 3", "answer=36", "input=2 * 2 * 3 * 3") + @Iteration("sqrt(4-2)!=sqrt(2)", "answer=sqrt(4-2)", "input=sqrt(2)") + @Iteration("bc-c!=c*b-c", "answer=bc-c", "input=c*b-c") + @Iteration("-c+bc!=c*b-c", "answer=-c+bc", "input=c*b-c") + @Iteration("-c+cb!=c*b-c", "answer=-c+cb", "input=c*b-c") + @Iteration("y+4x+x^2!=x^2+y+4x", "answer=y+4x+x^2", "input=x^2+y+4x") + @Iteration("x^2+4x+y!=x^2+y+4x", "answer=x^2+4x+y", "input=x^2+y+4x") + @Iteration("5+Y!=Y+5", "answer=5+Y", "input=Y+5") + @Iteration( + "a^2 + b^2 + c^2+ 2a*b + 2bc + 2a*c!=a^2+b^2+c^2+2a*b+2a*c+2bc", + "answer=a^2 + b^2 + c^2+ 2a*b + 2bc + 2a*c", + "input=a^2+b^2+c^2+2a*b+2a*c+2bc" + ) + @Iteration( + "2a*b + 2bc + 2a*c + a^2 + b^2 + c^2!=a^2+b^2+c^2+2a*b+2a*c+2bc", + "answer=2a*b + 2bc + 2a*c + a^2 + b^2 + c^2", + "input=a^2+b^2+c^2+2a*b+2a*c+2bc" + ) + @Iteration( + "2a*b + b^2 + c^2+ a^2 + 2bc + 2a*c!=a^2+b^2+c^2+2a*b+2a*c+2bc", + "answer=2a*b + b^2 + c^2+ a^2 + 2bc + 2a*c", + "input=a^2+b^2+c^2+2a*b+2a*c+2bc" + ) + @Iteration( + "a*a + b*b + c*c + 2*a*b + 2*a*c + 2*b*c!=a^2+b^2+c^2+2a*b+2a*c+2bc", + "answer=a*a + b*b + c*c + 2*a*b + 2*a*c + 2*b*c", + "input=a^2+b^2+c^2+2a*b+2a*c+2bc" + ) + @Iteration( + "(a+ b)^2 + c^2 + 2bc + 2a*c!=a^2+b^2+c^2+2a*b+2a*c+2bc", + "answer=(a+ b)^2 + c^2 + 2bc + 2a*c", + "input=a^2+b^2+c^2+2a*b+2a*c+2bc" + ) + @Iteration( + "(a+b+c)^2!=a^2+b^2+c^2+2a*b+2a*c+2bc", "answer=(a+b+c)^2", "input=a^2+b^2+c^2+2a*b+2a*c+2bc" + ) + @Iteration( + "(-a -b -c)^2!=a^2+b^2+c^2+2a*b+2a*c+2bc", + "answer=(-a -b -c)^2", + "input=a^2+b^2+c^2+2a*b+2a*c+2bc" + ) + @Iteration("1 - 6x + 9x^2!=9x^2 − 6x + 1", "answer=1 - 6x + 9x^2", "input=9x^2 − 6x + 1") + @Iteration("9x^2 + 1 - 6x!=9x^2 − 6x + 1", "answer=9x^2 + 1 - 6x", "input=9x^2 − 6x + 1") + @Iteration("2+1+x!=x+1+2", "answer=2+1+x", "input=x+1+2") + @Iteration("1+2+x!=x+1+2", "answer=1+2+x", "input=x+1+2") + @Iteration("1+x+2!=x+1+2", "answer=1+x+2", "input=x+1+2") + @Iteration("2+x+1!=x+1+2", "answer=2+x+1", "input=x+1+2") + @Iteration("(x+1)+2!=x+1+2", "answer=(x+1)+2", "input=x+1+2") + @Iteration("x + (1+2)!=x+1+2", "answer=x + (1+2)", "input=x+1+2") + @Iteration( + "y+1+ 9x(x − 6)!=9x(x − 6) + 1+ y", "answer=y+1+ 9x(x − 6)", "input=9x(x − 6) + 1+ y" + ) + @Iteration("1+y+9x(x − 6)!=9x(x − 6) + 1+ y", "answer=1+y+9x(x − 6)", "input=9x(x − 6) + 1+ y") + @Iteration( + "1 + 9x(x − 6) + y!=9x(x − 6) + 1+ y", "answer=1 + 9x(x − 6) + y", "input=9x(x − 6) + 1+ y" + ) + @Iteration( + "(y+1)+9x(x − 6)!=9x(x − 6) + 1+ y", "answer=(y+1)+9x(x − 6)", "input=9x(x − 6) + 1+ y" + ) + @Iteration( + "-4y + (x^2 − x)/3!=(x^2 − x)/3 − 4y", "answer=-4y + (x^2 − x)/3", "input=(x^2 − x)/3 − 4y" + ) + @Iteration( + "x(x − 1)/3 −4y!=(x^2 − x)/3 − 4y", "answer=x(x − 1)/3 −4y", "input=(x^2 − x)/3 − 4y" + ) + @Iteration( + "x^2/3 − x/3 − 4y!=(x^2 − x)/3 − 4y", "answer=x^2/3 − x/3 − 4y", "input=(x^2 − x)/3 − 4y" + ) + @Iteration( + "x^2/3 − (x/3 + 4y)!=(x^2 − x)/3 − 4y", "answer=x^2/3 − (x/3 + 4y)", "input=(x^2 − x)/3 − 4y" + ) + @Iteration("√(3x −1)4!=(3x-1)^2", "answer=√(3x −1)4", "input=(3x-1)^2") + @Iteration("3x(3x - 2) + 1!=(3x-1)^2", "answer=3x(3x - 2) + 1", "input=(3x-1)^2") + @Iteration("3(3x^2) - 6x +1!=(3x-1)^2", "answer=3(3x^2) - 6x +1", "input=(3x-1)^2") + @Iteration("2x!=sqrt(4x^2)", "answer=2x", "input=sqrt(4x^2)") + @Iteration("x^2+2x+1!=(x+1)^2", "answer=x^2+2x+1", "input=(x+1)^2") + @Iteration("x^2-1!=(x+1)(x-1)", "answer=x^2-1", "input=(x+1)(x-1)") + @Iteration("x+1!=(x^2+2x+1)/(x+1)", "answer=x+1", "input=(x^2+2x+1)/(x+1)") + @Iteration("x-1!=(x^2-1)/(x+1)", "answer=x-1", "input=(x^2-1)/(x+1)") + @Iteration("x+1!=(x^2-1)/(x-1)", "answer=x+1", "input=(x^2-1)/(x-1)") + @Iteration("-3x!=(-27x^3)^(1/3)", "answer=-3x", "input=(-27x^3)^(1/3)") + @Iteration("1!=(x^2-1)/(x^2-1)", "answer=1", "input=(x^2-1)/(x^2-1)") + @Iteration("2*(6+3+4) + 4!=2*(2+6+3+4)", "answer=2*(6+3+4) + 4", "input=2*(2+6+3+4)") + @Iteration("2*(2+6+3) + 8!=2*(2+6+3+4)", "answer=2*(2+6+3) + 8", "input=2*(2+6+3+4)") + @Iteration("(2+6+3+4)*2!=2*(2+6+3+4)", "answer=(2+6+3+4)*2", "input=2*(2+6+3+4)") + @Iteration("(2+6+3+4) × 2!=2*(2+6+3+4)", "answer=(2+6+3+4) × 2", "input=2*(2+6+3+4)") + @Iteration("15 - 12 + 3!=15 - (6 × 2) + 3", "answer=15 - 12 + 3", "input=15 - (6 × 2) + 3") + @Iteration( + "3 - (6 * 2) + 15!=15 - (6 × 2) + 3", "answer=3 - (6 * 2) + 15", "input=15 - (6 × 2) + 3" + ) + @Iteration( + "15 - (2 × 6) + 3!=15 - (6 × 2) + 3", "answer=15 - (2 × 6) + 3", "input=15 - (6 × 2) + 3" + ) + @Iteration( + "2 *(50 + 150) + 2*(100 + 25)!=(50 + 150 + 100 + 25) × 2", + "answer=2 *(50 + 150) + 2*(100 + 25)", + "input=(50 + 150 + 100 + 25) × 2" + ) + @Iteration( + "2* ( 25+50+100+150)!=(50 + 150 + 100 + 25) × 2", + "answer=2* ( 25+50+100+150)", + "input=(50 + 150 + 100 + 25) × 2" + ) + @Iteration("10^−5 * 3!=3 * 10^-5", "answer=10^−5 * 3", "input=3 * 10^-5") + @Iteration("3 * 10^5!=3 * 10^-5", "answer=3 * 10^5", "input=3 * 10^-5") + @Iteration("2 * 10^−5!=3 * 10^-5", "answer=2 * 10^−5", "input=3 * 10^-5") + @Iteration("5 * 10^−3!=3 * 10^-5", "answer=5 * 10^−3", "input=3 * 10^-5") + @Iteration("30 * 10^−6!=3 * 10^-5", "answer=30 * 10^−6", "input=3 * 10^-5") + @Iteration("0.00003!=3 * 10^-5", "answer=0.00003", "input=3 * 10^-5") + @Iteration("3/10^5!=3 * 10^-5", "answer=3/10^5", "input=3 * 10^-5") + @Iteration( + "123456!=1000 + 200 + 30 + 4 + 0.5 + 0.06", + "answer=123456", + "input=1000 + 200 + 30 + 4 + 0.5 + 0.06" + ) + @Iteration( + "1000 + 200 + 30!=1000 + 200 + 30 + 4 + 0.5 + 0.06", + "answer=1000 + 200 + 30", + "input=1000 + 200 + 30 + 4 + 0.5 + 0.06" + ) + @Iteration("3 *2 – (− 4)!=6 − (− 4)", "answer=3 *2 – (− 4)", "input=6 − (− 4)") + @Iteration("6 − 4!=6 − (− 4)", "answer=6 − 4", "input=6 − (− 4)") + @Iteration("6 + (− 4)!=6 − (− 4)", "answer=6 + (− 4)", "input=6 − (− 4)") + @Iteration("100!=6 − (− 4)", "answer=100", "input=6 − (− 4)") + @Iteration("7!=5+2", "answer=7", "input=5+2") + @Iteration("3+4!=5+2", "answer=3+4", "input=5+2") + @Iteration("2 * 2 * 3!=2 * 2 * 3 * 3", "answer=2 * 2 * 3", "input=2 * 2 * 3 * 3") + @Iteration("2 * 3 * 3 * 3!=2 * 2 * 3 * 3", "answer=2 * 3 * 3 * 3", "input=2 * 2 * 3 * 3") + @Iteration("20x+4x^2!=4*x^2+20x", "answer=20x+4x^2", "input=4*x^2+20x") + @Iteration("x-5+3!=3+x-5", "answer=x-5+3", "input=3+x-5") + @Iteration("-5+3+x!=3+x-5", "answer=-5+3+x", "input=3+x-5") + @Iteration("-5+x+3!=3+x-5", "answer=-5+x+3", "input=3+x-5") + @Iteration("3+(x-5)!=3+x-5", "answer=3+(x-5)", "input=3+x-5") + @Iteration("A!=Z+A-Z", "answer=A", "input=Z+A-Z") + @Iteration("A+Z-Z!=Z+A-Z", "answer=A+Z-Z", "input=Z+A-Z") + @Iteration("Z+(A-Z)!=Z+A-Z", "answer=Z+(A-Z)", "input=Z+A-Z") + @Iteration("6C - (5A+1)!=6C - 5A -1", "answer=6C - (5A+1)", "input=6C - 5A -1") + @Iteration("-5A-1+6C!=6C - 5A -1", "answer=-5A-1+6C", "input=6C - 5A -1") + @Iteration("-W+5Z!=5*Z-W", "answer=-W+5Z", "input=5*Z-W") + @Iteration("L(1+S)-3S!=L*S-3S+L", "answer=L(1+S)-3S", "input=L*S-3S+L") + @Iteration("S(L-3)+L!=L*S-3S+L", "answer=S(L-3)+L", "input=L*S-3S+L") + @Iteration("L+LS-3S!=L*S-3S+L", "answer=L+LS-3S", "input=L*S-3S+L") + @Iteration( + "x(x − 1)/3 − 4y!=(x^2 − x)/3 − 4y", "answer=x(x − 1)/3 − 4y", "input=(x^2 − x)/3 − 4y" + ) + @Iteration( + "- 4y + (x^2 − x)/3!=(x^2 − x)/3 − 4y", "answer=- 4y + (x^2 − x)/3", "input=(x^2 − x)/3 − 4y" + ) + @Iteration( + "(x^2 − x) * 3^-1 − 4y!=(x^2 − x)/3 − 4y", + "answer=(x^2 − x) * 3^-1 − 4y", + "input=(x^2 − x)/3 − 4y" + ) + @Iteration( + "x(x^2 − x)/3 − 4y!=(x^2 − x)/3 − 4y", "answer=x(x^2 − x)/3 − 4y", "input=(x^2 − x)/3 − 4y" + ) + @Iteration( + "(x^2 − x)/3 + 4y!=(x^2 − x)/3 − 4y", "answer=(x^2 − x)/3 + 4y", "input=(x^2 − x)/3 − 4y" + ) + @Iteration( + "(x^2 + x)/3 - 4y!=(x^2 − x)/3 − 4y", "answer=(x^2 + x)/3 - 4y", "input=(x^2 − x)/3 − 4y" + ) + @Iteration( + "(x^2 − x)*0.33 - 4y!=(x^2 − x)/3 − 4y", + "answer=(x^2 − x)*0.33 - 4y", + "input=(x^2 − x)/3 − 4y" + ) + @Iteration( + "a^2 + b^2 + c^2 + 2(a*b + a*c + bc)!=a^2+b^2+c^2+2a*b+2a*c+2bc", + "answer=a^2 + b^2 + c^2 + 2(a*b + a*c + bc)", + "input=a^2+b^2+c^2+2a*b+2a*c+2bc" + ) + @Iteration( + "(a + b)^2 + c^2 + 2a*c + 2bc!=a^2+b^2+c^2+2a*b+2a*c+2bc", + "answer=(a + b)^2 + c^2 + 2a*c + 2bc", + "input=a^2+b^2+c^2+2a*b+2a*c+2bc" + ) + @Iteration( + "a * a + b * b + c^3/c + 2a*b + 2a*c + 2bc!=a^2+b^2+c^2+2a*b+2a*c+2bc", + "answer=a * a + b * b + c^3/c + 2a*b + 2a*c + 2bc", + "input=a^2+b^2+c^2+2a*b+2a*c+2bc" + ) + @Iteration( + "a^2+ b^2 + c^2 + 2bc + 2a*c + 2a*b!=a^2+b^2+c^2+2a*b+2a*c+2bc", + "answer=a^2+ b^2 + c^2 + 2bc + 2a*c + 2a*b", + "input=a^2+b^2+c^2+2a*b+2a*c+2bc" + ) + @Iteration( + "(a + b + c)^3!=a^2+b^2+c^2+2a*b+2a*c+2bc", + "answer=(a + b + c)^3", + "input=a^2+b^2+c^2+2a*b+2a*c+2bc" + ) + @Iteration( + "a^2 + b^2 + c^2!=a^2+b^2+c^2+2a*b+2a*c+2bc", + "answer=a^2 + b^2 + c^2", + "input=a^2+b^2+c^2+2a*b+2a*c+2bc" + ) + @Iteration( + "a^2 + b^2 + c^2- 2a*b - 2a*c - 2bc!=a^2+b^2+c^2+2a*b+2a*c+2bc", + "answer=a^2 + b^2 + c^2- 2a*b - 2a*c - 2bc", + "input=a^2+b^2+c^2+2a*b+2a*c+2bc" ) + @Iteration("(3x − 1)^2!=9x^2 − 6x + 1", "answer=(3x − 1)^2", "input=9x^2 − 6x + 1") + @Iteration("3x(3x − 2) + 1!=9x^2 − 6x + 1", "answer=3x(3x − 2) + 1", "input=9x^2 − 6x + 1") + @Iteration("3(3x^2 − 2x) + 1!=9x^2 − 6x + 1", "answer=3(3x^2 − 2x) + 1", "input=9x^2 − 6x + 1") + @Iteration("(3x)^2 − 6x + 1!=9x^2 − 6x + 1", "answer=(3x)^2 − 6x + 1", "input=9x^2 − 6x + 1") + @Iteration("c(b-1)!=c*b-c", "answer=c(b-1)", "input=c*b-c") + @Iteration("x(x+4)+y!=x^2+y+4x", "answer=x(x+4)+y", "input=x^2+y+4x") + @Iteration("Y!=Y+5", "answer=Y", "input=Y+5") + @Iteration("5!=Y+5", "answer=5", "input=Y+5") + @Iteration("x+3!=x+1+2", "answer=x+3", "input=x+1+2") + @Iteration("(1 - 3x)^2!=(3x-1)^2", "answer=(1 - 3x)^2", "input=(3x-1)^2") + @Iteration("9x^2 - 6x - 1!=(3x-1)^2", "answer=9x^2 - 6x - 1", "input=(3x-1)^2") + @Iteration("(3x −1)!=(3x-1)^2", "answer=(3x −1)", "input=(3x-1)^2") + @Iteration("2x!=sqrt(2x)^2", "answer=2x", "input=sqrt(2x)^2") + @Iteration("2x!=sqrt(-4x^2)", "answer=2x", "input=sqrt(-4x^2)") + @Iteration("x^2+2x+1!=(x+2)^2", "answer=x^2+2x+1", "input=(x+2)^2") + @Iteration("x^2-1!=(x+1)(1-x)", "answer=x^2-1", "input=(x+1)(1-x)") + @Iteration("x+1!=(x^2+2x+1)/(x-1)", "answer=x+1", "input=(x^2+2x+1)/(x-1)") + @Iteration("x-1!=(x^2-1)/x", "answer=x-1", "input=(x^2-1)/x") + @Iteration("x+1!=(x^2-1)/(x-2)", "answer=x+1", "input=(x^2-1)/(x-2)") + @Iteration("-3x!=(9x^3)^(1/3)", "answer=-3x", "input=(9x^3)^(1/3)") fun testMatches_assortedExpressions_withoutMatchingCharacteristics_returnsFalse() { val answerExpression = createMathExpression(answer) val inputExpression = createMathExpression(input) diff --git a/domain/src/test/java/org/oppia/android/domain/classify/rules/algebraicexpressioninput/AlgebraicExpressionInputMatchesUpToTrivialManipulationsRuleClassifierProviderTest.kt b/domain/src/test/java/org/oppia/android/domain/classify/rules/algebraicexpressioninput/AlgebraicExpressionInputMatchesUpToTrivialManipulationsRuleClassifierProviderTest.kt index 22e3f4b749f..5b711d3b879 100644 --- a/domain/src/test/java/org/oppia/android/domain/classify/rules/algebraicexpressioninput/AlgebraicExpressionInputMatchesUpToTrivialManipulationsRuleClassifierProviderTest.kt +++ b/domain/src/test/java/org/oppia/android/domain/classify/rules/algebraicexpressioninput/AlgebraicExpressionInputMatchesUpToTrivialManipulationsRuleClassifierProviderTest.kt @@ -19,7 +19,6 @@ import org.oppia.android.domain.classify.RuleClassifier import org.oppia.android.testing.junit.OppiaParameterizedTestRunner import org.oppia.android.testing.junit.OppiaParameterizedTestRunner.Iteration import org.oppia.android.testing.junit.OppiaParameterizedTestRunner.Parameter -import org.oppia.android.testing.junit.OppiaParameterizedTestRunner.RunParameterized import org.oppia.android.testing.junit.OppiaParameterizedTestRunner.SelectRunnerPlatform import org.oppia.android.testing.junit.ParameterizedRobolectricTestRunner import org.oppia.android.testing.robolectric.RobolectricModule @@ -76,13 +75,11 @@ class AlgebraicExpressionInputMatchesUpToTrivialManipulationsRuleClassifierProvi } @Test - @RunParameterized( - Iteration("0==0", "answer=0", "input=0"), - Iteration("1==1", "answer=1", "input=1"), - Iteration("2==2", "answer=2", "input=2"), - Iteration("x==x", "answer=x", "input=x"), - Iteration("y==y", "answer=y", "input=y") - ) + @Iteration("0==0", "answer=0", "input=0") + @Iteration("1==1", "answer=1", "input=1") + @Iteration("2==2", "answer=2", "input=2") + @Iteration("x==x", "answer=x", "input=x") + @Iteration("y==y", "answer=y", "input=y") fun testMatches_sameSingleTerms_returnsTrue() { val answerExpression = createMathExpression(answer) val inputExpression = createMathExpression(input) @@ -94,25 +91,23 @@ class AlgebraicExpressionInputMatchesUpToTrivialManipulationsRuleClassifierProvi } @Test - @RunParameterized( - Iteration("-2==-2", "answer=-2", "input=-2"), - Iteration("1+3.14==1+3.14", "answer=1+3.14", "input=1+3.14"), - Iteration(" 1 + 3.14 ==1+3.14", "answer= 1 + 3.14 ", "input=1+3.14"), - Iteration("1+2+3==1+2+3", "answer=1+2+3", "input=1+2+3"), - Iteration("1-3.14==1-3.14", "answer=1-3.14", "input=1-3.14"), - Iteration("2*3.14==2*3.14", "answer=2*3.14", "input=2*3.14"), - Iteration("2/3==2/3", "answer=2/3", "input=2/3"), - Iteration("2/3.14==2/3.14", "answer=2/3.14", "input=2/3.14"), - Iteration("2^3==2^3", "answer=2^3", "input=2^3"), - Iteration("2^3.14==2^3.14", "answer=2^3.14", "input=2^3.14"), - Iteration("sqrt(2)==sqrt(2)", "answer=sqrt(2)", "input=sqrt(2)"), - Iteration("-x==-x", "answer=-x", "input=-x"), - Iteration("x+3.14==x+3.14", "answer=x+3.14", "input=x+3.14"), - Iteration("x-3.14==x-3.14", "answer=x-3.14", "input=x-3.14"), - Iteration("x*3.14==x*3.14", "answer=x*3.14", "input=x*3.14"), - Iteration("x/3==x/3", "answer=x/3", "input=x/3"), - Iteration("sqrt(x)==sqrt(x)", "answer=sqrt(x)", "input=sqrt(x)") - ) + @Iteration("-2==-2", "answer=-2", "input=-2") + @Iteration("1+3.14==1+3.14", "answer=1+3.14", "input=1+3.14") + @Iteration(" 1 + 3.14 ==1+3.14", "answer= 1 + 3.14 ", "input=1+3.14") + @Iteration("1+2+3==1+2+3", "answer=1+2+3", "input=1+2+3") + @Iteration("1-3.14==1-3.14", "answer=1-3.14", "input=1-3.14") + @Iteration("2*3.14==2*3.14", "answer=2*3.14", "input=2*3.14") + @Iteration("2/3==2/3", "answer=2/3", "input=2/3") + @Iteration("2/3.14==2/3.14", "answer=2/3.14", "input=2/3.14") + @Iteration("2^3==2^3", "answer=2^3", "input=2^3") + @Iteration("2^3.14==2^3.14", "answer=2^3.14", "input=2^3.14") + @Iteration("sqrt(2)==sqrt(2)", "answer=sqrt(2)", "input=sqrt(2)") + @Iteration("-x==-x", "answer=-x", "input=-x") + @Iteration("x+3.14==x+3.14", "answer=x+3.14", "input=x+3.14") + @Iteration("x-3.14==x-3.14", "answer=x-3.14", "input=x-3.14") + @Iteration("x*3.14==x*3.14", "answer=x*3.14", "input=x*3.14") + @Iteration("x/3==x/3", "answer=x/3", "input=x/3") + @Iteration("sqrt(x)==sqrt(x)", "answer=sqrt(x)", "input=sqrt(x)") fun testMatches_sameSingleOperations_returnsTrue() { val answerExpression = createMathExpression(answer) val inputExpression = createMathExpression(input) @@ -124,15 +119,13 @@ class AlgebraicExpressionInputMatchesUpToTrivialManipulationsRuleClassifierProvi } @Test - @RunParameterized( - Iteration("1!=0", "answer=1", "input=0"), - Iteration("0!=1", "answer=0", "input=1"), - Iteration("3.14!=1", "answer=3.14", "input=1"), - Iteration("1!=3.14", "answer=1", "input=3.14"), - Iteration("x!=3.14", "answer=x", "input=3.14"), - Iteration("y!=x", "answer=y", "input=x"), - Iteration("3.14!=x", "answer=3.14", "input=x") - ) + @Iteration("1!=0", "answer=1", "input=0") + @Iteration("0!=1", "answer=0", "input=1") + @Iteration("3.14!=1", "answer=3.14", "input=1") + @Iteration("1!=3.14", "answer=1", "input=3.14") + @Iteration("x!=3.14", "answer=x", "input=3.14") + @Iteration("y!=x", "answer=y", "input=x") + @Iteration("3.14!=x", "answer=3.14", "input=x") fun testMatches_differentSingleTerms_returnsFalse() { val answerExpression = createMathExpression(answer) val inputExpression = createMathExpression(input) @@ -145,16 +138,14 @@ class AlgebraicExpressionInputMatchesUpToTrivialManipulationsRuleClassifierProvi } @Test - @RunParameterized( - Iteration("3.14+1==1+3.14", "answer=3.14+1", "input=1+3.14"), - Iteration("3+2+1==1+2+3", "answer=3+2+1", "input=1+2+3"), - Iteration("-3.14+1==1-3.14", "answer=-3.14+1", "input=1-3.14"), - Iteration("3.14*2==2*3.14", "answer=3.14*2", "input=2*3.14"), - Iteration("2+x==x+2", "answer=2+x", "input=x+2"), - Iteration("y+x==x+y", "answer=y+x", "input=x+y"), - Iteration("x*2==2x", "answer=x*2", "input=2x"), - Iteration("yx==xy", "answer=yx", "input=xy") - ) + @Iteration("3.14+1==1+3.14", "answer=3.14+1", "input=1+3.14") + @Iteration("3+2+1==1+2+3", "answer=3+2+1", "input=1+2+3") + @Iteration("-3.14+1==1-3.14", "answer=-3.14+1", "input=1-3.14") + @Iteration("3.14*2==2*3.14", "answer=3.14*2", "input=2*3.14") + @Iteration("2+x==x+2", "answer=2+x", "input=x+2") + @Iteration("y+x==x+y", "answer=y+x", "input=x+y") + @Iteration("x*2==2x", "answer=x*2", "input=2x") + @Iteration("yx==xy", "answer=yx", "input=xy") fun testMatches_operationsDiffer_byCommutativity_returnsTrue() { val answerExpression = createMathExpression(answer) val inputExpression = createMathExpression(input) @@ -166,14 +157,12 @@ class AlgebraicExpressionInputMatchesUpToTrivialManipulationsRuleClassifierProvi } @Test - @RunParameterized( - Iteration("1+(2+3)==(1+2)+3", "answer=1+(2+3)", "input=(1+2)+3"), - Iteration("2*(3*4)==(2*3)*4", "answer=2*(3*4)", "input=(2*3)*4"), - Iteration("x+(2+3)==(x+2)+3", "answer=x+(2+3)", "input=(x+2)+3"), - Iteration("x+(y+z)==(x+y)+z", "answer=x+(y+z)", "input=(x+y)+z"), - Iteration("2*(3x)==(2x)*3", "answer=2*(3x)", "input=(2x)*3"), - Iteration("x(yz)==(xy)z", "answer=x(yz)", "input=(xy)z") - ) + @Iteration("1+(2+3)==(1+2)+3", "answer=1+(2+3)", "input=(1+2)+3") + @Iteration("2*(3*4)==(2*3)*4", "answer=2*(3*4)", "input=(2*3)*4") + @Iteration("x+(2+3)==(x+2)+3", "answer=x+(2+3)", "input=(x+2)+3") + @Iteration("x+(y+z)==(x+y)+z", "answer=x+(y+z)", "input=(x+y)+z") + @Iteration("2*(3x)==(2x)*3", "answer=2*(3x)", "input=(2x)*3") + @Iteration("x(yz)==(xy)z", "answer=x(yz)", "input=(xy)z") fun testMatches_operationsDiffer_byAssociativity_returnsTrue() { val answerExpression = createMathExpression(answer) val inputExpression = createMathExpression(input) @@ -185,17 +174,15 @@ class AlgebraicExpressionInputMatchesUpToTrivialManipulationsRuleClassifierProvi } @Test - @RunParameterized( - Iteration("3.14-1!=1-3.14", "answer=3.14-1", "input=1-3.14"), - Iteration("1-(2-3)!=(1-2)-3", "answer=1-(2-3)", "input=(1-2)-3"), - Iteration("3.14/2!=2/3.14", "answer=3.14/2", "input=2/3.14"), - Iteration("2/(3/4)!=(2/3)/4", "answer=2/(3/4)", "input=(2/3)/4"), - Iteration("3.14^2!=2^3.14", "answer=3.14^2", "input=2^3.14"), - Iteration("3.14-x!=x-3.14", "answer=3.14-x", "input=x-3.14"), - Iteration("x-(y-z)!=(x-y)-z", "answer=x-(y-z)", "input=(x-y)-z"), - Iteration("3.14/x!=x/3.14", "answer=3.14/x", "input=x/3.14"), - Iteration("x/(y/z)!=(x/y)/z", "answer=x/(y/z)", "input=(x/y)/z") - ) + @Iteration("3.14-1!=1-3.14", "answer=3.14-1", "input=1-3.14") + @Iteration("1-(2-3)!=(1-2)-3", "answer=1-(2-3)", "input=(1-2)-3") + @Iteration("3.14/2!=2/3.14", "answer=3.14/2", "input=2/3.14") + @Iteration("2/(3/4)!=(2/3)/4", "answer=2/(3/4)", "input=(2/3)/4") + @Iteration("3.14^2!=2^3.14", "answer=3.14^2", "input=2^3.14") + @Iteration("3.14-x!=x-3.14", "answer=3.14-x", "input=x-3.14") + @Iteration("x-(y-z)!=(x-y)-z", "answer=x-(y-z)", "input=(x-y)-z") + @Iteration("3.14/x!=x/3.14", "answer=3.14/x", "input=x/3.14") + @Iteration("x/(y/z)!=(x/y)/z", "answer=x/(y/z)", "input=(x/y)/z") fun testMatches_operationsDiffer_byNonCommutativeOrAssociativeReordering_returnsFalse() { val answerExpression = createMathExpression(answer) val inputExpression = createMathExpression(input) @@ -208,10 +195,8 @@ class AlgebraicExpressionInputMatchesUpToTrivialManipulationsRuleClassifierProvi } @Test - @RunParameterized( - Iteration("1+2==1-(-2)", "answer=1+2", "input=1-(-2)"), - Iteration("1+x==1-(-x)", "answer=1+x", "input=1-(-x)") - ) + @Iteration("1+2==1-(-2)", "answer=1+2", "input=1-(-2)") + @Iteration("1+x==1-(-x)", "answer=1+x", "input=1-(-x)") fun testMatches_operationsDiffer_byDistributingNegation_returnsTrue() { val answerExpression = createMathExpression(answer) val inputExpression = createMathExpression(input) @@ -223,24 +208,22 @@ class AlgebraicExpressionInputMatchesUpToTrivialManipulationsRuleClassifierProvi } @Test - @RunParameterized( - Iteration("x-y==-(y-x)", "answer=x-y", "input=-(y-x)"), - Iteration("1-2!=-(2-1)", "answer=1-2", "input=-(2-1)"), - Iteration("1+2!=1+1+1", "answer=1+2", "input=1+1+1"), - Iteration("4-6!=1-2-1", "answer=4-6", "input=1-2-1"), - Iteration("2*3*2*2!=2*3*4", "answer=2*3*2*2", "input=2*3*4"), - Iteration("-6-2!=2*-(3+1)", "answer=-6-2", "input=2*-(3+1)"), - Iteration("2/3/2/2!=2/3/4", "answer=2/3/2/2", "input=2/3/4"), - Iteration("2^(2+1)!=2^3", "answer=2^(2+1)", "input=2^3"), - Iteration("2^(-1)!=1/2", "answer=2^(-1)", "input=1/2"), - Iteration("2+x!=1+x+1", "answer=2+x", "input=1+x+1"), - Iteration("x!=1-x-1", "answer=x", "input=1-x-1"), - Iteration("4x!=2*2*x", "answer=4x", "input=2*2*x"), - Iteration("2-6x!=2*(-3x+1)", "answer=2-6x", "input=2*(-3x+1)"), - Iteration("x/4!=x/2/2", "answer=x/4", "input=x/2/2"), - Iteration("x^(2+1)!=x^3", "answer=x^(2+1)", "input=x^3"), - Iteration("x*(2^(-1))!=x/2", "answer=x*(2^(-1))", "input=x/2") - ) + @Iteration("x-y==-(y-x)", "answer=x-y", "input=-(y-x)") + @Iteration("1-2!=-(2-1)", "answer=1-2", "input=-(2-1)") + @Iteration("1+2!=1+1+1", "answer=1+2", "input=1+1+1") + @Iteration("4-6!=1-2-1", "answer=4-6", "input=1-2-1") + @Iteration("2*3*2*2!=2*3*4", "answer=2*3*2*2", "input=2*3*4") + @Iteration("-6-2!=2*-(3+1)", "answer=-6-2", "input=2*-(3+1)") + @Iteration("2/3/2/2!=2/3/4", "answer=2/3/2/2", "input=2/3/4") + @Iteration("2^(2+1)!=2^3", "answer=2^(2+1)", "input=2^3") + @Iteration("2^(-1)!=1/2", "answer=2^(-1)", "input=1/2") + @Iteration("2+x!=1+x+1", "answer=2+x", "input=1+x+1") + @Iteration("x!=1-x-1", "answer=x", "input=1-x-1") + @Iteration("4x!=2*2*x", "answer=4x", "input=2*2*x") + @Iteration("2-6x!=2*(-3x+1)", "answer=2-6x", "input=2*(-3x+1)") + @Iteration("x/4!=x/2/2", "answer=x/4", "input=x/2/2") + @Iteration("x^(2+1)!=x^3", "answer=x^(2+1)", "input=x^3") + @Iteration("x*(2^(-1))!=x/2", "answer=x*(2^(-1))", "input=x/2") fun testMatches_operationsDiffer_byDistributionAndCombining_returnsFalse() { val answerExpression = createMathExpression(answer) val inputExpression = createMathExpression(input) @@ -252,144 +235,142 @@ class AlgebraicExpressionInputMatchesUpToTrivialManipulationsRuleClassifierProvi } @Test - @RunParameterized( - Iteration("2*(2+6+3+4)==2*(2+6+3+4)", "answer=2*(2+6+3+4)", "input=2*(2+6+3+4)"), - Iteration("2 × (2+6+3+4)==2*(2+6+3+4)", "answer=2 × (2+6+3+4)", "input=2*(2+6+3+4)"), - Iteration( - "15 - (6 × 2) + 3==15 - (6 × 2) + 3", "answer=15 - (6 × 2) + 3", "input=15 - (6 × 2) + 3" - ), - Iteration( - "2 × (50 + 150 + 100 + 25) ==(50 + 150 + 100 + 25) × 2", - "answer=2 × (50 + 150 + 100 + 25) ", - "input=(50 + 150 + 100 + 25) × 2" - ), - Iteration( - "2 * (50 + 150 + 100 + 25) ==2 × (50 + 150 + 100 + 25)", - "answer=2 * (50 + 150 + 100 + 25) ", - "input=2 × (50 + 150 + 100 + 25)" - ), - Iteration("2+5==5+2", "answer=2+5", "input=5+2"), - Iteration("5+2==5+2", "answer=5+2", "input=5+2"), - Iteration("6 + 4!=6 − (− 4)", "answer=6 + 4", "input=6 − (− 4)"), - Iteration("6 − (− 4)==6 − (− 4)", "answer=6 − (− 4)", "input=6 − (− 4)"), - Iteration("6-(-4)==6 − (− 4)", "answer=6-(-4)", "input=6 − (− 4)"), - Iteration("− (− 4) + 6==6 − (− 4)", "answer=− (− 4) + 6", "input=6 − (− 4)"), - Iteration("10^−5 * 3!=3 * 10^-5", "answer=10^−5 * 3", "input=3 * 10^-5"), - Iteration("3 * 10^-5==3 * 10^-5", "answer=3 * 10^-5", "input=3 * 10^-5"), - Iteration( - "1000 + 200 + 30 + 4 + 0.5 + 0.06==1000 + 200 + 30 + 4 + 0.5 + 0.06", - "answer=1000 + 200 + 30 + 4 + 0.5 + 0.06", - "input=1000 + 200 + 30 + 4 + 0.5 + 0.06" - ), - Iteration( - "200 + 30 + 4 + 0.5 + 0.06 + 1000==1000 + 200 + 30 + 4 + 0.5 + 0.06", - "answer=200 + 30 + 4 + 0.5 + 0.06 + 1000", - "input=1000 + 200 + 30 + 4 + 0.5 + 0.06" - ), - Iteration( - "0.06 + 0.5 + 4 + 30 + 200 + 1000==1000 + 200 + 30 + 4 + 0.5 + 0.06", - "answer=0.06 + 0.5 + 4 + 30 + 200 + 1000", - "input=1000 + 200 + 30 + 4 + 0.5 + 0.06" - ), - Iteration("2 * 2 * 3 * 3==2 * 2 * 3 * 3", "answer=2 * 2 * 3 * 3", "input=2 * 2 * 3 * 3"), - Iteration("4x^2+20x==4*x^2+20x", "answer=4x^2+20x", "input=4*x^2+20x"), - Iteration("3+x-5==3+x-5", "answer=3+x-5", "input=3+x-5"), - Iteration("Z+A-Z==Z+A-Z", "answer=Z+A-Z", "input=Z+A-Z"), - Iteration("6C - 5A -1==6C - 5A -1", "answer=6C - 5A -1", "input=6C - 5A -1"), - Iteration("5Z-w==5*Z-w", "answer=5Z-w", "input=5*Z-w"), - Iteration("5*Z-w==5*Z-w", "answer=5*Z-w", "input=5*Z-w"), - Iteration("LS-3S+L==L*S-3S+L", "answer=LS-3S+L", "input=L*S-3S+L"), - Iteration("L*S-3S+L==L*S-3S+L", "answer=L*S-3S+L", "input=L*S-3S+L"), - Iteration("L*S-3*S+L==L*S-3S+L", "answer=L*S-3*S+L", "input=L*S-3S+L"), - Iteration("LS-3*S+L==L*S-3S+L", "answer=LS-3*S+L", "input=L*S-3S+L"), - Iteration("9x^2 − 6x + 1==9x^2 − 6x + 1", "answer=9x^2 − 6x + 1", "input=9x^2 − 6x + 1"), - Iteration("c*b-c==c*b-c", "answer=c*b-c", "input=c*b-c"), - Iteration("bc-c==c*b-c", "answer=bc-c", "input=c*b-c"), - Iteration("cb-c==c*b-c", "answer=cb-c", "input=c*b-c"), - Iteration("-c+bc==c*b-c", "answer=-c+bc", "input=c*b-c"), - Iteration("-c+cb==c*b-c", "answer=-c+cb", "input=c*b-c"), - Iteration("x^2+y+4x==x^2+y+4x", "answer=x^2+y+4x", "input=x^2+y+4x"), - Iteration("y+4x+x^2==x^2+y+4x", "answer=y+4x+x^2", "input=x^2+y+4x"), - Iteration("x^2+4x+y==x^2+y+4x", "answer=x^2+4x+y", "input=x^2+y+4x"), - Iteration("Y+5==Y+5", "answer=Y+5", "input=Y+5"), - Iteration("5+Y==Y+5", "answer=5+Y", "input=Y+5"), - Iteration( - "a^2 + b^2 + c^2+ 2a*b + 2a*c + 2bc==a^2+b^2+c^2+2a*b+2a*c+2bc", - "answer=a^2 + b^2 + c^2+ 2a*b + 2a*c + 2bc", - "input=a^2+b^2+c^2+2a*b+2a*c+2bc" - ), - Iteration( - "a^2 + b^2 + c^2+ 2a*b + 2bc + 2a*c==a^2+b^2+c^2+2a*b+2a*c+2bc", - "answer=a^2 + b^2 + c^2+ 2a*b + 2bc + 2a*c", - "input=a^2+b^2+c^2+2a*b+2a*c+2bc" - ), - Iteration( - "2a*b + 2bc + 2a*c + a^2 + b^2 + c^2==a^2+b^2+c^2+2a*b+2a*c+2bc", - "answer=2a*b + 2bc + 2a*c + a^2 + b^2 + c^2", - "input=a^2+b^2+c^2+2a*b+2a*c+2bc" - ), - Iteration( - "2a*b + b^2 + c^2+ a^2 + 2bc + 2a*c==a^2+b^2+c^2+2a*b+2a*c+2bc", - "answer=2a*b + b^2 + c^2+ a^2 + 2bc + 2a*c", - "input=a^2+b^2+c^2+2a*b+2a*c+2bc" - ), - Iteration("1 - 6x + 9x^2==9x^2 − 6x + 1", "answer=1 - 6x + 9x^2", "input=9x^2 − 6x + 1"), - Iteration("9x^2 + 1 - 6x==9x^2 − 6x + 1", "answer=9x^2 + 1 - 6x", "input=9x^2 − 6x + 1"), - Iteration("2+1+x==x+1+2", "answer=2+1+x", "input=x+1+2"), - Iteration("1+2+x==x+1+2", "answer=1+2+x", "input=x+1+2"), - Iteration("1+x+2==x+1+2", "answer=1+x+2", "input=x+1+2"), - Iteration("2+x+1==x+1+2", "answer=2+x+1", "input=x+1+2"), - Iteration("(x+1)+2==x+1+2", "answer=(x+1)+2", "input=x+1+2"), - Iteration("x + (1+2)==x+1+2", "answer=x + (1+2)", "input=x+1+2"), - Iteration( - "y+1+ 9x(x − 6)==9x(x − 6) + 1+ y", "answer=y+1+ 9x(x − 6)", "input=9x(x − 6) + 1+ y" - ), - Iteration("1+y+9x(x − 6)==9x(x − 6) + 1+ y", "answer=1+y+9x(x − 6)", "input=9x(x − 6) + 1+ y"), - Iteration( - "1 + 9x(x − 6) + y==9x(x − 6) + 1+ y", "answer=1 + 9x(x − 6) + y", "input=9x(x − 6) + 1+ y" - ), - Iteration( - "(y+1)+9x(x − 6)==9x(x − 6) + 1+ y", "answer=(y+1)+9x(x − 6)", "input=9x(x − 6) + 1+ y" - ), - Iteration( - "(x^2 − x)/3 − 4y==(x^2 − x)/3 − 4y", "answer=(x^2 − x)/3 − 4y", "input=(x^2 − x)/3 − 4y" - ), - Iteration( - "-4y + (x^2 − x)/3==(x^2 − x)/3 − 4y", "answer=-4y + (x^2 − x)/3", "input=(x^2 − x)/3 − 4y" - ), - Iteration("(3x -1)^2==(3x-1)^2", "answer=(3x -1)^2", "input=(3x-1)^2"), - Iteration("(2+6+3+4)*2==2*(2+6+3+4)", "answer=(2+6+3+4)*2", "input=2*(2+6+3+4)"), - Iteration("(2+6+3+4) × 2==2*(2+6+3+4)", "answer=(2+6+3+4) × 2", "input=2*(2+6+3+4)"), - Iteration( - "3 - (6 * 2) + 15==15 - (6 × 2) + 3", "answer=3 - (6 * 2) + 15", "input=15 - (6 × 2) + 3" - ), - Iteration( - "15 - (2 × 6) + 3==15 - (6 × 2) + 3", "answer=15 - (2 × 6) + 3", "input=15 - (6 × 2) + 3" - ), - Iteration( - "2* ( 25+50+100+150)==(50 + 150 + 100 + 25) × 2", - "answer=2* ( 25+50+100+150)", - "input=(50 + 150 + 100 + 25) × 2" - ), - Iteration("20x+4x^2==4*x^2+20x", "answer=20x+4x^2", "input=4*x^2+20x"), - Iteration("x-5+3==3+x-5", "answer=x-5+3", "input=3+x-5"), - Iteration("-5+3+x==3+x-5", "answer=-5+3+x", "input=3+x-5"), - Iteration("-5+x+3==3+x-5", "answer=-5+x+3", "input=3+x-5"), - Iteration("3+(x-5)==3+x-5", "answer=3+(x-5)", "input=3+x-5"), - Iteration("A+Z-Z==Z+A-Z", "answer=A+Z-Z", "input=Z+A-Z"), - Iteration("Z+(A-Z)==Z+A-Z", "answer=Z+(A-Z)", "input=Z+A-Z"), - Iteration("6C - (5A+1)==6C - 5A -1", "answer=6C - (5A+1)", "input=6C - 5A -1"), - Iteration("-5A-1+6C==6C - 5A -1", "answer=-5A-1+6C", "input=6C - 5A -1"), - Iteration("-W+5Z==5*Z-W", "answer=-W+5Z", "input=5*Z-W"), - Iteration("L+LS-3S==L*S-3S+L", "answer=L+LS-3S", "input=L*S-3S+L"), - Iteration( - "- 4y + (x^2 − x)/3==(x^2 − x)/3 − 4y", "answer=- 4y + (x^2 − x)/3", "input=(x^2 − x)/3 − 4y" - ), - Iteration( - "a^2+ b^2 + c^2 + 2bc + 2a*c + 2a*b==a^2+b^2+c^2+2a*b+2a*c+2bc", - "answer=a^2+ b^2 + c^2 + 2bc + 2a*c + 2a*b", - "input=a^2+b^2+c^2+2a*b+2a*c+2bc" - ) + @Iteration("2*(2+6+3+4)==2*(2+6+3+4)", "answer=2*(2+6+3+4)", "input=2*(2+6+3+4)") + @Iteration("2 × (2+6+3+4)==2*(2+6+3+4)", "answer=2 × (2+6+3+4)", "input=2*(2+6+3+4)") + @Iteration( + "15 - (6 × 2) + 3==15 - (6 × 2) + 3", "answer=15 - (6 × 2) + 3", "input=15 - (6 × 2) + 3" + ) + @Iteration( + "2 × (50 + 150 + 100 + 25) ==(50 + 150 + 100 + 25) × 2", + "answer=2 × (50 + 150 + 100 + 25) ", + "input=(50 + 150 + 100 + 25) × 2" + ) + @Iteration( + "2 * (50 + 150 + 100 + 25) ==2 × (50 + 150 + 100 + 25)", + "answer=2 * (50 + 150 + 100 + 25) ", + "input=2 × (50 + 150 + 100 + 25)" + ) + @Iteration("2+5==5+2", "answer=2+5", "input=5+2") + @Iteration("5+2==5+2", "answer=5+2", "input=5+2") + @Iteration("6 + 4!=6 − (− 4)", "answer=6 + 4", "input=6 − (− 4)") + @Iteration("6 − (− 4)==6 − (− 4)", "answer=6 − (− 4)", "input=6 − (− 4)") + @Iteration("6-(-4)==6 − (− 4)", "answer=6-(-4)", "input=6 − (− 4)") + @Iteration("− (− 4) + 6==6 − (− 4)", "answer=− (− 4) + 6", "input=6 − (− 4)") + @Iteration("10^−5 * 3!=3 * 10^-5", "answer=10^−5 * 3", "input=3 * 10^-5") + @Iteration("3 * 10^-5==3 * 10^-5", "answer=3 * 10^-5", "input=3 * 10^-5") + @Iteration( + "1000 + 200 + 30 + 4 + 0.5 + 0.06==1000 + 200 + 30 + 4 + 0.5 + 0.06", + "answer=1000 + 200 + 30 + 4 + 0.5 + 0.06", + "input=1000 + 200 + 30 + 4 + 0.5 + 0.06" + ) + @Iteration( + "200 + 30 + 4 + 0.5 + 0.06 + 1000==1000 + 200 + 30 + 4 + 0.5 + 0.06", + "answer=200 + 30 + 4 + 0.5 + 0.06 + 1000", + "input=1000 + 200 + 30 + 4 + 0.5 + 0.06" + ) + @Iteration( + "0.06 + 0.5 + 4 + 30 + 200 + 1000==1000 + 200 + 30 + 4 + 0.5 + 0.06", + "answer=0.06 + 0.5 + 4 + 30 + 200 + 1000", + "input=1000 + 200 + 30 + 4 + 0.5 + 0.06" + ) + @Iteration("2 * 2 * 3 * 3==2 * 2 * 3 * 3", "answer=2 * 2 * 3 * 3", "input=2 * 2 * 3 * 3") + @Iteration("4x^2+20x==4*x^2+20x", "answer=4x^2+20x", "input=4*x^2+20x") + @Iteration("3+x-5==3+x-5", "answer=3+x-5", "input=3+x-5") + @Iteration("Z+A-Z==Z+A-Z", "answer=Z+A-Z", "input=Z+A-Z") + @Iteration("6C - 5A -1==6C - 5A -1", "answer=6C - 5A -1", "input=6C - 5A -1") + @Iteration("5Z-w==5*Z-w", "answer=5Z-w", "input=5*Z-w") + @Iteration("5*Z-w==5*Z-w", "answer=5*Z-w", "input=5*Z-w") + @Iteration("LS-3S+L==L*S-3S+L", "answer=LS-3S+L", "input=L*S-3S+L") + @Iteration("L*S-3S+L==L*S-3S+L", "answer=L*S-3S+L", "input=L*S-3S+L") + @Iteration("L*S-3*S+L==L*S-3S+L", "answer=L*S-3*S+L", "input=L*S-3S+L") + @Iteration("LS-3*S+L==L*S-3S+L", "answer=LS-3*S+L", "input=L*S-3S+L") + @Iteration("9x^2 − 6x + 1==9x^2 − 6x + 1", "answer=9x^2 − 6x + 1", "input=9x^2 − 6x + 1") + @Iteration("c*b-c==c*b-c", "answer=c*b-c", "input=c*b-c") + @Iteration("bc-c==c*b-c", "answer=bc-c", "input=c*b-c") + @Iteration("cb-c==c*b-c", "answer=cb-c", "input=c*b-c") + @Iteration("-c+bc==c*b-c", "answer=-c+bc", "input=c*b-c") + @Iteration("-c+cb==c*b-c", "answer=-c+cb", "input=c*b-c") + @Iteration("x^2+y+4x==x^2+y+4x", "answer=x^2+y+4x", "input=x^2+y+4x") + @Iteration("y+4x+x^2==x^2+y+4x", "answer=y+4x+x^2", "input=x^2+y+4x") + @Iteration("x^2+4x+y==x^2+y+4x", "answer=x^2+4x+y", "input=x^2+y+4x") + @Iteration("Y+5==Y+5", "answer=Y+5", "input=Y+5") + @Iteration("5+Y==Y+5", "answer=5+Y", "input=Y+5") + @Iteration( + "a^2 + b^2 + c^2+ 2a*b + 2a*c + 2bc==a^2+b^2+c^2+2a*b+2a*c+2bc", + "answer=a^2 + b^2 + c^2+ 2a*b + 2a*c + 2bc", + "input=a^2+b^2+c^2+2a*b+2a*c+2bc" + ) + @Iteration( + "a^2 + b^2 + c^2+ 2a*b + 2bc + 2a*c==a^2+b^2+c^2+2a*b+2a*c+2bc", + "answer=a^2 + b^2 + c^2+ 2a*b + 2bc + 2a*c", + "input=a^2+b^2+c^2+2a*b+2a*c+2bc" + ) + @Iteration( + "2a*b + 2bc + 2a*c + a^2 + b^2 + c^2==a^2+b^2+c^2+2a*b+2a*c+2bc", + "answer=2a*b + 2bc + 2a*c + a^2 + b^2 + c^2", + "input=a^2+b^2+c^2+2a*b+2a*c+2bc" + ) + @Iteration( + "2a*b + b^2 + c^2+ a^2 + 2bc + 2a*c==a^2+b^2+c^2+2a*b+2a*c+2bc", + "answer=2a*b + b^2 + c^2+ a^2 + 2bc + 2a*c", + "input=a^2+b^2+c^2+2a*b+2a*c+2bc" + ) + @Iteration("1 - 6x + 9x^2==9x^2 − 6x + 1", "answer=1 - 6x + 9x^2", "input=9x^2 − 6x + 1") + @Iteration("9x^2 + 1 - 6x==9x^2 − 6x + 1", "answer=9x^2 + 1 - 6x", "input=9x^2 − 6x + 1") + @Iteration("2+1+x==x+1+2", "answer=2+1+x", "input=x+1+2") + @Iteration("1+2+x==x+1+2", "answer=1+2+x", "input=x+1+2") + @Iteration("1+x+2==x+1+2", "answer=1+x+2", "input=x+1+2") + @Iteration("2+x+1==x+1+2", "answer=2+x+1", "input=x+1+2") + @Iteration("(x+1)+2==x+1+2", "answer=(x+1)+2", "input=x+1+2") + @Iteration("x + (1+2)==x+1+2", "answer=x + (1+2)", "input=x+1+2") + @Iteration( + "y+1+ 9x(x − 6)==9x(x − 6) + 1+ y", "answer=y+1+ 9x(x − 6)", "input=9x(x − 6) + 1+ y" + ) + @Iteration("1+y+9x(x − 6)==9x(x − 6) + 1+ y", "answer=1+y+9x(x − 6)", "input=9x(x − 6) + 1+ y") + @Iteration( + "1 + 9x(x − 6) + y==9x(x − 6) + 1+ y", "answer=1 + 9x(x − 6) + y", "input=9x(x − 6) + 1+ y" + ) + @Iteration( + "(y+1)+9x(x − 6)==9x(x − 6) + 1+ y", "answer=(y+1)+9x(x − 6)", "input=9x(x − 6) + 1+ y" + ) + @Iteration( + "(x^2 − x)/3 − 4y==(x^2 − x)/3 − 4y", "answer=(x^2 − x)/3 − 4y", "input=(x^2 − x)/3 − 4y" + ) + @Iteration( + "-4y + (x^2 − x)/3==(x^2 − x)/3 − 4y", "answer=-4y + (x^2 − x)/3", "input=(x^2 − x)/3 − 4y" + ) + @Iteration("(3x -1)^2==(3x-1)^2", "answer=(3x -1)^2", "input=(3x-1)^2") + @Iteration("(2+6+3+4)*2==2*(2+6+3+4)", "answer=(2+6+3+4)*2", "input=2*(2+6+3+4)") + @Iteration("(2+6+3+4) × 2==2*(2+6+3+4)", "answer=(2+6+3+4) × 2", "input=2*(2+6+3+4)") + @Iteration( + "3 - (6 * 2) + 15==15 - (6 × 2) + 3", "answer=3 - (6 * 2) + 15", "input=15 - (6 × 2) + 3" + ) + @Iteration( + "15 - (2 × 6) + 3==15 - (6 × 2) + 3", "answer=15 - (2 × 6) + 3", "input=15 - (6 × 2) + 3" + ) + @Iteration( + "2* ( 25+50+100+150)==(50 + 150 + 100 + 25) × 2", + "answer=2* ( 25+50+100+150)", + "input=(50 + 150 + 100 + 25) × 2" + ) + @Iteration("20x+4x^2==4*x^2+20x", "answer=20x+4x^2", "input=4*x^2+20x") + @Iteration("x-5+3==3+x-5", "answer=x-5+3", "input=3+x-5") + @Iteration("-5+3+x==3+x-5", "answer=-5+3+x", "input=3+x-5") + @Iteration("-5+x+3==3+x-5", "answer=-5+x+3", "input=3+x-5") + @Iteration("3+(x-5)==3+x-5", "answer=3+(x-5)", "input=3+x-5") + @Iteration("A+Z-Z==Z+A-Z", "answer=A+Z-Z", "input=Z+A-Z") + @Iteration("Z+(A-Z)==Z+A-Z", "answer=Z+(A-Z)", "input=Z+A-Z") + @Iteration("6C - (5A+1)==6C - 5A -1", "answer=6C - (5A+1)", "input=6C - 5A -1") + @Iteration("-5A-1+6C==6C - 5A -1", "answer=-5A-1+6C", "input=6C - 5A -1") + @Iteration("-W+5Z==5*Z-W", "answer=-W+5Z", "input=5*Z-W") + @Iteration("L+LS-3S==L*S-3S+L", "answer=L+LS-3S", "input=L*S-3S+L") + @Iteration( + "- 4y + (x^2 − x)/3==(x^2 − x)/3 − 4y", "answer=- 4y + (x^2 − x)/3", "input=(x^2 − x)/3 − 4y" + ) + @Iteration( + "a^2+ b^2 + c^2 + 2bc + 2a*c + 2a*b==a^2+b^2+c^2+2a*b+2a*c+2bc", + "answer=a^2+ b^2 + c^2 + 2bc + 2a*c + 2a*b", + "input=a^2+b^2+c^2+2a*b+2a*c+2bc" ) fun testMatches_assortedExpressions_withMatchingCharacteristics_returnsTrue() { val answerExpression = createMathExpression(answer) @@ -403,191 +384,189 @@ class AlgebraicExpressionInputMatchesUpToTrivialManipulationsRuleClassifierProvi } @Test - @RunParameterized( - Iteration("10!=6 − (− 4)", "answer=10", "input=6 − (− 4)"), - Iteration("6 + 2^2!=6 − (− 4)", "answer=6 + 2^2", "input=6 − (− 4)"), - Iteration("3 * 2 − (− 4)!=6 − (− 4)", "answer=3 * 2 − (− 4)", "input=6 − (− 4)"), - Iteration("100/10!=6 − (− 4)", "answer=100/10", "input=6 − (− 4)"), - Iteration("3/(10 * 10^4)!=3 * 10^-5", "answer=3/(10 * 10^4)", "input=3 * 10^-5"), - Iteration( - "1234.56!=1000 + 200 + 30 + 4 + 0.5 + 0.06", - "answer=1234.56", - "input=1000 + 200 + 30 + 4 + 0.5 + 0.06" - ), - Iteration( - "123456/100!=1000 + 200 + 30 + 4 + 0.5 + 0.06", - "answer=123456/100", - "input=1000 + 200 + 30 + 4 + 0.5 + 0.06" - ), - Iteration( - "61728/50!=1000 + 200 + 30 + 4 + 0.5 + 0.06", - "answer=61728/50", - "input=1000 + 200 + 30 + 4 + 0.5 + 0.06" - ), - Iteration( - "1234 + 56/100!=1000 + 200 + 30 + 4 + 0.5 + 0.06", - "answer=1234 + 56/100", - "input=1000 + 200 + 30 + 4 + 0.5 + 0.06" - ), - Iteration( - "1230 + 4.56!=1000 + 200 + 30 + 4 + 0.5 + 0.06", - "answer=1230 + 4.56", - "input=1000 + 200 + 30 + 4 + 0.5 + 0.06" - ), - Iteration( - "2 * 2 * 3 * 3 * 1!=2 * 2 * 3 * 3", "answer=2 * 2 * 3 * 3 * 1", "input=2 * 2 * 3 * 3" - ), - Iteration("2 * 2 * 9!=2 * 2 * 3 * 3", "answer=2 * 2 * 9", "input=2 * 2 * 3 * 3"), - Iteration("4 * 3^2!=2 * 2 * 3 * 3", "answer=4 * 3^2", "input=2 * 2 * 3 * 3"), - Iteration("8/2 * 3 * 3!=2 * 2 * 3 * 3", "answer=8/2 * 3 * 3", "input=2 * 2 * 3 * 3"), - Iteration("36!=2 * 2 * 3 * 3", "answer=36", "input=2 * 2 * 3 * 3"), - Iteration("sqrt(4-2)!=sqrt(2)", "answer=sqrt(4-2)", "input=sqrt(2)"), - Iteration( - "(a+ b)^2 + c^2 + 2bc + 2a*c!=a^2+b^2+c^2+2a*b+2a*c+2bc", - "answer=(a+ b)^2 + c^2 + 2bc + 2a*c", - "input=a^2+b^2+c^2+2a*b+2a*c+2bc" - ), - Iteration( - "(a+b+c)^2!=a^2+b^2+c^2+2a*b+2a*c+2bc", "answer=(a+b+c)^2", "input=a^2+b^2+c^2+2a*b+2a*c+2bc" - ), - Iteration( - "(-a -b -c)^2!=a^2+b^2+c^2+2a*b+2a*c+2bc", - "answer=(-a -b -c)^2", - "input=a^2+b^2+c^2+2a*b+2a*c+2bc" - ), - Iteration( - "x(x − 1)/3 −4y!=(x^2 − x)/3 − 4y", "answer=x(x − 1)/3 −4y", "input=(x^2 − x)/3 − 4y" - ), - Iteration( - "x^2/3 − x/3 − 4y!=(x^2 − x)/3 − 4y", "answer=x^2/3 − x/3 − 4y", "input=(x^2 − x)/3 − 4y" - ), - Iteration( - "x^2/3 − (x/3 + 4y)!=(x^2 − x)/3 − 4y", "answer=x^2/3 − (x/3 + 4y)", "input=(x^2 − x)/3 − 4y" - ), - Iteration("√(3x −1)4!=(3x-1)^2", "answer=√(3x −1)4", "input=(3x-1)^2"), - Iteration("3x(3x - 2) + 1!=(3x-1)^2", "answer=3x(3x - 2) + 1", "input=(3x-1)^2"), - Iteration("3(3x^2) - 6x +1!=(3x-1)^2", "answer=3(3x^2) - 6x +1", "input=(3x-1)^2"), - Iteration("2x!=sqrt(4x^2)", "answer=2x", "input=sqrt(4x^2)"), - Iteration("x^2+2x+1!=(x+1)^2", "answer=x^2+2x+1", "input=(x+1)^2"), - Iteration("x^2-1!=(x+1)(x-1)", "answer=x^2-1", "input=(x+1)(x-1)"), - Iteration("x+1!=(x^2+2x+1)/(x+1)", "answer=x+1", "input=(x^2+2x+1)/(x+1)"), - Iteration("x-1!=(x^2-1)/(x+1)", "answer=x-1", "input=(x^2-1)/(x+1)"), - Iteration("x+1!=(x^2-1)/(x-1)", "answer=x+1", "input=(x^2-1)/(x-1)"), - Iteration("-3x!=(-27x^3)^(1/3)", "answer=-3x", "input=(-27x^3)^(1/3)"), - Iteration("1!=(x^2-1)/(x^2-1)", "answer=1", "input=(x^2-1)/(x^2-1)"), - Iteration("2*(6+3+4) + 4!=2*(2+6+3+4)", "answer=2*(6+3+4) + 4", "input=2*(2+6+3+4)"), - Iteration("2*(2+6+3) + 8!=2*(2+6+3+4)", "answer=2*(2+6+3) + 8", "input=2*(2+6+3+4)"), - Iteration("15 - 12 + 3!=15 - (6 × 2) + 3", "answer=15 - 12 + 3", "input=15 - (6 × 2) + 3"), - Iteration( - "2 *(50 + 150) + 2*(100 + 25)!=(50 + 150 + 100 + 25) × 2", - "answer=2 *(50 + 150) + 2*(100 + 25)", - "input=(50 + 150 + 100 + 25) × 2" - ), - Iteration("3 * 10^5!=3 * 10^-5", "answer=3 * 10^5", "input=3 * 10^-5"), - Iteration("2 * 10^−5!=3 * 10^-5", "answer=2 * 10^−5", "input=3 * 10^-5"), - Iteration("5 * 10^−3!=3 * 10^-5", "answer=5 * 10^−3", "input=3 * 10^-5"), - Iteration("30 * 10^−6!=3 * 10^-5", "answer=30 * 10^−6", "input=3 * 10^-5"), - Iteration("0.00003!=3 * 10^-5", "answer=0.00003", "input=3 * 10^-5"), - Iteration("3/10^5!=3 * 10^-5", "answer=3/10^5", "input=3 * 10^-5"), - Iteration( - "123456!=1000 + 200 + 30 + 4 + 0.5 + 0.06", - "answer=123456", - "input=1000 + 200 + 30 + 4 + 0.5 + 0.06" - ), - Iteration( - "1000 + 200 + 30!=1000 + 200 + 30 + 4 + 0.5 + 0.06", - "answer=1000 + 200 + 30", - "input=1000 + 200 + 30 + 4 + 0.5 + 0.06" - ), - Iteration("3 *2 – (− 4)!=6 − (− 4)", "answer=3 *2 – (− 4)", "input=6 − (− 4)"), - Iteration("6 − 4!=6 − (− 4)", "answer=6 − 4", "input=6 − (− 4)"), - Iteration("6 + (− 4)!=6 − (− 4)", "answer=6 + (− 4)", "input=6 − (− 4)"), - Iteration("100!=6 − (− 4)", "answer=100", "input=6 − (− 4)"), - Iteration("7!=5+2", "answer=7", "input=5+2"), - Iteration("3+4!=5+2", "answer=3+4", "input=5+2"), - Iteration("2 * 2 * 3!=2 * 2 * 3 * 3", "answer=2 * 2 * 3", "input=2 * 2 * 3 * 3"), - Iteration("2 * 3 * 3 * 3!=2 * 2 * 3 * 3", "answer=2 * 3 * 3 * 3", "input=2 * 2 * 3 * 3"), - Iteration("A!=Z+A-Z", "answer=A", "input=Z+A-Z"), - Iteration("L(1+S)-3S!=L*S-3S+L", "answer=L(1+S)-3S", "input=L*S-3S+L"), - Iteration("S(L-3)+L!=L*S-3S+L", "answer=S(L-3)+L", "input=L*S-3S+L"), - Iteration( - "x(x − 1)/3 − 4y!=(x^2 − x)/3 − 4y", "answer=x(x − 1)/3 − 4y", "input=(x^2 − x)/3 − 4y" - ), - Iteration( - "(x^2 − x) * 3^-1 − 4y!=(x^2 − x)/3 − 4y", - "answer=(x^2 − x) * 3^-1 − 4y", - "input=(x^2 − x)/3 − 4y" - ), - Iteration( - "x(x^2 − x)/3 − 4y!=(x^2 − x)/3 − 4y", "answer=x(x^2 − x)/3 − 4y", "input=(x^2 − x)/3 − 4y" - ), - Iteration( - "(x^2 − x)/3 + 4y!=(x^2 − x)/3 − 4y", "answer=(x^2 − x)/3 + 4y", "input=(x^2 − x)/3 − 4y" - ), - Iteration( - "(x^2 + x)/3 - 4y!=(x^2 − x)/3 − 4y", "answer=(x^2 + x)/3 - 4y", "input=(x^2 − x)/3 − 4y" - ), - Iteration( - "(x^2 − x)*0.33 - 4y!=(x^2 − x)/3 − 4y", - "answer=(x^2 − x)*0.33 - 4y", - "input=(x^2 − x)/3 − 4y" - ), - Iteration( - "a*a + b*b + c*c + 2*a*b + 2*a*c + 2*b*c==a^2+b^2+c^2+2a*b+2a*c+2bc", - "answer=a*a + b*b + c*c + 2*a*b + 2*a*c + 2*b*c", - "input=a^2+b^2+c^2+2a*b+2a*c+2bc" - ), - Iteration( - "a^2 + b^2 + c^2 + 2(a*b + a*c + bc)!=a^2+b^2+c^2+2a*b+2a*c+2bc", - "answer=a^2 + b^2 + c^2 + 2(a*b + a*c + bc)", - "input=a^2+b^2+c^2+2a*b+2a*c+2bc" - ), - Iteration( - "(a + b)^2 + c^2 + 2a*c + 2bc!=a^2+b^2+c^2+2a*b+2a*c+2bc", - "answer=(a + b)^2 + c^2 + 2a*c + 2bc", - "input=a^2+b^2+c^2+2a*b+2a*c+2bc" - ), - Iteration( - "a * a + b * b + c^3/c + 2a*b + 2a*c + 2bc!=a^2+b^2+c^2+2a*b+2a*c+2bc", - "answer=a * a + b * b + c^3/c + 2a*b + 2a*c + 2bc", - "input=a^2+b^2+c^2+2a*b+2a*c+2bc" - ), - Iteration( - "(a + b + c)^3!=a^2+b^2+c^2+2a*b+2a*c+2bc", - "answer=(a + b + c)^3", - "input=a^2+b^2+c^2+2a*b+2a*c+2bc" - ), - Iteration( - "a^2 + b^2 + c^2!=a^2+b^2+c^2+2a*b+2a*c+2bc", - "answer=a^2 + b^2 + c^2", - "input=a^2+b^2+c^2+2a*b+2a*c+2bc" - ), - Iteration( - "a^2 + b^2 + c^2- 2a*b - 2a*c - 2bc!=a^2+b^2+c^2+2a*b+2a*c+2bc", - "answer=a^2 + b^2 + c^2- 2a*b - 2a*c - 2bc", - "input=a^2+b^2+c^2+2a*b+2a*c+2bc" - ), - Iteration("(3x − 1)^2!=9x^2 − 6x + 1", "answer=(3x − 1)^2", "input=9x^2 − 6x + 1"), - Iteration("3x(3x − 2) + 1!=9x^2 − 6x + 1", "answer=3x(3x − 2) + 1", "input=9x^2 − 6x + 1"), - Iteration("3(3x^2 − 2x) + 1!=9x^2 − 6x + 1", "answer=3(3x^2 − 2x) + 1", "input=9x^2 − 6x + 1"), - Iteration("(3x)^2 − 6x + 1!=9x^2 − 6x + 1", "answer=(3x)^2 − 6x + 1", "input=9x^2 − 6x + 1"), - Iteration("c(b-1)!=c*b-c", "answer=c(b-1)", "input=c*b-c"), - Iteration("x(x+4)+y!=x^2+y+4x", "answer=x(x+4)+y", "input=x^2+y+4x"), - Iteration("Y!=Y+5", "answer=Y", "input=Y+5"), - Iteration("5!=Y+5", "answer=5", "input=Y+5"), - Iteration("x+3!=x+1+2", "answer=x+3", "input=x+1+2"), - Iteration("(1 - 3x)^2!=(3x-1)^2", "answer=(1 - 3x)^2", "input=(3x-1)^2"), - Iteration("9x^2 - 6x - 1!=(3x-1)^2", "answer=9x^2 - 6x - 1", "input=(3x-1)^2"), - Iteration("(3x −1)!=(3x-1)^2", "answer=(3x −1)", "input=(3x-1)^2"), - Iteration("2x!=sqrt(2x)^2", "answer=2x", "input=sqrt(2x)^2"), - Iteration("2x!=sqrt(-4x^2)", "answer=2x", "input=sqrt(-4x^2)"), - Iteration("x^2+2x+1!=(x+2)^2", "answer=x^2+2x+1", "input=(x+2)^2"), - Iteration("x^2-1!=(x+1)(1-x)", "answer=x^2-1", "input=(x+1)(1-x)"), - Iteration("x+1!=(x^2+2x+1)/(x-1)", "answer=x+1", "input=(x^2+2x+1)/(x-1)"), - Iteration("x-1!=(x^2-1)/x", "answer=x-1", "input=(x^2-1)/x"), - Iteration("x+1!=(x^2-1)/(x-2)", "answer=x+1", "input=(x^2-1)/(x-2)"), - Iteration("-3x!=(9x^3)^(1/3)", "answer=-3x", "input=(9x^3)^(1/3)") + @Iteration("10!=6 − (− 4)", "answer=10", "input=6 − (− 4)") + @Iteration("6 + 2^2!=6 − (− 4)", "answer=6 + 2^2", "input=6 − (− 4)") + @Iteration("3 * 2 − (− 4)!=6 − (− 4)", "answer=3 * 2 − (− 4)", "input=6 − (− 4)") + @Iteration("100/10!=6 − (− 4)", "answer=100/10", "input=6 − (− 4)") + @Iteration("3/(10 * 10^4)!=3 * 10^-5", "answer=3/(10 * 10^4)", "input=3 * 10^-5") + @Iteration( + "1234.56!=1000 + 200 + 30 + 4 + 0.5 + 0.06", + "answer=1234.56", + "input=1000 + 200 + 30 + 4 + 0.5 + 0.06" + ) + @Iteration( + "123456/100!=1000 + 200 + 30 + 4 + 0.5 + 0.06", + "answer=123456/100", + "input=1000 + 200 + 30 + 4 + 0.5 + 0.06" + ) + @Iteration( + "61728/50!=1000 + 200 + 30 + 4 + 0.5 + 0.06", + "answer=61728/50", + "input=1000 + 200 + 30 + 4 + 0.5 + 0.06" + ) + @Iteration( + "1234 + 56/100!=1000 + 200 + 30 + 4 + 0.5 + 0.06", + "answer=1234 + 56/100", + "input=1000 + 200 + 30 + 4 + 0.5 + 0.06" + ) + @Iteration( + "1230 + 4.56!=1000 + 200 + 30 + 4 + 0.5 + 0.06", + "answer=1230 + 4.56", + "input=1000 + 200 + 30 + 4 + 0.5 + 0.06" + ) + @Iteration( + "2 * 2 * 3 * 3 * 1!=2 * 2 * 3 * 3", "answer=2 * 2 * 3 * 3 * 1", "input=2 * 2 * 3 * 3" + ) + @Iteration("2 * 2 * 9!=2 * 2 * 3 * 3", "answer=2 * 2 * 9", "input=2 * 2 * 3 * 3") + @Iteration("4 * 3^2!=2 * 2 * 3 * 3", "answer=4 * 3^2", "input=2 * 2 * 3 * 3") + @Iteration("8/2 * 3 * 3!=2 * 2 * 3 * 3", "answer=8/2 * 3 * 3", "input=2 * 2 * 3 * 3") + @Iteration("36!=2 * 2 * 3 * 3", "answer=36", "input=2 * 2 * 3 * 3") + @Iteration("sqrt(4-2)!=sqrt(2)", "answer=sqrt(4-2)", "input=sqrt(2)") + @Iteration( + "(a+ b)^2 + c^2 + 2bc + 2a*c!=a^2+b^2+c^2+2a*b+2a*c+2bc", + "answer=(a+ b)^2 + c^2 + 2bc + 2a*c", + "input=a^2+b^2+c^2+2a*b+2a*c+2bc" + ) + @Iteration( + "(a+b+c)^2!=a^2+b^2+c^2+2a*b+2a*c+2bc", "answer=(a+b+c)^2", "input=a^2+b^2+c^2+2a*b+2a*c+2bc" + ) + @Iteration( + "(-a -b -c)^2!=a^2+b^2+c^2+2a*b+2a*c+2bc", + "answer=(-a -b -c)^2", + "input=a^2+b^2+c^2+2a*b+2a*c+2bc" + ) + @Iteration( + "x(x − 1)/3 −4y!=(x^2 − x)/3 − 4y", "answer=x(x − 1)/3 −4y", "input=(x^2 − x)/3 − 4y" + ) + @Iteration( + "x^2/3 − x/3 − 4y!=(x^2 − x)/3 − 4y", "answer=x^2/3 − x/3 − 4y", "input=(x^2 − x)/3 − 4y" + ) + @Iteration( + "x^2/3 − (x/3 + 4y)!=(x^2 − x)/3 − 4y", "answer=x^2/3 − (x/3 + 4y)", "input=(x^2 − x)/3 − 4y" + ) + @Iteration("√(3x −1)4!=(3x-1)^2", "answer=√(3x −1)4", "input=(3x-1)^2") + @Iteration("3x(3x - 2) + 1!=(3x-1)^2", "answer=3x(3x - 2) + 1", "input=(3x-1)^2") + @Iteration("3(3x^2) - 6x +1!=(3x-1)^2", "answer=3(3x^2) - 6x +1", "input=(3x-1)^2") + @Iteration("2x!=sqrt(4x^2)", "answer=2x", "input=sqrt(4x^2)") + @Iteration("x^2+2x+1!=(x+1)^2", "answer=x^2+2x+1", "input=(x+1)^2") + @Iteration("x^2-1!=(x+1)(x-1)", "answer=x^2-1", "input=(x+1)(x-1)") + @Iteration("x+1!=(x^2+2x+1)/(x+1)", "answer=x+1", "input=(x^2+2x+1)/(x+1)") + @Iteration("x-1!=(x^2-1)/(x+1)", "answer=x-1", "input=(x^2-1)/(x+1)") + @Iteration("x+1!=(x^2-1)/(x-1)", "answer=x+1", "input=(x^2-1)/(x-1)") + @Iteration("-3x!=(-27x^3)^(1/3)", "answer=-3x", "input=(-27x^3)^(1/3)") + @Iteration("1!=(x^2-1)/(x^2-1)", "answer=1", "input=(x^2-1)/(x^2-1)") + @Iteration("2*(6+3+4) + 4!=2*(2+6+3+4)", "answer=2*(6+3+4) + 4", "input=2*(2+6+3+4)") + @Iteration("2*(2+6+3) + 8!=2*(2+6+3+4)", "answer=2*(2+6+3) + 8", "input=2*(2+6+3+4)") + @Iteration("15 - 12 + 3!=15 - (6 × 2) + 3", "answer=15 - 12 + 3", "input=15 - (6 × 2) + 3") + @Iteration( + "2 *(50 + 150) + 2*(100 + 25)!=(50 + 150 + 100 + 25) × 2", + "answer=2 *(50 + 150) + 2*(100 + 25)", + "input=(50 + 150 + 100 + 25) × 2" + ) + @Iteration("3 * 10^5!=3 * 10^-5", "answer=3 * 10^5", "input=3 * 10^-5") + @Iteration("2 * 10^−5!=3 * 10^-5", "answer=2 * 10^−5", "input=3 * 10^-5") + @Iteration("5 * 10^−3!=3 * 10^-5", "answer=5 * 10^−3", "input=3 * 10^-5") + @Iteration("30 * 10^−6!=3 * 10^-5", "answer=30 * 10^−6", "input=3 * 10^-5") + @Iteration("0.00003!=3 * 10^-5", "answer=0.00003", "input=3 * 10^-5") + @Iteration("3/10^5!=3 * 10^-5", "answer=3/10^5", "input=3 * 10^-5") + @Iteration( + "123456!=1000 + 200 + 30 + 4 + 0.5 + 0.06", + "answer=123456", + "input=1000 + 200 + 30 + 4 + 0.5 + 0.06" + ) + @Iteration( + "1000 + 200 + 30!=1000 + 200 + 30 + 4 + 0.5 + 0.06", + "answer=1000 + 200 + 30", + "input=1000 + 200 + 30 + 4 + 0.5 + 0.06" + ) + @Iteration("3 *2 – (− 4)!=6 − (− 4)", "answer=3 *2 – (− 4)", "input=6 − (− 4)") + @Iteration("6 − 4!=6 − (− 4)", "answer=6 − 4", "input=6 − (− 4)") + @Iteration("6 + (− 4)!=6 − (− 4)", "answer=6 + (− 4)", "input=6 − (− 4)") + @Iteration("100!=6 − (− 4)", "answer=100", "input=6 − (− 4)") + @Iteration("7!=5+2", "answer=7", "input=5+2") + @Iteration("3+4!=5+2", "answer=3+4", "input=5+2") + @Iteration("2 * 2 * 3!=2 * 2 * 3 * 3", "answer=2 * 2 * 3", "input=2 * 2 * 3 * 3") + @Iteration("2 * 3 * 3 * 3!=2 * 2 * 3 * 3", "answer=2 * 3 * 3 * 3", "input=2 * 2 * 3 * 3") + @Iteration("A!=Z+A-Z", "answer=A", "input=Z+A-Z") + @Iteration("L(1+S)-3S!=L*S-3S+L", "answer=L(1+S)-3S", "input=L*S-3S+L") + @Iteration("S(L-3)+L!=L*S-3S+L", "answer=S(L-3)+L", "input=L*S-3S+L") + @Iteration( + "x(x − 1)/3 − 4y!=(x^2 − x)/3 − 4y", "answer=x(x − 1)/3 − 4y", "input=(x^2 − x)/3 − 4y" + ) + @Iteration( + "(x^2 − x) * 3^-1 − 4y!=(x^2 − x)/3 − 4y", + "answer=(x^2 − x) * 3^-1 − 4y", + "input=(x^2 − x)/3 − 4y" + ) + @Iteration( + "x(x^2 − x)/3 − 4y!=(x^2 − x)/3 − 4y", "answer=x(x^2 − x)/3 − 4y", "input=(x^2 − x)/3 − 4y" + ) + @Iteration( + "(x^2 − x)/3 + 4y!=(x^2 − x)/3 − 4y", "answer=(x^2 − x)/3 + 4y", "input=(x^2 − x)/3 − 4y" + ) + @Iteration( + "(x^2 + x)/3 - 4y!=(x^2 − x)/3 − 4y", "answer=(x^2 + x)/3 - 4y", "input=(x^2 − x)/3 − 4y" + ) + @Iteration( + "(x^2 − x)*0.33 - 4y!=(x^2 − x)/3 − 4y", + "answer=(x^2 − x)*0.33 - 4y", + "input=(x^2 − x)/3 − 4y" + ) + @Iteration( + "a*a + b*b + c*c + 2*a*b + 2*a*c + 2*b*c==a^2+b^2+c^2+2a*b+2a*c+2bc", + "answer=a*a + b*b + c*c + 2*a*b + 2*a*c + 2*b*c", + "input=a^2+b^2+c^2+2a*b+2a*c+2bc" + ) + @Iteration( + "a^2 + b^2 + c^2 + 2(a*b + a*c + bc)!=a^2+b^2+c^2+2a*b+2a*c+2bc", + "answer=a^2 + b^2 + c^2 + 2(a*b + a*c + bc)", + "input=a^2+b^2+c^2+2a*b+2a*c+2bc" + ) + @Iteration( + "(a + b)^2 + c^2 + 2a*c + 2bc!=a^2+b^2+c^2+2a*b+2a*c+2bc", + "answer=(a + b)^2 + c^2 + 2a*c + 2bc", + "input=a^2+b^2+c^2+2a*b+2a*c+2bc" + ) + @Iteration( + "a * a + b * b + c^3/c + 2a*b + 2a*c + 2bc!=a^2+b^2+c^2+2a*b+2a*c+2bc", + "answer=a * a + b * b + c^3/c + 2a*b + 2a*c + 2bc", + "input=a^2+b^2+c^2+2a*b+2a*c+2bc" + ) + @Iteration( + "(a + b + c)^3!=a^2+b^2+c^2+2a*b+2a*c+2bc", + "answer=(a + b + c)^3", + "input=a^2+b^2+c^2+2a*b+2a*c+2bc" + ) + @Iteration( + "a^2 + b^2 + c^2!=a^2+b^2+c^2+2a*b+2a*c+2bc", + "answer=a^2 + b^2 + c^2", + "input=a^2+b^2+c^2+2a*b+2a*c+2bc" + ) + @Iteration( + "a^2 + b^2 + c^2- 2a*b - 2a*c - 2bc!=a^2+b^2+c^2+2a*b+2a*c+2bc", + "answer=a^2 + b^2 + c^2- 2a*b - 2a*c - 2bc", + "input=a^2+b^2+c^2+2a*b+2a*c+2bc" ) + @Iteration("(3x − 1)^2!=9x^2 − 6x + 1", "answer=(3x − 1)^2", "input=9x^2 − 6x + 1") + @Iteration("3x(3x − 2) + 1!=9x^2 − 6x + 1", "answer=3x(3x − 2) + 1", "input=9x^2 − 6x + 1") + @Iteration("3(3x^2 − 2x) + 1!=9x^2 − 6x + 1", "answer=3(3x^2 − 2x) + 1", "input=9x^2 − 6x + 1") + @Iteration("(3x)^2 − 6x + 1!=9x^2 − 6x + 1", "answer=(3x)^2 − 6x + 1", "input=9x^2 − 6x + 1") + @Iteration("c(b-1)!=c*b-c", "answer=c(b-1)", "input=c*b-c") + @Iteration("x(x+4)+y!=x^2+y+4x", "answer=x(x+4)+y", "input=x^2+y+4x") + @Iteration("Y!=Y+5", "answer=Y", "input=Y+5") + @Iteration("5!=Y+5", "answer=5", "input=Y+5") + @Iteration("x+3!=x+1+2", "answer=x+3", "input=x+1+2") + @Iteration("(1 - 3x)^2!=(3x-1)^2", "answer=(1 - 3x)^2", "input=(3x-1)^2") + @Iteration("9x^2 - 6x - 1!=(3x-1)^2", "answer=9x^2 - 6x - 1", "input=(3x-1)^2") + @Iteration("(3x −1)!=(3x-1)^2", "answer=(3x −1)", "input=(3x-1)^2") + @Iteration("2x!=sqrt(2x)^2", "answer=2x", "input=sqrt(2x)^2") + @Iteration("2x!=sqrt(-4x^2)", "answer=2x", "input=sqrt(-4x^2)") + @Iteration("x^2+2x+1!=(x+2)^2", "answer=x^2+2x+1", "input=(x+2)^2") + @Iteration("x^2-1!=(x+1)(1-x)", "answer=x^2-1", "input=(x+1)(1-x)") + @Iteration("x+1!=(x^2+2x+1)/(x-1)", "answer=x+1", "input=(x^2+2x+1)/(x-1)") + @Iteration("x-1!=(x^2-1)/x", "answer=x-1", "input=(x^2-1)/x") + @Iteration("x+1!=(x^2-1)/(x-2)", "answer=x+1", "input=(x^2-1)/(x-2)") + @Iteration("-3x!=(9x^3)^(1/3)", "answer=-3x", "input=(9x^3)^(1/3)") fun testMatches_assortedExpressions_withoutMatchingCharacteristics_returnsFalse() { val answerExpression = createMathExpression(answer) val inputExpression = createMathExpression(input) diff --git a/domain/src/test/java/org/oppia/android/domain/classify/rules/mathequationinput/MathEquationInputIsEquivalentToRuleClassifierProviderTest.kt b/domain/src/test/java/org/oppia/android/domain/classify/rules/mathequationinput/MathEquationInputIsEquivalentToRuleClassifierProviderTest.kt index 11d8bbbaac1..9435187bb25 100644 --- a/domain/src/test/java/org/oppia/android/domain/classify/rules/mathequationinput/MathEquationInputIsEquivalentToRuleClassifierProviderTest.kt +++ b/domain/src/test/java/org/oppia/android/domain/classify/rules/mathequationinput/MathEquationInputIsEquivalentToRuleClassifierProviderTest.kt @@ -19,7 +19,6 @@ import org.oppia.android.domain.classify.RuleClassifier import org.oppia.android.testing.junit.OppiaParameterizedTestRunner import org.oppia.android.testing.junit.OppiaParameterizedTestRunner.Iteration import org.oppia.android.testing.junit.OppiaParameterizedTestRunner.Parameter -import org.oppia.android.testing.junit.OppiaParameterizedTestRunner.RunParameterized import org.oppia.android.testing.junit.OppiaParameterizedTestRunner.SelectRunnerPlatform import org.oppia.android.testing.junit.ParameterizedRobolectricTestRunner import org.oppia.android.testing.robolectric.RobolectricModule @@ -62,10 +61,8 @@ class MathEquationInputIsEquivalentToRuleClassifierProviderTest { } @Test - @RunParameterized( - Iteration("y=1!=y=1", "answer=y=1", "input=y=1"), - Iteration("1=y!=1=y", "answer=1=y", "input=1=y") - ) + @Iteration("y=1!=y=1", "answer=y=1", "input=y=1") + @Iteration("1=y!=1=y", "answer=1=y", "input=1=y") fun testMatches_answerHasDisallowedVariable_returnsFalse() { val answerExpression = createMathExpression(answer) val inputExpression = createMathExpression(input) @@ -79,15 +76,13 @@ class MathEquationInputIsEquivalentToRuleClassifierProviderTest { } @Test - @RunParameterized( - Iteration("0=1==0=1", "answer=0=1", "input=0=1"), - Iteration("y=0==y=0", "answer=y=0", "input=y=0"), - Iteration("y=1==y=1", "answer=y=1", "input=y=1"), - Iteration("0=y==0=y", "answer=0=y", "input=0=y"), - Iteration("1=y==1=y", "answer=1=y", "input=1=y"), - Iteration("y=x==y=x", "answer=y=x", "input=y=x"), - Iteration("x=y==x=y", "answer=x=y", "input=x=y") - ) + @Iteration("0=1==0=1", "answer=0=1", "input=0=1") + @Iteration("y=0==y=0", "answer=y=0", "input=y=0") + @Iteration("y=1==y=1", "answer=y=1", "input=y=1") + @Iteration("0=y==0=y", "answer=0=y", "input=0=y") + @Iteration("1=y==1=y", "answer=1=y", "input=1=y") + @Iteration("y=x==y=x", "answer=y=x", "input=y=x") + @Iteration("x=y==x=y", "answer=x=y", "input=x=y") fun testMatches_sameSingleTerms_returnsTrue() { val answerExpression = createMathExpression(answer) val inputExpression = createMathExpression(input) @@ -99,14 +94,12 @@ class MathEquationInputIsEquivalentToRuleClassifierProviderTest { } @Test - @RunParameterized( - Iteration("y=-x==y=-x", "answer=y=-x", "input=y=-x"), - Iteration("-y=x==-y=x", "answer=-y=x", "input=-y=x"), - Iteration("y=3.14+x==y=3.14+x", "answer=y=3.14+x", "input=y=3.14+x"), - Iteration("y=x+y+z==y=x+y+z", "answer=y=x+y+z", "input=y=x+y+z"), - Iteration("y=x/2/3==y=x/2/3", "answer=y=x/2/3", "input=y=x/2/3"), - Iteration("y=x^2==y=x^2", "answer=y=x^2", "input=y=x^2") - ) + @Iteration("y=-x==y=-x", "answer=y=-x", "input=y=-x") + @Iteration("-y=x==-y=x", "answer=-y=x", "input=-y=x") + @Iteration("y=3.14+x==y=3.14+x", "answer=y=3.14+x", "input=y=3.14+x") + @Iteration("y=x+y+z==y=x+y+z", "answer=y=x+y+z", "input=y=x+y+z") + @Iteration("y=x/2/3==y=x/2/3", "answer=y=x/2/3", "input=y=x/2/3") + @Iteration("y=x^2==y=x^2", "answer=y=x^2", "input=y=x^2") fun testMatches_sameSingleOperations_returnsTrue() { val answerExpression = createMathExpression(answer) val inputExpression = createMathExpression(input) @@ -118,10 +111,8 @@ class MathEquationInputIsEquivalentToRuleClassifierProviderTest { } @Test - @RunParameterized( - Iteration("y=x/y/z!=y=x/y/z", "answer=y=x/y/z", "input=y=x/y/z"), - Iteration("y=sqrt(x)!=y=sqrt(x)", "answer=y=sqrt(x)", "input=y=sqrt(x)") - ) + @Iteration("y=x/y/z!=y=x/y/z", "answer=y=x/y/z", "input=y=x/y/z") + @Iteration("y=sqrt(x)!=y=sqrt(x)", "answer=y=sqrt(x)", "input=y=sqrt(x)") fun testMatches_sameSingleOperations_thatCannotBecomePolynomials_returnsFalse() { val answerExpression = createMathExpression(answer) val inputExpression = createMathExpression(input) @@ -134,17 +125,15 @@ class MathEquationInputIsEquivalentToRuleClassifierProviderTest { } @Test - @RunParameterized( - Iteration("y=1!=y=0", "answer=y=1", "input=y=0"), - Iteration("y=0!=y=1", "answer=y=0", "input=y=1"), - Iteration("y=3.14!=y=1", "answer=y=3.14", "input=y=1"), - Iteration("y=1!=y=3.14", "answer=y=1", "input=y=3.14"), - Iteration("y=x!=y=3.14", "answer=y=x", "input=y=3.14"), - Iteration("y=1!=y=x", "answer=y=1", "input=y=x"), - Iteration("y=3.14!=y=x", "answer=y=3.14", "input=y=x"), - Iteration("y=z!=y=x", "answer=y=z", "input=y=x"), - Iteration("y=x!=y=z", "answer=y=x", "input=y=z") - ) + @Iteration("y=1!=y=0", "answer=y=1", "input=y=0") + @Iteration("y=0!=y=1", "answer=y=0", "input=y=1") + @Iteration("y=3.14!=y=1", "answer=y=3.14", "input=y=1") + @Iteration("y=1!=y=3.14", "answer=y=1", "input=y=3.14") + @Iteration("y=x!=y=3.14", "answer=y=x", "input=y=3.14") + @Iteration("y=1!=y=x", "answer=y=1", "input=y=x") + @Iteration("y=3.14!=y=x", "answer=y=3.14", "input=y=x") + @Iteration("y=z!=y=x", "answer=y=z", "input=y=x") + @Iteration("y=x!=y=z", "answer=y=x", "input=y=z") fun testMatches_differentSingleTerms_returnsFalse() { val answerExpression = createMathExpression(answer) val inputExpression = createMathExpression(input) @@ -156,20 +145,18 @@ class MathEquationInputIsEquivalentToRuleClassifierProviderTest { } @Test - @RunParameterized( - Iteration("y=1+x==y=x+1", "answer=y=1+x", "input=y=x+1"), - Iteration("y=z+x==y=x+z", "answer=y=z+x", "input=y=x+z"), - Iteration("y+1=x==1+y=x", "answer=y+1=x", "input=1+y=x"), - Iteration("y+z=x==z+y=x", "answer=y+z=x", "input=z+y=x"), - Iteration("x+y=1+z==y+x=z+1", "answer=x+y=1+z", "input=y+x=z+1"), - Iteration("y=-x+1==y=1-x", "answer=y=-x+1", "input=y=1-x"), - Iteration("-y+x=z==x-y=z", "answer=-y+x=z", "input=x-y=z"), - Iteration("y=x*2==y=2x", "answer=y=x*2", "input=y=2x"), - Iteration("y*2=z==2y=z", "answer=y*2=z", "input=2y=z"), - Iteration("y=3*2==y=2*3", "answer=y=3*2", "input=y=2*3"), - Iteration("y=zx==y=xz", "answer=y=zx", "input=y=xz"), - Iteration("yx=z==xy=z", "answer=yx=z", "input=xy=z") - ) + @Iteration("y=1+x==y=x+1", "answer=y=1+x", "input=y=x+1") + @Iteration("y=z+x==y=x+z", "answer=y=z+x", "input=y=x+z") + @Iteration("y+1=x==1+y=x", "answer=y+1=x", "input=1+y=x") + @Iteration("y+z=x==z+y=x", "answer=y+z=x", "input=z+y=x") + @Iteration("x+y=1+z==y+x=z+1", "answer=x+y=1+z", "input=y+x=z+1") + @Iteration("y=-x+1==y=1-x", "answer=y=-x+1", "input=y=1-x") + @Iteration("-y+x=z==x-y=z", "answer=-y+x=z", "input=x-y=z") + @Iteration("y=x*2==y=2x", "answer=y=x*2", "input=y=2x") + @Iteration("y*2=z==2y=z", "answer=y*2=z", "input=2y=z") + @Iteration("y=3*2==y=2*3", "answer=y=3*2", "input=y=2*3") + @Iteration("y=zx==y=xz", "answer=y=zx", "input=y=xz") + @Iteration("yx=z==xy=z", "answer=yx=z", "input=xy=z") fun testMatches_operationsDiffer_byCommutativity_returnsTrue() { val answerExpression = createMathExpression(answer) val inputExpression = createMathExpression(input) @@ -181,20 +168,18 @@ class MathEquationInputIsEquivalentToRuleClassifierProviderTest { } @Test - @RunParameterized( - Iteration("y=1+(2+3)==y=(1+2)+3", "answer=y=1+(2+3)", "input=y=(1+2)+3"), - Iteration("y=x+(y+z)==y=(x+y)+z", "answer=y=x+(y+z)", "input=y=(x+y)+z"), - Iteration("x+(y+z)=1==(x+y)+z=1", "answer=x+(y+z)=1", "input=(x+y)+z=1"), - Iteration( - "(x+y)+z=1+(2+3)==x+(y+z)=(1+2)+3", "answer=(x+y)+z=1+(2+3)", "input=x+(y+z)=(1+2)+3" - ), - Iteration("y=2*(3*4)==y=(2*3)*4", "answer=y=2*(3*4)", "input=y=(2*3)*4"), - Iteration("y=2*(3x)==y=(2x)*3", "answer=y=2*(3x)", "input=y=(2x)*3"), - Iteration("y=x(yz)==y=(xy)z", "answer=y=x(yz)", "input=y=(xy)z"), - Iteration("x(yz)=2==(xy)z=2", "answer=x(yz)=2", "input=(xy)z=2"), - Iteration("2*(3y)=4==(2y)*3=4", "answer=2*(3y)=4", "input=(2y)*3=4"), - Iteration("x(yz)=(2*3)*4==(xy)z=2*(3*4)", "answer=x(yz)=(2*3)*4", "input=(xy)z=2*(3*4)") + @Iteration("y=1+(2+3)==y=(1+2)+3", "answer=y=1+(2+3)", "input=y=(1+2)+3") + @Iteration("y=x+(y+z)==y=(x+y)+z", "answer=y=x+(y+z)", "input=y=(x+y)+z") + @Iteration("x+(y+z)=1==(x+y)+z=1", "answer=x+(y+z)=1", "input=(x+y)+z=1") + @Iteration( + "(x+y)+z=1+(2+3)==x+(y+z)=(1+2)+3", "answer=(x+y)+z=1+(2+3)", "input=x+(y+z)=(1+2)+3" ) + @Iteration("y=2*(3*4)==y=(2*3)*4", "answer=y=2*(3*4)", "input=y=(2*3)*4") + @Iteration("y=2*(3x)==y=(2x)*3", "answer=y=2*(3x)", "input=y=(2x)*3") + @Iteration("y=x(yz)==y=(xy)z", "answer=y=x(yz)", "input=y=(xy)z") + @Iteration("x(yz)=2==(xy)z=2", "answer=x(yz)=2", "input=(xy)z=2") + @Iteration("2*(3y)=4==(2y)*3=4", "answer=2*(3y)=4", "input=(2y)*3=4") + @Iteration("x(yz)=(2*3)*4==(xy)z=2*(3*4)", "answer=x(yz)=(2*3)*4", "input=(xy)z=2*(3*4)") fun testMatches_operationsDiffer_byAssociativity_returnsTrue() { val answerExpression = createMathExpression(answer) val inputExpression = createMathExpression(input) @@ -206,18 +191,16 @@ class MathEquationInputIsEquivalentToRuleClassifierProviderTest { } @Test - @RunParameterized( - Iteration("y=3.14-1!=y=1-3.14", "answer=y=3.14-1", "input=y=1-3.14"), - Iteration("y=1-(2-3)!=y=(1-2)-3", "answer=y=1-(2-3)", "input=y=(1-2)-3"), - Iteration("y-1=3!=1-y=3", "answer=y-1=3", "input=1-y=3"), - Iteration("x-(y-z)=3!=(x-y)-z=3", "answer=x-(y-z)=3", "input=(x-y)-z=3"), - Iteration("y=3.14/x!=y=x/3.14", "answer=y=3.14/x", "input=y=x/3.14"), - Iteration("y/x=2!=x/y=2", "answer=y/x=2", "input=x/y=2"), - Iteration("y=3.14^2!=y=2^3.14", "answer=y=3.14^2", "input=y=2^3.14"), - Iteration("(3.14^2)y=2!=(2^3.14)y=2", "answer=(3.14^2)y=2", "input=(2^3.14)y=2"), - Iteration("y=x/(y/z)!=y=(x/y)/z", "answer=y=x/(y/z)", "input=y=(x/y)/z"), - Iteration("x/(y/z)=2!=(x/y)/z=2", "answer=x/(y/z)=2", "input=(x/y)/z=2") - ) + @Iteration("y=3.14-1!=y=1-3.14", "answer=y=3.14-1", "input=y=1-3.14") + @Iteration("y=1-(2-3)!=y=(1-2)-3", "answer=y=1-(2-3)", "input=y=(1-2)-3") + @Iteration("y-1=3!=1-y=3", "answer=y-1=3", "input=1-y=3") + @Iteration("x-(y-z)=3!=(x-y)-z=3", "answer=x-(y-z)=3", "input=(x-y)-z=3") + @Iteration("y=3.14/x!=y=x/3.14", "answer=y=3.14/x", "input=y=x/3.14") + @Iteration("y/x=2!=x/y=2", "answer=y/x=2", "input=x/y=2") + @Iteration("y=3.14^2!=y=2^3.14", "answer=y=3.14^2", "input=y=2^3.14") + @Iteration("(3.14^2)y=2!=(2^3.14)y=2", "answer=(3.14^2)y=2", "input=(2^3.14)y=2") + @Iteration("y=x/(y/z)!=y=(x/y)/z", "answer=y=x/(y/z)", "input=y=(x/y)/z") + @Iteration("x/(y/z)=2!=(x/y)/z=2", "answer=x/(y/z)=2", "input=(x/y)/z=2") fun testMatches_operationsDiffer_byNonCommutativeOrAssociativeReordering_returnsFalse() { val answerExpression = createMathExpression(answer) val inputExpression = createMathExpression(input) @@ -230,30 +213,28 @@ class MathEquationInputIsEquivalentToRuleClassifierProviderTest { } @Test - @RunParameterized( - Iteration("y=1-2==y=-(2-1)", "answer=y=1-2", "input=y=-(2-1)"), - Iteration("y=1+2==y=1+1+1", "answer=y=1+2", "input=y=1+1+1"), - Iteration("y=1+2==y=1-(-2)", "answer=y=1+2", "input=y=1-(-2)"), - Iteration("y=4-6==y=1-2-1", "answer=y=4-6", "input=y=1-2-1"), - Iteration("y=2*3*2*2==y=2*3*4", "answer=y=2*3*2*2", "input=y=2*3*4"), - Iteration("y=-6-2==y=2*-(3+1)", "answer=y=-6-2", "input=y=2*-(3+1)"), - Iteration("y=2/3/2/2==y=2/3/4", "answer=y=2/3/2/2", "input=y=2/3/4"), - Iteration("y=2^(2+1)==y=2^3", "answer=y=2^(2+1)", "input=y=2^3"), - Iteration("y=2^(-1)==y=1/2", "answer=y=2^(-1)", "input=y=1/2"), - Iteration("z=x-y==z=-(y-x)", "answer=z=x-y", "input=z=-(y-x)"), - Iteration("y=2+x==y=1+x+1", "answer=y=2+x", "input=y=1+x+1"), - Iteration("y=1+x==y=1-(-x)", "answer=y=1+x", "input=y=1-(-x)"), - Iteration("y=-x==y=1-x-1", "answer=y=-x", "input=y=1-x-1"), - Iteration("y=4x==y=2*2*x", "answer=y=4x", "input=y=2*2*x"), - Iteration("y=2-6x==y=2*(-3x+1)", "answer=y=2-6x", "input=y=2*(-3x+1)"), - Iteration("y=x/4==y=x/2/2", "answer=y=x/4", "input=y=x/2/2"), - Iteration("y=x^(2+1)==y=x^3", "answer=y=x^(2+1)", "input=y=x^3"), - Iteration("y=x*(2^(-1))==y=x/2", "answer=y=x*(2^(-1))", "input=y=x/2"), - Iteration("y+2=x==1+1+y=x", "answer=y+2=x", "input=1+1+y=x"), - Iteration("(2^2)y=x+2==4y=x+2", "answer=(2^2)y=x+2", "input=4y=x+2"), - Iteration("y^(4-2)=3x==y^2=3x", "answer=y^(4-2)=3x", "input=y^2=3x"), - Iteration("y/2/2=3x==y/4=3x", "answer=y/2/2=3x", "input=y/4=3x") - ) + @Iteration("y=1-2==y=-(2-1)", "answer=y=1-2", "input=y=-(2-1)") + @Iteration("y=1+2==y=1+1+1", "answer=y=1+2", "input=y=1+1+1") + @Iteration("y=1+2==y=1-(-2)", "answer=y=1+2", "input=y=1-(-2)") + @Iteration("y=4-6==y=1-2-1", "answer=y=4-6", "input=y=1-2-1") + @Iteration("y=2*3*2*2==y=2*3*4", "answer=y=2*3*2*2", "input=y=2*3*4") + @Iteration("y=-6-2==y=2*-(3+1)", "answer=y=-6-2", "input=y=2*-(3+1)") + @Iteration("y=2/3/2/2==y=2/3/4", "answer=y=2/3/2/2", "input=y=2/3/4") + @Iteration("y=2^(2+1)==y=2^3", "answer=y=2^(2+1)", "input=y=2^3") + @Iteration("y=2^(-1)==y=1/2", "answer=y=2^(-1)", "input=y=1/2") + @Iteration("z=x-y==z=-(y-x)", "answer=z=x-y", "input=z=-(y-x)") + @Iteration("y=2+x==y=1+x+1", "answer=y=2+x", "input=y=1+x+1") + @Iteration("y=1+x==y=1-(-x)", "answer=y=1+x", "input=y=1-(-x)") + @Iteration("y=-x==y=1-x-1", "answer=y=-x", "input=y=1-x-1") + @Iteration("y=4x==y=2*2*x", "answer=y=4x", "input=y=2*2*x") + @Iteration("y=2-6x==y=2*(-3x+1)", "answer=y=2-6x", "input=y=2*(-3x+1)") + @Iteration("y=x/4==y=x/2/2", "answer=y=x/4", "input=y=x/2/2") + @Iteration("y=x^(2+1)==y=x^3", "answer=y=x^(2+1)", "input=y=x^3") + @Iteration("y=x*(2^(-1))==y=x/2", "answer=y=x*(2^(-1))", "input=y=x/2") + @Iteration("y+2=x==1+1+y=x", "answer=y+2=x", "input=1+1+y=x") + @Iteration("(2^2)y=x+2==4y=x+2", "answer=(2^2)y=x+2", "input=4y=x+2") + @Iteration("y^(4-2)=3x==y^2=3x", "answer=y^(4-2)=3x", "input=y^2=3x") + @Iteration("y/2/2=3x==y/4=3x", "answer=y/2/2=3x", "input=y/4=3x") fun testMatches_operationsDiffer_byDistributionAndCombining_returnTrue() { val answerExpression = createMathExpression(answer) val inputExpression = createMathExpression(input) @@ -265,13 +246,11 @@ class MathEquationInputIsEquivalentToRuleClassifierProviderTest { } @Test - @RunParameterized( - Iteration("2+x=y==y=2+x", "answer=2+x=y", "input=y=2+x"), - Iteration("-3x^3=2y^2==2y^2=-3x^3", "answer=-3x^3=2y^2", "input=2y^2=-3x^3"), - Iteration("-4+x=2+y+1-1==2+y=x-4", "answer=-4+x=2+y+1-1", "input=2+y=x-4"), - Iteration("y=x-6==2+y=x-4", "answer=y=x-6", "input=2+y=x-4"), - Iteration("(1+1+1)*x=2*y/4==y/2=3x", "answer=(1+1+1)*x=2*y/4", "input=y/2=3x") - ) + @Iteration("2+x=y==y=2+x", "answer=2+x=y", "input=y=2+x") + @Iteration("-3x^3=2y^2==2y^2=-3x^3", "answer=-3x^3=2y^2", "input=2y^2=-3x^3") + @Iteration("-4+x=2+y+1-1==2+y=x-4", "answer=-4+x=2+y+1-1", "input=2+y=x-4") + @Iteration("y=x-6==2+y=x-4", "answer=y=x-6", "input=2+y=x-4") + @Iteration("(1+1+1)*x=2*y/4==y/2=3x", "answer=(1+1+1)*x=2*y/4", "input=y/2=3x") fun testMatches_sidesRearrangedAroundEqualsSign_returnsTrue() { val answerExpression = createMathExpression(answer) val inputExpression = createMathExpression(input) @@ -284,23 +263,21 @@ class MathEquationInputIsEquivalentToRuleClassifierProviderTest { } @Test - @RunParameterized( - Iteration("y = 3x^2 - 4==y = 3x^2 - 4", "answer=y = 3x^2 - 4", "input=y = 3x^2 - 4"), - Iteration("y = -4 + 3x^2==y = 3x^2 - 4", "answer=y = -4 + 3x^2", "input=y = 3x^2 - 4"), - Iteration("y = x^2*3 - 4==y = 3x^2 - 4", "answer=y = x^2*3 - 4", "input=y = 3x^2 - 4"), - Iteration("y+4=3x^2==y = 3x^2 - 4", "answer=y+4=3x^2", "input=y = 3x^2 - 4"), - Iteration("y-3x^2=-4==y = 3x^2 - 4", "answer=y-3x^2=-4", "input=y = 3x^2 - 4"), - Iteration("-4=y-3x^2==y = 3x^2 - 4", "answer=-4=y-3x^2", "input=y = 3x^2 - 4"), - Iteration("3x^2-y=4==y = 3x^2 - 4", "answer=3x^2-y=4", "input=y = 3x^2 - 4"), - Iteration("3x^2=4+y==y = 3x^2 - 4", "answer=3x^2=4+y", "input=y = 3x^2 - 4"), - Iteration("y-x^2=2x^2-4==y = 3x^2 - 4", "answer=y-x^2=2x^2-4", "input=y = 3x^2 - 4"), - Iteration("y=x*(2^(1/2))==y=sqrt(2)x", "answer=y=x*(2^(1/2))", "input=y=sqrt(2)x"), - Iteration("y − 3x^2 = -4==y = 3x^2 - 4", "answer=y − 3x^2 = -4", "input=y = 3x^2 - 4"), - Iteration("3x^2 - 4 = y==y = 3x^2 - 4", "answer=3x^2 - 4 = y", "input=y = 3x^2 - 4"), - Iteration("y − 3x^2 + 4 = 0==y = 3x^2 - 4", "answer=y − 3x^2 + 4 = 0", "input=y = 3x^2 - 4"), - Iteration("y = (3x^3 - 4x)/x==y = 3x^2 - 4", "answer=y = (3x^3 - 4x)/x", "input=y = 3x^2 - 4"), - Iteration("y^2/y = 3x^2 - 4==y = 3x^2 - 4", "answer=y^2/y = 3x^2 - 4", "input=y = 3x^2 - 4") - ) + @Iteration("y = 3x^2 - 4==y = 3x^2 - 4", "answer=y = 3x^2 - 4", "input=y = 3x^2 - 4") + @Iteration("y = -4 + 3x^2==y = 3x^2 - 4", "answer=y = -4 + 3x^2", "input=y = 3x^2 - 4") + @Iteration("y = x^2*3 - 4==y = 3x^2 - 4", "answer=y = x^2*3 - 4", "input=y = 3x^2 - 4") + @Iteration("y+4=3x^2==y = 3x^2 - 4", "answer=y+4=3x^2", "input=y = 3x^2 - 4") + @Iteration("y-3x^2=-4==y = 3x^2 - 4", "answer=y-3x^2=-4", "input=y = 3x^2 - 4") + @Iteration("-4=y-3x^2==y = 3x^2 - 4", "answer=-4=y-3x^2", "input=y = 3x^2 - 4") + @Iteration("3x^2-y=4==y = 3x^2 - 4", "answer=3x^2-y=4", "input=y = 3x^2 - 4") + @Iteration("3x^2=4+y==y = 3x^2 - 4", "answer=3x^2=4+y", "input=y = 3x^2 - 4") + @Iteration("y-x^2=2x^2-4==y = 3x^2 - 4", "answer=y-x^2=2x^2-4", "input=y = 3x^2 - 4") + @Iteration("y=x*(2^(1/2))==y=sqrt(2)x", "answer=y=x*(2^(1/2))", "input=y=sqrt(2)x") + @Iteration("y − 3x^2 = -4==y = 3x^2 - 4", "answer=y − 3x^2 = -4", "input=y = 3x^2 - 4") + @Iteration("3x^2 - 4 = y==y = 3x^2 - 4", "answer=3x^2 - 4 = y", "input=y = 3x^2 - 4") + @Iteration("y − 3x^2 + 4 = 0==y = 3x^2 - 4", "answer=y − 3x^2 + 4 = 0", "input=y = 3x^2 - 4") + @Iteration("y = (3x^3 - 4x)/x==y = 3x^2 - 4", "answer=y = (3x^3 - 4x)/x", "input=y = 3x^2 - 4") + @Iteration("y^2/y = 3x^2 - 4==y = 3x^2 - 4", "answer=y^2/y = 3x^2 - 4", "input=y = 3x^2 - 4") fun testMatches_assortedExpressions_withMatchingCharacteristics_returnsTrue() { val answerExpression = createMathExpression(answer) val inputExpression = createMathExpression(input) @@ -313,28 +290,26 @@ class MathEquationInputIsEquivalentToRuleClassifierProviderTest { } @Test - @RunParameterized( - Iteration("y = 3x^2 - 7!=y = 3x^2 - 4", "answer=y = 3x^2 - 7", "input=y = 3x^2 - 4"), - Iteration("x^2 = 3y - 4!=y = 3x^2 - 4", "answer=x^2 = 3y - 4", "input=y = 3x^2 - 4"), - Iteration("y/(3x^2 - 4) = 1!=y = 3x^2 - 4", "answer=y/(3x^2 - 4) = 1", "input=y = 3x^2 - 4"), - Iteration("y + 3x^2 - 4 = 0!=y = 3x^2 - 4", "answer=y + 3x^2 - 4 = 0", "input=y = 3x^2 - 4"), - Iteration("y^2 = 3x^2y - 4y!=y = 3x^2 - 4", "answer=y^2 = 3x^2y - 4y", "input=y = 3x^2 - 4"), - Iteration( - "y^2 * y^−1 = -12x^2!=y = 3x^2 - 4", "answer=y^2 * y^−1 = -12x^2", "input=y = 3x^2 - 4" - ), - Iteration("2 − 3 = -4!=y = 3x^2 - 4", "answer=2 − 3 = -4", "input=y = 3x^2 - 4"), - Iteration("y = 3x^2 + 4!=y = 3x^2 - 4", "answer=y = 3x^2 + 4", "input=y = 3x^2 - 4"), - Iteration("y - 4 = 3x^2!=y = 3x^2 - 4", "answer=y - 4 = 3x^2", "input=y = 3x^2 - 4"), - Iteration("y − 3x^2 - 4 = 0!=y = 3x^2 - 4", "answer=y − 3x^2 - 4 = 0", "input=y = 3x^2 - 4"), - Iteration("0 = y + 3x^2 - 4!=y = 3x^2 - 4", "answer=0 = y + 3x^2 - 4", "input=y = 3x^2 - 4"), - Iteration("2 = 0!=y = 3x^2 - 4", "answer=2 = 0", "input=y = 3x^2 - 4"), - Iteration("y=3x-4!=y = 3x^2 - 4", "answer=y=3x-4", "input=y = 3x^2 - 4"), - Iteration("y - x^2 = -4!=y = 3x^2 - 4", "answer=y - x^2 = -4", "input=y = 3x^2 - 4"), - Iteration("y/sqrt(2)=x!=y=sqrt(2)x", "answer=y/sqrt(2)=x", "input=y=sqrt(2)x"), - Iteration("y/4=x!=y=4x", "answer=y/4=x", "input=y=4x"), - Iteration("y/4=16x!=y=4x", "answer=y/4=16x", "input=y=4x"), - Iteration("xy=x^2!=y=x", "answer=xy=x^2", "input=y=x") + @Iteration("y = 3x^2 - 7!=y = 3x^2 - 4", "answer=y = 3x^2 - 7", "input=y = 3x^2 - 4") + @Iteration("x^2 = 3y - 4!=y = 3x^2 - 4", "answer=x^2 = 3y - 4", "input=y = 3x^2 - 4") + @Iteration("y/(3x^2 - 4) = 1!=y = 3x^2 - 4", "answer=y/(3x^2 - 4) = 1", "input=y = 3x^2 - 4") + @Iteration("y + 3x^2 - 4 = 0!=y = 3x^2 - 4", "answer=y + 3x^2 - 4 = 0", "input=y = 3x^2 - 4") + @Iteration("y^2 = 3x^2y - 4y!=y = 3x^2 - 4", "answer=y^2 = 3x^2y - 4y", "input=y = 3x^2 - 4") + @Iteration( + "y^2 * y^−1 = -12x^2!=y = 3x^2 - 4", "answer=y^2 * y^−1 = -12x^2", "input=y = 3x^2 - 4" ) + @Iteration("2 − 3 = -4!=y = 3x^2 - 4", "answer=2 − 3 = -4", "input=y = 3x^2 - 4") + @Iteration("y = 3x^2 + 4!=y = 3x^2 - 4", "answer=y = 3x^2 + 4", "input=y = 3x^2 - 4") + @Iteration("y - 4 = 3x^2!=y = 3x^2 - 4", "answer=y - 4 = 3x^2", "input=y = 3x^2 - 4") + @Iteration("y − 3x^2 - 4 = 0!=y = 3x^2 - 4", "answer=y − 3x^2 - 4 = 0", "input=y = 3x^2 - 4") + @Iteration("0 = y + 3x^2 - 4!=y = 3x^2 - 4", "answer=0 = y + 3x^2 - 4", "input=y = 3x^2 - 4") + @Iteration("2 = 0!=y = 3x^2 - 4", "answer=2 = 0", "input=y = 3x^2 - 4") + @Iteration("y=3x-4!=y = 3x^2 - 4", "answer=y=3x-4", "input=y = 3x^2 - 4") + @Iteration("y - x^2 = -4!=y = 3x^2 - 4", "answer=y - x^2 = -4", "input=y = 3x^2 - 4") + @Iteration("y/sqrt(2)=x!=y=sqrt(2)x", "answer=y/sqrt(2)=x", "input=y=sqrt(2)x") + @Iteration("y/4=x!=y=4x", "answer=y/4=x", "input=y=4x") + @Iteration("y/4=16x!=y=4x", "answer=y/4=16x", "input=y=4x") + @Iteration("xy=x^2!=y=x", "answer=xy=x^2", "input=y=x") fun testMatches_assortedExpressions_withoutMatchingCharacteristics_returnsFalse() { val answerExpression = createMathExpression(answer) val inputExpression = createMathExpression(input) diff --git a/domain/src/test/java/org/oppia/android/domain/classify/rules/mathequationinput/MathEquationInputMatchesExactlyWithRuleClassifierProviderTest.kt b/domain/src/test/java/org/oppia/android/domain/classify/rules/mathequationinput/MathEquationInputMatchesExactlyWithRuleClassifierProviderTest.kt index 7c8a7d596d1..22a7444050a 100644 --- a/domain/src/test/java/org/oppia/android/domain/classify/rules/mathequationinput/MathEquationInputMatchesExactlyWithRuleClassifierProviderTest.kt +++ b/domain/src/test/java/org/oppia/android/domain/classify/rules/mathequationinput/MathEquationInputMatchesExactlyWithRuleClassifierProviderTest.kt @@ -19,7 +19,6 @@ import org.oppia.android.domain.classify.RuleClassifier import org.oppia.android.testing.junit.OppiaParameterizedTestRunner import org.oppia.android.testing.junit.OppiaParameterizedTestRunner.Iteration import org.oppia.android.testing.junit.OppiaParameterizedTestRunner.Parameter -import org.oppia.android.testing.junit.OppiaParameterizedTestRunner.RunParameterized import org.oppia.android.testing.junit.OppiaParameterizedTestRunner.SelectRunnerPlatform import org.oppia.android.testing.junit.ParameterizedRobolectricTestRunner import org.oppia.android.testing.robolectric.RobolectricModule @@ -62,10 +61,8 @@ class MathEquationInputMatchesExactlyWithRuleClassifierProviderTest { } @Test - @RunParameterized( - Iteration("y=1!=y=1", "answer=y=1", "input=y=1"), - Iteration("1=y!=1=y", "answer=1=y", "input=1=y") - ) + @Iteration("y=1!=y=1", "answer=y=1", "input=y=1") + @Iteration("1=y!=1=y", "answer=1=y", "input=1=y") fun testMatches_answerHasDisallowedVariable_returnsFalse() { val answerExpression = createMathExpression(answer) val inputExpression = createMathExpression(input) @@ -79,15 +76,13 @@ class MathEquationInputMatchesExactlyWithRuleClassifierProviderTest { } @Test - @RunParameterized( - Iteration("0=1==0=1", "answer=0=1", "input=0=1"), - Iteration("y=0==y=0", "answer=y=0", "input=y=0"), - Iteration("y=1==y=1", "answer=y=1", "input=y=1"), - Iteration("0=y==0=y", "answer=0=y", "input=0=y"), - Iteration("1=y==1=y", "answer=1=y", "input=1=y"), - Iteration("y=x==y=x", "answer=y=x", "input=y=x"), - Iteration("x=y==x=y", "answer=x=y", "input=x=y") - ) + @Iteration("0=1==0=1", "answer=0=1", "input=0=1") + @Iteration("y=0==y=0", "answer=y=0", "input=y=0") + @Iteration("y=1==y=1", "answer=y=1", "input=y=1") + @Iteration("0=y==0=y", "answer=0=y", "input=0=y") + @Iteration("1=y==1=y", "answer=1=y", "input=1=y") + @Iteration("y=x==y=x", "answer=y=x", "input=y=x") + @Iteration("x=y==x=y", "answer=x=y", "input=x=y") fun testMatches_sameSingleTerms_returnsTrue() { val answerExpression = createMathExpression(answer) val inputExpression = createMathExpression(input) @@ -99,16 +94,14 @@ class MathEquationInputMatchesExactlyWithRuleClassifierProviderTest { } @Test - @RunParameterized( - Iteration("y=-x==y=-x", "answer=y=-x", "input=y=-x"), - Iteration("-y=x==-y=x", "answer=-y=x", "input=-y=x"), - Iteration("y=3.14+x==y=3.14+x", "answer=y=3.14+x", "input=y=3.14+x"), - Iteration("y=x+y+z==y=x+y+z", "answer=y=x+y+z", "input=y=x+y+z"), - Iteration("y=x/y/z==y=x/y/z", "answer=y=x/y/z", "input=y=x/y/z"), - Iteration("y=x/2/3==y=x/2/3", "answer=y=x/2/3", "input=y=x/2/3"), - Iteration("y=x^2==y=x^2", "answer=y=x^2", "input=y=x^2"), - Iteration("y=sqrt(x)==y=sqrt(x)", "answer=y=sqrt(x)", "input=y=sqrt(x)") - ) + @Iteration("y=-x==y=-x", "answer=y=-x", "input=y=-x") + @Iteration("-y=x==-y=x", "answer=-y=x", "input=-y=x") + @Iteration("y=3.14+x==y=3.14+x", "answer=y=3.14+x", "input=y=3.14+x") + @Iteration("y=x+y+z==y=x+y+z", "answer=y=x+y+z", "input=y=x+y+z") + @Iteration("y=x/y/z==y=x/y/z", "answer=y=x/y/z", "input=y=x/y/z") + @Iteration("y=x/2/3==y=x/2/3", "answer=y=x/2/3", "input=y=x/2/3") + @Iteration("y=x^2==y=x^2", "answer=y=x^2", "input=y=x^2") + @Iteration("y=sqrt(x)==y=sqrt(x)", "answer=y=sqrt(x)", "input=y=sqrt(x)") fun testMatches_sameSingleOperations_returnsTrue() { val answerExpression = createMathExpression(answer) val inputExpression = createMathExpression(input) @@ -120,17 +113,15 @@ class MathEquationInputMatchesExactlyWithRuleClassifierProviderTest { } @Test - @RunParameterized( - Iteration("y=1!=y=0", "answer=y=1", "input=y=0"), - Iteration("y=0!=y=1", "answer=y=0", "input=y=1"), - Iteration("y=3.14!=y=1", "answer=y=3.14", "input=y=1"), - Iteration("y=1!=y=3.14", "answer=y=1", "input=y=3.14"), - Iteration("y=x!=y=3.14", "answer=y=x", "input=y=3.14"), - Iteration("y=1!=y=x", "answer=y=1", "input=y=x"), - Iteration("y=3.14!=y=x", "answer=y=3.14", "input=y=x"), - Iteration("y=z!=y=x", "answer=y=z", "input=y=x"), - Iteration("y=x!=y=z", "answer=y=x", "input=y=z") - ) + @Iteration("y=1!=y=0", "answer=y=1", "input=y=0") + @Iteration("y=0!=y=1", "answer=y=0", "input=y=1") + @Iteration("y=3.14!=y=1", "answer=y=3.14", "input=y=1") + @Iteration("y=1!=y=3.14", "answer=y=1", "input=y=3.14") + @Iteration("y=x!=y=3.14", "answer=y=x", "input=y=3.14") + @Iteration("y=1!=y=x", "answer=y=1", "input=y=x") + @Iteration("y=3.14!=y=x", "answer=y=3.14", "input=y=x") + @Iteration("y=z!=y=x", "answer=y=z", "input=y=x") + @Iteration("y=x!=y=z", "answer=y=x", "input=y=z") fun testMatches_differentSingleTerms_returnsFalse() { val answerExpression = createMathExpression(answer) val inputExpression = createMathExpression(input) @@ -142,20 +133,18 @@ class MathEquationInputMatchesExactlyWithRuleClassifierProviderTest { } @Test - @RunParameterized( - Iteration("y=1+x!=y=x+1", "answer=y=1+x", "input=y=x+1"), - Iteration("y=z+x!=y=x+z", "answer=y=z+x", "input=y=x+z"), - Iteration("y+1=x!=1+y=x", "answer=y+1=x", "input=1+y=x"), - Iteration("y+z=x!=z+y=x", "answer=y+z=x", "input=z+y=x"), - Iteration("x+y=1+z!=y+x=z+1", "answer=x+y=1+z", "input=y+x=z+1"), - Iteration("y=-x+1!=y=1-x", "answer=y=-x+1", "input=y=1-x"), - Iteration("-y+x=z!=x-y=z", "answer=-y+x=z", "input=x-y=z"), - Iteration("y=x*2!=y=2x", "answer=y=x*2", "input=y=2x"), - Iteration("y*2=z!=2y=z", "answer=y*2=z", "input=2y=z"), - Iteration("y=3*2!=y=2*3", "answer=y=3*2", "input=y=2*3"), - Iteration("y=zx!=y=xz", "answer=y=zx", "input=y=xz"), - Iteration("yx=z!=xy=z", "answer=yx=z", "input=xy=z") - ) + @Iteration("y=1+x!=y=x+1", "answer=y=1+x", "input=y=x+1") + @Iteration("y=z+x!=y=x+z", "answer=y=z+x", "input=y=x+z") + @Iteration("y+1=x!=1+y=x", "answer=y+1=x", "input=1+y=x") + @Iteration("y+z=x!=z+y=x", "answer=y+z=x", "input=z+y=x") + @Iteration("x+y=1+z!=y+x=z+1", "answer=x+y=1+z", "input=y+x=z+1") + @Iteration("y=-x+1!=y=1-x", "answer=y=-x+1", "input=y=1-x") + @Iteration("-y+x=z!=x-y=z", "answer=-y+x=z", "input=x-y=z") + @Iteration("y=x*2!=y=2x", "answer=y=x*2", "input=y=2x") + @Iteration("y*2=z!=2y=z", "answer=y*2=z", "input=2y=z") + @Iteration("y=3*2!=y=2*3", "answer=y=3*2", "input=y=2*3") + @Iteration("y=zx!=y=xz", "answer=y=zx", "input=y=xz") + @Iteration("yx=z!=xy=z", "answer=yx=z", "input=xy=z") fun testMatches_operationsDiffer_byCommutativity_returnsFalse() { val answerExpression = createMathExpression(answer) val inputExpression = createMathExpression(input) @@ -167,20 +156,18 @@ class MathEquationInputMatchesExactlyWithRuleClassifierProviderTest { } @Test - @RunParameterized( - Iteration("y=1+(2+3)!=y=(1+2)+3", "answer=y=1+(2+3)", "input=y=(1+2)+3"), - Iteration("y=x+(y+z)!=y=(x+y)+z", "answer=y=x+(y+z)", "input=y=(x+y)+z"), - Iteration("x+(y+z)=1!=(x+y)+z=1", "answer=x+(y+z)=1", "input=(x+y)+z=1"), - Iteration( - "(x+y)+z=1+(2+3)!=x+(y+z)=(1+2)+3", "answer=(x+y)+z=1+(2+3)", "input=x+(y+z)=(1+2)+3" - ), - Iteration("y=2*(3*4)!=y=(2*3)*4", "answer=y=2*(3*4)", "input=y=(2*3)*4"), - Iteration("y=2*(3x)!=y=(2x)*3", "answer=y=2*(3x)", "input=y=(2x)*3"), - Iteration("y=x(yz)!=y=(xy)z", "answer=y=x(yz)", "input=y=(xy)z"), - Iteration("x(yz)=2!=(xy)z=2", "answer=x(yz)=2", "input=(xy)z=2"), - Iteration("2*(3y)=4!=(2y)*3=4", "answer=2*(3y)=4", "input=(2y)*3=4"), - Iteration("x(yz)=(2*3)*4!=(xy)z=2*(3*4)", "answer=x(yz)=(2*3)*4", "input=(xy)z=2*(3*4)") + @Iteration("y=1+(2+3)!=y=(1+2)+3", "answer=y=1+(2+3)", "input=y=(1+2)+3") + @Iteration("y=x+(y+z)!=y=(x+y)+z", "answer=y=x+(y+z)", "input=y=(x+y)+z") + @Iteration("x+(y+z)=1!=(x+y)+z=1", "answer=x+(y+z)=1", "input=(x+y)+z=1") + @Iteration( + "(x+y)+z=1+(2+3)!=x+(y+z)=(1+2)+3", "answer=(x+y)+z=1+(2+3)", "input=x+(y+z)=(1+2)+3" ) + @Iteration("y=2*(3*4)!=y=(2*3)*4", "answer=y=2*(3*4)", "input=y=(2*3)*4") + @Iteration("y=2*(3x)!=y=(2x)*3", "answer=y=2*(3x)", "input=y=(2x)*3") + @Iteration("y=x(yz)!=y=(xy)z", "answer=y=x(yz)", "input=y=(xy)z") + @Iteration("x(yz)=2!=(xy)z=2", "answer=x(yz)=2", "input=(xy)z=2") + @Iteration("2*(3y)=4!=(2y)*3=4", "answer=2*(3y)=4", "input=(2y)*3=4") + @Iteration("x(yz)=(2*3)*4!=(xy)z=2*(3*4)", "answer=x(yz)=(2*3)*4", "input=(xy)z=2*(3*4)") fun testMatches_operationsDiffer_byAssociativity_returnsFalse() { val answerExpression = createMathExpression(answer) val inputExpression = createMathExpression(input) @@ -192,18 +179,16 @@ class MathEquationInputMatchesExactlyWithRuleClassifierProviderTest { } @Test - @RunParameterized( - Iteration("y=3.14-1!=y=1-3.14", "answer=y=3.14-1", "input=y=1-3.14"), - Iteration("y=1-(2-3)!=y=(1-2)-3", "answer=y=1-(2-3)", "input=y=(1-2)-3"), - Iteration("y-1=3!=1-y=3", "answer=y-1=3", "input=1-y=3"), - Iteration("x-(y-z)=3!=(x-y)-z=3", "answer=x-(y-z)=3", "input=(x-y)-z=3"), - Iteration("y=3.14/x!=y=x/3.14", "answer=y=3.14/x", "input=y=x/3.14"), - Iteration("y/x=2!=x/y=2", "answer=y/x=2", "input=x/y=2"), - Iteration("y=3.14^2!=y=2^3.14", "answer=y=3.14^2", "input=y=2^3.14"), - Iteration("(3.14^2)y=2!=(2^3.14)y=2", "answer=(3.14^2)y=2", "input=(2^3.14)y=2"), - Iteration("y=x/(y/z)!=y=(x/y)/z", "answer=y=x/(y/z)", "input=y=(x/y)/z"), - Iteration("x/(y/z)=2!=(x/y)/z=2", "answer=x/(y/z)=2", "input=(x/y)/z=2") - ) + @Iteration("y=3.14-1!=y=1-3.14", "answer=y=3.14-1", "input=y=1-3.14") + @Iteration("y=1-(2-3)!=y=(1-2)-3", "answer=y=1-(2-3)", "input=y=(1-2)-3") + @Iteration("y-1=3!=1-y=3", "answer=y-1=3", "input=1-y=3") + @Iteration("x-(y-z)=3!=(x-y)-z=3", "answer=x-(y-z)=3", "input=(x-y)-z=3") + @Iteration("y=3.14/x!=y=x/3.14", "answer=y=3.14/x", "input=y=x/3.14") + @Iteration("y/x=2!=x/y=2", "answer=y/x=2", "input=x/y=2") + @Iteration("y=3.14^2!=y=2^3.14", "answer=y=3.14^2", "input=y=2^3.14") + @Iteration("(3.14^2)y=2!=(2^3.14)y=2", "answer=(3.14^2)y=2", "input=(2^3.14)y=2") + @Iteration("y=x/(y/z)!=y=(x/y)/z", "answer=y=x/(y/z)", "input=y=(x/y)/z") + @Iteration("x/(y/z)=2!=(x/y)/z=2", "answer=x/(y/z)=2", "input=(x/y)/z=2") fun testMatches_operationsDiffer_byNonCommutativeOrAssociativeReordering_returnsFalse() { val answerExpression = createMathExpression(answer) val inputExpression = createMathExpression(input) @@ -216,30 +201,28 @@ class MathEquationInputMatchesExactlyWithRuleClassifierProviderTest { } @Test - @RunParameterized( - Iteration("y=1-2!=y=-(2-1)", "answer=y=1-2", "input=y=-(2-1)"), - Iteration("y=1+2!=y=1+1+1", "answer=y=1+2", "input=y=1+1+1"), - Iteration("y=1+2!=y=1-(-2)", "answer=y=1+2", "input=y=1-(-2)"), - Iteration("y=4-6!=y=1-2-1", "answer=y=4-6", "input=y=1-2-1"), - Iteration("y=2*3*2*2!=y=2*3*4", "answer=y=2*3*2*2", "input=y=2*3*4"), - Iteration("y=-6-2!=y=2*-(3+1)", "answer=y=-6-2", "input=y=2*-(3+1)"), - Iteration("y=2/3/2/2!=y=2/3/4", "answer=y=2/3/2/2", "input=y=2/3/4"), - Iteration("y=2^(2+1)!=y=2^3", "answer=y=2^(2+1)", "input=y=2^3"), - Iteration("y=2^(-1)!=y=1/2", "answer=y=2^(-1)", "input=y=1/2"), - Iteration("z=x-y!=z=-(y-x)", "answer=z=x-y", "input=z=-(y-x)"), - Iteration("y=2+x!=y=1+x+1", "answer=y=2+x", "input=y=1+x+1"), - Iteration("y=1+x!=y=1-(-x)", "answer=y=1+x", "input=y=1-(-x)"), - Iteration("y=-x!=y=1-x-1", "answer=y=-x", "input=y=1-x-1"), - Iteration("y=4x!=y=2*2*x", "answer=y=4x", "input=y=2*2*x"), - Iteration("y=2-6x!=y=2*(-3x+1)", "answer=y=2-6x", "input=y=2*(-3x+1)"), - Iteration("y=x/4!=y=x/2/2", "answer=y=x/4", "input=y=x/2/2"), - Iteration("y=x^(2+1)!=y=x^3", "answer=y=x^(2+1)", "input=y=x^3"), - Iteration("y=x*(2^(-1))!=y=x/2", "answer=y=x*(2^(-1))", "input=y=x/2"), - Iteration("y+2=x!=1+1+y=x", "answer=y+2=x", "input=1+1+y=x"), - Iteration("(2^2)y=x+2!=4y=x+2", "answer=(2^2)y=x+2", "input=4y=x+2"), - Iteration("y^(4-2)=3x!=y^2=3x", "answer=y^(4-2)=3x", "input=y^2=3x"), - Iteration("y/2/2=3x!=y/4=3x", "answer=y/2/2=3x", "input=y/4=3x") - ) + @Iteration("y=1-2!=y=-(2-1)", "answer=y=1-2", "input=y=-(2-1)") + @Iteration("y=1+2!=y=1+1+1", "answer=y=1+2", "input=y=1+1+1") + @Iteration("y=1+2!=y=1-(-2)", "answer=y=1+2", "input=y=1-(-2)") + @Iteration("y=4-6!=y=1-2-1", "answer=y=4-6", "input=y=1-2-1") + @Iteration("y=2*3*2*2!=y=2*3*4", "answer=y=2*3*2*2", "input=y=2*3*4") + @Iteration("y=-6-2!=y=2*-(3+1)", "answer=y=-6-2", "input=y=2*-(3+1)") + @Iteration("y=2/3/2/2!=y=2/3/4", "answer=y=2/3/2/2", "input=y=2/3/4") + @Iteration("y=2^(2+1)!=y=2^3", "answer=y=2^(2+1)", "input=y=2^3") + @Iteration("y=2^(-1)!=y=1/2", "answer=y=2^(-1)", "input=y=1/2") + @Iteration("z=x-y!=z=-(y-x)", "answer=z=x-y", "input=z=-(y-x)") + @Iteration("y=2+x!=y=1+x+1", "answer=y=2+x", "input=y=1+x+1") + @Iteration("y=1+x!=y=1-(-x)", "answer=y=1+x", "input=y=1-(-x)") + @Iteration("y=-x!=y=1-x-1", "answer=y=-x", "input=y=1-x-1") + @Iteration("y=4x!=y=2*2*x", "answer=y=4x", "input=y=2*2*x") + @Iteration("y=2-6x!=y=2*(-3x+1)", "answer=y=2-6x", "input=y=2*(-3x+1)") + @Iteration("y=x/4!=y=x/2/2", "answer=y=x/4", "input=y=x/2/2") + @Iteration("y=x^(2+1)!=y=x^3", "answer=y=x^(2+1)", "input=y=x^3") + @Iteration("y=x*(2^(-1))!=y=x/2", "answer=y=x*(2^(-1))", "input=y=x/2") + @Iteration("y+2=x!=1+1+y=x", "answer=y+2=x", "input=1+1+y=x") + @Iteration("(2^2)y=x+2!=4y=x+2", "answer=(2^2)y=x+2", "input=4y=x+2") + @Iteration("y^(4-2)=3x!=y^2=3x", "answer=y^(4-2)=3x", "input=y^2=3x") + @Iteration("y/2/2=3x!=y/4=3x", "answer=y/2/2=3x", "input=y/4=3x") fun testMatches_operationsDiffer_byDistributionAndCombining_returnsFalse() { val answerExpression = createMathExpression(answer) val inputExpression = createMathExpression(input) @@ -251,13 +234,11 @@ class MathEquationInputMatchesExactlyWithRuleClassifierProviderTest { } @Test - @RunParameterized( - Iteration("2+x=y!=y=2+x", "answer=2+x=y", "input=y=2+x"), - Iteration("-3x^3=2y^2!=2y^2=-3x^3", "answer=-3x^3=2y^2", "input=2y^2=-3x^3"), - Iteration("-4+x=2+y+1-1!=2+y=x-4", "answer=-4+x=2+y+1-1", "input=2+y=x-4"), - Iteration("y=x-6!=2+y=x-4", "answer=y=x-6", "input=2+y=x-4"), - Iteration("(1+1+1)*x=2*y/4!=y/2=3x", "answer=(1+1+1)*x=2*y/4", "input=y/2=3x") - ) + @Iteration("2+x=y!=y=2+x", "answer=2+x=y", "input=y=2+x") + @Iteration("-3x^3=2y^2!=2y^2=-3x^3", "answer=-3x^3=2y^2", "input=2y^2=-3x^3") + @Iteration("-4+x=2+y+1-1!=2+y=x-4", "answer=-4+x=2+y+1-1", "input=2+y=x-4") + @Iteration("y=x-6!=2+y=x-4", "answer=y=x-6", "input=2+y=x-4") + @Iteration("(1+1+1)*x=2*y/4!=y/2=3x", "answer=(1+1+1)*x=2*y/4", "input=y/2=3x") fun testMatches_sidesRearrangedAroundEqualsSign_returnsFalse() { val answerExpression = createMathExpression(answer) val inputExpression = createMathExpression(input) @@ -269,9 +250,7 @@ class MathEquationInputMatchesExactlyWithRuleClassifierProviderTest { } @Test - @RunParameterized( - Iteration("y = 3x^2 - 4==y = 3x^2 - 4", "answer=y = 3x^2 - 4", "input=y = 3x^2 - 4") - ) + @Iteration("y = 3x^2 - 4==y = 3x^2 - 4", "answer=y = 3x^2 - 4", "input=y = 3x^2 - 4") fun testMatches_assortedExpressions_withMatchingCharacteristics_returnsTrue() { val answerExpression = createMathExpression(answer) val inputExpression = createMathExpression(input) @@ -284,42 +263,40 @@ class MathEquationInputMatchesExactlyWithRuleClassifierProviderTest { } @Test - @RunParameterized( - Iteration("y = -4 + 3x^2!=y = 3x^2 - 4", "answer=y = -4 + 3x^2", "input=y = 3x^2 - 4"), - Iteration("y = x^2*3 - 4!=y = 3x^2 - 4", "answer=y = x^2*3 - 4", "input=y = 3x^2 - 4"), - Iteration("y+4=3x^2!=y = 3x^2 - 4", "answer=y+4=3x^2", "input=y = 3x^2 - 4"), - Iteration("y-3x^2=-4!=y = 3x^2 - 4", "answer=y-3x^2=-4", "input=y = 3x^2 - 4"), - Iteration("-4=y-3x^2!=y = 3x^2 - 4", "answer=-4=y-3x^2", "input=y = 3x^2 - 4"), - Iteration("3x^2-y=4!=y = 3x^2 - 4", "answer=3x^2-y=4", "input=y = 3x^2 - 4"), - Iteration("3x^2=4+y!=y = 3x^2 - 4", "answer=3x^2=4+y", "input=y = 3x^2 - 4"), - Iteration("y-x^2=2x^2-4!=y = 3x^2 - 4", "answer=y-x^2=2x^2-4", "input=y = 3x^2 - 4"), - Iteration("y=x*(2^(1/2))!=y=sqrt(2)x", "answer=y=x*(2^(1/2))", "input=y=sqrt(2)x"), - Iteration("y − 3x^2 = -4!=y = 3x^2 - 4", "answer=y − 3x^2 = -4", "input=y = 3x^2 - 4"), - Iteration("3x^2 - 4 = y!=y = 3x^2 - 4", "answer=3x^2 - 4 = y", "input=y = 3x^2 - 4"), - Iteration("y = 3x^2 - 7!=y = 3x^2 - 4", "answer=y = 3x^2 - 7", "input=y = 3x^2 - 4"), - Iteration("x^2 = 3y - 4!=y = 3x^2 - 4", "answer=x^2 = 3y - 4", "input=y = 3x^2 - 4"), - Iteration("y/(3x^2 - 4) = 1!=y = 3x^2 - 4", "answer=y/(3x^2 - 4) = 1", "input=y = 3x^2 - 4"), - Iteration("y + 3x^2 - 4 = 0!=y = 3x^2 - 4", "answer=y + 3x^2 - 4 = 0", "input=y = 3x^2 - 4"), - Iteration("y − 3x^2 + 4 = 0!=y = 3x^2 - 4", "answer=y − 3x^2 + 4 = 0", "input=y = 3x^2 - 4"), - Iteration("y^2 = 3x^2y - 4y!=y = 3x^2 - 4", "answer=y^2 = 3x^2y - 4y", "input=y = 3x^2 - 4"), - Iteration("y = (3x^3 - 4x)/x!=y = 3x^2 - 4", "answer=y = (3x^3 - 4x)/x", "input=y = 3x^2 - 4"), - Iteration( - "y^2 * y^−1 = -12x^2!=y = 3x^2 - 4", "answer=y^2 * y^−1 = -12x^2", "input=y = 3x^2 - 4" - ), - Iteration("y^2/y = 3x^2 - 4!=y = 3x^2 - 4", "answer=y^2/y = 3x^2 - 4", "input=y = 3x^2 - 4"), - Iteration("2 − 3 = -4!=y = 3x^2 - 4", "answer=2 − 3 = -4", "input=y = 3x^2 - 4"), - Iteration("y = 3x^2 + 4!=y = 3x^2 - 4", "answer=y = 3x^2 + 4", "input=y = 3x^2 - 4"), - Iteration("y - 4 = 3x^2!=y = 3x^2 - 4", "answer=y - 4 = 3x^2", "input=y = 3x^2 - 4"), - Iteration("y − 3x^2 - 4 = 0!=y = 3x^2 - 4", "answer=y − 3x^2 - 4 = 0", "input=y = 3x^2 - 4"), - Iteration("0 = y + 3x^2 - 4!=y = 3x^2 - 4", "answer=0 = y + 3x^2 - 4", "input=y = 3x^2 - 4"), - Iteration("2 = 0!=y = 3x^2 - 4", "answer=2 = 0", "input=y = 3x^2 - 4"), - Iteration("y - x^2 = -4!=y = 3x^2 - 4", "answer=y - x^2 = -4", "input=y = 3x^2 - 4"), - Iteration("y=3x-4!=y = 3x^2 - 4", "answer=y=3x-4", "input=y = 3x^2 - 4"), - Iteration("y/sqrt(2)=x!=y=sqrt(2)x", "answer=y/sqrt(2)=x", "input=y=sqrt(2)x"), - Iteration("y/4=x!=y=4x", "answer=y/4=x", "input=y=4x"), - Iteration("y/4=16x!=y=4x", "answer=y/4=16x", "input=y=4x"), - Iteration("xy=x^2!=y=x", "answer=xy=x^2", "input=y=x") + @Iteration("y = -4 + 3x^2!=y = 3x^2 - 4", "answer=y = -4 + 3x^2", "input=y = 3x^2 - 4") + @Iteration("y = x^2*3 - 4!=y = 3x^2 - 4", "answer=y = x^2*3 - 4", "input=y = 3x^2 - 4") + @Iteration("y+4=3x^2!=y = 3x^2 - 4", "answer=y+4=3x^2", "input=y = 3x^2 - 4") + @Iteration("y-3x^2=-4!=y = 3x^2 - 4", "answer=y-3x^2=-4", "input=y = 3x^2 - 4") + @Iteration("-4=y-3x^2!=y = 3x^2 - 4", "answer=-4=y-3x^2", "input=y = 3x^2 - 4") + @Iteration("3x^2-y=4!=y = 3x^2 - 4", "answer=3x^2-y=4", "input=y = 3x^2 - 4") + @Iteration("3x^2=4+y!=y = 3x^2 - 4", "answer=3x^2=4+y", "input=y = 3x^2 - 4") + @Iteration("y-x^2=2x^2-4!=y = 3x^2 - 4", "answer=y-x^2=2x^2-4", "input=y = 3x^2 - 4") + @Iteration("y=x*(2^(1/2))!=y=sqrt(2)x", "answer=y=x*(2^(1/2))", "input=y=sqrt(2)x") + @Iteration("y − 3x^2 = -4!=y = 3x^2 - 4", "answer=y − 3x^2 = -4", "input=y = 3x^2 - 4") + @Iteration("3x^2 - 4 = y!=y = 3x^2 - 4", "answer=3x^2 - 4 = y", "input=y = 3x^2 - 4") + @Iteration("y = 3x^2 - 7!=y = 3x^2 - 4", "answer=y = 3x^2 - 7", "input=y = 3x^2 - 4") + @Iteration("x^2 = 3y - 4!=y = 3x^2 - 4", "answer=x^2 = 3y - 4", "input=y = 3x^2 - 4") + @Iteration("y/(3x^2 - 4) = 1!=y = 3x^2 - 4", "answer=y/(3x^2 - 4) = 1", "input=y = 3x^2 - 4") + @Iteration("y + 3x^2 - 4 = 0!=y = 3x^2 - 4", "answer=y + 3x^2 - 4 = 0", "input=y = 3x^2 - 4") + @Iteration("y − 3x^2 + 4 = 0!=y = 3x^2 - 4", "answer=y − 3x^2 + 4 = 0", "input=y = 3x^2 - 4") + @Iteration("y^2 = 3x^2y - 4y!=y = 3x^2 - 4", "answer=y^2 = 3x^2y - 4y", "input=y = 3x^2 - 4") + @Iteration("y = (3x^3 - 4x)/x!=y = 3x^2 - 4", "answer=y = (3x^3 - 4x)/x", "input=y = 3x^2 - 4") + @Iteration( + "y^2 * y^−1 = -12x^2!=y = 3x^2 - 4", "answer=y^2 * y^−1 = -12x^2", "input=y = 3x^2 - 4" ) + @Iteration("y^2/y = 3x^2 - 4!=y = 3x^2 - 4", "answer=y^2/y = 3x^2 - 4", "input=y = 3x^2 - 4") + @Iteration("2 − 3 = -4!=y = 3x^2 - 4", "answer=2 − 3 = -4", "input=y = 3x^2 - 4") + @Iteration("y = 3x^2 + 4!=y = 3x^2 - 4", "answer=y = 3x^2 + 4", "input=y = 3x^2 - 4") + @Iteration("y - 4 = 3x^2!=y = 3x^2 - 4", "answer=y - 4 = 3x^2", "input=y = 3x^2 - 4") + @Iteration("y − 3x^2 - 4 = 0!=y = 3x^2 - 4", "answer=y − 3x^2 - 4 = 0", "input=y = 3x^2 - 4") + @Iteration("0 = y + 3x^2 - 4!=y = 3x^2 - 4", "answer=0 = y + 3x^2 - 4", "input=y = 3x^2 - 4") + @Iteration("2 = 0!=y = 3x^2 - 4", "answer=2 = 0", "input=y = 3x^2 - 4") + @Iteration("y - x^2 = -4!=y = 3x^2 - 4", "answer=y - x^2 = -4", "input=y = 3x^2 - 4") + @Iteration("y=3x-4!=y = 3x^2 - 4", "answer=y=3x-4", "input=y = 3x^2 - 4") + @Iteration("y/sqrt(2)=x!=y=sqrt(2)x", "answer=y/sqrt(2)=x", "input=y=sqrt(2)x") + @Iteration("y/4=x!=y=4x", "answer=y/4=x", "input=y=4x") + @Iteration("y/4=16x!=y=4x", "answer=y/4=16x", "input=y=4x") + @Iteration("xy=x^2!=y=x", "answer=xy=x^2", "input=y=x") fun testMatches_assortedExpressions_withoutMatchingCharacteristics_returnsFalse() { val answerExpression = createMathExpression(answer) val inputExpression = createMathExpression(input) diff --git a/domain/src/test/java/org/oppia/android/domain/classify/rules/mathequationinput/MathEquationInputMatchesUpToTrivialManipulationsRuleClassifierProviderTest.kt b/domain/src/test/java/org/oppia/android/domain/classify/rules/mathequationinput/MathEquationInputMatchesUpToTrivialManipulationsRuleClassifierProviderTest.kt index 9af344ecb91..9a3d9d24c05 100644 --- a/domain/src/test/java/org/oppia/android/domain/classify/rules/mathequationinput/MathEquationInputMatchesUpToTrivialManipulationsRuleClassifierProviderTest.kt +++ b/domain/src/test/java/org/oppia/android/domain/classify/rules/mathequationinput/MathEquationInputMatchesUpToTrivialManipulationsRuleClassifierProviderTest.kt @@ -19,7 +19,6 @@ import org.oppia.android.domain.classify.RuleClassifier import org.oppia.android.testing.junit.OppiaParameterizedTestRunner import org.oppia.android.testing.junit.OppiaParameterizedTestRunner.Iteration import org.oppia.android.testing.junit.OppiaParameterizedTestRunner.Parameter -import org.oppia.android.testing.junit.OppiaParameterizedTestRunner.RunParameterized import org.oppia.android.testing.junit.OppiaParameterizedTestRunner.SelectRunnerPlatform import org.oppia.android.testing.junit.ParameterizedRobolectricTestRunner import org.oppia.android.testing.robolectric.RobolectricModule @@ -63,10 +62,8 @@ class MathEquationInputMatchesUpToTrivialManipulationsRuleClassifierProviderTest } @Test - @RunParameterized( - Iteration("y=1!=y=1", "answer=y=1", "input=y=1"), - Iteration("1=y!=1=y", "answer=1=y", "input=1=y") - ) + @Iteration("y=1!=y=1", "answer=y=1", "input=y=1") + @Iteration("1=y!=1=y", "answer=1=y", "input=1=y") fun testMatches_answerHasDisallowedVariable_returnsFalse() { val answerExpression = createMathExpression(answer) val inputExpression = createMathExpression(input) @@ -80,15 +77,13 @@ class MathEquationInputMatchesUpToTrivialManipulationsRuleClassifierProviderTest } @Test - @RunParameterized( - Iteration("0=1==0=1", "answer=0=1", "input=0=1"), - Iteration("y=0==y=0", "answer=y=0", "input=y=0"), - Iteration("y=1==y=1", "answer=y=1", "input=y=1"), - Iteration("0=y==0=y", "answer=0=y", "input=0=y"), - Iteration("1=y==1=y", "answer=1=y", "input=1=y"), - Iteration("y=x==y=x", "answer=y=x", "input=y=x"), - Iteration("x=y==x=y", "answer=x=y", "input=x=y") - ) + @Iteration("0=1==0=1", "answer=0=1", "input=0=1") + @Iteration("y=0==y=0", "answer=y=0", "input=y=0") + @Iteration("y=1==y=1", "answer=y=1", "input=y=1") + @Iteration("0=y==0=y", "answer=0=y", "input=0=y") + @Iteration("1=y==1=y", "answer=1=y", "input=1=y") + @Iteration("y=x==y=x", "answer=y=x", "input=y=x") + @Iteration("x=y==x=y", "answer=x=y", "input=x=y") fun testMatches_sameSingleTerms_returnsTrue() { val answerExpression = createMathExpression(answer) val inputExpression = createMathExpression(input) @@ -100,16 +95,14 @@ class MathEquationInputMatchesUpToTrivialManipulationsRuleClassifierProviderTest } @Test - @RunParameterized( - Iteration("y=-x==y=-x", "answer=y=-x", "input=y=-x"), - Iteration("-y=x==-y=x", "answer=-y=x", "input=-y=x"), - Iteration("y=3.14+x==y=3.14+x", "answer=y=3.14+x", "input=y=3.14+x"), - Iteration("y=x+y+z==y=x+y+z", "answer=y=x+y+z", "input=y=x+y+z"), - Iteration("y=x/y/z==y=x/y/z", "answer=y=x/y/z", "input=y=x/y/z"), - Iteration("y=x/2/3==y=x/2/3", "answer=y=x/2/3", "input=y=x/2/3"), - Iteration("y=x^2==y=x^2", "answer=y=x^2", "input=y=x^2"), - Iteration("y=sqrt(x)==y=sqrt(x)", "answer=y=sqrt(x)", "input=y=sqrt(x)") - ) + @Iteration("y=-x==y=-x", "answer=y=-x", "input=y=-x") + @Iteration("-y=x==-y=x", "answer=-y=x", "input=-y=x") + @Iteration("y=3.14+x==y=3.14+x", "answer=y=3.14+x", "input=y=3.14+x") + @Iteration("y=x+y+z==y=x+y+z", "answer=y=x+y+z", "input=y=x+y+z") + @Iteration("y=x/y/z==y=x/y/z", "answer=y=x/y/z", "input=y=x/y/z") + @Iteration("y=x/2/3==y=x/2/3", "answer=y=x/2/3", "input=y=x/2/3") + @Iteration("y=x^2==y=x^2", "answer=y=x^2", "input=y=x^2") + @Iteration("y=sqrt(x)==y=sqrt(x)", "answer=y=sqrt(x)", "input=y=sqrt(x)") fun testMatches_sameSingleOperations_returnsTrue() { val answerExpression = createMathExpression(answer) val inputExpression = createMathExpression(input) @@ -121,17 +114,15 @@ class MathEquationInputMatchesUpToTrivialManipulationsRuleClassifierProviderTest } @Test - @RunParameterized( - Iteration("y=1!=y=0", "answer=y=1", "input=y=0"), - Iteration("y=0!=y=1", "answer=y=0", "input=y=1"), - Iteration("y=3.14!=y=1", "answer=y=3.14", "input=y=1"), - Iteration("y=1!=y=3.14", "answer=y=1", "input=y=3.14"), - Iteration("y=x!=y=3.14", "answer=y=x", "input=y=3.14"), - Iteration("y=1!=y=x", "answer=y=1", "input=y=x"), - Iteration("y=3.14!=y=x", "answer=y=3.14", "input=y=x"), - Iteration("y=z!=y=x", "answer=y=z", "input=y=x"), - Iteration("y=x!=y=z", "answer=y=x", "input=y=z") - ) + @Iteration("y=1!=y=0", "answer=y=1", "input=y=0") + @Iteration("y=0!=y=1", "answer=y=0", "input=y=1") + @Iteration("y=3.14!=y=1", "answer=y=3.14", "input=y=1") + @Iteration("y=1!=y=3.14", "answer=y=1", "input=y=3.14") + @Iteration("y=x!=y=3.14", "answer=y=x", "input=y=3.14") + @Iteration("y=1!=y=x", "answer=y=1", "input=y=x") + @Iteration("y=3.14!=y=x", "answer=y=3.14", "input=y=x") + @Iteration("y=z!=y=x", "answer=y=z", "input=y=x") + @Iteration("y=x!=y=z", "answer=y=x", "input=y=z") fun testMatches_differentSingleTerms_returnsFalse() { val answerExpression = createMathExpression(answer) val inputExpression = createMathExpression(input) @@ -144,20 +135,18 @@ class MathEquationInputMatchesUpToTrivialManipulationsRuleClassifierProviderTest } @Test - @RunParameterized( - Iteration("y=1+x==y=x+1", "answer=y=1+x", "input=y=x+1"), - Iteration("y=z+x==y=x+z", "answer=y=z+x", "input=y=x+z"), - Iteration("y+1=x==1+y=x", "answer=y+1=x", "input=1+y=x"), - Iteration("y+z=x==z+y=x", "answer=y+z=x", "input=z+y=x"), - Iteration("x+y=1+z==y+x=z+1", "answer=x+y=1+z", "input=y+x=z+1"), - Iteration("y=-x+1==y=1-x", "answer=y=-x+1", "input=y=1-x"), - Iteration("-y+x=z==x-y=z", "answer=-y+x=z", "input=x-y=z"), - Iteration("y=x*2==y=2x", "answer=y=x*2", "input=y=2x"), - Iteration("y*2=z==2y=z", "answer=y*2=z", "input=2y=z"), - Iteration("y=3*2==y=2*3", "answer=y=3*2", "input=y=2*3"), - Iteration("y=zx==y=xz", "answer=y=zx", "input=y=xz"), - Iteration("yx=z==xy=z", "answer=yx=z", "input=xy=z") - ) + @Iteration("y=1+x==y=x+1", "answer=y=1+x", "input=y=x+1") + @Iteration("y=z+x==y=x+z", "answer=y=z+x", "input=y=x+z") + @Iteration("y+1=x==1+y=x", "answer=y+1=x", "input=1+y=x") + @Iteration("y+z=x==z+y=x", "answer=y+z=x", "input=z+y=x") + @Iteration("x+y=1+z==y+x=z+1", "answer=x+y=1+z", "input=y+x=z+1") + @Iteration("y=-x+1==y=1-x", "answer=y=-x+1", "input=y=1-x") + @Iteration("-y+x=z==x-y=z", "answer=-y+x=z", "input=x-y=z") + @Iteration("y=x*2==y=2x", "answer=y=x*2", "input=y=2x") + @Iteration("y*2=z==2y=z", "answer=y*2=z", "input=2y=z") + @Iteration("y=3*2==y=2*3", "answer=y=3*2", "input=y=2*3") + @Iteration("y=zx==y=xz", "answer=y=zx", "input=y=xz") + @Iteration("yx=z==xy=z", "answer=yx=z", "input=xy=z") fun testMatches_operationsDiffer_byCommutativity_returnsTrue() { val answerExpression = createMathExpression(answer) val inputExpression = createMathExpression(input) @@ -169,20 +158,18 @@ class MathEquationInputMatchesUpToTrivialManipulationsRuleClassifierProviderTest } @Test - @RunParameterized( - Iteration("y=1+(2+3)==y=(1+2)+3", "answer=y=1+(2+3)", "input=y=(1+2)+3"), - Iteration("y=x+(y+z)==y=(x+y)+z", "answer=y=x+(y+z)", "input=y=(x+y)+z"), - Iteration("x+(y+z)=1==(x+y)+z=1", "answer=x+(y+z)=1", "input=(x+y)+z=1"), - Iteration( - "(x+y)+z=1+(2+3)==x+(y+z)=(1+2)+3", "answer=(x+y)+z=1+(2+3)", "input=x+(y+z)=(1+2)+3" - ), - Iteration("y=2*(3*4)==y=(2*3)*4", "answer=y=2*(3*4)", "input=y=(2*3)*4"), - Iteration("y=2*(3x)==y=(2x)*3", "answer=y=2*(3x)", "input=y=(2x)*3"), - Iteration("y=x(yz)==y=(xy)z", "answer=y=x(yz)", "input=y=(xy)z"), - Iteration("x(yz)=2==(xy)z=2", "answer=x(yz)=2", "input=(xy)z=2"), - Iteration("2*(3y)=4==(2y)*3=4", "answer=2*(3y)=4", "input=(2y)*3=4"), - Iteration("x(yz)=(2*3)*4==(xy)z=2*(3*4)", "answer=x(yz)=(2*3)*4", "input=(xy)z=2*(3*4)") + @Iteration("y=1+(2+3)==y=(1+2)+3", "answer=y=1+(2+3)", "input=y=(1+2)+3") + @Iteration("y=x+(y+z)==y=(x+y)+z", "answer=y=x+(y+z)", "input=y=(x+y)+z") + @Iteration("x+(y+z)=1==(x+y)+z=1", "answer=x+(y+z)=1", "input=(x+y)+z=1") + @Iteration( + "(x+y)+z=1+(2+3)==x+(y+z)=(1+2)+3", "answer=(x+y)+z=1+(2+3)", "input=x+(y+z)=(1+2)+3" ) + @Iteration("y=2*(3*4)==y=(2*3)*4", "answer=y=2*(3*4)", "input=y=(2*3)*4") + @Iteration("y=2*(3x)==y=(2x)*3", "answer=y=2*(3x)", "input=y=(2x)*3") + @Iteration("y=x(yz)==y=(xy)z", "answer=y=x(yz)", "input=y=(xy)z") + @Iteration("x(yz)=2==(xy)z=2", "answer=x(yz)=2", "input=(xy)z=2") + @Iteration("2*(3y)=4==(2y)*3=4", "answer=2*(3y)=4", "input=(2y)*3=4") + @Iteration("x(yz)=(2*3)*4==(xy)z=2*(3*4)", "answer=x(yz)=(2*3)*4", "input=(xy)z=2*(3*4)") fun testMatches_operationsDiffer_byAssociativity_returnsTrue() { val answerExpression = createMathExpression(answer) val inputExpression = createMathExpression(input) @@ -194,18 +181,16 @@ class MathEquationInputMatchesUpToTrivialManipulationsRuleClassifierProviderTest } @Test - @RunParameterized( - Iteration("y=3.14-1!=y=1-3.14", "answer=y=3.14-1", "input=y=1-3.14"), - Iteration("y=1-(2-3)!=y=(1-2)-3", "answer=y=1-(2-3)", "input=y=(1-2)-3"), - Iteration("y-1=3!=1-y=3", "answer=y-1=3", "input=1-y=3"), - Iteration("x-(y-z)=3!=(x-y)-z=3", "answer=x-(y-z)=3", "input=(x-y)-z=3"), - Iteration("y=3.14/x!=y=x/3.14", "answer=y=3.14/x", "input=y=x/3.14"), - Iteration("y/x=2!=x/y=2", "answer=y/x=2", "input=x/y=2"), - Iteration("y=3.14^2!=y=2^3.14", "answer=y=3.14^2", "input=y=2^3.14"), - Iteration("(3.14^2)y=2!=(2^3.14)y=2", "answer=(3.14^2)y=2", "input=(2^3.14)y=2"), - Iteration("y=x/(y/z)!=y=(x/y)/z", "answer=y=x/(y/z)", "input=y=(x/y)/z"), - Iteration("x/(y/z)=2!=(x/y)/z=2", "answer=x/(y/z)=2", "input=(x/y)/z=2") - ) + @Iteration("y=3.14-1!=y=1-3.14", "answer=y=3.14-1", "input=y=1-3.14") + @Iteration("y=1-(2-3)!=y=(1-2)-3", "answer=y=1-(2-3)", "input=y=(1-2)-3") + @Iteration("y-1=3!=1-y=3", "answer=y-1=3", "input=1-y=3") + @Iteration("x-(y-z)=3!=(x-y)-z=3", "answer=x-(y-z)=3", "input=(x-y)-z=3") + @Iteration("y=3.14/x!=y=x/3.14", "answer=y=3.14/x", "input=y=x/3.14") + @Iteration("y/x=2!=x/y=2", "answer=y/x=2", "input=x/y=2") + @Iteration("y=3.14^2!=y=2^3.14", "answer=y=3.14^2", "input=y=2^3.14") + @Iteration("(3.14^2)y=2!=(2^3.14)y=2", "answer=(3.14^2)y=2", "input=(2^3.14)y=2") + @Iteration("y=x/(y/z)!=y=(x/y)/z", "answer=y=x/(y/z)", "input=y=(x/y)/z") + @Iteration("x/(y/z)=2!=(x/y)/z=2", "answer=x/(y/z)=2", "input=(x/y)/z=2") fun testMatches_operationsDiffer_byNonCommutativeOrAssociativeReordering_returnsFalse() { val answerExpression = createMathExpression(answer) val inputExpression = createMathExpression(input) @@ -218,10 +203,8 @@ class MathEquationInputMatchesUpToTrivialManipulationsRuleClassifierProviderTest } @Test - @RunParameterized( - Iteration("y=1+2==y=1-(-2)", "answer=y=1+2", "input=y=1-(-2)"), - Iteration("y=1+x==y=1-(-x)", "answer=y=1+x", "input=y=1-(-x)") - ) + @Iteration("y=1+2==y=1-(-2)", "answer=y=1+2", "input=y=1-(-2)") + @Iteration("y=1+x==y=1-(-x)", "answer=y=1+x", "input=y=1-(-x)") fun testMatches_operationsDiffer_byDistributingNegation_returnsTrue() { val answerExpression = createMathExpression(answer) val inputExpression = createMathExpression(input) @@ -233,28 +216,26 @@ class MathEquationInputMatchesUpToTrivialManipulationsRuleClassifierProviderTest } @Test - @RunParameterized( - Iteration("y=1-2!=y=-(2-1)", "answer=y=1-2", "input=y=-(2-1)"), - Iteration("z=x-y!=z=-(y-x)", "answer=z=x-y", "input=z=-(y-x)"), - Iteration("y=1+2!=y=1+1+1", "answer=y=1+2", "input=y=1+1+1"), - Iteration("y=4-6!=y=1-2-1", "answer=y=4-6", "input=y=1-2-1"), - Iteration("y=2*3*2*2!=y=2*3*4", "answer=y=2*3*2*2", "input=y=2*3*4"), - Iteration("y=-6-2!=y=2*-(3+1)", "answer=y=-6-2", "input=y=2*-(3+1)"), - Iteration("y=2/3/2/2!=y=2/3/4", "answer=y=2/3/2/2", "input=y=2/3/4"), - Iteration("y=2^(2+1)!=y=2^3", "answer=y=2^(2+1)", "input=y=2^3"), - Iteration("y=2^(-1)!=y=1/2", "answer=y=2^(-1)", "input=y=1/2"), - Iteration("y=2+x!=y=1+x+1", "answer=y=2+x", "input=y=1+x+1"), - Iteration("y=-x!=y=1-x-1", "answer=y=-x", "input=y=1-x-1"), - Iteration("y=4x!=y=2*2*x", "answer=y=4x", "input=y=2*2*x"), - Iteration("y=2-6x!=y=2*(-3x+1)", "answer=y=2-6x", "input=y=2*(-3x+1)"), - Iteration("y=x/4!=y=x/2/2", "answer=y=x/4", "input=y=x/2/2"), - Iteration("y=x^(2+1)!=y=x^3", "answer=y=x^(2+1)", "input=y=x^3"), - Iteration("y=x*(2^(-1))!=y=x/2", "answer=y=x*(2^(-1))", "input=y=x/2"), - Iteration("y+2=x!=1+1+y=x", "answer=y+2=x", "input=1+1+y=x"), - Iteration("(2^2)y=x+2!=4y=x+2", "answer=(2^2)y=x+2", "input=4y=x+2"), - Iteration("y^(4-2)=3x!=y^2=3x", "answer=y^(4-2)=3x", "input=y^2=3x"), - Iteration("y/2/2=3x!=y/4=3x", "answer=y/2/2=3x", "input=y/4=3x") - ) + @Iteration("y=1-2!=y=-(2-1)", "answer=y=1-2", "input=y=-(2-1)") + @Iteration("z=x-y!=z=-(y-x)", "answer=z=x-y", "input=z=-(y-x)") + @Iteration("y=1+2!=y=1+1+1", "answer=y=1+2", "input=y=1+1+1") + @Iteration("y=4-6!=y=1-2-1", "answer=y=4-6", "input=y=1-2-1") + @Iteration("y=2*3*2*2!=y=2*3*4", "answer=y=2*3*2*2", "input=y=2*3*4") + @Iteration("y=-6-2!=y=2*-(3+1)", "answer=y=-6-2", "input=y=2*-(3+1)") + @Iteration("y=2/3/2/2!=y=2/3/4", "answer=y=2/3/2/2", "input=y=2/3/4") + @Iteration("y=2^(2+1)!=y=2^3", "answer=y=2^(2+1)", "input=y=2^3") + @Iteration("y=2^(-1)!=y=1/2", "answer=y=2^(-1)", "input=y=1/2") + @Iteration("y=2+x!=y=1+x+1", "answer=y=2+x", "input=y=1+x+1") + @Iteration("y=-x!=y=1-x-1", "answer=y=-x", "input=y=1-x-1") + @Iteration("y=4x!=y=2*2*x", "answer=y=4x", "input=y=2*2*x") + @Iteration("y=2-6x!=y=2*(-3x+1)", "answer=y=2-6x", "input=y=2*(-3x+1)") + @Iteration("y=x/4!=y=x/2/2", "answer=y=x/4", "input=y=x/2/2") + @Iteration("y=x^(2+1)!=y=x^3", "answer=y=x^(2+1)", "input=y=x^3") + @Iteration("y=x*(2^(-1))!=y=x/2", "answer=y=x*(2^(-1))", "input=y=x/2") + @Iteration("y+2=x!=1+1+y=x", "answer=y+2=x", "input=1+1+y=x") + @Iteration("(2^2)y=x+2!=4y=x+2", "answer=(2^2)y=x+2", "input=4y=x+2") + @Iteration("y^(4-2)=3x!=y^2=3x", "answer=y^(4-2)=3x", "input=y^2=3x") + @Iteration("y/2/2=3x!=y/4=3x", "answer=y/2/2=3x", "input=y/4=3x") fun testMatches_operationsDiffer_byDistributionAndCombining_returnsFalse() { val answerExpression = createMathExpression(answer) val inputExpression = createMathExpression(input) @@ -266,13 +247,11 @@ class MathEquationInputMatchesUpToTrivialManipulationsRuleClassifierProviderTest } @Test - @RunParameterized( - Iteration("2+x=y!=y=2+x", "answer=2+x=y", "input=y=2+x"), - Iteration("-3x^3=2y^2!=2y^2=-3x^3", "answer=-3x^3=2y^2", "input=2y^2=-3x^3"), - Iteration("-4+x=2+y+1-1!=2+y=x-4", "answer=-4+x=2+y+1-1", "input=2+y=x-4"), - Iteration("y=x-6!=2+y=x-4", "answer=y=x-6", "input=2+y=x-4"), - Iteration("(1+1+1)*x=2*y/4!=y/2=3x", "answer=(1+1+1)*x=2*y/4", "input=y/2=3x") - ) + @Iteration("2+x=y!=y=2+x", "answer=2+x=y", "input=y=2+x") + @Iteration("-3x^3=2y^2!=2y^2=-3x^3", "answer=-3x^3=2y^2", "input=2y^2=-3x^3") + @Iteration("-4+x=2+y+1-1!=2+y=x-4", "answer=-4+x=2+y+1-1", "input=2+y=x-4") + @Iteration("y=x-6!=2+y=x-4", "answer=y=x-6", "input=2+y=x-4") + @Iteration("(1+1+1)*x=2*y/4!=y/2=3x", "answer=(1+1+1)*x=2*y/4", "input=y/2=3x") fun testMatches_sidesRearrangedAroundEqualsSign_returnsFalse() { val answerExpression = createMathExpression(answer) val inputExpression = createMathExpression(input) @@ -284,11 +263,9 @@ class MathEquationInputMatchesUpToTrivialManipulationsRuleClassifierProviderTest } @Test - @RunParameterized( - Iteration("y = 3x^2 - 4==y = 3x^2 - 4", "answer=y = 3x^2 - 4", "input=y = 3x^2 - 4"), - Iteration("y = -4 + 3x^2==y = 3x^2 - 4", "answer=y = -4 + 3x^2", "input=y = 3x^2 - 4"), - Iteration("y = x^2*3 - 4==y = 3x^2 - 4", "answer=y = x^2*3 - 4", "input=y = 3x^2 - 4") - ) + @Iteration("y = 3x^2 - 4==y = 3x^2 - 4", "answer=y = 3x^2 - 4", "input=y = 3x^2 - 4") + @Iteration("y = -4 + 3x^2==y = 3x^2 - 4", "answer=y = -4 + 3x^2", "input=y = 3x^2 - 4") + @Iteration("y = x^2*3 - 4==y = 3x^2 - 4", "answer=y = x^2*3 - 4", "input=y = 3x^2 - 4") fun testMatches_assortedExpressions_withMatchingCharacteristics_returnsTrue() { val answerExpression = createMathExpression(answer) val inputExpression = createMathExpression(input) @@ -301,40 +278,38 @@ class MathEquationInputMatchesUpToTrivialManipulationsRuleClassifierProviderTest } @Test - @RunParameterized( - Iteration("y+4=3x^2!=y = 3x^2 - 4", "answer=y+4=3x^2", "input=y = 3x^2 - 4"), - Iteration("y-3x^2=-4!=y = 3x^2 - 4", "answer=y-3x^2=-4", "input=y = 3x^2 - 4"), - Iteration("-4=y-3x^2!=y = 3x^2 - 4", "answer=-4=y-3x^2", "input=y = 3x^2 - 4"), - Iteration("3x^2-y=4!=y = 3x^2 - 4", "answer=3x^2-y=4", "input=y = 3x^2 - 4"), - Iteration("3x^2=4+y!=y = 3x^2 - 4", "answer=3x^2=4+y", "input=y = 3x^2 - 4"), - Iteration("y-x^2=2x^2-4!=y = 3x^2 - 4", "answer=y-x^2=2x^2-4", "input=y = 3x^2 - 4"), - Iteration("y=x*(2^(1/2))!=y=sqrt(2)x", "answer=y=x*(2^(1/2))", "input=y=sqrt(2)x"), - Iteration("y − 3x^2 = -4!=y = 3x^2 - 4", "answer=y − 3x^2 = -4", "input=y = 3x^2 - 4"), - Iteration("3x^2 - 4 = y!=y = 3x^2 - 4", "answer=3x^2 - 4 = y", "input=y = 3x^2 - 4"), - Iteration("y = 3x^2 - 7!=y = 3x^2 - 4", "answer=y = 3x^2 - 7", "input=y = 3x^2 - 4"), - Iteration("x^2 = 3y - 4!=y = 3x^2 - 4", "answer=x^2 = 3y - 4", "input=y = 3x^2 - 4"), - Iteration("y/(3x^2 - 4) = 1!=y = 3x^2 - 4", "answer=y/(3x^2 - 4) = 1", "input=y = 3x^2 - 4"), - Iteration("y + 3x^2 - 4 = 0!=y = 3x^2 - 4", "answer=y + 3x^2 - 4 = 0", "input=y = 3x^2 - 4"), - Iteration("y − 3x^2 + 4 = 0!=y = 3x^2 - 4", "answer=y − 3x^2 + 4 = 0", "input=y = 3x^2 - 4"), - Iteration("y^2 = 3x^2y - 4y!=y = 3x^2 - 4", "answer=y^2 = 3x^2y - 4y", "input=y = 3x^2 - 4"), - Iteration("y = (3x^3 - 4x)/x!=y = 3x^2 - 4", "answer=y = (3x^3 - 4x)/x", "input=y = 3x^2 - 4"), - Iteration( - "y^2 * y^−1 = -12x^2!=y = 3x^2 - 4", "answer=y^2 * y^−1 = -12x^2", "input=y = 3x^2 - 4" - ), - Iteration("y^2/y = 3x^2 - 4!=y = 3x^2 - 4", "answer=y^2/y = 3x^2 - 4", "input=y = 3x^2 - 4"), - Iteration("2 − 3 = -4!=y = 3x^2 - 4", "answer=2 − 3 = -4", "input=y = 3x^2 - 4"), - Iteration("y = 3x^2 + 4!=y = 3x^2 - 4", "answer=y = 3x^2 + 4", "input=y = 3x^2 - 4"), - Iteration("y - 4 = 3x^2!=y = 3x^2 - 4", "answer=y - 4 = 3x^2", "input=y = 3x^2 - 4"), - Iteration("y − 3x^2 - 4 = 0!=y = 3x^2 - 4", "answer=y − 3x^2 - 4 = 0", "input=y = 3x^2 - 4"), - Iteration("0 = y + 3x^2 - 4!=y = 3x^2 - 4", "answer=0 = y + 3x^2 - 4", "input=y = 3x^2 - 4"), - Iteration("2 = 0!=y = 3x^2 - 4", "answer=2 = 0", "input=y = 3x^2 - 4"), - Iteration("y - x^2 = -4!=y = 3x^2 - 4", "answer=y - x^2 = -4", "input=y = 3x^2 - 4"), - Iteration("y=3x-4!=y = 3x^2 - 4", "answer=y=3x-4", "input=y = 3x^2 - 4"), - Iteration("y/sqrt(2)=x!=y=sqrt(2)x", "answer=y/sqrt(2)=x", "input=y=sqrt(2)x"), - Iteration("y/4=x!=y=4x", "answer=y/4=x", "input=y=4x"), - Iteration("y/4=16x!=y=4x", "answer=y/4=16x", "input=y=4x"), - Iteration("xy=x^2!=y=x", "answer=xy=x^2", "input=y=x") + @Iteration("y+4=3x^2!=y = 3x^2 - 4", "answer=y+4=3x^2", "input=y = 3x^2 - 4") + @Iteration("y-3x^2=-4!=y = 3x^2 - 4", "answer=y-3x^2=-4", "input=y = 3x^2 - 4") + @Iteration("-4=y-3x^2!=y = 3x^2 - 4", "answer=-4=y-3x^2", "input=y = 3x^2 - 4") + @Iteration("3x^2-y=4!=y = 3x^2 - 4", "answer=3x^2-y=4", "input=y = 3x^2 - 4") + @Iteration("3x^2=4+y!=y = 3x^2 - 4", "answer=3x^2=4+y", "input=y = 3x^2 - 4") + @Iteration("y-x^2=2x^2-4!=y = 3x^2 - 4", "answer=y-x^2=2x^2-4", "input=y = 3x^2 - 4") + @Iteration("y=x*(2^(1/2))!=y=sqrt(2)x", "answer=y=x*(2^(1/2))", "input=y=sqrt(2)x") + @Iteration("y − 3x^2 = -4!=y = 3x^2 - 4", "answer=y − 3x^2 = -4", "input=y = 3x^2 - 4") + @Iteration("3x^2 - 4 = y!=y = 3x^2 - 4", "answer=3x^2 - 4 = y", "input=y = 3x^2 - 4") + @Iteration("y = 3x^2 - 7!=y = 3x^2 - 4", "answer=y = 3x^2 - 7", "input=y = 3x^2 - 4") + @Iteration("x^2 = 3y - 4!=y = 3x^2 - 4", "answer=x^2 = 3y - 4", "input=y = 3x^2 - 4") + @Iteration("y/(3x^2 - 4) = 1!=y = 3x^2 - 4", "answer=y/(3x^2 - 4) = 1", "input=y = 3x^2 - 4") + @Iteration("y + 3x^2 - 4 = 0!=y = 3x^2 - 4", "answer=y + 3x^2 - 4 = 0", "input=y = 3x^2 - 4") + @Iteration("y − 3x^2 + 4 = 0!=y = 3x^2 - 4", "answer=y − 3x^2 + 4 = 0", "input=y = 3x^2 - 4") + @Iteration("y^2 = 3x^2y - 4y!=y = 3x^2 - 4", "answer=y^2 = 3x^2y - 4y", "input=y = 3x^2 - 4") + @Iteration("y = (3x^3 - 4x)/x!=y = 3x^2 - 4", "answer=y = (3x^3 - 4x)/x", "input=y = 3x^2 - 4") + @Iteration( + "y^2 * y^−1 = -12x^2!=y = 3x^2 - 4", "answer=y^2 * y^−1 = -12x^2", "input=y = 3x^2 - 4" ) + @Iteration("y^2/y = 3x^2 - 4!=y = 3x^2 - 4", "answer=y^2/y = 3x^2 - 4", "input=y = 3x^2 - 4") + @Iteration("2 − 3 = -4!=y = 3x^2 - 4", "answer=2 − 3 = -4", "input=y = 3x^2 - 4") + @Iteration("y = 3x^2 + 4!=y = 3x^2 - 4", "answer=y = 3x^2 + 4", "input=y = 3x^2 - 4") + @Iteration("y - 4 = 3x^2!=y = 3x^2 - 4", "answer=y - 4 = 3x^2", "input=y = 3x^2 - 4") + @Iteration("y − 3x^2 - 4 = 0!=y = 3x^2 - 4", "answer=y − 3x^2 - 4 = 0", "input=y = 3x^2 - 4") + @Iteration("0 = y + 3x^2 - 4!=y = 3x^2 - 4", "answer=0 = y + 3x^2 - 4", "input=y = 3x^2 - 4") + @Iteration("2 = 0!=y = 3x^2 - 4", "answer=2 = 0", "input=y = 3x^2 - 4") + @Iteration("y - x^2 = -4!=y = 3x^2 - 4", "answer=y - x^2 = -4", "input=y = 3x^2 - 4") + @Iteration("y=3x-4!=y = 3x^2 - 4", "answer=y=3x-4", "input=y = 3x^2 - 4") + @Iteration("y/sqrt(2)=x!=y=sqrt(2)x", "answer=y/sqrt(2)=x", "input=y=sqrt(2)x") + @Iteration("y/4=x!=y=4x", "answer=y/4=x", "input=y=4x") + @Iteration("y/4=16x!=y=4x", "answer=y/4=16x", "input=y=4x") + @Iteration("xy=x^2!=y=x", "answer=xy=x^2", "input=y=x") fun testMatches_assortedExpressions_withoutMatchingCharacteristics_returnsFalse() { val answerExpression = createMathExpression(answer) val inputExpression = createMathExpression(input) diff --git a/domain/src/test/java/org/oppia/android/domain/classify/rules/numericexpressioninput/NumericExpressionInputIsEquivalentToRuleClassifierProviderTest.kt b/domain/src/test/java/org/oppia/android/domain/classify/rules/numericexpressioninput/NumericExpressionInputIsEquivalentToRuleClassifierProviderTest.kt index 611fcb04b04..7a0f3a1b6c2 100644 --- a/domain/src/test/java/org/oppia/android/domain/classify/rules/numericexpressioninput/NumericExpressionInputIsEquivalentToRuleClassifierProviderTest.kt +++ b/domain/src/test/java/org/oppia/android/domain/classify/rules/numericexpressioninput/NumericExpressionInputIsEquivalentToRuleClassifierProviderTest.kt @@ -17,7 +17,6 @@ import org.oppia.android.domain.classify.RuleClassifier import org.oppia.android.testing.junit.OppiaParameterizedTestRunner import org.oppia.android.testing.junit.OppiaParameterizedTestRunner.Iteration import org.oppia.android.testing.junit.OppiaParameterizedTestRunner.Parameter -import org.oppia.android.testing.junit.OppiaParameterizedTestRunner.RunParameterized import org.oppia.android.testing.junit.OppiaParameterizedTestRunner.SelectRunnerPlatform import org.oppia.android.testing.junit.ParameterizedRobolectricTestRunner import org.oppia.android.testing.robolectric.RobolectricModule @@ -59,11 +58,9 @@ class NumericExpressionInputIsEquivalentToRuleClassifierProviderTest { } @Test - @RunParameterized( - Iteration("0==0", "answer=0", "input=0"), - Iteration("1==1", "answer=1", "input=1"), - Iteration("2==2", "answer=2", "input=2") - ) + @Iteration("0==0", "answer=0", "input=0") + @Iteration("1==1", "answer=1", "input=1") + @Iteration("2==2", "answer=2", "input=2") fun testMatches_sameSingleTerms_returnsTrue() { val answerExpression = createMathExpression(answer) val inputExpression = createMathExpression(input) @@ -75,19 +72,17 @@ class NumericExpressionInputIsEquivalentToRuleClassifierProviderTest { } @Test - @RunParameterized( - Iteration("-2==-2", "answer=-2", "input=-2"), - Iteration("1+3.14==1+3.14", "answer=1+3.14", "input=1+3.14"), - Iteration(" 1 + 3.14 ==1+3.14", "answer= 1 + 3.14 ", "input=1+3.14"), - Iteration("1+2+3==1+2+3", "answer=1+2+3", "input=1+2+3"), - Iteration("1-3.14==1-3.14", "answer=1-3.14", "input=1-3.14"), - Iteration("2*3.14==2*3.14", "answer=2*3.14", "input=2*3.14"), - Iteration("2/3==2/3", "answer=2/3", "input=2/3"), - Iteration("2/3.14==2/3.14", "answer=2/3.14", "input=2/3.14"), - Iteration("2^3==2^3", "answer=2^3", "input=2^3"), - Iteration("2^3.14==2^3.14", "answer=2^3.14", "input=2^3.14"), - Iteration("sqrt(2)==sqrt(2)", "answer=sqrt(2)", "input=sqrt(2)") - ) + @Iteration("-2==-2", "answer=-2", "input=-2") + @Iteration("1+3.14==1+3.14", "answer=1+3.14", "input=1+3.14") + @Iteration(" 1 + 3.14 ==1+3.14", "answer= 1 + 3.14 ", "input=1+3.14") + @Iteration("1+2+3==1+2+3", "answer=1+2+3", "input=1+2+3") + @Iteration("1-3.14==1-3.14", "answer=1-3.14", "input=1-3.14") + @Iteration("2*3.14==2*3.14", "answer=2*3.14", "input=2*3.14") + @Iteration("2/3==2/3", "answer=2/3", "input=2/3") + @Iteration("2/3.14==2/3.14", "answer=2/3.14", "input=2/3.14") + @Iteration("2^3==2^3", "answer=2^3", "input=2^3") + @Iteration("2^3.14==2^3.14", "answer=2^3.14", "input=2^3.14") + @Iteration("sqrt(2)==sqrt(2)", "answer=sqrt(2)", "input=sqrt(2)") fun testMatches_sameSingleOperations_returnsTrue() { val answerExpression = createMathExpression(answer) val inputExpression = createMathExpression(input) @@ -99,12 +94,10 @@ class NumericExpressionInputIsEquivalentToRuleClassifierProviderTest { } @Test - @RunParameterized( - Iteration("1!=0", "answer=1", "input=0"), - Iteration("0!=1", "answer=0", "input=1"), - Iteration("3.14!=1", "answer=3.14", "input=1"), - Iteration("1!=3.14", "answer=1", "input=3.14") - ) + @Iteration("1!=0", "answer=1", "input=0") + @Iteration("0!=1", "answer=0", "input=1") + @Iteration("3.14!=1", "answer=3.14", "input=1") + @Iteration("1!=3.14", "answer=1", "input=3.14") fun testMatches_differentSingleTerms_returnsFalse() { val answerExpression = createMathExpression(answer) val inputExpression = createMathExpression(input) @@ -116,12 +109,10 @@ class NumericExpressionInputIsEquivalentToRuleClassifierProviderTest { } @Test - @RunParameterized( - Iteration("3.14+1==1+3.14", "answer=3.14+1", "input=1+3.14"), - Iteration("3+2+1==1+2+3", "answer=3+2+1", "input=1+2+3"), - Iteration("-3.14+1==1-3.14", "answer=-3.14+1", "input=1-3.14"), - Iteration("3.14*2==2*3.14", "answer=3.14*2", "input=2*3.14") - ) + @Iteration("3.14+1==1+3.14", "answer=3.14+1", "input=1+3.14") + @Iteration("3+2+1==1+2+3", "answer=3+2+1", "input=1+2+3") + @Iteration("-3.14+1==1-3.14", "answer=-3.14+1", "input=1-3.14") + @Iteration("3.14*2==2*3.14", "answer=3.14*2", "input=2*3.14") fun testMatches_operationsDiffer_byCommutativity_returnsTrue() { val answerExpression = createMathExpression(answer) val inputExpression = createMathExpression(input) @@ -133,10 +124,8 @@ class NumericExpressionInputIsEquivalentToRuleClassifierProviderTest { } @Test - @RunParameterized( - Iteration("1+(2+3)==(1+2)+3", "answer=1+(2+3)", "input=(1+2)+3"), - Iteration("2*(3*4)==(2*3)*4", "answer=2*(3*4)", "input=(2*3)*4") - ) + @Iteration("1+(2+3)==(1+2)+3", "answer=1+(2+3)", "input=(1+2)+3") + @Iteration("2*(3*4)==(2*3)*4", "answer=2*(3*4)", "input=(2*3)*4") fun testMatches_operationsDiffer_byAssociativity_returnsTrue() { val answerExpression = createMathExpression(answer) val inputExpression = createMathExpression(input) @@ -148,17 +137,15 @@ class NumericExpressionInputIsEquivalentToRuleClassifierProviderTest { } @Test - @RunParameterized( - Iteration("3.14-1!=1-3.14", "answer=3.14-1", "input=1-3.14"), - Iteration("1-(2-3)!=(1-2)-3", "answer=1-(2-3)", "input=(1-2)-3"), - Iteration("3.14/2!=2/3.14", "answer=3.14/2", "input=2/3.14"), - Iteration("2/(3/4)!=(2/3)/4", "answer=2/(3/4)", "input=(2/3)/4"), - Iteration("3.14^2!=2^3.14", "answer=3.14^2", "input=2^3.14"), - Iteration("3.14-x!=x-3.14", "answer=3.14-x", "input=x-3.14"), - Iteration("x-(y-z)!=(x-y)-z", "answer=x-(y-z)", "input=(x-y)-z"), - Iteration("3.14/x!=x/3.14", "answer=3.14/x", "input=x/3.14"), - Iteration("x/(y/z)!=(x/y)/z", "answer=x/(y/z)", "input=(x/y)/z") - ) + @Iteration("3.14-1!=1-3.14", "answer=3.14-1", "input=1-3.14") + @Iteration("1-(2-3)!=(1-2)-3", "answer=1-(2-3)", "input=(1-2)-3") + @Iteration("3.14/2!=2/3.14", "answer=3.14/2", "input=2/3.14") + @Iteration("2/(3/4)!=(2/3)/4", "answer=2/(3/4)", "input=(2/3)/4") + @Iteration("3.14^2!=2^3.14", "answer=3.14^2", "input=2^3.14") + @Iteration("3.14-x!=x-3.14", "answer=3.14-x", "input=x-3.14") + @Iteration("x-(y-z)!=(x-y)-z", "answer=x-(y-z)", "input=(x-y)-z") + @Iteration("3.14/x!=x/3.14", "answer=3.14/x", "input=x/3.14") + @Iteration("x/(y/z)!=(x/y)/z", "answer=x/(y/z)", "input=(x/y)/z") fun testMatches_operationsDiffer_byNonCommutativeOrAssociativeReordering_returnsFalse() { val answerExpression = createMathExpression(answer) val inputExpression = createMathExpression(input) @@ -171,17 +158,15 @@ class NumericExpressionInputIsEquivalentToRuleClassifierProviderTest { } @Test - @RunParameterized( - Iteration("1-2==-(2-1)", "answer=1-2", "input=-(2-1)"), - Iteration("1+2==1+1+1", "answer=1+2", "input=1+1+1"), - Iteration("1+2==1-(-2)", "answer=1+2", "input=1-(-2)"), - Iteration("4-6==1-2-1", "answer=4-6", "input=1-2-1"), - Iteration("2*3*2*2==2*3*4", "answer=2*3*2*2", "input=2*3*4"), - Iteration("-6-2==2*-(3+1)", "answer=-6-2", "input=2*-(3+1)"), - Iteration("2/3/2/2==2/3/4", "answer=2/3/2/2", "input=2/3/4"), - Iteration("2^(2+1)==2^3", "answer=2^(2+1)", "input=2^3"), - Iteration("2^(-1)==1/2", "answer=2^(-1)", "input=1/2") - ) + @Iteration("1-2==-(2-1)", "answer=1-2", "input=-(2-1)") + @Iteration("1+2==1+1+1", "answer=1+2", "input=1+1+1") + @Iteration("1+2==1-(-2)", "answer=1+2", "input=1-(-2)") + @Iteration("4-6==1-2-1", "answer=4-6", "input=1-2-1") + @Iteration("2*3*2*2==2*3*4", "answer=2*3*2*2", "input=2*3*4") + @Iteration("-6-2==2*-(3+1)", "answer=-6-2", "input=2*-(3+1)") + @Iteration("2/3/2/2==2/3/4", "answer=2/3/2/2", "input=2/3/4") + @Iteration("2^(2+1)==2^3", "answer=2^(2+1)", "input=2^3") + @Iteration("2^(-1)==1/2", "answer=2^(-1)", "input=1/2") fun testMatches_operationsDiffer_byDistributionAndCombining_returnTrue() { val answerExpression = createMathExpression(answer) val inputExpression = createMathExpression(input) @@ -193,112 +178,110 @@ class NumericExpressionInputIsEquivalentToRuleClassifierProviderTest { } @Test - @RunParameterized( - Iteration("2*(2+6+3+4)==2*(2+6+3+4)", "answer=2*(2+6+3+4)", "input=2*(2+6+3+4)"), - Iteration("2 × (2+6+3+4)==2*(2+6+3+4)", "answer=2 × (2+6+3+4)", "input=2*(2+6+3+4)"), - Iteration( - "15 - (6 × 2) + 3==15 - (6 × 2) + 3", "answer=15 - (6 × 2) + 3", "input=15 - (6 × 2) + 3" - ), - Iteration( - "2 × (50 + 150 + 100 + 25) ==(50 + 150 + 100 + 25) × 2", - "answer=2 × (50 + 150 + 100 + 25) ", - "input=(50 + 150 + 100 + 25) × 2" - ), - Iteration( - "2 * (50 + 150 + 100 + 25) ==2 × (50 + 150 + 100 + 25)", - "answer=2 * (50 + 150 + 100 + 25) ", - "input=2 × (50 + 150 + 100 + 25)" - ), - Iteration("2+5==5+2", "answer=2+5", "input=5+2"), - Iteration("5+2==5+2", "answer=5+2", "input=5+2"), - Iteration("6 − (− 4)==6 − (− 4)", "answer=6 − (− 4)", "input=6 − (− 4)"), - Iteration("6-(-4)==6 − (− 4)", "answer=6-(-4)", "input=6 − (− 4)"), - Iteration("− (− 4) + 6==6 − (− 4)", "answer=− (− 4) + 6", "input=6 − (− 4)"), - Iteration("10==6 − (− 4)", "answer=10", "input=6 − (− 4)"), - Iteration("6 + 4==6 − (− 4)", "answer=6 + 4", "input=6 − (− 4)"), - Iteration("6 + 2^2==6 − (− 4)", "answer=6 + 2^2", "input=6 − (− 4)"), - Iteration("3 * 2 − (− 4)==6 − (− 4)", "answer=3 * 2 − (− 4)", "input=6 − (− 4)"), - Iteration("100/10==6 − (− 4)", "answer=100/10", "input=6 − (− 4)"), - Iteration("3 * 10^-5==3 * 10^-5", "answer=3 * 10^-5", "input=3 * 10^-5"), - Iteration("3/(10 * 10^4)==3 * 10^-5", "answer=3/(10 * 10^4)", "input=3 * 10^-5"), - Iteration( - "1000 + 200 + 30 + 4 + 0.5 + 0.06==1000 + 200 + 30 + 4 + 0.5 + 0.06", - "answer=1000 + 200 + 30 + 4 + 0.5 + 0.06", - "input=1000 + 200 + 30 + 4 + 0.5 + 0.06" - ), - Iteration( - "200 + 30 + 4 + 0.5 + 0.06 + 1000==1000 + 200 + 30 + 4 + 0.5 + 0.06", - "answer=200 + 30 + 4 + 0.5 + 0.06 + 1000", - "input=1000 + 200 + 30 + 4 + 0.5 + 0.06" - ), - Iteration( - "0.06 + 0.5 + 4 + 30 + 200 + 1000==1000 + 200 + 30 + 4 + 0.5 + 0.06", - "answer=0.06 + 0.5 + 4 + 30 + 200 + 1000", - "input=1000 + 200 + 30 + 4 + 0.5 + 0.06" - ), - Iteration( - "1234.56==1000 + 200 + 30 + 4 + 0.5 + 0.06", - "answer=1234.56", - "input=1000 + 200 + 30 + 4 + 0.5 + 0.06" - ), - Iteration( - "123456/100==1000 + 200 + 30 + 4 + 0.5 + 0.06", - "answer=123456/100", - "input=1000 + 200 + 30 + 4 + 0.5 + 0.06" - ), - Iteration( - "61728/50==1000 + 200 + 30 + 4 + 0.5 + 0.06", - "answer=61728/50", - "input=1000 + 200 + 30 + 4 + 0.5 + 0.06" - ), - Iteration( - "1234 + 56/100==1000 + 200 + 30 + 4 + 0.5 + 0.06", - "answer=1234 + 56/100", - "input=1000 + 200 + 30 + 4 + 0.5 + 0.06" - ), - Iteration( - "1230 + 4.56==1000 + 200 + 30 + 4 + 0.5 + 0.06", - "answer=1230 + 4.56", - "input=1000 + 200 + 30 + 4 + 0.5 + 0.06" - ), - Iteration("2 * 2 * 3 * 3==2 * 2 * 3 * 3", "answer=2 * 2 * 3 * 3", "input=2 * 2 * 3 * 3"), - Iteration( - "2 * 2 * 3 * 3 * 1==2 * 2 * 3 * 3", "answer=2 * 2 * 3 * 3 * 1", "input=2 * 2 * 3 * 3" - ), - Iteration("2 * 2 * 9==2 * 2 * 3 * 3", "answer=2 * 2 * 9", "input=2 * 2 * 3 * 3"), - Iteration("4 * 3^2==2 * 2 * 3 * 3", "answer=4 * 3^2", "input=2 * 2 * 3 * 3"), - Iteration("8/2 * 3 * 3==2 * 2 * 3 * 3", "answer=8/2 * 3 * 3", "input=2 * 2 * 3 * 3"), - Iteration("36==2 * 2 * 3 * 3", "answer=36", "input=2 * 2 * 3 * 3"), - Iteration("sqrt(4-2)==sqrt(2)", "answer=sqrt(4-2)", "input=sqrt(2)"), - Iteration("2*(6+3+4) + 4==2*(2+6+3+4)", "answer=2*(6+3+4) + 4", "input=2*(2+6+3+4)"), - Iteration("2*(2+6+3) + 8==2*(2+6+3+4)", "answer=2*(2+6+3) + 8", "input=2*(2+6+3+4)"), - Iteration("(2+6+3+4)*2==2*(2+6+3+4)", "answer=(2+6+3+4)*2", "input=2*(2+6+3+4)"), - Iteration("(2+6+3+4) × 2==2*(2+6+3+4)", "answer=(2+6+3+4) × 2", "input=2*(2+6+3+4)"), - Iteration("15 - 12 + 3==15 - (6 × 2) + 3", "answer=15 - 12 + 3", "input=15 - (6 × 2) + 3"), - Iteration( - "3 - (6 * 2) + 15==15 - (6 × 2) + 3", "answer=3 - (6 * 2) + 15", "input=15 - (6 × 2) + 3" - ), - Iteration( - "15 - (2 × 6) + 3==15 - (6 × 2) + 3", "answer=15 - (2 × 6) + 3", "input=15 - (6 × 2) + 3" - ), - Iteration( - "2 *(50 + 150) + 2*(100 + 25)==(50 + 150 + 100 + 25) × 2", - "answer=2 *(50 + 150) + 2*(100 + 25)", - "input=(50 + 150 + 100 + 25) × 2" - ), - Iteration( - "2* ( 25+50+100+150)==(50 + 150 + 100 + 25) × 2", - "answer=2* ( 25+50+100+150)", - "input=(50 + 150 + 100 + 25) × 2" - ), - Iteration("10^−5 * 3==3 * 10^-5", "answer=10^−5 * 3", "input=3 * 10^-5"), - Iteration("30 * 10^−6==3 * 10^-5", "answer=30 * 10^−6", "input=3 * 10^-5"), - Iteration("0.00003==3 * 10^-5", "answer=0.00003", "input=3 * 10^-5"), - Iteration("3/10^5==3 * 10^-5", "answer=3/10^5", "input=3 * 10^-5"), - Iteration("3 *2 – (− 4)==6 − (− 4)", "answer=3 *2 – (− 4)", "input=6 − (− 4)"), - Iteration("7==5+2", "answer=7", "input=5+2"), - Iteration("3+4==5+2", "answer=3+4", "input=5+2") + @Iteration("2*(2+6+3+4)==2*(2+6+3+4)", "answer=2*(2+6+3+4)", "input=2*(2+6+3+4)") + @Iteration("2 × (2+6+3+4)==2*(2+6+3+4)", "answer=2 × (2+6+3+4)", "input=2*(2+6+3+4)") + @Iteration( + "15 - (6 × 2) + 3==15 - (6 × 2) + 3", "answer=15 - (6 × 2) + 3", "input=15 - (6 × 2) + 3" + ) + @Iteration( + "2 × (50 + 150 + 100 + 25) ==(50 + 150 + 100 + 25) × 2", + "answer=2 × (50 + 150 + 100 + 25) ", + "input=(50 + 150 + 100 + 25) × 2" + ) + @Iteration( + "2 * (50 + 150 + 100 + 25) ==2 × (50 + 150 + 100 + 25)", + "answer=2 * (50 + 150 + 100 + 25) ", + "input=2 × (50 + 150 + 100 + 25)" + ) + @Iteration("2+5==5+2", "answer=2+5", "input=5+2") + @Iteration("5+2==5+2", "answer=5+2", "input=5+2") + @Iteration("6 − (− 4)==6 − (− 4)", "answer=6 − (− 4)", "input=6 − (− 4)") + @Iteration("6-(-4)==6 − (− 4)", "answer=6-(-4)", "input=6 − (− 4)") + @Iteration("− (− 4) + 6==6 − (− 4)", "answer=− (− 4) + 6", "input=6 − (− 4)") + @Iteration("10==6 − (− 4)", "answer=10", "input=6 − (− 4)") + @Iteration("6 + 4==6 − (− 4)", "answer=6 + 4", "input=6 − (− 4)") + @Iteration("6 + 2^2==6 − (− 4)", "answer=6 + 2^2", "input=6 − (− 4)") + @Iteration("3 * 2 − (− 4)==6 − (− 4)", "answer=3 * 2 − (− 4)", "input=6 − (− 4)") + @Iteration("100/10==6 − (− 4)", "answer=100/10", "input=6 − (− 4)") + @Iteration("3 * 10^-5==3 * 10^-5", "answer=3 * 10^-5", "input=3 * 10^-5") + @Iteration("3/(10 * 10^4)==3 * 10^-5", "answer=3/(10 * 10^4)", "input=3 * 10^-5") + @Iteration( + "1000 + 200 + 30 + 4 + 0.5 + 0.06==1000 + 200 + 30 + 4 + 0.5 + 0.06", + "answer=1000 + 200 + 30 + 4 + 0.5 + 0.06", + "input=1000 + 200 + 30 + 4 + 0.5 + 0.06" + ) + @Iteration( + "200 + 30 + 4 + 0.5 + 0.06 + 1000==1000 + 200 + 30 + 4 + 0.5 + 0.06", + "answer=200 + 30 + 4 + 0.5 + 0.06 + 1000", + "input=1000 + 200 + 30 + 4 + 0.5 + 0.06" + ) + @Iteration( + "0.06 + 0.5 + 4 + 30 + 200 + 1000==1000 + 200 + 30 + 4 + 0.5 + 0.06", + "answer=0.06 + 0.5 + 4 + 30 + 200 + 1000", + "input=1000 + 200 + 30 + 4 + 0.5 + 0.06" ) + @Iteration( + "1234.56==1000 + 200 + 30 + 4 + 0.5 + 0.06", + "answer=1234.56", + "input=1000 + 200 + 30 + 4 + 0.5 + 0.06" + ) + @Iteration( + "123456/100==1000 + 200 + 30 + 4 + 0.5 + 0.06", + "answer=123456/100", + "input=1000 + 200 + 30 + 4 + 0.5 + 0.06" + ) + @Iteration( + "61728/50==1000 + 200 + 30 + 4 + 0.5 + 0.06", + "answer=61728/50", + "input=1000 + 200 + 30 + 4 + 0.5 + 0.06" + ) + @Iteration( + "1234 + 56/100==1000 + 200 + 30 + 4 + 0.5 + 0.06", + "answer=1234 + 56/100", + "input=1000 + 200 + 30 + 4 + 0.5 + 0.06" + ) + @Iteration( + "1230 + 4.56==1000 + 200 + 30 + 4 + 0.5 + 0.06", + "answer=1230 + 4.56", + "input=1000 + 200 + 30 + 4 + 0.5 + 0.06" + ) + @Iteration("2 * 2 * 3 * 3==2 * 2 * 3 * 3", "answer=2 * 2 * 3 * 3", "input=2 * 2 * 3 * 3") + @Iteration( + "2 * 2 * 3 * 3 * 1==2 * 2 * 3 * 3", "answer=2 * 2 * 3 * 3 * 1", "input=2 * 2 * 3 * 3" + ) + @Iteration("2 * 2 * 9==2 * 2 * 3 * 3", "answer=2 * 2 * 9", "input=2 * 2 * 3 * 3") + @Iteration("4 * 3^2==2 * 2 * 3 * 3", "answer=4 * 3^2", "input=2 * 2 * 3 * 3") + @Iteration("8/2 * 3 * 3==2 * 2 * 3 * 3", "answer=8/2 * 3 * 3", "input=2 * 2 * 3 * 3") + @Iteration("36==2 * 2 * 3 * 3", "answer=36", "input=2 * 2 * 3 * 3") + @Iteration("sqrt(4-2)==sqrt(2)", "answer=sqrt(4-2)", "input=sqrt(2)") + @Iteration("2*(6+3+4) + 4==2*(2+6+3+4)", "answer=2*(6+3+4) + 4", "input=2*(2+6+3+4)") + @Iteration("2*(2+6+3) + 8==2*(2+6+3+4)", "answer=2*(2+6+3) + 8", "input=2*(2+6+3+4)") + @Iteration("(2+6+3+4)*2==2*(2+6+3+4)", "answer=(2+6+3+4)*2", "input=2*(2+6+3+4)") + @Iteration("(2+6+3+4) × 2==2*(2+6+3+4)", "answer=(2+6+3+4) × 2", "input=2*(2+6+3+4)") + @Iteration("15 - 12 + 3==15 - (6 × 2) + 3", "answer=15 - 12 + 3", "input=15 - (6 × 2) + 3") + @Iteration( + "3 - (6 * 2) + 15==15 - (6 × 2) + 3", "answer=3 - (6 * 2) + 15", "input=15 - (6 × 2) + 3" + ) + @Iteration( + "15 - (2 × 6) + 3==15 - (6 × 2) + 3", "answer=15 - (2 × 6) + 3", "input=15 - (6 × 2) + 3" + ) + @Iteration( + "2 *(50 + 150) + 2*(100 + 25)==(50 + 150 + 100 + 25) × 2", + "answer=2 *(50 + 150) + 2*(100 + 25)", + "input=(50 + 150 + 100 + 25) × 2" + ) + @Iteration( + "2* ( 25+50+100+150)==(50 + 150 + 100 + 25) × 2", + "answer=2* ( 25+50+100+150)", + "input=(50 + 150 + 100 + 25) × 2" + ) + @Iteration("10^−5 * 3==3 * 10^-5", "answer=10^−5 * 3", "input=3 * 10^-5") + @Iteration("30 * 10^−6==3 * 10^-5", "answer=30 * 10^−6", "input=3 * 10^-5") + @Iteration("0.00003==3 * 10^-5", "answer=0.00003", "input=3 * 10^-5") + @Iteration("3/10^5==3 * 10^-5", "answer=3/10^5", "input=3 * 10^-5") + @Iteration("3 *2 – (− 4)==6 − (− 4)", "answer=3 *2 – (− 4)", "input=6 − (− 4)") + @Iteration("7==5+2", "answer=7", "input=5+2") + @Iteration("3+4==5+2", "answer=3+4", "input=5+2") fun testMatches_assortedExpressions_withMatchingCharacteristics_returnsTrue() { val answerExpression = createMathExpression(answer) val inputExpression = createMathExpression(input) @@ -311,26 +294,24 @@ class NumericExpressionInputIsEquivalentToRuleClassifierProviderTest { } @Test - @RunParameterized( - Iteration("3 * 10^5!=3 * 10^-5", "answer=3 * 10^5", "input=3 * 10^-5"), - Iteration("2 * 10^−5!=3 * 10^-5", "answer=2 * 10^−5", "input=3 * 10^-5"), - Iteration("5 * 10^−3!=3 * 10^-5", "answer=5 * 10^−3", "input=3 * 10^-5"), - Iteration( - "123456!=1000 + 200 + 30 + 4 + 0.5 + 0.06", - "answer=123456", - "input=1000 + 200 + 30 + 4 + 0.5 + 0.06" - ), - Iteration( - "1000 + 200 + 30!=1000 + 200 + 30 + 4 + 0.5 + 0.06", - "answer=1000 + 200 + 30", - "input=1000 + 200 + 30 + 4 + 0.5 + 0.06" - ), - Iteration("6 − 4!=6 − (− 4)", "answer=6 − 4", "input=6 − (− 4)"), - Iteration("6 + (− 4)!=6 − (− 4)", "answer=6 + (− 4)", "input=6 − (− 4)"), - Iteration("100!=6 − (− 4)", "answer=100", "input=6 − (− 4)"), - Iteration("2 * 2 * 3!=2 * 2 * 3 * 3", "answer=2 * 2 * 3", "input=2 * 2 * 3 * 3"), - Iteration("2 * 3 * 3 * 3!=2 * 2 * 3 * 3", "answer=2 * 3 * 3 * 3", "input=2 * 2 * 3 * 3") + @Iteration("3 * 10^5!=3 * 10^-5", "answer=3 * 10^5", "input=3 * 10^-5") + @Iteration("2 * 10^−5!=3 * 10^-5", "answer=2 * 10^−5", "input=3 * 10^-5") + @Iteration("5 * 10^−3!=3 * 10^-5", "answer=5 * 10^−3", "input=3 * 10^-5") + @Iteration( + "123456!=1000 + 200 + 30 + 4 + 0.5 + 0.06", + "answer=123456", + "input=1000 + 200 + 30 + 4 + 0.5 + 0.06" + ) + @Iteration( + "1000 + 200 + 30!=1000 + 200 + 30 + 4 + 0.5 + 0.06", + "answer=1000 + 200 + 30", + "input=1000 + 200 + 30 + 4 + 0.5 + 0.06" ) + @Iteration("6 − 4!=6 − (− 4)", "answer=6 − 4", "input=6 − (− 4)") + @Iteration("6 + (− 4)!=6 − (− 4)", "answer=6 + (− 4)", "input=6 − (− 4)") + @Iteration("100!=6 − (− 4)", "answer=100", "input=6 − (− 4)") + @Iteration("2 * 2 * 3!=2 * 2 * 3 * 3", "answer=2 * 2 * 3", "input=2 * 2 * 3 * 3") + @Iteration("2 * 3 * 3 * 3!=2 * 2 * 3 * 3", "answer=2 * 3 * 3 * 3", "input=2 * 2 * 3 * 3") fun testMatches_assortedExpressions_withoutMatchingCharacteristics_returnsFalse() { val answerExpression = createMathExpression(answer) val inputExpression = createMathExpression(input) diff --git a/domain/src/test/java/org/oppia/android/domain/classify/rules/numericexpressioninput/NumericExpressionInputMatchesExactlyWithRuleClassifierProviderTest.kt b/domain/src/test/java/org/oppia/android/domain/classify/rules/numericexpressioninput/NumericExpressionInputMatchesExactlyWithRuleClassifierProviderTest.kt index b091adab625..bf48dd05303 100644 --- a/domain/src/test/java/org/oppia/android/domain/classify/rules/numericexpressioninput/NumericExpressionInputMatchesExactlyWithRuleClassifierProviderTest.kt +++ b/domain/src/test/java/org/oppia/android/domain/classify/rules/numericexpressioninput/NumericExpressionInputMatchesExactlyWithRuleClassifierProviderTest.kt @@ -17,7 +17,6 @@ import org.oppia.android.domain.classify.RuleClassifier import org.oppia.android.testing.junit.OppiaParameterizedTestRunner import org.oppia.android.testing.junit.OppiaParameterizedTestRunner.Iteration import org.oppia.android.testing.junit.OppiaParameterizedTestRunner.Parameter -import org.oppia.android.testing.junit.OppiaParameterizedTestRunner.RunParameterized import org.oppia.android.testing.junit.OppiaParameterizedTestRunner.SelectRunnerPlatform import org.oppia.android.testing.junit.ParameterizedRobolectricTestRunner import org.oppia.android.testing.robolectric.RobolectricModule @@ -60,11 +59,9 @@ class NumericExpressionInputMatchesExactlyWithRuleClassifierProviderTest { } @Test - @RunParameterized( - Iteration("0==0", "answer=0", "input=0"), - Iteration("1==1", "answer=1", "input=1"), - Iteration("2==2", "answer=2", "input=2") - ) + @Iteration("0==0", "answer=0", "input=0") + @Iteration("1==1", "answer=1", "input=1") + @Iteration("2==2", "answer=2", "input=2") fun testMatches_sameSingleTerms_returnsTrue() { val answerExpression = createMathExpression(answer) val inputExpression = createMathExpression(input) @@ -76,19 +73,17 @@ class NumericExpressionInputMatchesExactlyWithRuleClassifierProviderTest { } @Test - @RunParameterized( - Iteration("-2==-2", "answer=-2", "input=-2"), - Iteration("1+3.14==1+3.14", "answer=1+3.14", "input=1+3.14"), - Iteration(" 1 + 3.14 ==1+3.14", "answer= 1 + 3.14 ", "input=1+3.14"), - Iteration("1+2+3==1+2+3", "answer=1+2+3", "input=1+2+3"), - Iteration("1-3.14==1-3.14", "answer=1-3.14", "input=1-3.14"), - Iteration("2*3.14==2*3.14", "answer=2*3.14", "input=2*3.14"), - Iteration("2/3==2/3", "answer=2/3", "input=2/3"), - Iteration("2/3.14==2/3.14", "answer=2/3.14", "input=2/3.14"), - Iteration("2^3==2^3", "answer=2^3", "input=2^3"), - Iteration("2^3.14==2^3.14", "answer=2^3.14", "input=2^3.14"), - Iteration("sqrt(2)==sqrt(2)", "answer=sqrt(2)", "input=sqrt(2)") - ) + @Iteration("-2==-2", "answer=-2", "input=-2") + @Iteration("1+3.14==1+3.14", "answer=1+3.14", "input=1+3.14") + @Iteration(" 1 + 3.14 ==1+3.14", "answer= 1 + 3.14 ", "input=1+3.14") + @Iteration("1+2+3==1+2+3", "answer=1+2+3", "input=1+2+3") + @Iteration("1-3.14==1-3.14", "answer=1-3.14", "input=1-3.14") + @Iteration("2*3.14==2*3.14", "answer=2*3.14", "input=2*3.14") + @Iteration("2/3==2/3", "answer=2/3", "input=2/3") + @Iteration("2/3.14==2/3.14", "answer=2/3.14", "input=2/3.14") + @Iteration("2^3==2^3", "answer=2^3", "input=2^3") + @Iteration("2^3.14==2^3.14", "answer=2^3.14", "input=2^3.14") + @Iteration("sqrt(2)==sqrt(2)", "answer=sqrt(2)", "input=sqrt(2)") fun testMatches_sameSingleOperations_returnsTrue() { val answerExpression = createMathExpression(answer) val inputExpression = createMathExpression(input) @@ -100,12 +95,10 @@ class NumericExpressionInputMatchesExactlyWithRuleClassifierProviderTest { } @Test - @RunParameterized( - Iteration("1!=0", "answer=1", "input=0"), - Iteration("0!=1", "answer=0", "input=1"), - Iteration("3.14!=1", "answer=3.14", "input=1"), - Iteration("1!=3.14", "answer=1", "input=3.14") - ) + @Iteration("1!=0", "answer=1", "input=0") + @Iteration("0!=1", "answer=0", "input=1") + @Iteration("3.14!=1", "answer=3.14", "input=1") + @Iteration("1!=3.14", "answer=1", "input=3.14") fun testMatches_differentSingleTerms_returnsFalse() { val answerExpression = createMathExpression(answer) val inputExpression = createMathExpression(input) @@ -117,12 +110,10 @@ class NumericExpressionInputMatchesExactlyWithRuleClassifierProviderTest { } @Test - @RunParameterized( - Iteration("3.14+1!=1+3.14", "answer=3.14+1", "input=1+3.14"), - Iteration("3+2+1!=1+2+3", "answer=3+2+1", "input=1+2+3"), - Iteration("-3.14+1!=1-3.14", "answer=-3.14+1", "input=1-3.14"), - Iteration("3.14*2!=2*3.14", "answer=3.14*2", "input=2*3.14") - ) + @Iteration("3.14+1!=1+3.14", "answer=3.14+1", "input=1+3.14") + @Iteration("3+2+1!=1+2+3", "answer=3+2+1", "input=1+2+3") + @Iteration("-3.14+1!=1-3.14", "answer=-3.14+1", "input=1-3.14") + @Iteration("3.14*2!=2*3.14", "answer=3.14*2", "input=2*3.14") fun testMatches_operationsDiffer_byCommutativity_returnsFalse() { val answerExpression = createMathExpression(answer) val inputExpression = createMathExpression(input) @@ -134,10 +125,8 @@ class NumericExpressionInputMatchesExactlyWithRuleClassifierProviderTest { } @Test - @RunParameterized( - Iteration("1+(2+3)!=(1+2)+3", "answer=1+(2+3)", "input=(1+2)+3"), - Iteration("2*(3*4)!=(2*3)*4", "answer=2*(3*4)", "input=(2*3)*4") - ) + @Iteration("1+(2+3)!=(1+2)+3", "answer=1+(2+3)", "input=(1+2)+3") + @Iteration("2*(3*4)!=(2*3)*4", "answer=2*(3*4)", "input=(2*3)*4") fun testMatches_operationsDiffer_byAssociativity_returnsFalse() { val answerExpression = createMathExpression(answer) val inputExpression = createMathExpression(input) @@ -149,17 +138,15 @@ class NumericExpressionInputMatchesExactlyWithRuleClassifierProviderTest { } @Test - @RunParameterized( - Iteration("3.14-1!=1-3.14", "answer=3.14-1", "input=1-3.14"), - Iteration("1-(2-3)!=(1-2)-3", "answer=1-(2-3)", "input=(1-2)-3"), - Iteration("3.14/2!=2/3.14", "answer=3.14/2", "input=2/3.14"), - Iteration("2/(3/4)!=(2/3)/4", "answer=2/(3/4)", "input=(2/3)/4"), - Iteration("3.14^2!=2^3.14", "answer=3.14^2", "input=2^3.14"), - Iteration("3.14-x!=x-3.14", "answer=3.14-x", "input=x-3.14"), - Iteration("x-(y-z)!=(x-y)-z", "answer=x-(y-z)", "input=(x-y)-z"), - Iteration("3.14/x!=x/3.14", "answer=3.14/x", "input=x/3.14"), - Iteration("x/(y/z)!=(x/y)/z", "answer=x/(y/z)", "input=(x/y)/z") - ) + @Iteration("3.14-1!=1-3.14", "answer=3.14-1", "input=1-3.14") + @Iteration("1-(2-3)!=(1-2)-3", "answer=1-(2-3)", "input=(1-2)-3") + @Iteration("3.14/2!=2/3.14", "answer=3.14/2", "input=2/3.14") + @Iteration("2/(3/4)!=(2/3)/4", "answer=2/(3/4)", "input=(2/3)/4") + @Iteration("3.14^2!=2^3.14", "answer=3.14^2", "input=2^3.14") + @Iteration("3.14-x!=x-3.14", "answer=3.14-x", "input=x-3.14") + @Iteration("x-(y-z)!=(x-y)-z", "answer=x-(y-z)", "input=(x-y)-z") + @Iteration("3.14/x!=x/3.14", "answer=3.14/x", "input=x/3.14") + @Iteration("x/(y/z)!=(x/y)/z", "answer=x/(y/z)", "input=(x/y)/z") fun testMatches_operationsDiffer_byNonCommutativeOrAssociativeReordering_returnsFalse() { val answerExpression = createMathExpression(answer) val inputExpression = createMathExpression(input) @@ -172,17 +159,15 @@ class NumericExpressionInputMatchesExactlyWithRuleClassifierProviderTest { } @Test - @RunParameterized( - Iteration("1-2!=-(2-1)", "answer=1-2", "input=-(2-1)"), - Iteration("1+2!=1+1+1", "answer=1+2", "input=1+1+1"), - Iteration("1+2!=1-(-2)", "answer=1+2", "input=1-(-2)"), - Iteration("4-6!=1-2-1", "answer=4-6", "input=1-2-1"), - Iteration("2*3*2*2!=2*3*4", "answer=2*3*2*2", "input=2*3*4"), - Iteration("-6-2!=2*-(3+1)", "answer=-6-2", "input=2*-(3+1)"), - Iteration("2/3/2/2!=2/3/4", "answer=2/3/2/2", "input=2/3/4"), - Iteration("2^(2+1)!=2^3", "answer=2^(2+1)", "input=2^3"), - Iteration("2^(-1)!=1/2", "answer=2^(-1)", "input=1/2") - ) + @Iteration("1-2!=-(2-1)", "answer=1-2", "input=-(2-1)") + @Iteration("1+2!=1+1+1", "answer=1+2", "input=1+1+1") + @Iteration("1+2!=1-(-2)", "answer=1+2", "input=1-(-2)") + @Iteration("4-6!=1-2-1", "answer=4-6", "input=1-2-1") + @Iteration("2*3*2*2!=2*3*4", "answer=2*3*2*2", "input=2*3*4") + @Iteration("-6-2!=2*-(3+1)", "answer=-6-2", "input=2*-(3+1)") + @Iteration("2/3/2/2!=2/3/4", "answer=2/3/2/2", "input=2/3/4") + @Iteration("2^(2+1)!=2^3", "answer=2^(2+1)", "input=2^3") + @Iteration("2^(-1)!=1/2", "answer=2^(-1)", "input=1/2") fun testMatches_operationsDiffer_byDistributionAndCombining_returnsFalse() { val answerExpression = createMathExpression(answer) val inputExpression = createMathExpression(input) @@ -194,28 +179,26 @@ class NumericExpressionInputMatchesExactlyWithRuleClassifierProviderTest { } @Test - @RunParameterized( - Iteration("2*(2+6+3+4)==2*(2+6+3+4)", "answer=2*(2+6+3+4)", "input=2*(2+6+3+4)"), - Iteration("2 × (2+6+3+4)==2*(2+6+3+4)", "answer=2 × (2+6+3+4)", "input=2*(2+6+3+4)"), - Iteration( - "15 - (6 × 2) + 3==15 - (6 × 2) + 3", "answer=15 - (6 × 2) + 3", "input=15 - (6 × 2) + 3" - ), - Iteration( - "2 * (50 + 150 + 100 + 25) ==2 × (50 + 150 + 100 + 25)", - "answer=2 * (50 + 150 + 100 + 25) ", - "input=2 × (50 + 150 + 100 + 25)" - ), - Iteration("5+2==5+2", "answer=5+2", "input=5+2"), - Iteration("6 − (− 4)==6 − (− 4)", "answer=6 − (− 4)", "input=6 − (− 4)"), - Iteration("6-(-4)==6 − (− 4)", "answer=6-(-4)", "input=6 − (− 4)"), - Iteration("3 * 10^-5==3 * 10^-5", "answer=3 * 10^-5", "input=3 * 10^-5"), - Iteration( - "1000 + 200 + 30 + 4 + 0.5 + 0.06==1000 + 200 + 30 + 4 + 0.5 + 0.06", - "answer=1000 + 200 + 30 + 4 + 0.5 + 0.06", - "input=1000 + 200 + 30 + 4 + 0.5 + 0.06" - ), - Iteration("2 * 2 * 3 * 3==2 * 2 * 3 * 3", "answer=2 * 2 * 3 * 3", "input=2 * 2 * 3 * 3") + @Iteration("2*(2+6+3+4)==2*(2+6+3+4)", "answer=2*(2+6+3+4)", "input=2*(2+6+3+4)") + @Iteration("2 × (2+6+3+4)==2*(2+6+3+4)", "answer=2 × (2+6+3+4)", "input=2*(2+6+3+4)") + @Iteration( + "15 - (6 × 2) + 3==15 - (6 × 2) + 3", "answer=15 - (6 × 2) + 3", "input=15 - (6 × 2) + 3" + ) + @Iteration( + "2 * (50 + 150 + 100 + 25) ==2 × (50 + 150 + 100 + 25)", + "answer=2 * (50 + 150 + 100 + 25) ", + "input=2 × (50 + 150 + 100 + 25)" + ) + @Iteration("5+2==5+2", "answer=5+2", "input=5+2") + @Iteration("6 − (− 4)==6 − (− 4)", "answer=6 − (− 4)", "input=6 − (− 4)") + @Iteration("6-(-4)==6 − (− 4)", "answer=6-(-4)", "input=6 − (− 4)") + @Iteration("3 * 10^-5==3 * 10^-5", "answer=3 * 10^-5", "input=3 * 10^-5") + @Iteration( + "1000 + 200 + 30 + 4 + 0.5 + 0.06==1000 + 200 + 30 + 4 + 0.5 + 0.06", + "answer=1000 + 200 + 30 + 4 + 0.5 + 0.06", + "input=1000 + 200 + 30 + 4 + 0.5 + 0.06" ) + @Iteration("2 * 2 * 3 * 3==2 * 2 * 3 * 3", "answer=2 * 2 * 3 * 3", "input=2 * 2 * 3 * 3") fun testMatches_assortedExpressions_withMatchingCharacteristics_returnsTrue() { val answerExpression = createMathExpression(answer) val inputExpression = createMathExpression(input) @@ -228,110 +211,108 @@ class NumericExpressionInputMatchesExactlyWithRuleClassifierProviderTest { } @Test - @RunParameterized( - Iteration( - "2 × (50 + 150 + 100 + 25) !=(50 + 150 + 100 + 25) × 2", - "answer=2 × (50 + 150 + 100 + 25) ", - "input=(50 + 150 + 100 + 25) × 2" - ), - Iteration("− (− 4) + 6!=6 − (− 4)", "answer=− (− 4) + 6", "input=6 − (− 4)"), - Iteration("10!=6 − (− 4)", "answer=10", "input=6 − (− 4)"), - Iteration("6 + 4!=6 − (− 4)", "answer=6 + 4", "input=6 − (− 4)"), - Iteration("6 + 2^2!=6 − (− 4)", "answer=6 + 2^2", "input=6 − (− 4)"), - Iteration("3 * 2 − (− 4)!=6 − (− 4)", "answer=3 * 2 − (− 4)", "input=6 − (− 4)"), - Iteration("100/10!=6 − (− 4)", "answer=100/10", "input=6 − (− 4)"), - Iteration("2+5!=5+2", "answer=2+5", "input=5+2"), - Iteration("3/(10 * 10^4)!=3 * 10^-5", "answer=3/(10 * 10^4)", "input=3 * 10^-5"), - Iteration( - "200 + 30 + 4 + 0.5 + 0.06 + 1000!=1000 + 200 + 30 + 4 + 0.5 + 0.06", - "answer=200 + 30 + 4 + 0.5 + 0.06 + 1000", - "input=1000 + 200 + 30 + 4 + 0.5 + 0.06" - ), - Iteration( - "0.06 + 0.5 + 4 + 30 + 200 + 1000!=1000 + 200 + 30 + 4 + 0.5 + 0.06", - "answer=0.06 + 0.5 + 4 + 30 + 200 + 1000", - "input=1000 + 200 + 30 + 4 + 0.5 + 0.06" - ), - Iteration( - "1234.56!=1000 + 200 + 30 + 4 + 0.5 + 0.06", - "answer=1234.56", - "input=1000 + 200 + 30 + 4 + 0.5 + 0.06" - ), - Iteration( - "123456/100!=1000 + 200 + 30 + 4 + 0.5 + 0.06", - "answer=123456/100", - "input=1000 + 200 + 30 + 4 + 0.5 + 0.06" - ), - Iteration( - "61728/50!=1000 + 200 + 30 + 4 + 0.5 + 0.06", - "answer=61728/50", - "input=1000 + 200 + 30 + 4 + 0.5 + 0.06" - ), - Iteration( - "1234 + 56/10!=1000 + 200 + 30 + 4 + 0.5 + 0.06", - "answer=1234 + 56/10", - "input=1000 + 200 + 30 + 4 + 0.5 + 0.06" - ), - Iteration( - "1230 + 4.56!=1000 + 200 + 30 + 4 + 0.5 + 0.06", - "answer=1230 + 4.56", - "input=1000 + 200 + 30 + 4 + 0.5 + 0.06" - ), - Iteration( - "2 * 2 * 3 * 3 * 1!=2 * 2 * 3 * 3", "answer=2 * 2 * 3 * 3 * 1", "input=2 * 2 * 3 * 3" - ), - Iteration("2 * 2 * 9!=2 * 2 * 3 * 3", "answer=2 * 2 * 9", "input=2 * 2 * 3 * 3"), - Iteration("4 * 3^2!=2 * 2 * 3 * 3", "answer=4 * 3^2", "input=2 * 2 * 3 * 3"), - Iteration("8/2 * 3 * 3!=2 * 2 * 3 * 3", "answer=8/2 * 3 * 3", "input=2 * 2 * 3 * 3"), - Iteration("36!=2 * 2 * 3 * 3", "answer=36", "input=2 * 2 * 3 * 3"), - Iteration("sqrt(4-2)!=sqrt(2)", "answer=sqrt(4-2)", "input=sqrt(2)"), - Iteration("2*(6+3+4) + 4!=2*(2+6+3+4)", "answer=2*(6+3+4) + 4", "input=2*(2+6+3+4)"), - Iteration("2*(2+6+3) + 8!=2*(2+6+3+4)", "answer=2*(2+6+3) + 8", "input=2*(2+6+3+4)"), - Iteration("(2+6+3+4)*2!=2*(2+6+3+4)", "answer=(2+6+3+4)*2", "input=2*(2+6+3+4)"), - Iteration("(2+6+3+4) × 2!=2*(2+6+3+4)", "answer=(2+6+3+4) × 2", "input=2*(2+6+3+4)"), - Iteration("15 - 12 + 3!=15 - (6 × 2) + 3", "answer=15 - 12 + 3", "input=15 - (6 × 2) + 3"), - Iteration( - "3 - (6 * 2) + 15!=15 - (6 × 2) + 3", "answer=3 - (6 * 2) + 15", "input=15 - (6 × 2) + 3" - ), - Iteration( - "15 - (2 × 6) + 3!=15 - (6 × 2) + 3", "answer=15 - (2 × 6) + 3", "input=15 - (6 × 2) + 3" - ), - Iteration( - "2 *(50 + 150) + 2*(100 + 25)!=(50 + 150 + 100 + 25) × 2", - "answer=2 *(50 + 150) + 2*(100 + 25)", - "input=(50 + 150 + 100 + 25) × 2" - ), - Iteration( - "2* ( 25+50+100+150)!=(50 + 150 + 100 + 25) × 2", - "answer=2* ( 25+50+100+150)", - "input=(50 + 150 + 100 + 25) × 2" - ), - Iteration("10^−5 * 3!=3 * 10^-5", "answer=10^−5 * 3", "input=3 * 10^-5"), - Iteration("3 * 10^5!=3 * 10^-5", "answer=3 * 10^5", "input=3 * 10^-5"), - Iteration("2 * 10^−5!=3 * 10^-5", "answer=2 * 10^−5", "input=3 * 10^-5"), - Iteration("5 * 10^−3!=3 * 10^-5", "answer=5 * 10^−3", "input=3 * 10^-5"), - Iteration("30 * 10^−6!=3 * 10^-5", "answer=30 * 10^−6", "input=3 * 10^-5"), - Iteration("0.00003!=3 * 10^-5", "answer=0.00003", "input=3 * 10^-5"), - Iteration("3/10^5!=3 * 10^-5", "answer=3/10^5", "input=3 * 10^-5"), - Iteration( - "123456!=1000 + 200 + 30 + 4 + 0.5 + 0.06", - "answer=123456", - "input=1000 + 200 + 30 + 4 + 0.5 + 0.06" - ), - Iteration( - "1000 + 200 + 30!=1000 + 200 + 30 + 4 + 0.5 + 0.06", - "answer=1000 + 200 + 30", - "input=1000 + 200 + 30 + 4 + 0.5 + 0.06" - ), - Iteration("3 *2 – (− 4)!=6 − (− 4)", "answer=3 *2 – (− 4)", "input=6 − (− 4)"), - Iteration("6 − 4!=6 − (− 4)", "answer=6 − 4", "input=6 − (− 4)"), - Iteration("6 + (− 4)!=6 − (− 4)", "answer=6 + (− 4)", "input=6 − (− 4)"), - Iteration("100!=6 − (− 4)", "answer=100", "input=6 − (− 4)"), - Iteration("7!=5+2", "answer=7", "input=5+2"), - Iteration("3+4!=5+2", "answer=3+4", "input=5+2"), - Iteration("2 * 2 * 3!=2 * 2 * 3 * 3", "answer=2 * 2 * 3", "input=2 * 2 * 3 * 3"), - Iteration("2 * 3 * 3 * 3!=2 * 2 * 3 * 3", "answer=2 * 3 * 3 * 3", "input=2 * 2 * 3 * 3") + @Iteration( + "2 × (50 + 150 + 100 + 25) !=(50 + 150 + 100 + 25) × 2", + "answer=2 × (50 + 150 + 100 + 25) ", + "input=(50 + 150 + 100 + 25) × 2" + ) + @Iteration("− (− 4) + 6!=6 − (− 4)", "answer=− (− 4) + 6", "input=6 − (− 4)") + @Iteration("10!=6 − (− 4)", "answer=10", "input=6 − (− 4)") + @Iteration("6 + 4!=6 − (− 4)", "answer=6 + 4", "input=6 − (− 4)") + @Iteration("6 + 2^2!=6 − (− 4)", "answer=6 + 2^2", "input=6 − (− 4)") + @Iteration("3 * 2 − (− 4)!=6 − (− 4)", "answer=3 * 2 − (− 4)", "input=6 − (− 4)") + @Iteration("100/10!=6 − (− 4)", "answer=100/10", "input=6 − (− 4)") + @Iteration("2+5!=5+2", "answer=2+5", "input=5+2") + @Iteration("3/(10 * 10^4)!=3 * 10^-5", "answer=3/(10 * 10^4)", "input=3 * 10^-5") + @Iteration( + "200 + 30 + 4 + 0.5 + 0.06 + 1000!=1000 + 200 + 30 + 4 + 0.5 + 0.06", + "answer=200 + 30 + 4 + 0.5 + 0.06 + 1000", + "input=1000 + 200 + 30 + 4 + 0.5 + 0.06" + ) + @Iteration( + "0.06 + 0.5 + 4 + 30 + 200 + 1000!=1000 + 200 + 30 + 4 + 0.5 + 0.06", + "answer=0.06 + 0.5 + 4 + 30 + 200 + 1000", + "input=1000 + 200 + 30 + 4 + 0.5 + 0.06" + ) + @Iteration( + "1234.56!=1000 + 200 + 30 + 4 + 0.5 + 0.06", + "answer=1234.56", + "input=1000 + 200 + 30 + 4 + 0.5 + 0.06" + ) + @Iteration( + "123456/100!=1000 + 200 + 30 + 4 + 0.5 + 0.06", + "answer=123456/100", + "input=1000 + 200 + 30 + 4 + 0.5 + 0.06" + ) + @Iteration( + "61728/50!=1000 + 200 + 30 + 4 + 0.5 + 0.06", + "answer=61728/50", + "input=1000 + 200 + 30 + 4 + 0.5 + 0.06" + ) + @Iteration( + "1234 + 56/10!=1000 + 200 + 30 + 4 + 0.5 + 0.06", + "answer=1234 + 56/10", + "input=1000 + 200 + 30 + 4 + 0.5 + 0.06" + ) + @Iteration( + "1230 + 4.56!=1000 + 200 + 30 + 4 + 0.5 + 0.06", + "answer=1230 + 4.56", + "input=1000 + 200 + 30 + 4 + 0.5 + 0.06" + ) + @Iteration( + "2 * 2 * 3 * 3 * 1!=2 * 2 * 3 * 3", "answer=2 * 2 * 3 * 3 * 1", "input=2 * 2 * 3 * 3" + ) + @Iteration("2 * 2 * 9!=2 * 2 * 3 * 3", "answer=2 * 2 * 9", "input=2 * 2 * 3 * 3") + @Iteration("4 * 3^2!=2 * 2 * 3 * 3", "answer=4 * 3^2", "input=2 * 2 * 3 * 3") + @Iteration("8/2 * 3 * 3!=2 * 2 * 3 * 3", "answer=8/2 * 3 * 3", "input=2 * 2 * 3 * 3") + @Iteration("36!=2 * 2 * 3 * 3", "answer=36", "input=2 * 2 * 3 * 3") + @Iteration("sqrt(4-2)!=sqrt(2)", "answer=sqrt(4-2)", "input=sqrt(2)") + @Iteration("2*(6+3+4) + 4!=2*(2+6+3+4)", "answer=2*(6+3+4) + 4", "input=2*(2+6+3+4)") + @Iteration("2*(2+6+3) + 8!=2*(2+6+3+4)", "answer=2*(2+6+3) + 8", "input=2*(2+6+3+4)") + @Iteration("(2+6+3+4)*2!=2*(2+6+3+4)", "answer=(2+6+3+4)*2", "input=2*(2+6+3+4)") + @Iteration("(2+6+3+4) × 2!=2*(2+6+3+4)", "answer=(2+6+3+4) × 2", "input=2*(2+6+3+4)") + @Iteration("15 - 12 + 3!=15 - (6 × 2) + 3", "answer=15 - 12 + 3", "input=15 - (6 × 2) + 3") + @Iteration( + "3 - (6 * 2) + 15!=15 - (6 × 2) + 3", "answer=3 - (6 * 2) + 15", "input=15 - (6 × 2) + 3" + ) + @Iteration( + "15 - (2 × 6) + 3!=15 - (6 × 2) + 3", "answer=15 - (2 × 6) + 3", "input=15 - (6 × 2) + 3" + ) + @Iteration( + "2 *(50 + 150) + 2*(100 + 25)!=(50 + 150 + 100 + 25) × 2", + "answer=2 *(50 + 150) + 2*(100 + 25)", + "input=(50 + 150 + 100 + 25) × 2" + ) + @Iteration( + "2* ( 25+50+100+150)!=(50 + 150 + 100 + 25) × 2", + "answer=2* ( 25+50+100+150)", + "input=(50 + 150 + 100 + 25) × 2" + ) + @Iteration("10^−5 * 3!=3 * 10^-5", "answer=10^−5 * 3", "input=3 * 10^-5") + @Iteration("3 * 10^5!=3 * 10^-5", "answer=3 * 10^5", "input=3 * 10^-5") + @Iteration("2 * 10^−5!=3 * 10^-5", "answer=2 * 10^−5", "input=3 * 10^-5") + @Iteration("5 * 10^−3!=3 * 10^-5", "answer=5 * 10^−3", "input=3 * 10^-5") + @Iteration("30 * 10^−6!=3 * 10^-5", "answer=30 * 10^−6", "input=3 * 10^-5") + @Iteration("0.00003!=3 * 10^-5", "answer=0.00003", "input=3 * 10^-5") + @Iteration("3/10^5!=3 * 10^-5", "answer=3/10^5", "input=3 * 10^-5") + @Iteration( + "123456!=1000 + 200 + 30 + 4 + 0.5 + 0.06", + "answer=123456", + "input=1000 + 200 + 30 + 4 + 0.5 + 0.06" + ) + @Iteration( + "1000 + 200 + 30!=1000 + 200 + 30 + 4 + 0.5 + 0.06", + "answer=1000 + 200 + 30", + "input=1000 + 200 + 30 + 4 + 0.5 + 0.06" ) + @Iteration("3 *2 – (− 4)!=6 − (− 4)", "answer=3 *2 – (− 4)", "input=6 − (− 4)") + @Iteration("6 − 4!=6 − (− 4)", "answer=6 − 4", "input=6 − (− 4)") + @Iteration("6 + (− 4)!=6 − (− 4)", "answer=6 + (− 4)", "input=6 − (− 4)") + @Iteration("100!=6 − (− 4)", "answer=100", "input=6 − (− 4)") + @Iteration("7!=5+2", "answer=7", "input=5+2") + @Iteration("3+4!=5+2", "answer=3+4", "input=5+2") + @Iteration("2 * 2 * 3!=2 * 2 * 3 * 3", "answer=2 * 2 * 3", "input=2 * 2 * 3 * 3") + @Iteration("2 * 3 * 3 * 3!=2 * 2 * 3 * 3", "answer=2 * 3 * 3 * 3", "input=2 * 2 * 3 * 3") fun testMatches_assortedExpressions_withoutMatchingCharacteristics_returnsFalse() { val answerExpression = createMathExpression(answer) val inputExpression = createMathExpression(input) diff --git a/domain/src/test/java/org/oppia/android/domain/classify/rules/numericexpressioninput/NumericExpressionInputMatchesUpToTrivialManipulationsRuleClassifierProviderTest.kt b/domain/src/test/java/org/oppia/android/domain/classify/rules/numericexpressioninput/NumericExpressionInputMatchesUpToTrivialManipulationsRuleClassifierProviderTest.kt index 9e095d504dd..d4ad34e873a 100644 --- a/domain/src/test/java/org/oppia/android/domain/classify/rules/numericexpressioninput/NumericExpressionInputMatchesUpToTrivialManipulationsRuleClassifierProviderTest.kt +++ b/domain/src/test/java/org/oppia/android/domain/classify/rules/numericexpressioninput/NumericExpressionInputMatchesUpToTrivialManipulationsRuleClassifierProviderTest.kt @@ -17,7 +17,6 @@ import org.oppia.android.domain.classify.RuleClassifier import org.oppia.android.testing.junit.OppiaParameterizedTestRunner import org.oppia.android.testing.junit.OppiaParameterizedTestRunner.Iteration import org.oppia.android.testing.junit.OppiaParameterizedTestRunner.Parameter -import org.oppia.android.testing.junit.OppiaParameterizedTestRunner.RunParameterized import org.oppia.android.testing.junit.OppiaParameterizedTestRunner.SelectRunnerPlatform import org.oppia.android.testing.junit.ParameterizedRobolectricTestRunner import org.oppia.android.testing.robolectric.RobolectricModule @@ -60,11 +59,9 @@ class NumericExpressionInputMatchesUpToTrivialManipulationsRuleClassifierProvide } @Test - @RunParameterized( - Iteration("0==0", "answer=0", "input=0"), - Iteration("1==1", "answer=1", "input=1"), - Iteration("2==2", "answer=2", "input=2") - ) + @Iteration("0==0", "answer=0", "input=0") + @Iteration("1==1", "answer=1", "input=1") + @Iteration("2==2", "answer=2", "input=2") fun testMatches_sameSingleTerms_returnsTrue() { val answerExpression = createMathExpression(answer) val inputExpression = createMathExpression(input) @@ -76,19 +73,17 @@ class NumericExpressionInputMatchesUpToTrivialManipulationsRuleClassifierProvide } @Test - @RunParameterized( - Iteration("-2==-2", "answer=-2", "input=-2"), - Iteration("1+3.14==1+3.14", "answer=1+3.14", "input=1+3.14"), - Iteration(" 1 + 3.14 ==1+3.14", "answer= 1 + 3.14 ", "input=1+3.14"), - Iteration("1+2+3==1+2+3", "answer=1+2+3", "input=1+2+3"), - Iteration("1-3.14==1-3.14", "answer=1-3.14", "input=1-3.14"), - Iteration("2*3.14==2*3.14", "answer=2*3.14", "input=2*3.14"), - Iteration("2/3==2/3", "answer=2/3", "input=2/3"), - Iteration("2/3.14==2/3.14", "answer=2/3.14", "input=2/3.14"), - Iteration("2^3==2^3", "answer=2^3", "input=2^3"), - Iteration("2^3.14==2^3.14", "answer=2^3.14", "input=2^3.14"), - Iteration("sqrt(2)==sqrt(2)", "answer=sqrt(2)", "input=sqrt(2)") - ) + @Iteration("-2==-2", "answer=-2", "input=-2") + @Iteration("1+3.14==1+3.14", "answer=1+3.14", "input=1+3.14") + @Iteration(" 1 + 3.14 ==1+3.14", "answer= 1 + 3.14 ", "input=1+3.14") + @Iteration("1+2+3==1+2+3", "answer=1+2+3", "input=1+2+3") + @Iteration("1-3.14==1-3.14", "answer=1-3.14", "input=1-3.14") + @Iteration("2*3.14==2*3.14", "answer=2*3.14", "input=2*3.14") + @Iteration("2/3==2/3", "answer=2/3", "input=2/3") + @Iteration("2/3.14==2/3.14", "answer=2/3.14", "input=2/3.14") + @Iteration("2^3==2^3", "answer=2^3", "input=2^3") + @Iteration("2^3.14==2^3.14", "answer=2^3.14", "input=2^3.14") + @Iteration("sqrt(2)==sqrt(2)", "answer=sqrt(2)", "input=sqrt(2)") fun testMatches_sameSingleOperations_returnsTrue() { val answerExpression = createMathExpression(answer) val inputExpression = createMathExpression(input) @@ -100,12 +95,10 @@ class NumericExpressionInputMatchesUpToTrivialManipulationsRuleClassifierProvide } @Test - @RunParameterized( - Iteration("1!=0", "answer=1", "input=0"), - Iteration("0!=1", "answer=0", "input=1"), - Iteration("3.14!=1", "answer=3.14", "input=1"), - Iteration("1!=3.14", "answer=1", "input=3.14") - ) + @Iteration("1!=0", "answer=1", "input=0") + @Iteration("0!=1", "answer=0", "input=1") + @Iteration("3.14!=1", "answer=3.14", "input=1") + @Iteration("1!=3.14", "answer=1", "input=3.14") fun testMatches_differentSingleTerms_returnsFalse() { val answerExpression = createMathExpression(answer) val inputExpression = createMathExpression(input) @@ -118,12 +111,10 @@ class NumericExpressionInputMatchesUpToTrivialManipulationsRuleClassifierProvide } @Test - @RunParameterized( - Iteration("3.14+1==1+3.14", "answer=3.14+1", "input=1+3.14"), - Iteration("3+2+1==1+2+3", "answer=3+2+1", "input=1+2+3"), - Iteration("-3.14+1==1-3.14", "answer=-3.14+1", "input=1-3.14"), - Iteration("3.14*2==2*3.14", "answer=3.14*2", "input=2*3.14") - ) + @Iteration("3.14+1==1+3.14", "answer=3.14+1", "input=1+3.14") + @Iteration("3+2+1==1+2+3", "answer=3+2+1", "input=1+2+3") + @Iteration("-3.14+1==1-3.14", "answer=-3.14+1", "input=1-3.14") + @Iteration("3.14*2==2*3.14", "answer=3.14*2", "input=2*3.14") fun testMatches_operationsDiffer_byCommutativity_returnsTrue() { val answerExpression = createMathExpression(answer) val inputExpression = createMathExpression(input) @@ -135,10 +126,8 @@ class NumericExpressionInputMatchesUpToTrivialManipulationsRuleClassifierProvide } @Test - @RunParameterized( - Iteration("1+(2+3)==(1+2)+3", "answer=1+(2+3)", "input=(1+2)+3"), - Iteration("2*(3*4)==(2*3)*4", "answer=2*(3*4)", "input=(2*3)*4") - ) + @Iteration("1+(2+3)==(1+2)+3", "answer=1+(2+3)", "input=(1+2)+3") + @Iteration("2*(3*4)==(2*3)*4", "answer=2*(3*4)", "input=(2*3)*4") fun testMatches_operationsDiffer_byAssociativity_returnsTrue() { val answerExpression = createMathExpression(answer) val inputExpression = createMathExpression(input) @@ -150,17 +139,15 @@ class NumericExpressionInputMatchesUpToTrivialManipulationsRuleClassifierProvide } @Test - @RunParameterized( - Iteration("3.14-1!=1-3.14", "answer=3.14-1", "input=1-3.14"), - Iteration("1-(2-3)!=(1-2)-3", "answer=1-(2-3)", "input=(1-2)-3"), - Iteration("3.14/2!=2/3.14", "answer=3.14/2", "input=2/3.14"), - Iteration("2/(3/4)!=(2/3)/4", "answer=2/(3/4)", "input=(2/3)/4"), - Iteration("3.14^2!=2^3.14", "answer=3.14^2", "input=2^3.14"), - Iteration("3.14-x!=x-3.14", "answer=3.14-x", "input=x-3.14"), - Iteration("x-(y-z)!=(x-y)-z", "answer=x-(y-z)", "input=(x-y)-z"), - Iteration("3.14/x!=x/3.14", "answer=3.14/x", "input=x/3.14"), - Iteration("x/(y/z)!=(x/y)/z", "answer=x/(y/z)", "input=(x/y)/z") - ) + @Iteration("3.14-1!=1-3.14", "answer=3.14-1", "input=1-3.14") + @Iteration("1-(2-3)!=(1-2)-3", "answer=1-(2-3)", "input=(1-2)-3") + @Iteration("3.14/2!=2/3.14", "answer=3.14/2", "input=2/3.14") + @Iteration("2/(3/4)!=(2/3)/4", "answer=2/(3/4)", "input=(2/3)/4") + @Iteration("3.14^2!=2^3.14", "answer=3.14^2", "input=2^3.14") + @Iteration("3.14-x!=x-3.14", "answer=3.14-x", "input=x-3.14") + @Iteration("x-(y-z)!=(x-y)-z", "answer=x-(y-z)", "input=(x-y)-z") + @Iteration("3.14/x!=x/3.14", "answer=3.14/x", "input=x/3.14") + @Iteration("x/(y/z)!=(x/y)/z", "answer=x/(y/z)", "input=(x/y)/z") fun testMatches_operationsDiffer_byNonCommutativeOrAssociativeReordering_returnsFalse() { val answerExpression = createMathExpression(answer) val inputExpression = createMathExpression(input) @@ -173,9 +160,7 @@ class NumericExpressionInputMatchesUpToTrivialManipulationsRuleClassifierProvide } @Test - @RunParameterized( - Iteration("1+2==1-(-2)", "answer=1+2", "input=1-(-2)") - ) + @Iteration("1+2==1-(-2)", "answer=1+2", "input=1-(-2)") fun testMatches_operationsDiffer_byDistributingNegation_returnsTrue() { val answerExpression = createMathExpression(answer) val inputExpression = createMathExpression(input) @@ -187,16 +172,14 @@ class NumericExpressionInputMatchesUpToTrivialManipulationsRuleClassifierProvide } @Test - @RunParameterized( - Iteration("1-2==-(2-1)", "answer=1-2", "input=-(2-1)"), - Iteration("1+2!=1+1+1", "answer=1+2", "input=1+1+1"), - Iteration("4-6!=1-2-1", "answer=4-6", "input=1-2-1"), - Iteration("2*3*2*2!=2*3*4", "answer=2*3*2*2", "input=2*3*4"), - Iteration("-6-2!=2*-(3+1)", "answer=-6-2", "input=2*-(3+1)"), - Iteration("2/3/2/2!=2/3/4", "answer=2/3/2/2", "input=2/3/4"), - Iteration("2^(2+1)!=2^3", "answer=2^(2+1)", "input=2^3"), - Iteration("2^(-1)!=1/2", "answer=2^(-1)", "input=1/2") - ) + @Iteration("1-2==-(2-1)", "answer=1-2", "input=-(2-1)") + @Iteration("1+2!=1+1+1", "answer=1+2", "input=1+1+1") + @Iteration("4-6!=1-2-1", "answer=4-6", "input=1-2-1") + @Iteration("2*3*2*2!=2*3*4", "answer=2*3*2*2", "input=2*3*4") + @Iteration("-6-2!=2*-(3+1)", "answer=-6-2", "input=2*-(3+1)") + @Iteration("2/3/2/2!=2/3/4", "answer=2/3/2/2", "input=2/3/4") + @Iteration("2^(2+1)!=2^3", "answer=2^(2+1)", "input=2^3") + @Iteration("2^(-1)!=1/2", "answer=2^(-1)", "input=1/2") fun testMatches_operationsDiffer_byDistributionAndCombining_returnsFalse() { val answerExpression = createMathExpression(answer) val inputExpression = createMathExpression(input) @@ -208,59 +191,57 @@ class NumericExpressionInputMatchesUpToTrivialManipulationsRuleClassifierProvide } @Test - @RunParameterized( - Iteration("2*(2+6+3+4)==2*(2+6+3+4)", "answer=2*(2+6+3+4)", "input=2*(2+6+3+4)"), - Iteration("2 × (2+6+3+4)==2*(2+6+3+4)", "answer=2 × (2+6+3+4)", "input=2*(2+6+3+4)"), - Iteration( - "15 - (6 × 2) + 3==15 - (6 × 2) + 3", "answer=15 - (6 × 2) + 3", "input=15 - (6 × 2) + 3" - ), - Iteration( - "2 × (50 + 150 + 100 + 25) ==(50 + 150 + 100 + 25) × 2", - "answer=2 × (50 + 150 + 100 + 25) ", - "input=(50 + 150 + 100 + 25) × 2" - ), - Iteration( - "2 * (50 + 150 + 100 + 25) ==2 × (50 + 150 + 100 + 25)", - "answer=2 * (50 + 150 + 100 + 25) ", - "input=2 × (50 + 150 + 100 + 25)" - ), - Iteration("2+5==5+2", "answer=2+5", "input=5+2"), - Iteration("5+2==5+2", "answer=5+2", "input=5+2"), - Iteration("6 − (− 4)==6 − (− 4)", "answer=6 − (− 4)", "input=6 − (− 4)"), - Iteration("6-(-4)==6 − (− 4)", "answer=6-(-4)", "input=6 − (− 4)"), - Iteration("− (− 4) + 6==6 − (− 4)", "answer=− (− 4) + 6", "input=6 − (− 4)"), - Iteration("6 + 4!=6 − (− 4)", "answer=6 + 4", "input=6 − (− 4)"), - Iteration("3 * 10^-5==3 * 10^-5", "answer=3 * 10^-5", "input=3 * 10^-5"), - Iteration("10^−5 * 3==3 * 10^-5", "answer=10^−5 * 3", "input=3 * 10^-5"), - Iteration( - "1000 + 200 + 30 + 4 + 0.5 + 0.06==1000 + 200 + 30 + 4 + 0.5 + 0.06", - "answer=1000 + 200 + 30 + 4 + 0.5 + 0.06", - "input=1000 + 200 + 30 + 4 + 0.5 + 0.06" - ), - Iteration( - "200 + 30 + 4 + 0.5 + 0.06 + 1000==1000 + 200 + 30 + 4 + 0.5 + 0.06", - "answer=200 + 30 + 4 + 0.5 + 0.06 + 1000", - "input=1000 + 200 + 30 + 4 + 0.5 + 0.06" - ), - Iteration( - "0.06 + 0.5 + 4 + 30 + 200 + 1000==1000 + 200 + 30 + 4 + 0.5 + 0.06", - "answer=0.06 + 0.5 + 4 + 30 + 200 + 1000", - "input=1000 + 200 + 30 + 4 + 0.5 + 0.06" - ), - Iteration("2 * 2 * 3 * 3==2 * 2 * 3 * 3", "answer=2 * 2 * 3 * 3", "input=2 * 2 * 3 * 3"), - Iteration("(2+6+3+4)*2==2*(2+6+3+4)", "answer=(2+6+3+4)*2", "input=2*(2+6+3+4)"), - Iteration("(2+6+3+4) × 2==2*(2+6+3+4)", "answer=(2+6+3+4) × 2", "input=2*(2+6+3+4)"), - Iteration( - "3 - (6 * 2) + 15==15 - (6 × 2) + 3", "answer=3 - (6 * 2) + 15", "input=15 - (6 × 2) + 3" - ), - Iteration( - "15 - (2 × 6) + 3==15 - (6 × 2) + 3", "answer=15 - (2 × 6) + 3", "input=15 - (6 × 2) + 3" - ), - Iteration( - "2* ( 25+50+100+150)==(50 + 150 + 100 + 25) × 2", - "answer=2* ( 25+50+100+150)", - "input=(50 + 150 + 100 + 25) × 2" - ) + @Iteration("2*(2+6+3+4)==2*(2+6+3+4)", "answer=2*(2+6+3+4)", "input=2*(2+6+3+4)") + @Iteration("2 × (2+6+3+4)==2*(2+6+3+4)", "answer=2 × (2+6+3+4)", "input=2*(2+6+3+4)") + @Iteration( + "15 - (6 × 2) + 3==15 - (6 × 2) + 3", "answer=15 - (6 × 2) + 3", "input=15 - (6 × 2) + 3" + ) + @Iteration( + "2 × (50 + 150 + 100 + 25) ==(50 + 150 + 100 + 25) × 2", + "answer=2 × (50 + 150 + 100 + 25) ", + "input=(50 + 150 + 100 + 25) × 2" + ) + @Iteration( + "2 * (50 + 150 + 100 + 25) ==2 × (50 + 150 + 100 + 25)", + "answer=2 * (50 + 150 + 100 + 25) ", + "input=2 × (50 + 150 + 100 + 25)" + ) + @Iteration("2+5==5+2", "answer=2+5", "input=5+2") + @Iteration("5+2==5+2", "answer=5+2", "input=5+2") + @Iteration("6 − (− 4)==6 − (− 4)", "answer=6 − (− 4)", "input=6 − (− 4)") + @Iteration("6-(-4)==6 − (− 4)", "answer=6-(-4)", "input=6 − (− 4)") + @Iteration("− (− 4) + 6==6 − (− 4)", "answer=− (− 4) + 6", "input=6 − (− 4)") + @Iteration("6 + 4!=6 − (− 4)", "answer=6 + 4", "input=6 − (− 4)") + @Iteration("3 * 10^-5==3 * 10^-5", "answer=3 * 10^-5", "input=3 * 10^-5") + @Iteration("10^−5 * 3==3 * 10^-5", "answer=10^−5 * 3", "input=3 * 10^-5") + @Iteration( + "1000 + 200 + 30 + 4 + 0.5 + 0.06==1000 + 200 + 30 + 4 + 0.5 + 0.06", + "answer=1000 + 200 + 30 + 4 + 0.5 + 0.06", + "input=1000 + 200 + 30 + 4 + 0.5 + 0.06" + ) + @Iteration( + "200 + 30 + 4 + 0.5 + 0.06 + 1000==1000 + 200 + 30 + 4 + 0.5 + 0.06", + "answer=200 + 30 + 4 + 0.5 + 0.06 + 1000", + "input=1000 + 200 + 30 + 4 + 0.5 + 0.06" + ) + @Iteration( + "0.06 + 0.5 + 4 + 30 + 200 + 1000==1000 + 200 + 30 + 4 + 0.5 + 0.06", + "answer=0.06 + 0.5 + 4 + 30 + 200 + 1000", + "input=1000 + 200 + 30 + 4 + 0.5 + 0.06" + ) + @Iteration("2 * 2 * 3 * 3==2 * 2 * 3 * 3", "answer=2 * 2 * 3 * 3", "input=2 * 2 * 3 * 3") + @Iteration("(2+6+3+4)*2==2*(2+6+3+4)", "answer=(2+6+3+4)*2", "input=2*(2+6+3+4)") + @Iteration("(2+6+3+4) × 2==2*(2+6+3+4)", "answer=(2+6+3+4) × 2", "input=2*(2+6+3+4)") + @Iteration( + "3 - (6 * 2) + 15==15 - (6 × 2) + 3", "answer=3 - (6 * 2) + 15", "input=15 - (6 × 2) + 3" + ) + @Iteration( + "15 - (2 × 6) + 3==15 - (6 × 2) + 3", "answer=15 - (2 × 6) + 3", "input=15 - (6 × 2) + 3" + ) + @Iteration( + "2* ( 25+50+100+150)==(50 + 150 + 100 + 25) × 2", + "answer=2* ( 25+50+100+150)", + "input=(50 + 150 + 100 + 25) × 2" ) fun testMatches_assortedExpressions_withMatchingCharacteristics_returnsTrue() { val answerExpression = createMathExpression(answer) @@ -274,78 +255,76 @@ class NumericExpressionInputMatchesUpToTrivialManipulationsRuleClassifierProvide } @Test - @RunParameterized( - Iteration("10!=6 − (− 4)", "answer=10", "input=6 − (− 4)"), - Iteration("6 + 2^2!=6 − (− 4)", "answer=6 + 2^2", "input=6 − (− 4)"), - Iteration("3 * 2 − (− 4)!=6 − (− 4)", "answer=3 * 2 − (− 4)", "input=6 − (− 4)"), - Iteration("100/10!=6 − (− 4)", "answer=100/10", "input=6 − (− 4)"), - Iteration("3/(10 * 10^4)!=3 * 10^-5", "answer=3/(10 * 10^4)", "input=3 * 10^-5"), - Iteration( - "1234.56!=1000 + 200 + 30 + 4 + 0.5 + 0.06", - "answer=1234.56", - "input=1000 + 200 + 30 + 4 + 0.5 + 0.06" - ), - Iteration( - "123456/100!=1000 + 200 + 30 + 4 + 0.5 + 0.06", - "answer=123456/100", - "input=1000 + 200 + 30 + 4 + 0.5 + 0.06" - ), - Iteration( - "61728/50!=1000 + 200 + 30 + 4 + 0.5 + 0.06", - "answer=61728/50", - "input=1000 + 200 + 30 + 4 + 0.5 + 0.06" - ), - Iteration( - "1234 + 56/10!=1000 + 200 + 30 + 4 + 0.5 + 0.06", - "answer=1234 + 56/10", - "input=1000 + 200 + 30 + 4 + 0.5 + 0.06" - ), - Iteration( - "1230 + 4.56!=1000 + 200 + 30 + 4 + 0.5 + 0.06", - "answer=1230 + 4.56", - "input=1000 + 200 + 30 + 4 + 0.5 + 0.06" - ), - Iteration( - "2 * 2 * 3 * 3 * 1!=2 * 2 * 3 * 3", "answer=2 * 2 * 3 * 3 * 1", "input=2 * 2 * 3 * 3" - ), - Iteration("2 * 2 * 9!=2 * 2 * 3 * 3", "answer=2 * 2 * 9", "input=2 * 2 * 3 * 3"), - Iteration("4 * 3^2!=2 * 2 * 3 * 3", "answer=4 * 3^2", "input=2 * 2 * 3 * 3"), - Iteration("8/2 * 3 * 3!=2 * 2 * 3 * 3", "answer=8/2 * 3 * 3", "input=2 * 2 * 3 * 3"), - Iteration("36!=2 * 2 * 3 * 3", "answer=36", "input=2 * 2 * 3 * 3"), - Iteration("sqrt(4-2)!=sqrt(2)", "answer=sqrt(4-2)", "input=sqrt(2)"), - Iteration("3 * 10^5!=3 * 10^-5", "answer=3 * 10^5", "input=3 * 10^-5"), - Iteration("2 * 10^−5!=3 * 10^-5", "answer=2 * 10^−5", "input=3 * 10^-5"), - Iteration("5 * 10^−3!=3 * 10^-5", "answer=5 * 10^−3", "input=3 * 10^-5"), - Iteration("30 * 10^−6!=3 * 10^-5", "answer=30 * 10^−6", "input=3 * 10^-5"), - Iteration("0.00003!=3 * 10^-5", "answer=0.00003", "input=3 * 10^-5"), - Iteration("3/10^5!=3 * 10^-5", "answer=3/10^5", "input=3 * 10^-5"), - Iteration( - "123456!=1000 + 200 + 30 + 4 + 0.5 + 0.06", - "answer=123456", - "input=1000 + 200 + 30 + 4 + 0.5 + 0.06" - ), - Iteration( - "1000 + 200 + 30!=1000 + 200 + 30 + 4 + 0.5 + 0.06", - "answer=1000 + 200 + 30", - "input=1000 + 200 + 30 + 4 + 0.5 + 0.06" - ), - Iteration("3 *2 – (− 4)!=6 − (− 4)", "answer=3 *2 – (− 4)", "input=6 − (− 4)"), - Iteration("6 − 4!=6 − (− 4)", "answer=6 − 4", "input=6 − (− 4)"), - Iteration("6 + (− 4)!=6 − (− 4)", "answer=6 + (− 4)", "input=6 − (− 4)"), - Iteration("100!=6 − (− 4)", "answer=100", "input=6 − (− 4)"), - Iteration("7!=5+2", "answer=7", "input=5+2"), - Iteration("3+4!=5+2", "answer=3+4", "input=5+2"), - Iteration("2 * 2 * 3!=2 * 2 * 3 * 3", "answer=2 * 2 * 3", "input=2 * 2 * 3 * 3"), - Iteration("2 * 3 * 3 * 3!=2 * 2 * 3 * 3", "answer=2 * 3 * 3 * 3", "input=2 * 2 * 3 * 3"), - Iteration( - "2 *(50 + 150) + 2*(100 + 25)!=(50 + 150 + 100 + 25) × 2", - "answer=2 *(50 + 150) + 2*(100 + 25)", - "input=(50 + 150 + 100 + 25) × 2" - ), - Iteration("15 - 12 + 3!=15 - (6 × 2) + 3", "answer=15 - 12 + 3", "input=15 - (6 × 2) + 3"), - Iteration("2*(6+3+4) + 4!=2*(2+6+3+4)", "answer=2*(6+3+4) + 4", "input=2*(2+6+3+4)"), - Iteration("2*(2+6+3) + 8!=2*(2+6+3+4)", "answer=2*(2+6+3) + 8", "input=2*(2+6+3+4)") + @Iteration("10!=6 − (− 4)", "answer=10", "input=6 − (− 4)") + @Iteration("6 + 2^2!=6 − (− 4)", "answer=6 + 2^2", "input=6 − (− 4)") + @Iteration("3 * 2 − (− 4)!=6 − (− 4)", "answer=3 * 2 − (− 4)", "input=6 − (− 4)") + @Iteration("100/10!=6 − (− 4)", "answer=100/10", "input=6 − (− 4)") + @Iteration("3/(10 * 10^4)!=3 * 10^-5", "answer=3/(10 * 10^4)", "input=3 * 10^-5") + @Iteration( + "1234.56!=1000 + 200 + 30 + 4 + 0.5 + 0.06", + "answer=1234.56", + "input=1000 + 200 + 30 + 4 + 0.5 + 0.06" + ) + @Iteration( + "123456/100!=1000 + 200 + 30 + 4 + 0.5 + 0.06", + "answer=123456/100", + "input=1000 + 200 + 30 + 4 + 0.5 + 0.06" + ) + @Iteration( + "61728/50!=1000 + 200 + 30 + 4 + 0.5 + 0.06", + "answer=61728/50", + "input=1000 + 200 + 30 + 4 + 0.5 + 0.06" + ) + @Iteration( + "1234 + 56/10!=1000 + 200 + 30 + 4 + 0.5 + 0.06", + "answer=1234 + 56/10", + "input=1000 + 200 + 30 + 4 + 0.5 + 0.06" + ) + @Iteration( + "1230 + 4.56!=1000 + 200 + 30 + 4 + 0.5 + 0.06", + "answer=1230 + 4.56", + "input=1000 + 200 + 30 + 4 + 0.5 + 0.06" + ) + @Iteration( + "2 * 2 * 3 * 3 * 1!=2 * 2 * 3 * 3", "answer=2 * 2 * 3 * 3 * 1", "input=2 * 2 * 3 * 3" + ) + @Iteration("2 * 2 * 9!=2 * 2 * 3 * 3", "answer=2 * 2 * 9", "input=2 * 2 * 3 * 3") + @Iteration("4 * 3^2!=2 * 2 * 3 * 3", "answer=4 * 3^2", "input=2 * 2 * 3 * 3") + @Iteration("8/2 * 3 * 3!=2 * 2 * 3 * 3", "answer=8/2 * 3 * 3", "input=2 * 2 * 3 * 3") + @Iteration("36!=2 * 2 * 3 * 3", "answer=36", "input=2 * 2 * 3 * 3") + @Iteration("sqrt(4-2)!=sqrt(2)", "answer=sqrt(4-2)", "input=sqrt(2)") + @Iteration("3 * 10^5!=3 * 10^-5", "answer=3 * 10^5", "input=3 * 10^-5") + @Iteration("2 * 10^−5!=3 * 10^-5", "answer=2 * 10^−5", "input=3 * 10^-5") + @Iteration("5 * 10^−3!=3 * 10^-5", "answer=5 * 10^−3", "input=3 * 10^-5") + @Iteration("30 * 10^−6!=3 * 10^-5", "answer=30 * 10^−6", "input=3 * 10^-5") + @Iteration("0.00003!=3 * 10^-5", "answer=0.00003", "input=3 * 10^-5") + @Iteration("3/10^5!=3 * 10^-5", "answer=3/10^5", "input=3 * 10^-5") + @Iteration( + "123456!=1000 + 200 + 30 + 4 + 0.5 + 0.06", + "answer=123456", + "input=1000 + 200 + 30 + 4 + 0.5 + 0.06" + ) + @Iteration( + "1000 + 200 + 30!=1000 + 200 + 30 + 4 + 0.5 + 0.06", + "answer=1000 + 200 + 30", + "input=1000 + 200 + 30 + 4 + 0.5 + 0.06" + ) + @Iteration("3 *2 – (− 4)!=6 − (− 4)", "answer=3 *2 – (− 4)", "input=6 − (− 4)") + @Iteration("6 − 4!=6 − (− 4)", "answer=6 − 4", "input=6 − (− 4)") + @Iteration("6 + (− 4)!=6 − (− 4)", "answer=6 + (− 4)", "input=6 − (− 4)") + @Iteration("100!=6 − (− 4)", "answer=100", "input=6 − (− 4)") + @Iteration("7!=5+2", "answer=7", "input=5+2") + @Iteration("3+4!=5+2", "answer=3+4", "input=5+2") + @Iteration("2 * 2 * 3!=2 * 2 * 3 * 3", "answer=2 * 2 * 3", "input=2 * 2 * 3 * 3") + @Iteration("2 * 3 * 3 * 3!=2 * 2 * 3 * 3", "answer=2 * 3 * 3 * 3", "input=2 * 2 * 3 * 3") + @Iteration( + "2 *(50 + 150) + 2*(100 + 25)!=(50 + 150 + 100 + 25) × 2", + "answer=2 *(50 + 150) + 2*(100 + 25)", + "input=(50 + 150 + 100 + 25) × 2" ) + @Iteration("15 - 12 + 3!=15 - (6 × 2) + 3", "answer=15 - 12 + 3", "input=15 - (6 × 2) + 3") + @Iteration("2*(6+3+4) + 4!=2*(2+6+3+4)", "answer=2*(6+3+4) + 4", "input=2*(2+6+3+4)") + @Iteration("2*(2+6+3) + 8!=2*(2+6+3+4)", "answer=2*(2+6+3) + 8", "input=2*(2+6+3+4)") fun testMatches_assortedExpressions_withoutMatchingCharacteristics_returnsFalse() { val answerExpression = createMathExpression(answer) val inputExpression = createMathExpression(input) diff --git a/domain/src/test/java/org/oppia/android/domain/onboarding/AppStartupStateControllerTest.kt b/domain/src/test/java/org/oppia/android/domain/onboarding/AppStartupStateControllerTest.kt index 9f924f394dd..abfa11daefd 100644 --- a/domain/src/test/java/org/oppia/android/domain/onboarding/AppStartupStateControllerTest.kt +++ b/domain/src/test/java/org/oppia/android/domain/onboarding/AppStartupStateControllerTest.kt @@ -34,7 +34,6 @@ import org.oppia.android.testing.data.DataProviderTestMonitor import org.oppia.android.testing.junit.OppiaParameterizedTestRunner import org.oppia.android.testing.junit.OppiaParameterizedTestRunner.Iteration import org.oppia.android.testing.junit.OppiaParameterizedTestRunner.Parameter -import org.oppia.android.testing.junit.OppiaParameterizedTestRunner.RunParameterized import org.oppia.android.testing.junit.OppiaParameterizedTestRunner.SelectRunnerPlatform import org.oppia.android.testing.junit.ParameterizedRobolectricTestRunner import org.oppia.android.testing.robolectric.RobolectricModule @@ -689,12 +688,10 @@ class AppStartupStateControllerTest { } @Test - @RunParameterized( - Iteration("testing_to_beta", "initialFlavorName=TESTING"), - Iteration("dev_to_beta", "initialFlavorName=DEVELOPER"), - Iteration("alpha_to_beta", "initialFlavorName=ALPHA"), - Iteration("ga_to_beta", "initialFlavorName=GENERAL_AVAILABILITY") - ) + @Iteration("testing_to_beta", "initialFlavorName=TESTING") + @Iteration("dev_to_beta", "initialFlavorName=DEVELOPER") + @Iteration("alpha_to_beta", "initialFlavorName=ALPHA") + @Iteration("ga_to_beta", "initialFlavorName=GENERAL_AVAILABILITY") fun testController_dismissBetaNoticePermanently_scenariosWhenBetaNoticeDoesShow_showNoNotice() { executeInPreviousAppInstance { testComponent -> TestModule.buildFlavor = BuildFlavor.valueOf(initialFlavorName) @@ -716,10 +713,8 @@ class AppStartupStateControllerTest { } @Test - @RunParameterized( - Iteration("testing_to_ga", "initialFlavorName=TESTING"), - Iteration("dev_to_ga", "initialFlavorName=DEVELOPER") - ) + @Iteration("testing_to_ga", "initialFlavorName=TESTING") + @Iteration("dev_to_ga", "initialFlavorName=DEVELOPER") fun testController_dismissGaNoticePermanently_scenariosWhenGaNoticeDoesNotShow_showNoNotice() { executeInPreviousAppInstance { testComponent -> TestModule.buildFlavor = BuildFlavor.valueOf(initialFlavorName) @@ -741,10 +736,8 @@ class AppStartupStateControllerTest { } @Test - @RunParameterized( - Iteration("alpha_to_ga", "initialFlavorName=ALPHA"), - Iteration("beta_to_ga", "initialFlavorName=BETA") - ) + @Iteration("alpha_to_ga", "initialFlavorName=ALPHA") + @Iteration("beta_to_ga", "initialFlavorName=BETA") fun testController_dismissGaNoticePermanently_scenariosWhenGaNoticeDoesShow_showNoNotice() { executeInPreviousAppInstance { testComponent -> TestModule.buildFlavor = BuildFlavor.valueOf(initialFlavorName) diff --git a/domain/src/test/java/org/oppia/android/domain/oppialogger/analytics/LearnerAnalyticsLoggerTest.kt b/domain/src/test/java/org/oppia/android/domain/oppialogger/analytics/LearnerAnalyticsLoggerTest.kt index 363161e6b57..b3fefc76056 100644 --- a/domain/src/test/java/org/oppia/android/domain/oppialogger/analytics/LearnerAnalyticsLoggerTest.kt +++ b/domain/src/test/java/org/oppia/android/domain/oppialogger/analytics/LearnerAnalyticsLoggerTest.kt @@ -47,7 +47,6 @@ import org.oppia.android.testing.data.DataProviderTestMonitor import org.oppia.android.testing.junit.OppiaParameterizedTestRunner import org.oppia.android.testing.junit.OppiaParameterizedTestRunner.Iteration import org.oppia.android.testing.junit.OppiaParameterizedTestRunner.Parameter -import org.oppia.android.testing.junit.OppiaParameterizedTestRunner.RunParameterized import org.oppia.android.testing.junit.OppiaParameterizedTestRunner.SelectRunnerPlatform import org.oppia.android.testing.junit.ParameterizedRobolectricTestRunner import org.oppia.android.testing.logging.EventLogSubject.Companion.assertThat @@ -1119,11 +1118,9 @@ class LearnerAnalyticsLoggerTest { } @Test - @RunParameterized( - Iteration("no_install_id", "lid=learn", "iid=null", "elid=learn", "eid="), - Iteration("no_learner_id", "lid=null", "iid=install", "elid=", "eid=install"), - Iteration("missing_install_and_learner_ids", "lid=null", "iid=null", "elid=", "eid=") - ) + @Iteration("no_install_id", "lid=learn", "iid=null", "elid=learn", "eid=") + @Iteration("no_learner_id", "lid=null", "iid=install", "elid=", "eid=install") + @Iteration("missing_install_and_learner_ids", "lid=null", "iid=null", "elid=", "eid=") fun testExpLogger_logResumeExploration_missingOneOrMoreIds_logsEventWithMissingIds() { val exploration5 = loadExploration(TEST_EXPLORATION_ID_5) val expLogger = @@ -1143,11 +1140,9 @@ class LearnerAnalyticsLoggerTest { } @Test - @RunParameterized( - Iteration("no_install_id", "lid=learn", "iid=null", "elid=learn", "eid="), - Iteration("no_learner_id", "lid=null", "iid=install", "elid=", "eid=install"), - Iteration("missing_install_and_learner_ids", "lid=null", "iid=null", "elid=", "eid=") - ) + @Iteration("no_install_id", "lid=learn", "iid=null", "elid=learn", "eid=") + @Iteration("no_learner_id", "lid=null", "iid=install", "elid=", "eid=install") + @Iteration("missing_install_and_learner_ids", "lid=null", "iid=null", "elid=", "eid=") fun testExpLogger_logStartExplorationOver_missingOneOrMoreIds_logsEventWithMissingIds() { val exploration5 = loadExploration(TEST_EXPLORATION_ID_5) val expLogger = @@ -1167,10 +1162,8 @@ class LearnerAnalyticsLoggerTest { } @Test - @RunParameterized( - Iteration("no_install_id", "lid=learn", "iid=null", "elid=learn", "eid="), - Iteration("no_learner_id", "lid=null", "iid=install", "elid=", "eid=install") - ) + @Iteration("no_install_id", "lid=learn", "iid=null", "elid=learn", "eid=") + @Iteration("no_learner_id", "lid=null", "iid=install", "elid=", "eid=install") fun testExpLogger_logExitExploration_missingOneId_logsEventWithMissingId() { val exploration5 = loadExploration(TEST_EXPLORATION_ID_5) val expLogger = @@ -1214,10 +1207,8 @@ class LearnerAnalyticsLoggerTest { } @Test - @RunParameterized( - Iteration("no_install_id", "lid=learn", "iid=null", "elid=learn", "eid="), - Iteration("no_learner_id", "lid=null", "iid=install", "elid=", "eid=install") - ) + @Iteration("no_install_id", "lid=learn", "iid=null", "elid=learn", "eid=") + @Iteration("no_learner_id", "lid=null", "iid=install", "elid=", "eid=install") fun testExpLogger_logFinishExploration_missingOneId_logsEventWithMissingId() { val exploration5 = loadExploration(TEST_EXPLORATION_ID_5) val expLogger = @@ -1259,10 +1250,8 @@ class LearnerAnalyticsLoggerTest { } @Test - @RunParameterized( - Iteration("no_install_id", "lid=learn", "iid=null", "elid=learn", "eid="), - Iteration("no_learner_id", "lid=null", "iid=install", "elid=", "eid=install") - ) + @Iteration("no_install_id", "lid=learn", "iid=null", "elid=learn", "eid=") + @Iteration("no_learner_id", "lid=null", "iid=install", "elid=", "eid=install") fun testStateAnalyticsLogger_logStartCard_missingOneId_logsEventWithMissingId() { val exploration5 = loadExploration(TEST_EXPLORATION_ID_5) val expLogger = @@ -1306,10 +1295,8 @@ class LearnerAnalyticsLoggerTest { } @Test - @RunParameterized( - Iteration("no_install_id", "lid=learn", "iid=null", "elid=learn", "eid="), - Iteration("no_learner_id", "lid=null", "iid=install", "elid=", "eid=install") - ) + @Iteration("no_install_id", "lid=learn", "iid=null", "elid=learn", "eid=") + @Iteration("no_learner_id", "lid=null", "iid=install", "elid=", "eid=install") fun testStateAnalyticsLogger_logEndCard_missingOneId_logsEventWithMissingId() { val exploration5 = loadExploration(TEST_EXPLORATION_ID_5) val expLogger = @@ -1353,10 +1340,8 @@ class LearnerAnalyticsLoggerTest { } @Test - @RunParameterized( - Iteration("no_install_id", "lid=learn", "iid=null", "elid=learn", "eid="), - Iteration("no_learner_id", "lid=null", "iid=install", "elid=", "eid=install") - ) + @Iteration("no_install_id", "lid=learn", "iid=null", "elid=learn", "eid=") + @Iteration("no_learner_id", "lid=null", "iid=install", "elid=", "eid=install") fun testStateAnalyticsLogger_logHintUnlocked_missingOneId_logsEventWithMissingId() { val exploration5 = loadExploration(TEST_EXPLORATION_ID_5) val expLogger = @@ -1400,10 +1385,8 @@ class LearnerAnalyticsLoggerTest { } @Test - @RunParameterized( - Iteration("no_install_id", "lid=learn", "iid=null", "elid=learn", "eid="), - Iteration("no_learner_id", "lid=null", "iid=install", "elid=", "eid=install") - ) + @Iteration("no_install_id", "lid=learn", "iid=null", "elid=learn", "eid=") + @Iteration("no_learner_id", "lid=null", "iid=install", "elid=", "eid=install") fun testStateAnalyticsLogger_logViewHint_missingOneId_logsEventWithMissingId() { val exploration5 = loadExploration(TEST_EXPLORATION_ID_5) val expLogger = @@ -1447,10 +1430,8 @@ class LearnerAnalyticsLoggerTest { } @Test - @RunParameterized( - Iteration("no_install_id", "lid=learn", "iid=null", "elid=learn", "eid="), - Iteration("no_learner_id", "lid=null", "iid=install", "elid=", "eid=install") - ) + @Iteration("no_install_id", "lid=learn", "iid=null", "elid=learn", "eid=") + @Iteration("no_learner_id", "lid=null", "iid=install", "elid=", "eid=install") fun testStateAnalyticsLogger_logSolutionUnlocked_missingOneId_logsEventWithMissingId() { val exploration5 = loadExploration(TEST_EXPLORATION_ID_5) val expLogger = @@ -1492,10 +1473,8 @@ class LearnerAnalyticsLoggerTest { } @Test - @RunParameterized( - Iteration("no_install_id", "lid=learn", "iid=null", "elid=learn", "eid="), - Iteration("no_learner_id", "lid=null", "iid=install", "elid=", "eid=install") - ) + @Iteration("no_install_id", "lid=learn", "iid=null", "elid=learn", "eid=") + @Iteration("no_learner_id", "lid=null", "iid=install", "elid=", "eid=install") fun testStateAnalyticsLogger_logViewSolution_missingOneId_logsEventWithMissingId() { val exploration5 = loadExploration(TEST_EXPLORATION_ID_5) val expLogger = @@ -1537,10 +1516,8 @@ class LearnerAnalyticsLoggerTest { } @Test - @RunParameterized( - Iteration("no_install_id", "lid=learn", "iid=null", "elid=learn", "eid="), - Iteration("no_learner_id", "lid=null", "iid=install", "elid=", "eid=install") - ) + @Iteration("no_install_id", "lid=learn", "iid=null", "elid=learn", "eid=") + @Iteration("no_learner_id", "lid=null", "iid=install", "elid=", "eid=install") fun testStateAnalyticsLogger_logSubmitAnswer_missingOneId_logsEventWithMissingId() { val exploration5 = loadExploration(TEST_EXPLORATION_ID_5) val expLogger = @@ -1592,10 +1569,8 @@ class LearnerAnalyticsLoggerTest { } @Test - @RunParameterized( - Iteration("no_install_id", "lid=learn", "iid=null", "elid=learn", "eid="), - Iteration("no_learner_id", "lid=null", "iid=install", "elid=", "eid=install") - ) + @Iteration("no_install_id", "lid=learn", "iid=null", "elid=learn", "eid=") + @Iteration("no_learner_id", "lid=null", "iid=install", "elid=", "eid=install") fun testStateAnalyticsLogger_logPlayVoiceOver_missingOneId_logsEventWithMissingId() { val exploration5 = loadExploration(TEST_EXPLORATION_ID_5) val expLogger = @@ -1639,10 +1614,8 @@ class LearnerAnalyticsLoggerTest { } @Test - @RunParameterized( - Iteration("no_install_id", "lid=learn", "iid=null", "elid=learn", "eid="), - Iteration("no_learner_id", "lid=null", "iid=install", "elid=", "eid=install") - ) + @Iteration("no_install_id", "lid=learn", "iid=null", "elid=learn", "eid=") + @Iteration("no_learner_id", "lid=null", "iid=install", "elid=", "eid=install") fun testStateAnalyticsLogger_logPauseVoiceOver_missingOneId_logsEventWithMissingId() { val exploration5 = loadExploration(TEST_EXPLORATION_ID_5) val expLogger = diff --git a/testing/src/main/java/org/oppia/android/testing/junit/OppiaParameterizedTestRunner.kt b/testing/src/main/java/org/oppia/android/testing/junit/OppiaParameterizedTestRunner.kt index 4dd7b3427c7..d5bd87e8db1 100644 --- a/testing/src/main/java/org/oppia/android/testing/junit/OppiaParameterizedTestRunner.kt +++ b/testing/src/main/java/org/oppia/android/testing/junit/OppiaParameterizedTestRunner.kt @@ -8,7 +8,6 @@ import org.junit.runner.manipulation.Sortable import org.junit.runner.manipulation.Sorter import org.junit.runner.notification.RunNotifier import org.junit.runners.Suite -import java.lang.annotation.Repeatable import java.lang.reflect.Field import java.lang.reflect.Method import kotlin.reflect.KClass @@ -28,10 +27,10 @@ import kotlin.reflect.KClass * necessary Bazel dependencies). However, it will only support the platform(s) selected. * * To introduce parameterized tests, add this runner along with one or more [Parameter]-annotated - * fields and one or more [RunParameterized]-annotated methods (where each method should have - * multiple [Iteration]s defined to describe each test iteration). Note that only strings and - * primitive types (e.g. [Int], [Long], [Float], [Double], and [Boolean]) are supported for - * parameter injection. Here's a simple example: + * fields and one or more [Iteration]-annotated methods (where each method should have multiple + * [Iteration]s defined to describe each test iteration). Note that only strings and primitive types + * (e.g. [Int], [Long], [Float], [Double], and [Boolean]) are supported for parameter injection. + * Here's a simple example: * * ```kotlin * @RunWith(OppiaParameterizedTestRunner::class) @@ -41,11 +40,9 @@ import kotlin.reflect.KClass * @Parameter var intParam: Int = Int.MIN_VALUE // Inited because primitives can't be lateinit. * * @Test - * @RunParameterized( - * Iteration("first", "strParam=first value", "intParam=12"), - * Iteration("second", "strParam=second value", "intParam=-72"), - * Iteration("third", "strParam=third value", "intParam=15") - * ) + * @Iteration("first", "strParam=first value", "intParam=12") + * @Iteration("second", "strParam=second value", "intParam=-72") + * @Iteration("third", "strParam=third value", "intParam=15") * fun testParams_multipleVals_isConsistent() { * val result = performOperation(strParam, intParam) * assertThat(result).isEqualTo(consistentExpectedValue) @@ -71,10 +68,9 @@ import kotlin.reflect.KClass * ``` * * Finally, regular tests can be added by simply using the JUnit ``Test`` annotation without also - * annotating with [RunParameterized]. Such tests should not ever read from the - * [Parameter]-annotated fields since there's no way to ensure what values those fields will - * contain (thus they should be treated as undefined outside of tests that specific define their - * value via [Iteration]). + * annotating with [Iteration]. Such tests should not ever read from the [Parameter]-annotated + * fields since there's no way to ensure what values those fields will contain (thus they should be + * treated as undefined outside of tests that specific define their value via [Iteration]). */ class OppiaParameterizedTestRunner(private val testClass: Class<*>) : Suite(testClass, listOf()) { private val parameterizedMethods = computeParameterizedMethods() @@ -242,17 +238,7 @@ class OppiaParameterizedTestRunner(private val testClass: Class<*>) : Suite(test @Target(AnnotationTarget.FIELD) annotation class Parameter /** - * Specifies that a method in a test that uses a [OppiaParameterizedTestRunner] runner should be - * run multiple times for each [Iteration] specified in the [value] iterations list. - * - * See the KDoc for the runner for example code. - */ - @Target(AnnotationTarget.FUNCTION) annotation class RunParameterized(vararg val value: Iteration) - - // TODO(#4120): Migrate to Kotlin @Repeatable once Kotlin 1.6 is used (see: - // https://youtrack.jetbrains.com/issue/KT-12794). - /** - * Defines an iteration to run as part of a [RunParameterized]-annotated test method. + * Defines an iteration to run as part of a parameterized test method. * * See the KDoc for the runner for example code. * @@ -262,7 +248,7 @@ class OppiaParameterizedTestRunner(private val testClass: Class<*>) : Suite(test * a [Parameter]-annotated field and 'value' is a stringified conforming value based on the * type of that field (incompatible values will result in test failures) */ - @Repeatable(RunParameterized::class) + @Repeatable @Target(AnnotationTarget.FUNCTION) annotation class Iteration(val name: String, vararg val keyValuePairs: String) diff --git a/testing/src/test/java/org/oppia/android/testing/logging/TestSyncStatusManagerTest.kt b/testing/src/test/java/org/oppia/android/testing/logging/TestSyncStatusManagerTest.kt index e20b1fd1b62..e92463a7982 100644 --- a/testing/src/test/java/org/oppia/android/testing/logging/TestSyncStatusManagerTest.kt +++ b/testing/src/test/java/org/oppia/android/testing/logging/TestSyncStatusManagerTest.kt @@ -20,7 +20,6 @@ import org.oppia.android.testing.data.DataProviderTestMonitor import org.oppia.android.testing.junit.OppiaParameterizedTestRunner import org.oppia.android.testing.junit.OppiaParameterizedTestRunner.Iteration import org.oppia.android.testing.junit.OppiaParameterizedTestRunner.Parameter -import org.oppia.android.testing.junit.OppiaParameterizedTestRunner.RunParameterized import org.oppia.android.testing.junit.OppiaParameterizedTestRunner.SelectRunnerPlatform import org.oppia.android.testing.junit.ParameterizedRobolectricTestRunner import org.oppia.android.testing.networking.NetworkConnectionTestUtil @@ -199,14 +198,12 @@ class TestSyncStatusManagerTest : SyncStatusManagerTestBase() { } @Test - @RunParameterized( - Iteration("initial_unknown", "status=INITIAL_UNKNOWN"), - Iteration("waiting_to_start_uploading", "status=WAITING_TO_START_UPLOADING"), - Iteration("data_uploading", "status=DATA_UPLOADING"), - Iteration("data_uploaded", "status=DATA_UPLOADED"), - Iteration("no_connectivity", "status=NO_CONNECTIVITY"), - Iteration("upload_error", "status=UPLOAD_ERROR") - ) + @Iteration("initial_unknown", "status=INITIAL_UNKNOWN") + @Iteration("waiting_to_start_uploading", "status=WAITING_TO_START_UPLOADING") + @Iteration("data_uploading", "status=DATA_UPLOADING") + @Iteration("data_uploaded", "status=DATA_UPLOADED") + @Iteration("no_connectivity", "status=NO_CONNECTIVITY") + @Iteration("upload_error", "status=UPLOAD_ERROR") fun testGetSyncStatus_withInitedLogStore_forceStatus_noConnectivity_returnsForcedStatus() { val syncStatusProvider = impl.getSyncStatus() impl.initializeEventLogStore(logsCacheStore) @@ -221,14 +218,12 @@ class TestSyncStatusManagerTest : SyncStatusManagerTestBase() { } @Test - @RunParameterized( - Iteration("initial_unknown", "status=INITIAL_UNKNOWN"), - Iteration("waiting_to_start_uploading", "status=WAITING_TO_START_UPLOADING"), - Iteration("data_uploading", "status=DATA_UPLOADING"), - Iteration("data_uploaded", "status=DATA_UPLOADED"), - Iteration("no_connectivity", "status=NO_CONNECTIVITY"), - Iteration("upload_error", "status=UPLOAD_ERROR") - ) + @Iteration("initial_unknown", "status=INITIAL_UNKNOWN") + @Iteration("waiting_to_start_uploading", "status=WAITING_TO_START_UPLOADING") + @Iteration("data_uploading", "status=DATA_UPLOADING") + @Iteration("data_uploaded", "status=DATA_UPLOADED") + @Iteration("no_connectivity", "status=NO_CONNECTIVITY") + @Iteration("upload_error", "status=UPLOAD_ERROR") fun testGetSyncStatus_withInitedLogStore_forceStatus_noEvents_returnsForcedStatus() { val syncStatusProvider = impl.getSyncStatus() impl.initializeEventLogStore(logsCacheStore) @@ -243,14 +238,12 @@ class TestSyncStatusManagerTest : SyncStatusManagerTestBase() { } @Test - @RunParameterized( - Iteration("initial_unknown", "status=INITIAL_UNKNOWN"), - Iteration("waiting_to_start_uploading", "status=WAITING_TO_START_UPLOADING"), - Iteration("data_uploading", "status=DATA_UPLOADING"), - Iteration("data_uploaded", "status=DATA_UPLOADED"), - Iteration("no_connectivity", "status=NO_CONNECTIVITY"), - Iteration("upload_error", "status=UPLOAD_ERROR") - ) + @Iteration("initial_unknown", "status=INITIAL_UNKNOWN") + @Iteration("waiting_to_start_uploading", "status=WAITING_TO_START_UPLOADING") + @Iteration("data_uploading", "status=DATA_UPLOADING") + @Iteration("data_uploaded", "status=DATA_UPLOADED") + @Iteration("no_connectivity", "status=NO_CONNECTIVITY") + @Iteration("upload_error", "status=UPLOAD_ERROR") fun testGetSyncStatus_withInitedLogStore_forceStatus_withEvents_returnsForcedStatus() { val syncStatusProvider = impl.getSyncStatus() impl.initializeEventLogStore(logsCacheStore) @@ -267,14 +260,12 @@ class TestSyncStatusManagerTest : SyncStatusManagerTestBase() { } @Test - @RunParameterized( - Iteration("initial_unknown", "status=INITIAL_UNKNOWN"), - Iteration("waiting_to_start_uploading", "status=WAITING_TO_START_UPLOADING"), - Iteration("data_uploading", "status=DATA_UPLOADING"), - Iteration("data_uploaded", "status=DATA_UPLOADED"), - Iteration("no_connectivity", "status=NO_CONNECTIVITY"), - Iteration("upload_error", "status=UPLOAD_ERROR") - ) + @Iteration("initial_unknown", "status=INITIAL_UNKNOWN") + @Iteration("waiting_to_start_uploading", "status=WAITING_TO_START_UPLOADING") + @Iteration("data_uploading", "status=DATA_UPLOADING") + @Iteration("data_uploaded", "status=DATA_UPLOADED") + @Iteration("no_connectivity", "status=NO_CONNECTIVITY") + @Iteration("upload_error", "status=UPLOAD_ERROR") fun testGetSyncStatus_withInitedLogStore_forceStatus_withEvents_allRemoved_returnsForcedStatus() { val syncStatusProvider = impl.getSyncStatus() impl.initializeEventLogStore(logsCacheStore) @@ -293,14 +284,12 @@ class TestSyncStatusManagerTest : SyncStatusManagerTestBase() { } @Test - @RunParameterized( - Iteration("initial_unknown", "status=INITIAL_UNKNOWN"), - Iteration("waiting_to_start_uploading", "status=WAITING_TO_START_UPLOADING"), - Iteration("data_uploading", "status=DATA_UPLOADING"), - Iteration("data_uploaded", "status=DATA_UPLOADED"), - Iteration("no_connectivity", "status=NO_CONNECTIVITY"), - Iteration("upload_error", "status=UPLOAD_ERROR") - ) + @Iteration("initial_unknown", "status=INITIAL_UNKNOWN") + @Iteration("waiting_to_start_uploading", "status=WAITING_TO_START_UPLOADING") + @Iteration("data_uploading", "status=DATA_UPLOADING") + @Iteration("data_uploaded", "status=DATA_UPLOADED") + @Iteration("no_connectivity", "status=NO_CONNECTIVITY") + @Iteration("upload_error", "status=UPLOAD_ERROR") fun testGetSyncStatus_withInitedLogs_forceStatus_reportUploadingStarted_returnsForcedStatus() { val syncStatusProvider = impl.getSyncStatus() impl.initializeEventLogStore(logsCacheStore) @@ -317,14 +306,12 @@ class TestSyncStatusManagerTest : SyncStatusManagerTestBase() { } @Test - @RunParameterized( - Iteration("initial_unknown", "status=INITIAL_UNKNOWN"), - Iteration("waiting_to_start_uploading", "status=WAITING_TO_START_UPLOADING"), - Iteration("data_uploading", "status=DATA_UPLOADING"), - Iteration("data_uploaded", "status=DATA_UPLOADED"), - Iteration("no_connectivity", "status=NO_CONNECTIVITY"), - Iteration("upload_error", "status=UPLOAD_ERROR") - ) + @Iteration("initial_unknown", "status=INITIAL_UNKNOWN") + @Iteration("waiting_to_start_uploading", "status=WAITING_TO_START_UPLOADING") + @Iteration("data_uploading", "status=DATA_UPLOADING") + @Iteration("data_uploaded", "status=DATA_UPLOADED") + @Iteration("no_connectivity", "status=NO_CONNECTIVITY") + @Iteration("upload_error", "status=UPLOAD_ERROR") fun testGetSyncStatus_withInitedLogStore_forceStatus_reportUploadingEnded_returnsForcedStatus() { val syncStatusProvider = impl.getSyncStatus() impl.initializeEventLogStore(logsCacheStore) @@ -344,14 +331,12 @@ class TestSyncStatusManagerTest : SyncStatusManagerTestBase() { } @Test - @RunParameterized( - Iteration("initial_unknown", "status=INITIAL_UNKNOWN"), - Iteration("waiting_to_start_uploading", "status=WAITING_TO_START_UPLOADING"), - Iteration("data_uploading", "status=DATA_UPLOADING"), - Iteration("data_uploaded", "status=DATA_UPLOADED"), - Iteration("no_connectivity", "status=NO_CONNECTIVITY"), - Iteration("upload_error", "status=UPLOAD_ERROR") - ) + @Iteration("initial_unknown", "status=INITIAL_UNKNOWN") + @Iteration("waiting_to_start_uploading", "status=WAITING_TO_START_UPLOADING") + @Iteration("data_uploading", "status=DATA_UPLOADING") + @Iteration("data_uploaded", "status=DATA_UPLOADED") + @Iteration("no_connectivity", "status=NO_CONNECTIVITY") + @Iteration("upload_error", "status=UPLOAD_ERROR") fun testGetSyncStatus_withInitedLogStore_forceStatus_reportError_returnsForcedStatus() { val syncStatusProvider = impl.getSyncStatus() impl.initializeEventLogStore(logsCacheStore) @@ -367,14 +352,12 @@ class TestSyncStatusManagerTest : SyncStatusManagerTestBase() { } @Test - @RunParameterized( - Iteration("initial_unknown", "status=INITIAL_UNKNOWN"), - Iteration("waiting_to_start_uploading", "status=WAITING_TO_START_UPLOADING"), - Iteration("data_uploading", "status=DATA_UPLOADING"), - Iteration("data_uploaded", "status=DATA_UPLOADED"), - Iteration("no_connectivity", "status=NO_CONNECTIVITY"), - Iteration("upload_error", "status=UPLOAD_ERROR") - ) + @Iteration("initial_unknown", "status=INITIAL_UNKNOWN") + @Iteration("waiting_to_start_uploading", "status=WAITING_TO_START_UPLOADING") + @Iteration("data_uploading", "status=DATA_UPLOADING") + @Iteration("data_uploaded", "status=DATA_UPLOADED") + @Iteration("no_connectivity", "status=NO_CONNECTIVITY") + @Iteration("upload_error", "status=UPLOAD_ERROR") fun testGetSyncStatus_initialState_resetStatus_returnsInitialUnknown() { val syncStatusProvider = impl.getSyncStatus() impl.forceSyncStatus(syncStatus) @@ -389,14 +372,12 @@ class TestSyncStatusManagerTest : SyncStatusManagerTestBase() { } @Test - @RunParameterized( - Iteration("initial_unknown", "status=INITIAL_UNKNOWN"), - Iteration("waiting_to_start_uploading", "status=WAITING_TO_START_UPLOADING"), - Iteration("data_uploading", "status=DATA_UPLOADING"), - Iteration("data_uploaded", "status=DATA_UPLOADED"), - Iteration("no_connectivity", "status=NO_CONNECTIVITY"), - Iteration("upload_error", "status=UPLOAD_ERROR") - ) + @Iteration("initial_unknown", "status=INITIAL_UNKNOWN") + @Iteration("waiting_to_start_uploading", "status=WAITING_TO_START_UPLOADING") + @Iteration("data_uploading", "status=DATA_UPLOADING") + @Iteration("data_uploaded", "status=DATA_UPLOADED") + @Iteration("no_connectivity", "status=NO_CONNECTIVITY") + @Iteration("upload_error", "status=UPLOAD_ERROR") fun testGetSyncStatus_withInitedLogStore_resetStatus_noConnectivity_returnsNoConnectivity() { val syncStatusProvider = impl.getSyncStatus() impl.initializeEventLogStore(logsCacheStore) @@ -414,14 +395,12 @@ class TestSyncStatusManagerTest : SyncStatusManagerTestBase() { } @Test - @RunParameterized( - Iteration("initial_unknown", "status=INITIAL_UNKNOWN"), - Iteration("waiting_to_start_uploading", "status=WAITING_TO_START_UPLOADING"), - Iteration("data_uploading", "status=DATA_UPLOADING"), - Iteration("data_uploaded", "status=DATA_UPLOADED"), - Iteration("no_connectivity", "status=NO_CONNECTIVITY"), - Iteration("upload_error", "status=UPLOAD_ERROR") - ) + @Iteration("initial_unknown", "status=INITIAL_UNKNOWN") + @Iteration("waiting_to_start_uploading", "status=WAITING_TO_START_UPLOADING") + @Iteration("data_uploading", "status=DATA_UPLOADING") + @Iteration("data_uploaded", "status=DATA_UPLOADED") + @Iteration("no_connectivity", "status=NO_CONNECTIVITY") + @Iteration("upload_error", "status=UPLOAD_ERROR") fun testGetSyncStatus_withInitedLogStore_resetStatus_noEvents_returnsInitialUnknown() { val syncStatusProvider = impl.getSyncStatus() impl.initializeEventLogStore(logsCacheStore) @@ -438,14 +417,12 @@ class TestSyncStatusManagerTest : SyncStatusManagerTestBase() { } @Test - @RunParameterized( - Iteration("initial_unknown", "status=INITIAL_UNKNOWN"), - Iteration("waiting_to_start_uploading", "status=WAITING_TO_START_UPLOADING"), - Iteration("data_uploading", "status=DATA_UPLOADING"), - Iteration("data_uploaded", "status=DATA_UPLOADED"), - Iteration("no_connectivity", "status=NO_CONNECTIVITY"), - Iteration("upload_error", "status=UPLOAD_ERROR") - ) + @Iteration("initial_unknown", "status=INITIAL_UNKNOWN") + @Iteration("waiting_to_start_uploading", "status=WAITING_TO_START_UPLOADING") + @Iteration("data_uploading", "status=DATA_UPLOADING") + @Iteration("data_uploaded", "status=DATA_UPLOADED") + @Iteration("no_connectivity", "status=NO_CONNECTIVITY") + @Iteration("upload_error", "status=UPLOAD_ERROR") fun testGetSyncStatus_withInitedLogStore_resetStatus_withEvents_returnsWaitingToStartUploading() { val syncStatusProvider = impl.getSyncStatus() impl.initializeEventLogStore(logsCacheStore) @@ -464,14 +441,12 @@ class TestSyncStatusManagerTest : SyncStatusManagerTestBase() { } @Test - @RunParameterized( - Iteration("initial_unknown", "status=INITIAL_UNKNOWN"), - Iteration("waiting_to_start_uploading", "status=WAITING_TO_START_UPLOADING"), - Iteration("data_uploading", "status=DATA_UPLOADING"), - Iteration("data_uploaded", "status=DATA_UPLOADED"), - Iteration("no_connectivity", "status=NO_CONNECTIVITY"), - Iteration("upload_error", "status=UPLOAD_ERROR") - ) + @Iteration("initial_unknown", "status=INITIAL_UNKNOWN") + @Iteration("waiting_to_start_uploading", "status=WAITING_TO_START_UPLOADING") + @Iteration("data_uploading", "status=DATA_UPLOADING") + @Iteration("data_uploaded", "status=DATA_UPLOADED") + @Iteration("no_connectivity", "status=NO_CONNECTIVITY") + @Iteration("upload_error", "status=UPLOAD_ERROR") fun testGetSyncStatus_withInitedLogStore_resetStatus_withEvents_allRemoved_returnsDataUploaded() { val syncStatusProvider = impl.getSyncStatus() impl.initializeEventLogStore(logsCacheStore) @@ -492,14 +467,12 @@ class TestSyncStatusManagerTest : SyncStatusManagerTestBase() { } @Test - @RunParameterized( - Iteration("initial_unknown", "status=INITIAL_UNKNOWN"), - Iteration("waiting_to_start_uploading", "status=WAITING_TO_START_UPLOADING"), - Iteration("data_uploading", "status=DATA_UPLOADING"), - Iteration("data_uploaded", "status=DATA_UPLOADED"), - Iteration("no_connectivity", "status=NO_CONNECTIVITY"), - Iteration("upload_error", "status=UPLOAD_ERROR") - ) + @Iteration("initial_unknown", "status=INITIAL_UNKNOWN") + @Iteration("waiting_to_start_uploading", "status=WAITING_TO_START_UPLOADING") + @Iteration("data_uploading", "status=DATA_UPLOADING") + @Iteration("data_uploaded", "status=DATA_UPLOADED") + @Iteration("no_connectivity", "status=NO_CONNECTIVITY") + @Iteration("upload_error", "status=UPLOAD_ERROR") fun testGetSyncStatus_withInitedLogStore_resetStatus_reportUploadingStarted_returnsUploading() { val syncStatusProvider = impl.getSyncStatus() impl.initializeEventLogStore(logsCacheStore) @@ -518,14 +491,12 @@ class TestSyncStatusManagerTest : SyncStatusManagerTestBase() { } @Test - @RunParameterized( - Iteration("initial_unknown", "status=INITIAL_UNKNOWN"), - Iteration("waiting_to_start_uploading", "status=WAITING_TO_START_UPLOADING"), - Iteration("data_uploading", "status=DATA_UPLOADING"), - Iteration("data_uploaded", "status=DATA_UPLOADED"), - Iteration("no_connectivity", "status=NO_CONNECTIVITY"), - Iteration("upload_error", "status=UPLOAD_ERROR") - ) + @Iteration("initial_unknown", "status=INITIAL_UNKNOWN") + @Iteration("waiting_to_start_uploading", "status=WAITING_TO_START_UPLOADING") + @Iteration("data_uploading", "status=DATA_UPLOADING") + @Iteration("data_uploaded", "status=DATA_UPLOADED") + @Iteration("no_connectivity", "status=NO_CONNECTIVITY") + @Iteration("upload_error", "status=UPLOAD_ERROR") fun testGetSyncStatus_withInitedLogStore_resetStatus_reportUploadingEnded_returnsUploaded() { val syncStatusProvider = impl.getSyncStatus() impl.initializeEventLogStore(logsCacheStore) @@ -546,14 +517,12 @@ class TestSyncStatusManagerTest : SyncStatusManagerTestBase() { } @Test - @RunParameterized( - Iteration("initial_unknown", "status=INITIAL_UNKNOWN"), - Iteration("waiting_to_start_uploading", "status=WAITING_TO_START_UPLOADING"), - Iteration("data_uploading", "status=DATA_UPLOADING"), - Iteration("data_uploaded", "status=DATA_UPLOADED"), - Iteration("no_connectivity", "status=NO_CONNECTIVITY"), - Iteration("upload_error", "status=UPLOAD_ERROR") - ) + @Iteration("initial_unknown", "status=INITIAL_UNKNOWN") + @Iteration("waiting_to_start_uploading", "status=WAITING_TO_START_UPLOADING") + @Iteration("data_uploading", "status=DATA_UPLOADING") + @Iteration("data_uploaded", "status=DATA_UPLOADED") + @Iteration("no_connectivity", "status=NO_CONNECTIVITY") + @Iteration("upload_error", "status=UPLOAD_ERROR") fun testGetSyncStatus_withInitedLogStore_resetStatus_reportError_returnsUploadError() { val syncStatusProvider = impl.getSyncStatus() impl.initializeEventLogStore(logsCacheStore) @@ -745,14 +714,12 @@ class TestSyncStatusManagerTest : SyncStatusManagerTestBase() { } @Test - @RunParameterized( - Iteration("initial_unknown", "status=INITIAL_UNKNOWN"), - Iteration("waiting_to_start_uploading", "status=WAITING_TO_START_UPLOADING"), - Iteration("data_uploading", "status=DATA_UPLOADING"), - Iteration("data_uploaded", "status=DATA_UPLOADED"), - Iteration("no_connectivity", "status=NO_CONNECTIVITY"), - Iteration("upload_error", "status=UPLOAD_ERROR") - ) + @Iteration("initial_unknown", "status=INITIAL_UNKNOWN") + @Iteration("waiting_to_start_uploading", "status=WAITING_TO_START_UPLOADING") + @Iteration("data_uploading", "status=DATA_UPLOADING") + @Iteration("data_uploaded", "status=DATA_UPLOADED") + @Iteration("no_connectivity", "status=NO_CONNECTIVITY") + @Iteration("upload_error", "status=UPLOAD_ERROR") fun testGetSyncStatuses_initialState_forceStatus_returnsWithForcedStatus() { impl.forceSyncStatus(syncStatus) testCoroutineDispatchers.runCurrent() @@ -764,14 +731,12 @@ class TestSyncStatusManagerTest : SyncStatusManagerTestBase() { } @Test - @RunParameterized( - Iteration("initial_unknown", "status=INITIAL_UNKNOWN"), - Iteration("waiting_to_start_uploading", "status=WAITING_TO_START_UPLOADING"), - Iteration("data_uploading", "status=DATA_UPLOADING"), - Iteration("data_uploaded", "status=DATA_UPLOADED"), - Iteration("no_connectivity", "status=NO_CONNECTIVITY"), - Iteration("upload_error", "status=UPLOAD_ERROR") - ) + @Iteration("initial_unknown", "status=INITIAL_UNKNOWN") + @Iteration("waiting_to_start_uploading", "status=WAITING_TO_START_UPLOADING") + @Iteration("data_uploading", "status=DATA_UPLOADING") + @Iteration("data_uploaded", "status=DATA_UPLOADED") + @Iteration("no_connectivity", "status=NO_CONNECTIVITY") + @Iteration("upload_error", "status=UPLOAD_ERROR") fun testGetSyncStatuses_withInitedLogStore_forceStatus_noConnectivity_returnsWithForcedStatus() { impl.initializeEventLogStore(logsCacheStore) disconnectNetwork() @@ -785,14 +750,12 @@ class TestSyncStatusManagerTest : SyncStatusManagerTestBase() { } @Test - @RunParameterized( - Iteration("initial_unknown", "status=INITIAL_UNKNOWN"), - Iteration("waiting_to_start_uploading", "status=WAITING_TO_START_UPLOADING"), - Iteration("data_uploading", "status=DATA_UPLOADING"), - Iteration("data_uploaded", "status=DATA_UPLOADED"), - Iteration("no_connectivity", "status=NO_CONNECTIVITY"), - Iteration("upload_error", "status=UPLOAD_ERROR") - ) + @Iteration("initial_unknown", "status=INITIAL_UNKNOWN") + @Iteration("waiting_to_start_uploading", "status=WAITING_TO_START_UPLOADING") + @Iteration("data_uploading", "status=DATA_UPLOADING") + @Iteration("data_uploaded", "status=DATA_UPLOADED") + @Iteration("no_connectivity", "status=NO_CONNECTIVITY") + @Iteration("upload_error", "status=UPLOAD_ERROR") fun testGetSyncStatuses_withInitedLogStore_forceStatus_noEvents_returnsWithForcedStatus() { impl.initializeEventLogStore(logsCacheStore) connectNetwork() @@ -806,14 +769,12 @@ class TestSyncStatusManagerTest : SyncStatusManagerTestBase() { } @Test - @RunParameterized( - Iteration("initial_unknown", "status=INITIAL_UNKNOWN"), - Iteration("waiting_to_start_uploading", "status=WAITING_TO_START_UPLOADING"), - Iteration("data_uploading", "status=DATA_UPLOADING"), - Iteration("data_uploaded", "status=DATA_UPLOADED"), - Iteration("no_connectivity", "status=NO_CONNECTIVITY"), - Iteration("upload_error", "status=UPLOAD_ERROR") - ) + @Iteration("initial_unknown", "status=INITIAL_UNKNOWN") + @Iteration("waiting_to_start_uploading", "status=WAITING_TO_START_UPLOADING") + @Iteration("data_uploading", "status=DATA_UPLOADING") + @Iteration("data_uploaded", "status=DATA_UPLOADED") + @Iteration("no_connectivity", "status=NO_CONNECTIVITY") + @Iteration("upload_error", "status=UPLOAD_ERROR") fun testGetSyncStatuses_withInitedLogStore_forceStatus_withEvents_returnsWithForcedStatus() { impl.initializeEventLogStore(logsCacheStore) connectNetwork() @@ -829,14 +790,12 @@ class TestSyncStatusManagerTest : SyncStatusManagerTestBase() { } @Test - @RunParameterized( - Iteration("initial_unknown", "status=INITIAL_UNKNOWN"), - Iteration("waiting_to_start_uploading", "status=WAITING_TO_START_UPLOADING"), - Iteration("data_uploading", "status=DATA_UPLOADING"), - Iteration("data_uploaded", "status=DATA_UPLOADED"), - Iteration("no_connectivity", "status=NO_CONNECTIVITY"), - Iteration("upload_error", "status=UPLOAD_ERROR") - ) + @Iteration("initial_unknown", "status=INITIAL_UNKNOWN") + @Iteration("waiting_to_start_uploading", "status=WAITING_TO_START_UPLOADING") + @Iteration("data_uploading", "status=DATA_UPLOADING") + @Iteration("data_uploaded", "status=DATA_UPLOADED") + @Iteration("no_connectivity", "status=NO_CONNECTIVITY") + @Iteration("upload_error", "status=UPLOAD_ERROR") fun testGetSyncStatuses_withLogStore_forceStatus_withEvents_allRemoved_returnsWithForcedStatus() { impl.initializeEventLogStore(logsCacheStore) connectNetwork() @@ -854,14 +813,12 @@ class TestSyncStatusManagerTest : SyncStatusManagerTestBase() { } @Test - @RunParameterized( - Iteration("initial_unknown", "status=INITIAL_UNKNOWN"), - Iteration("waiting_to_start_uploading", "status=WAITING_TO_START_UPLOADING"), - Iteration("data_uploading", "status=DATA_UPLOADING"), - Iteration("data_uploaded", "status=DATA_UPLOADED"), - Iteration("no_connectivity", "status=NO_CONNECTIVITY"), - Iteration("upload_error", "status=UPLOAD_ERROR") - ) + @Iteration("initial_unknown", "status=INITIAL_UNKNOWN") + @Iteration("waiting_to_start_uploading", "status=WAITING_TO_START_UPLOADING") + @Iteration("data_uploading", "status=DATA_UPLOADING") + @Iteration("data_uploaded", "status=DATA_UPLOADED") + @Iteration("no_connectivity", "status=NO_CONNECTIVITY") + @Iteration("upload_error", "status=UPLOAD_ERROR") fun testGetSyncStatuses_withLogStore_forceStatus_reportUploading_returnsWithForcedStatus() { impl.initializeEventLogStore(logsCacheStore) connectNetwork() @@ -878,14 +835,12 @@ class TestSyncStatusManagerTest : SyncStatusManagerTestBase() { } @Test - @RunParameterized( - Iteration("initial_unknown", "status=INITIAL_UNKNOWN"), - Iteration("waiting_to_start_uploading", "status=WAITING_TO_START_UPLOADING"), - Iteration("data_uploading", "status=DATA_UPLOADING"), - Iteration("data_uploaded", "status=DATA_UPLOADED"), - Iteration("no_connectivity", "status=NO_CONNECTIVITY"), - Iteration("upload_error", "status=UPLOAD_ERROR") - ) + @Iteration("initial_unknown", "status=INITIAL_UNKNOWN") + @Iteration("waiting_to_start_uploading", "status=WAITING_TO_START_UPLOADING") + @Iteration("data_uploading", "status=DATA_UPLOADING") + @Iteration("data_uploaded", "status=DATA_UPLOADED") + @Iteration("no_connectivity", "status=NO_CONNECTIVITY") + @Iteration("upload_error", "status=UPLOAD_ERROR") fun testGetSyncStatuses_withLogStore_forceStatus_reportUploadingEnded_returnsWithForcedStatus() { impl.initializeEventLogStore(logsCacheStore) connectNetwork() @@ -905,14 +860,12 @@ class TestSyncStatusManagerTest : SyncStatusManagerTestBase() { } @Test - @RunParameterized( - Iteration("initial_unknown", "status=INITIAL_UNKNOWN"), - Iteration("waiting_to_start_uploading", "status=WAITING_TO_START_UPLOADING"), - Iteration("data_uploading", "status=DATA_UPLOADING"), - Iteration("data_uploaded", "status=DATA_UPLOADED"), - Iteration("no_connectivity", "status=NO_CONNECTIVITY"), - Iteration("upload_error", "status=UPLOAD_ERROR") - ) + @Iteration("initial_unknown", "status=INITIAL_UNKNOWN") + @Iteration("waiting_to_start_uploading", "status=WAITING_TO_START_UPLOADING") + @Iteration("data_uploading", "status=DATA_UPLOADING") + @Iteration("data_uploaded", "status=DATA_UPLOADED") + @Iteration("no_connectivity", "status=NO_CONNECTIVITY") + @Iteration("upload_error", "status=UPLOAD_ERROR") fun testGetSyncStatuses_withInitedLogStore_forceStatus_reportError_returnsWithForcedStatus() { impl.initializeEventLogStore(logsCacheStore) connectNetwork() diff --git a/utility/src/test/java/org/oppia/android/util/logging/EventBundleCreatorTest.kt b/utility/src/test/java/org/oppia/android/util/logging/EventBundleCreatorTest.kt index b1fa6410ad9..9bff0c39dc2 100644 --- a/utility/src/test/java/org/oppia/android/util/logging/EventBundleCreatorTest.kt +++ b/utility/src/test/java/org/oppia/android/util/logging/EventBundleCreatorTest.kt @@ -85,7 +85,6 @@ import org.oppia.android.app.model.WrittenTranslationLanguageSelection import org.oppia.android.testing.junit.OppiaParameterizedTestRunner import org.oppia.android.testing.junit.OppiaParameterizedTestRunner.Iteration import org.oppia.android.testing.junit.OppiaParameterizedTestRunner.Parameter -import org.oppia.android.testing.junit.OppiaParameterizedTestRunner.RunParameterized import org.oppia.android.testing.junit.OppiaParameterizedTestRunner.SelectRunnerPlatform import org.oppia.android.testing.junit.ParameterizedRobolectricTestRunner import org.oppia.android.util.platformparameter.EnableLearnerStudyAnalytics @@ -275,16 +274,14 @@ class EventBundleCreatorTest { } @Test - @RunParameterized( - Iteration("lang_unspecified", "inLang=LANGUAGE_UNSPECIFIED", "expLang=unspecified_language"), - Iteration("ar", "inLang=ARABIC", "expLang=Arabic"), - Iteration("en", "inLang=ENGLISH", "expLang=English"), - Iteration("hi", "inLang=HINDI", "expLang=Hindi"), - Iteration("hi_en", "inLang=HINGLISH", "expLang=Hinglish"), - Iteration("pt", "inLang=PORTUGUESE", "expLang=Portuguese"), - Iteration("pt_br", "inLang=BRAZILIAN_PORTUGUESE", "expLang=Brazilian Portuguese"), - Iteration("sw", "inLang=SWAHILI", "expLang=Swahili") - ) + @Iteration("lang_unspecified", "inLang=LANGUAGE_UNSPECIFIED", "expLang=unspecified_language") + @Iteration("ar", "inLang=ARABIC", "expLang=Arabic") + @Iteration("en", "inLang=ENGLISH", "expLang=English") + @Iteration("hi", "inLang=HINDI", "expLang=Hindi") + @Iteration("hi_en", "inLang=HINGLISH", "expLang=Hinglish") + @Iteration("pt", "inLang=PORTUGUESE", "expLang=Portuguese") + @Iteration("pt_br", "inLang=BRAZILIAN_PORTUGUESE", "expLang=Brazilian Portuguese") + @Iteration("sw", "inLang=SWAHILI", "expLang=Swahili") fun testFillEventBundle_eventWithSelectedAppLanguage_savesCorrectAppLanguageInBundle() { setUpTestApplicationComponent() val bundle = Bundle() @@ -315,16 +312,14 @@ class EventBundleCreatorTest { } @Test - @RunParameterized( - Iteration("lang_unspecified", "inLang=LANGUAGE_UNSPECIFIED", "expLang=unspecified_language"), - Iteration("ar", "inLang=ARABIC", "expLang=Arabic"), - Iteration("en", "inLang=ENGLISH", "expLang=English"), - Iteration("hi", "inLang=HINDI", "expLang=Hindi"), - Iteration("hi_en", "inLang=HINGLISH", "expLang=Hinglish"), - Iteration("pt", "inLang=PORTUGUESE", "expLang=Portuguese"), - Iteration("pt_br", "inLang=BRAZILIAN_PORTUGUESE", "expLang=Brazilian Portuguese"), - Iteration("sw", "inLang=SWAHILI", "expLang=Swahili") - ) + @Iteration("lang_unspecified", "inLang=LANGUAGE_UNSPECIFIED", "expLang=unspecified_language") + @Iteration("ar", "inLang=ARABIC", "expLang=Arabic") + @Iteration("en", "inLang=ENGLISH", "expLang=English") + @Iteration("hi", "inLang=HINDI", "expLang=Hindi") + @Iteration("hi_en", "inLang=HINGLISH", "expLang=Hinglish") + @Iteration("pt", "inLang=PORTUGUESE", "expLang=Portuguese") + @Iteration("pt_br", "inLang=BRAZILIAN_PORTUGUESE", "expLang=Brazilian Portuguese") + @Iteration("sw", "inLang=SWAHILI", "expLang=Swahili") fun testFillEventBundle_eventWithSelectedWrittenTranslationsLanguage_savesCorrectWrittenLang() { setUpTestApplicationComponent() val bundle = Bundle() @@ -353,16 +348,14 @@ class EventBundleCreatorTest { } @Test - @RunParameterized( - Iteration("lang_unspecified", "inLang=LANGUAGE_UNSPECIFIED", "expLang=unspecified_language"), - Iteration("ar", "inLang=ARABIC", "expLang=Arabic"), - Iteration("en", "inLang=ENGLISH", "expLang=English"), - Iteration("hi", "inLang=HINDI", "expLang=Hindi"), - Iteration("hi_en", "inLang=HINGLISH", "expLang=Hinglish"), - Iteration("pt", "inLang=PORTUGUESE", "expLang=Portuguese"), - Iteration("pt_br", "inLang=BRAZILIAN_PORTUGUESE", "expLang=Brazilian Portuguese"), - Iteration("sw", "inLang=SWAHILI", "expLang=Swahili") - ) + @Iteration("lang_unspecified", "inLang=LANGUAGE_UNSPECIFIED", "expLang=unspecified_language") + @Iteration("ar", "inLang=ARABIC", "expLang=Arabic") + @Iteration("en", "inLang=ENGLISH", "expLang=English") + @Iteration("hi", "inLang=HINDI", "expLang=Hindi") + @Iteration("hi_en", "inLang=HINGLISH", "expLang=Hinglish") + @Iteration("pt", "inLang=PORTUGUESE", "expLang=Portuguese") + @Iteration("pt_br", "inLang=BRAZILIAN_PORTUGUESE", "expLang=Brazilian Portuguese") + @Iteration("sw", "inLang=SWAHILI", "expLang=Swahili") fun testFillEventBundle_eventWithSelectedAudioTranslationsLanguage_savesCorrectAudioLang() { setUpTestApplicationComponent() val bundle = Bundle() @@ -1844,145 +1837,143 @@ class EventBundleCreatorTest { } @Test - @RunParameterized( - Iteration("home", "name=HOME_ACTIVITY", "expNameStr=home_activity"), - Iteration("splash", "name=SPLASH_ACTIVITY", "expNameStr=splash_activity"), - Iteration( - "profileChooser", - "name=PROFILE_CHOOSER_ACTIVITY", - "expNameStr=profile_chooser_activity" - ), - Iteration("addProfile", "name=ADD_PROFILE_ACTIVITY", "expNameStr=add_profile_activity"), - Iteration("background", "name=BACKGROUND_SCREEN", "expNameStr=background_screen"), - Iteration("appVersion", "name=APP_VERSION_ACTIVITY", "expNameStr=app_version_activity"), - Iteration( - "administratorControls", - "name=ADMINISTRATOR_CONTROLS_ACTIVITY", - "expNameStr=administrator_controls_activity" - ), - Iteration( - "profileAndDeviceId", - "name=PROFILE_AND_DEVICE_ID_ACTIVITY", - "expNameStr=profile_and_device_id_activity" - ), - Iteration( - "completedStoryList", - "name=COMPLETED_STORY_LIST_ACTIVITY", - "expNameStr=completed_story_list_activity" - ), - Iteration("faqSingle", "name=FAQ_SINGLE_ACTIVITY", "expNameStr=faq_single_activity"), - Iteration("faqList", "name=FAQ_LIST_ACTIVITY", "expNameStr=faq_list_activity"), - Iteration("licenseList", "name=LICENSE_LIST_ACTIVITY", "expNameStr=license_list_activity"), - Iteration( - "licenseTextViewer", - "name=LICENSE_TEXT_VIEWER_ACTIVITY", - "expNameStr=license_text_viewer_activity" - ), - Iteration( - "thirdPartyDependencyList", - "name=THIRD_PARTY_DEPENDENCY_LIST_ACTIVITY", - "expNameStr=third_party_dependency_list_activity" - ), - Iteration("help", "name=HELP_ACTIVITY", "expNameStr=help_activity"), - Iteration( - "recentlyPlayed", - "name=RECENTLY_PLAYED_ACTIVITY", - "expNameStr=recently_played_activity" - ), - Iteration("myDownloads", "name=MY_DOWNLOADS_ACTIVITY", "expNameStr=my_downloads_activity"), - Iteration("onboarding", "name=ONBOARDING_ACTIVITY", "expNameStr=onboarding_activity"), - Iteration( - "ongoingTopicList", - "name=ONGOING_TOPIC_LIST_ACTIVITY", - "expNameStr=ongoing_topic_list_activity" - ), - Iteration( - "audioLanguage", - "name=AUDIO_LANGUAGE_ACTIVITY", - "expNameStr=audio_language_activity" - ), - Iteration("appLanguage", "name=APP_LANGUAGE_ACTIVITY", "expNameStr=app_language_activity"), - Iteration("options", "name=OPTIONS_ACTIVITY", "expNameStr=options_activity"), - Iteration( - "readingTextSize", - "name=READING_TEXT_SIZE_ACTIVITY", - "expNameStr=reading_text_size_activity" - ), - Iteration("exploration", "name=EXPLORATION_ACTIVITY", "expNameStr=exploration_activity"), - Iteration("adminAuth", "name=ADMIN_AUTH_ACTIVITY", "expNameStr=admin_auth_activity"), - Iteration("pinPassword", "name=PIN_PASSWORD_ACTIVITY", "expNameStr=pin_password_activity"), - Iteration( - "profilePicture", - "name=PROFILE_PICTURE_ACTIVITY", - "expNameStr=profile_picture_activity" - ), - Iteration( - "profileProgress", - "name=PROFILE_PROGRESS_ACTIVITY", - "expNameStr=profile_progress_activity" - ), - Iteration("resumeLesson", "name=RESUME_LESSON_ACTIVITY", "expNameStr=resume_lesson_activity"), - Iteration("profileEdit", "name=PROFILE_EDIT_ACTIVITY", "expNameStr=profile_edit_activity"), - Iteration( - "profileResetPin", - "name=PROFILE_RESET_PIN_ACTIVITY", - "expNameStr=profile_reset_pin_activity" - ), - Iteration( - "profileRename", - "name=PROFILE_RENAME_ACTIVITY", - "expNameStr=profile_rename_activity" - ), - Iteration("profileList", "name=PROFILE_LIST_ACTIVITY", "expNameStr=profile_list_activity"), - Iteration("story", "name=STORY_ACTIVITY", "expNameStr=story_activity"), - Iteration("topic", "name=TOPIC_ACTIVITY", "expNameStr=topic_activity"), - Iteration("revisionCard", "name=REVISION_CARD_ACTIVITY", "expNameStr=revision_card_activity"), - Iteration( - "questionPlayer", - "name=QUESTION_PLAYER_ACTIVITY", - "expNameStr=question_player_activity" - ), - Iteration("walkthrough", "name=WALKTHROUGH_ACTIVITY", "expNameStr=walkthrough_activity"), - Iteration( - "developerOptions", - "name=DEVELOPER_OPTIONS_ACTIVITY", - "expNameStr=developer_options_activity" - ), - Iteration( - "viewEventLogs", - "name=VIEW_EVENT_LOGS_ACTIVITY", - "expNameStr=view_event_logs_activity" - ), - Iteration( - "markTopicsCompleted", - "name=MARK_TOPICS_COMPLETED_ACTIVITY", - "expNameStr=mark_topics_completed_activity" - ), - Iteration( - "mathExpressionParser", - "name=MATH_EXPRESSION_PARSER_ACTIVITY", - "expNameStr=math_expression_parser_activity" - ), - Iteration( - "markChaptersCompleted", - "name=MARK_CHAPTERS_COMPLETED_ACTIVITY", - "expNameStr=mark_chapters_completed_activity" - ), - Iteration( - "markStoriesCompleted", - "name=MARK_STORIES_COMPLETED_ACTIVITY", - "expNameStr=mark_stories_completed_activity" - ), - Iteration( - "forceNetworkType", - "name=FORCE_NETWORK_TYPE_ACTIVITY", - "expNameStr=force_network_type_activity" - ), - Iteration("adminPin", "name=ADMIN_PIN_ACTIVITY", "expNameStr=admin_pin_activity"), - Iteration("policies", "name=POLICIES_ACTIVITY", "expNameStr=policies_activity"), - Iteration("unspecified", "name=SCREEN_NAME_UNSPECIFIED", "expNameStr=screen_name_unspecified"), - Iteration("foreground", "name=FOREGROUND_SCREEN", "expNameStr=foreground_screen"), + @Iteration("home", "name=HOME_ACTIVITY", "expNameStr=home_activity") + @Iteration("splash", "name=SPLASH_ACTIVITY", "expNameStr=splash_activity") + @Iteration( + "profileChooser", + "name=PROFILE_CHOOSER_ACTIVITY", + "expNameStr=profile_chooser_activity" + ) + @Iteration("addProfile", "name=ADD_PROFILE_ACTIVITY", "expNameStr=add_profile_activity") + @Iteration("background", "name=BACKGROUND_SCREEN", "expNameStr=background_screen") + @Iteration("appVersion", "name=APP_VERSION_ACTIVITY", "expNameStr=app_version_activity") + @Iteration( + "administratorControls", + "name=ADMINISTRATOR_CONTROLS_ACTIVITY", + "expNameStr=administrator_controls_activity" + ) + @Iteration( + "profileAndDeviceId", + "name=PROFILE_AND_DEVICE_ID_ACTIVITY", + "expNameStr=profile_and_device_id_activity" + ) + @Iteration( + "completedStoryList", + "name=COMPLETED_STORY_LIST_ACTIVITY", + "expNameStr=completed_story_list_activity" + ) + @Iteration("faqSingle", "name=FAQ_SINGLE_ACTIVITY", "expNameStr=faq_single_activity") + @Iteration("faqList", "name=FAQ_LIST_ACTIVITY", "expNameStr=faq_list_activity") + @Iteration("licenseList", "name=LICENSE_LIST_ACTIVITY", "expNameStr=license_list_activity") + @Iteration( + "licenseTextViewer", + "name=LICENSE_TEXT_VIEWER_ACTIVITY", + "expNameStr=license_text_viewer_activity" + ) + @Iteration( + "thirdPartyDependencyList", + "name=THIRD_PARTY_DEPENDENCY_LIST_ACTIVITY", + "expNameStr=third_party_dependency_list_activity" + ) + @Iteration("help", "name=HELP_ACTIVITY", "expNameStr=help_activity") + @Iteration( + "recentlyPlayed", + "name=RECENTLY_PLAYED_ACTIVITY", + "expNameStr=recently_played_activity" + ) + @Iteration("myDownloads", "name=MY_DOWNLOADS_ACTIVITY", "expNameStr=my_downloads_activity") + @Iteration("onboarding", "name=ONBOARDING_ACTIVITY", "expNameStr=onboarding_activity") + @Iteration( + "ongoingTopicList", + "name=ONGOING_TOPIC_LIST_ACTIVITY", + "expNameStr=ongoing_topic_list_activity" + ) + @Iteration( + "audioLanguage", + "name=AUDIO_LANGUAGE_ACTIVITY", + "expNameStr=audio_language_activity" + ) + @Iteration("appLanguage", "name=APP_LANGUAGE_ACTIVITY", "expNameStr=app_language_activity") + @Iteration("options", "name=OPTIONS_ACTIVITY", "expNameStr=options_activity") + @Iteration( + "readingTextSize", + "name=READING_TEXT_SIZE_ACTIVITY", + "expNameStr=reading_text_size_activity" + ) + @Iteration("exploration", "name=EXPLORATION_ACTIVITY", "expNameStr=exploration_activity") + @Iteration("adminAuth", "name=ADMIN_AUTH_ACTIVITY", "expNameStr=admin_auth_activity") + @Iteration("pinPassword", "name=PIN_PASSWORD_ACTIVITY", "expNameStr=pin_password_activity") + @Iteration( + "profilePicture", + "name=PROFILE_PICTURE_ACTIVITY", + "expNameStr=profile_picture_activity" + ) + @Iteration( + "profileProgress", + "name=PROFILE_PROGRESS_ACTIVITY", + "expNameStr=profile_progress_activity" + ) + @Iteration("resumeLesson", "name=RESUME_LESSON_ACTIVITY", "expNameStr=resume_lesson_activity") + @Iteration("profileEdit", "name=PROFILE_EDIT_ACTIVITY", "expNameStr=profile_edit_activity") + @Iteration( + "profileResetPin", + "name=PROFILE_RESET_PIN_ACTIVITY", + "expNameStr=profile_reset_pin_activity" + ) + @Iteration( + "profileRename", + "name=PROFILE_RENAME_ACTIVITY", + "expNameStr=profile_rename_activity" + ) + @Iteration("profileList", "name=PROFILE_LIST_ACTIVITY", "expNameStr=profile_list_activity") + @Iteration("story", "name=STORY_ACTIVITY", "expNameStr=story_activity") + @Iteration("topic", "name=TOPIC_ACTIVITY", "expNameStr=topic_activity") + @Iteration("revisionCard", "name=REVISION_CARD_ACTIVITY", "expNameStr=revision_card_activity") + @Iteration( + "questionPlayer", + "name=QUESTION_PLAYER_ACTIVITY", + "expNameStr=question_player_activity" + ) + @Iteration("walkthrough", "name=WALKTHROUGH_ACTIVITY", "expNameStr=walkthrough_activity") + @Iteration( + "developerOptions", + "name=DEVELOPER_OPTIONS_ACTIVITY", + "expNameStr=developer_options_activity" + ) + @Iteration( + "viewEventLogs", + "name=VIEW_EVENT_LOGS_ACTIVITY", + "expNameStr=view_event_logs_activity" + ) + @Iteration( + "markTopicsCompleted", + "name=MARK_TOPICS_COMPLETED_ACTIVITY", + "expNameStr=mark_topics_completed_activity" + ) + @Iteration( + "mathExpressionParser", + "name=MATH_EXPRESSION_PARSER_ACTIVITY", + "expNameStr=math_expression_parser_activity" + ) + @Iteration( + "markChaptersCompleted", + "name=MARK_CHAPTERS_COMPLETED_ACTIVITY", + "expNameStr=mark_chapters_completed_activity" + ) + @Iteration( + "markStoriesCompleted", + "name=MARK_STORIES_COMPLETED_ACTIVITY", + "expNameStr=mark_stories_completed_activity" + ) + @Iteration( + "forceNetworkType", + "name=FORCE_NETWORK_TYPE_ACTIVITY", + "expNameStr=force_network_type_activity" ) + @Iteration("adminPin", "name=ADMIN_PIN_ACTIVITY", "expNameStr=admin_pin_activity") + @Iteration("policies", "name=POLICIES_ACTIVITY", "expNameStr=policies_activity") + @Iteration("unspecified", "name=SCREEN_NAME_UNSPECIFIED", "expNameStr=screen_name_unspecified") + @Iteration("foreground", "name=FOREGROUND_SCREEN", "expNameStr=foreground_screen") fun testMetricsBundle_addScreenName_verifyConversionToCorrectAnalyticalName() { setUpTestApplicationComponent() val bundle = Bundle() diff --git a/utility/src/test/java/org/oppia/android/util/logging/performancemetrics/PerformanceMetricsAssessorImplTest.kt b/utility/src/test/java/org/oppia/android/util/logging/performancemetrics/PerformanceMetricsAssessorImplTest.kt index fade559675a..161a3b19fa7 100644 --- a/utility/src/test/java/org/oppia/android/util/logging/performancemetrics/PerformanceMetricsAssessorImplTest.kt +++ b/utility/src/test/java/org/oppia/android/util/logging/performancemetrics/PerformanceMetricsAssessorImplTest.kt @@ -21,7 +21,6 @@ import org.oppia.android.testing.TestLogReportingModule import org.oppia.android.testing.junit.OppiaParameterizedTestRunner import org.oppia.android.testing.junit.OppiaParameterizedTestRunner.Iteration import org.oppia.android.testing.junit.OppiaParameterizedTestRunner.Parameter -import org.oppia.android.testing.junit.OppiaParameterizedTestRunner.RunParameterized import org.oppia.android.testing.junit.OppiaParameterizedTestRunner.SelectRunnerPlatform import org.oppia.android.testing.junit.ParameterizedRobolectricTestRunner import org.oppia.android.testing.platformparameter.TestPlatformParameterModule @@ -220,47 +219,45 @@ class PerformanceMetricsAssessorImplTest { } @Test - @RunParameterized( - Iteration( - "zeroDoubleValue", - "firstCpuValue=1000", - "secondCpuValue=1000", - "firstAppTimeValue=1665790650", - "secondAppTimeValue=1665790700", - "firstNumberOfOnlineCoresValue=6", - "secondNumberOfOnlineCoresValue=2", - "relativeCpuUsage=0.00" - ), - Iteration( - "nonZeroDoubleValueTillTwoDecimalPoints", - "firstCpuValue=1000", - "secondCpuValue=1100", - "firstAppTimeValue=1665790650", - "secondAppTimeValue=1665790700", - "firstNumberOfOnlineCoresValue=6", - "secondNumberOfOnlineCoresValue=2", - "relativeCpuUsage=0.50" - ), - Iteration( - "nonZeroDoubleValueTillSevenDecimalPoints", - "firstCpuValue=1000", - "secondCpuValue=12100", - "firstAppTimeValue=1665790650", - "secondAppTimeValue=1869790700", - "firstNumberOfOnlineCoresValue=6", - "secondNumberOfOnlineCoresValue=8", - "relativeCpuUsage=0.0000077" - ), - Iteration( - "nonZeroDoubleValueTillElevenDecimalPoints", - "firstCpuValue=1000", - "secondCpuValue=2100", - "firstAppTimeValue=1665790650", - "secondAppTimeValue=186933790700", - "firstNumberOfOnlineCoresValue=6", - "secondNumberOfOnlineCoresValue=3", - "relativeCpuUsage=0.00000000239" - ) + @Iteration( + "zeroDoubleValue", + "firstCpuValue=1000", + "secondCpuValue=1000", + "firstAppTimeValue=1665790650", + "secondAppTimeValue=1665790700", + "firstNumberOfOnlineCoresValue=6", + "secondNumberOfOnlineCoresValue=2", + "relativeCpuUsage=0.00" + ) + @Iteration( + "nonZeroDoubleValueTillTwoDecimalPoints", + "firstCpuValue=1000", + "secondCpuValue=1100", + "firstAppTimeValue=1665790650", + "secondAppTimeValue=1665790700", + "firstNumberOfOnlineCoresValue=6", + "secondNumberOfOnlineCoresValue=2", + "relativeCpuUsage=0.50" + ) + @Iteration( + "nonZeroDoubleValueTillSevenDecimalPoints", + "firstCpuValue=1000", + "secondCpuValue=12100", + "firstAppTimeValue=1665790650", + "secondAppTimeValue=1869790700", + "firstNumberOfOnlineCoresValue=6", + "secondNumberOfOnlineCoresValue=8", + "relativeCpuUsage=0.0000077" + ) + @Iteration( + "nonZeroDoubleValueTillElevenDecimalPoints", + "firstCpuValue=1000", + "secondCpuValue=2100", + "firstAppTimeValue=1665790650", + "secondAppTimeValue=186933790700", + "firstNumberOfOnlineCoresValue=6", + "secondNumberOfOnlineCoresValue=3", + "relativeCpuUsage=0.00000000239" ) fun testAssessor_setFirstAndSecondSnapshot_returnsCorrectRelativeCpuUsage() { val firstSnapshot = PerformanceMetricsAssessor.CpuSnapshot( @@ -279,17 +276,15 @@ class PerformanceMetricsAssessorImplTest { } @Test - @RunParameterized( - Iteration( - "zeroDeltaOnlineCores", - "firstNumberOfOnlineCoresValue=6", - "secondNumberOfOnlineCoresValue=0" - ), - Iteration( - "negativeOnlineCores", - "firstNumberOfOnlineCoresValue=-1", - "secondNumberOfOnlineCoresValue=6" - ) + @Iteration( + "zeroDeltaOnlineCores", + "firstNumberOfOnlineCoresValue=6", + "secondNumberOfOnlineCoresValue=0" + ) + @Iteration( + "negativeOnlineCores", + "firstNumberOfOnlineCoresValue=-1", + "secondNumberOfOnlineCoresValue=6" ) fun testAssessor_inputInvalidOnlineCoresValues_calculateCpuUsage_returnsNull() { val firstSnapshot = PerformanceMetricsAssessor.CpuSnapshot( @@ -310,11 +305,9 @@ class PerformanceMetricsAssessorImplTest { } @Test - @RunParameterized( - Iteration("negativeDeltaCpuValue", "firstCpuValue=1000", "secondCpuValue=900"), - Iteration("negativeCpuValue", "firstCpuValue=1000", "secondCpuValue=-900"), - Iteration("outOfBoundsCpuValue", "firstCpuValue=1000", "secondCpuValue=9223372036854775807"), - ) + @Iteration("negativeDeltaCpuValue", "firstCpuValue=1000", "secondCpuValue=900") + @Iteration("negativeCpuValue", "firstCpuValue=1000", "secondCpuValue=-900") + @Iteration("outOfBoundsCpuValue", "firstCpuValue=1000", "secondCpuValue=9223372036854775807") fun testAssessor_inputInvalidCpuTimeValues_calculateCpuUsage_returnsNull() { val firstSnapshot = PerformanceMetricsAssessor.CpuSnapshot( firstAppTimeValue, @@ -334,22 +327,20 @@ class PerformanceMetricsAssessorImplTest { } @Test - @RunParameterized( - Iteration( - "negativeDeltaAppTimeValue", - "firstAppTimeValue=1665790650", - "secondAppTimeValue=1665790050" - ), - Iteration( - "negativeAppTimeValue", - "firstAppTimeValue=1665790650", - "secondAppTimeValue=-1665790050" - ), - Iteration( - "zeroDeltaAppTimeValue", - "firstAppTimeValue=1665790650", - "secondAppTimeValue=1665790650" - ), + @Iteration( + "negativeDeltaAppTimeValue", + "firstAppTimeValue=1665790650", + "secondAppTimeValue=1665790050" + ) + @Iteration( + "negativeAppTimeValue", + "firstAppTimeValue=1665790650", + "secondAppTimeValue=-1665790050" + ) + @Iteration( + "zeroDeltaAppTimeValue", + "firstAppTimeValue=1665790650", + "secondAppTimeValue=1665790650" ) fun testAssessor_inputInvalidAppTimeValues_calculateCpuUsage_returnsNull() { val firstSnapshot = PerformanceMetricsAssessor.CpuSnapshot( @@ -380,11 +371,9 @@ class PerformanceMetricsAssessorImplTest { } @Test - @RunParameterized( - Iteration("memoryEqualToLowerBound", "totalMemory=0"), - Iteration("memoryInRange", "totalMemory=1147483648"), - Iteration("memoryJustBelowUpperBound", "totalMemory=2147483647") - ) + @Iteration("memoryEqualToLowerBound", "totalMemory=0") + @Iteration("memoryInRange", "totalMemory=1147483648") + @Iteration("memoryJustBelowUpperBound", "totalMemory=2147483647") fun testAssessor_setTotalMemoryForLowMemoryRange_returnsCorrectLowMemoryTier() { val memoryInfo = ActivityManager.MemoryInfo() memoryInfo.totalMem = totalMemory @@ -395,11 +384,9 @@ class PerformanceMetricsAssessorImplTest { } @Test - @RunParameterized( - Iteration("memoryEqualToLowerBound", "totalMemory=2147483649"), - Iteration("memoryInRange", "totalMemory=2684354560"), - Iteration("memoryEqualToUpperBound", "totalMemory=3221225472") - ) + @Iteration("memoryEqualToLowerBound", "totalMemory=2147483649") + @Iteration("memoryInRange", "totalMemory=2684354560") + @Iteration("memoryEqualToUpperBound", "totalMemory=3221225472") fun testAssessor_setTotalMemoryForMediumMemoryRange_retsCorrectMediumMemoryTier() { val memoryInfo = ActivityManager.MemoryInfo() memoryInfo.totalMem = totalMemory @@ -410,13 +397,11 @@ class PerformanceMetricsAssessorImplTest { } @Test - @RunParameterized( - Iteration("memoryEqualToLowerBound", "totalMemory=3221225473"), - Iteration("memoryInRange", "totalMemory=5221225472"), - Iteration( - "memoryEqualToMaxValue", - "totalMemory=9223372036854775807" - ) + @Iteration("memoryEqualToLowerBound", "totalMemory=3221225473") + @Iteration("memoryInRange", "totalMemory=5221225472") + @Iteration( + "memoryEqualToMaxValue", + "totalMemory=9223372036854775807" ) fun testAssessor_setTotalMemoryForHighMemoryRange_retsCorrectHighMemoryTier() { val memoryInfo = ActivityManager.MemoryInfo() diff --git a/utility/src/test/java/org/oppia/android/util/math/ExpressionToComparableOperationConverterTest.kt b/utility/src/test/java/org/oppia/android/util/math/ExpressionToComparableOperationConverterTest.kt index 203ad029c5b..5a20ba0cc07 100644 --- a/utility/src/test/java/org/oppia/android/util/math/ExpressionToComparableOperationConverterTest.kt +++ b/utility/src/test/java/org/oppia/android/util/math/ExpressionToComparableOperationConverterTest.kt @@ -10,7 +10,6 @@ import org.oppia.android.app.model.MathExpression import org.oppia.android.testing.junit.OppiaParameterizedTestRunner import org.oppia.android.testing.junit.OppiaParameterizedTestRunner.Iteration import org.oppia.android.testing.junit.OppiaParameterizedTestRunner.Parameter -import org.oppia.android.testing.junit.OppiaParameterizedTestRunner.RunParameterized import org.oppia.android.testing.junit.OppiaParameterizedTestRunner.SelectRunnerPlatform import org.oppia.android.testing.junit.ParameterizedJunitTestRunner import org.oppia.android.testing.math.ComparableOperationSubject.Companion.assertThat @@ -1449,12 +1448,10 @@ class ExpressionToComparableOperationConverterTest { */ @Test - @RunParameterized( - Iteration(name = "(1+2)*sqrt(3)", "op1=(1+2)", "op2=sqrt(3)"), - Iteration(name = "sqrt(3)*(1+2)", "op1=sqrt(3)", "op2=(1+2)"), - Iteration(name = "(1+2)*(3^4)", "op1=(1+2)", "op2=(3^4)"), - Iteration(name = "(3^4)*(1+2)", "op1=(3^4)", "op2=(1+2)") - ) + @Iteration(name = "(1+2)*sqrt(3)", "op1=(1+2)", "op2=sqrt(3)") + @Iteration(name = "sqrt(3)*(1+2)", "op1=sqrt(3)", "op2=(1+2)") + @Iteration(name = "(1+2)*(3^4)", "op1=(1+2)", "op2=(3^4)") + @Iteration(name = "(3^4)*(1+2)", "op1=(3^4)", "op2=(1+2)") fun testConvert_additionAndNonCommutativeOp_samePrecedence_returnsOpWithSummationFirst() { val expression = parseNumericExpression("$op1 * $op2") @@ -1475,12 +1472,10 @@ class ExpressionToComparableOperationConverterTest { } @Test - @RunParameterized( - Iteration(name = "2+sqrt(3)", "op1=2", "op2=sqrt(3)"), - Iteration(name = "sqrt(3)+2", "op1=sqrt(3)", "op2=2"), - Iteration(name = "2+3^4", "op1=2", "op2=3^4"), - Iteration(name = "3^4+2", "op1=3^4", "op2=2") - ) + @Iteration(name = "2+sqrt(3)", "op1=2", "op2=sqrt(3)") + @Iteration(name = "sqrt(3)+2", "op1=sqrt(3)", "op2=2") + @Iteration(name = "2+3^4", "op1=2", "op2=3^4") + @Iteration(name = "3^4+2", "op1=3^4", "op2=2") fun testConvert_constantAndNonCommutativeOp_samePrecedence_returnsOpWithNonCommutativeFirst() { val expression = parseNumericExpression("$op1 + $op2") @@ -1501,10 +1496,8 @@ class ExpressionToComparableOperationConverterTest { } @Test - @RunParameterized( - Iteration(name = "2*x", "op1=2", "op2=x"), - Iteration(name = "x*2", "op1=x", "op2=2") - ) + @Iteration(name = "2*x", "op1=2", "op2=x") + @Iteration(name = "x*2", "op1=x", "op2=2") fun testConvert_constantAndVariable_samePrecedence_returnsOpWithConstantFirst() { val expression = parseAlgebraicExpression("$op1 * $op2") @@ -1525,10 +1518,8 @@ class ExpressionToComparableOperationConverterTest { } @Test - @RunParameterized( - Iteration(name = "x+(-y)", "op1=x", "op2=(-y)"), - Iteration(name = "(-y)+x", "op1=(-y)", "op2=x") - ) + @Iteration(name = "x+(-y)", "op1=x", "op2=(-y)") + @Iteration(name = "(-y)+x", "op1=(-y)", "op2=x") fun testConvert_positiveAndNegativeVariables_returnsOpWithNegatedLast() { val expression = parseAlgebraicExpression("$op1 + $op2") @@ -1551,10 +1542,8 @@ class ExpressionToComparableOperationConverterTest { } @Test - @RunParameterized( - Iteration(name = "x*(1/y)", "op1=x", "op2=(1/y)"), - Iteration(name = "(1/y)*x", "op1=(1/y)", "op2=x") - ) + @Iteration(name = "x*(1/y)", "op1=x", "op2=(1/y)") + @Iteration(name = "(1/y)*x", "op1=(1/y)", "op2=x") fun testConvert_invertedAndNonInvertedVariables_returnsOpWithInvertedLast() { val expression = parseAlgebraicExpression("$op1 * $op2") @@ -1581,16 +1570,14 @@ class ExpressionToComparableOperationConverterTest { } @Test - @RunParameterized( - Iteration(name = "(1+2)*(2+3)", "op1=1+2", "op2=2+3"), - Iteration(name = "(2+1)*(2+3)", "op1=2+1", "op2=2+3"), - Iteration(name = "(1+2)*(3+2)", "op1=1+2", "op2=3+2"), - Iteration(name = "(2+1)*(3+2)", "op1=2+1", "op2=3+2"), - Iteration(name = "(2+3)*(1+2)", "op1=2+3", "op2=1+2"), - Iteration(name = "(2+3)*(2+1)", "op1=2+3", "op2=2+1"), - Iteration(name = "(3+2)*(1+2)", "op1=3+2", "op2=1+2"), - Iteration(name = "(3+2)*(2+1)", "op1=3+2", "op2=2+1") - ) + @Iteration(name = "(1+2)*(2+3)", "op1=1+2", "op2=2+3") + @Iteration(name = "(2+1)*(2+3)", "op1=2+1", "op2=2+3") + @Iteration(name = "(1+2)*(3+2)", "op1=1+2", "op2=3+2") + @Iteration(name = "(2+1)*(3+2)", "op1=2+1", "op2=3+2") + @Iteration(name = "(2+3)*(1+2)", "op1=2+3", "op2=1+2") + @Iteration(name = "(2+3)*(2+1)", "op1=2+3", "op2=2+1") + @Iteration(name = "(3+2)*(1+2)", "op1=3+2", "op2=1+2") + @Iteration(name = "(3+2)*(2+1)", "op1=3+2", "op2=2+1") fun testConvert_twoAdditionsInProduct_smallerSumIsFirst() { val expression = parseNumericExpression("($op1)*($op2)") @@ -1626,16 +1613,14 @@ class ExpressionToComparableOperationConverterTest { } @Test - @RunParameterized( - Iteration(name = "(2*3)+(4*5)", "op1=2*3", "op2=4*5"), - Iteration(name = "(3*2)+(4*5)", "op1=3*2", "op2=4*5"), - Iteration(name = "(2*3)+(5*4)", "op1=2*3", "op2=5*4"), - Iteration(name = "(3*2)+(5*4)", "op1=3*2", "op2=5*4"), - Iteration(name = "(4*5)+(2*3)", "op1=4*5", "op2=2*3"), - Iteration(name = "(4*5)+(3*2)", "op1=4*5", "op2=3*2"), - Iteration(name = "(5*4)+(2*3)", "op1=5*4", "op2=2*3"), - Iteration(name = "(5*4)+(3*2)", "op1=5*4", "op2=3*2") - ) + @Iteration(name = "(2*3)+(4*5)", "op1=2*3", "op2=4*5") + @Iteration(name = "(3*2)+(4*5)", "op1=3*2", "op2=4*5") + @Iteration(name = "(2*3)+(5*4)", "op1=2*3", "op2=5*4") + @Iteration(name = "(3*2)+(5*4)", "op1=3*2", "op2=5*4") + @Iteration(name = "(4*5)+(2*3)", "op1=4*5", "op2=2*3") + @Iteration(name = "(4*5)+(3*2)", "op1=4*5", "op2=3*2") + @Iteration(name = "(5*4)+(2*3)", "op1=5*4", "op2=2*3") + @Iteration(name = "(5*4)+(3*2)", "op1=5*4", "op2=3*2") fun testConvert_twoMultiplicationsInSum_smallerProductIsFirst() { val expression = parseNumericExpression("($op1)+($op2)") @@ -1673,10 +1658,8 @@ class ExpressionToComparableOperationConverterTest { /* Non-commutative sorting */ @Test - @RunParameterized( - Iteration(name = "(2^3)+sqrt(2)", "op1=(2^3)", "op2=sqrt(2)"), - Iteration(name = "sqrt(2)+(2^3)", "op1=sqrt(2)", "op2=(2^3)") - ) + @Iteration(name = "(2^3)+sqrt(2)", "op1=(2^3)", "op2=sqrt(2)") + @Iteration(name = "sqrt(2)+(2^3)", "op1=sqrt(2)", "op2=(2^3)") fun testConvert_expAndSqrt_samePrecedence_returnsOpWithExpThenSqrt() { val expression = parseNumericExpression("$op1+$op2") @@ -1701,23 +1684,21 @@ class ExpressionToComparableOperationConverterTest { } @Test - @RunParameterized( - // const^const + const^const - Iteration(name = "(2^3)+(4^5)", "op1=2^3", "op2=4^5"), - Iteration(name = "(2^5)+(4^3)", "op1=2^5", "op2=4^3"), - Iteration(name = "(4^3)+(2^5)", "op1=4^3", "op2=2^5"), - Iteration(name = "(4^5)+(2^3)", "op1=4^5", "op2=2^3"), - // const^var + const^var - Iteration(name = "(2^x)+(4^5)", "op1=2^x", "op2=4^5"), - Iteration(name = "(2^5)+(4^x)", "op1=2^5", "op2=4^x"), - Iteration(name = "(4^x)+(2^5)", "op1=4^x", "op2=2^5"), - Iteration(name = "(4^5)+(2^x)", "op1=4^5", "op2=2^x"), - // const^(var or const) + const^(const or var) - Iteration(name = "(2^x)+(4^y)", "op1=2^x", "op2=4^y"), - Iteration(name = "(2^y)+(4^x)", "op1=2^y", "op2=4^x"), - Iteration(name = "(4^x)+(2^y)", "op1=4^x", "op2=2^y"), - Iteration(name = "(4^y)+(2^x)", "op1=4^y", "op2=2^x") - ) + // const^const + const^const + @Iteration(name = "(2^3)+(4^5)", "op1=2^3", "op2=4^5") + @Iteration(name = "(2^5)+(4^3)", "op1=2^5", "op2=4^3") + @Iteration(name = "(4^3)+(2^5)", "op1=4^3", "op2=2^5") + @Iteration(name = "(4^5)+(2^3)", "op1=4^5", "op2=2^3") + // const^var + const^var + @Iteration(name = "(2^x)+(4^5)", "op1=2^x", "op2=4^5") + @Iteration(name = "(2^5)+(4^x)", "op1=2^5", "op2=4^x") + @Iteration(name = "(4^x)+(2^5)", "op1=4^x", "op2=2^5") + @Iteration(name = "(4^5)+(2^x)", "op1=4^5", "op2=2^x") + // const^(var or const) + const^(const or var) + @Iteration(name = "(2^x)+(4^y)", "op1=2^x", "op2=4^y") + @Iteration(name = "(2^y)+(4^x)", "op1=2^y", "op2=4^x") + @Iteration(name = "(4^x)+(2^y)", "op1=4^x", "op2=2^y") + @Iteration(name = "(4^y)+(2^x)", "op1=4^y", "op2=2^x") fun testConvert_addTwoExps_lhs1Const_rhs1Any_lhs2Const_rhs2Any_returnsOpWithLhsSizeBasedOrder() { // Note that optional errors need to be disabled as part of testing exponents as powers. val expression = @@ -1756,23 +1737,21 @@ class ExpressionToComparableOperationConverterTest { } @Test - @RunParameterized( - // var^const + var^const - Iteration(name = "(u^3)+(v^5)", "op1=u^3", "op2=v^5"), - Iteration(name = "(u^5)+(v^3)", "op1=u^5", "op2=v^3"), - Iteration(name = "(v^3)+(u^5)", "op1=v^3", "op2=u^5"), - Iteration(name = "(v^5)+(u^3)", "op1=v^5", "op2=u^3"), - // var^var + var^var - Iteration(name = "(u^x)+(v^5)", "op1=u^x", "op2=v^5"), - Iteration(name = "(u^5)+(v^x)", "op1=u^5", "op2=v^x"), - Iteration(name = "(v^x)+(u^5)", "op1=v^x", "op2=u^5"), - Iteration(name = "(v^5)+(u^x)", "op1=v^5", "op2=u^x"), - // var^(var or const) + var^(const or var) - Iteration(name = "(u^x)+(v^y)", "op1=u^x", "op2=v^y"), - Iteration(name = "(u^y)+(v^x)", "op1=u^y", "op2=v^x"), - Iteration(name = "(v^x)+(u^y)", "op1=v^x", "op2=u^y"), - Iteration(name = "(v^y)+(u^x)", "op1=v^y", "op2=u^x") - ) + // var^const + var^const + @Iteration(name = "(u^3)+(v^5)", "op1=u^3", "op2=v^5") + @Iteration(name = "(u^5)+(v^3)", "op1=u^5", "op2=v^3") + @Iteration(name = "(v^3)+(u^5)", "op1=v^3", "op2=u^5") + @Iteration(name = "(v^5)+(u^3)", "op1=v^5", "op2=u^3") + // var^var + var^var + @Iteration(name = "(u^x)+(v^5)", "op1=u^x", "op2=v^5") + @Iteration(name = "(u^5)+(v^x)", "op1=u^5", "op2=v^x") + @Iteration(name = "(v^x)+(u^5)", "op1=v^x", "op2=u^5") + @Iteration(name = "(v^5)+(u^x)", "op1=v^5", "op2=u^x") + // var^(var or const) + var^(const or var) + @Iteration(name = "(u^x)+(v^y)", "op1=u^x", "op2=v^y") + @Iteration(name = "(u^y)+(v^x)", "op1=u^y", "op2=v^x") + @Iteration(name = "(v^x)+(u^y)", "op1=v^x", "op2=u^y") + @Iteration(name = "(v^y)+(u^x)", "op1=v^y", "op2=u^x") fun testConvert_addTwoExps_lhs1Var_rhs1Any_lhs2Var_rhs2Any_returnsOpWithLhsLetterBasedOrder() { // Note that optional errors need to be disabled as part of testing exponents as powers. val expression = @@ -1816,10 +1795,8 @@ class ExpressionToComparableOperationConverterTest { } @Test - @RunParameterized( - Iteration(name = "sqrt(2)+sqrt(3)", "op1=2", "op2=3"), - Iteration(name = "sqrt(3)+sqrt(2)", "op1=3", "op2=2") - ) + @Iteration(name = "sqrt(2)+sqrt(3)", "op1=2", "op2=3") + @Iteration(name = "sqrt(3)+sqrt(2)", "op1=3", "op2=2") fun testConvert_addTwoSqrts_leftConst_rightConst_returnsOpWithSqrtsByArgSize() { val expression = parseNumericExpression("sqrt($op1)+sqrt($op2)") @@ -1852,10 +1829,8 @@ class ExpressionToComparableOperationConverterTest { } @Test - @RunParameterized( - Iteration(name = "sqrt(x)+sqrt(y)", "op1=x", "op2=y"), - Iteration(name = "sqrt(y)+sqrt(x)", "op1=y", "op2=x") - ) + @Iteration(name = "sqrt(x)+sqrt(y)", "op1=x", "op2=y") + @Iteration(name = "sqrt(y)+sqrt(x)", "op1=y", "op2=x") fun testConvert_addTwoSqrts_leftVar_rightVar_returnsOpWithSqrtsByVariableOrder() { val expression = parseAlgebraicExpression("sqrt($op1)+sqrt($op2)") @@ -1888,10 +1863,8 @@ class ExpressionToComparableOperationConverterTest { } @Test - @RunParameterized( - Iteration(name = "sqrt(2)+sqrt(x)", "op1=2", "op2=x"), - Iteration(name = "sqrt(x)+sqrt(2)", "op1=x", "op2=2") - ) + @Iteration(name = "sqrt(2)+sqrt(x)", "op1=2", "op2=x") + @Iteration(name = "sqrt(x)+sqrt(2)", "op1=x", "op2=2") fun testConvert_addTwoSqrts_oneConst_oneVar_returnsOpWithSqrtsByConstFirst() { val expression = parseAlgebraicExpression("sqrt($op1)+sqrt($op2)") @@ -1926,10 +1899,8 @@ class ExpressionToComparableOperationConverterTest { /* Constant & variable sorting */ @Test - @RunParameterized( - Iteration(name = "2+3", "op1=2", "op2=3"), - Iteration(name = "3+2", "op1=3", "op2=2") - ) + @Iteration(name = "2+3", "op1=2", "op2=3") + @Iteration(name = "3+2", "op1=3", "op2=2") fun testConvert_addTwoConstants_leftInteger_rightInteger_returnsOpSortedByValues() { val expression = parseNumericExpression("$op1 + $op2") @@ -1954,10 +1925,8 @@ class ExpressionToComparableOperationConverterTest { } @Test - @RunParameterized( - Iteration(name = "3.2+6.3", "op1=3.2", "op2=6.3"), - Iteration(name = "6.3+3.2", "op1=6.3", "op2=3.2") - ) + @Iteration(name = "3.2+6.3", "op1=3.2", "op2=6.3") + @Iteration(name = "6.3+3.2", "op1=6.3", "op2=3.2") fun testConvert_addTwoConstants_leftDouble_rightDouble_returnsOpSortedByValues() { val expression = parseNumericExpression("$op1 + $op2") @@ -1982,10 +1951,8 @@ class ExpressionToComparableOperationConverterTest { } @Test - @RunParameterized( - Iteration(name = "3+6.3", "op1=3", "op2=6.3"), - Iteration(name = "6.3+3", "op1=6.3", "op2=3") - ) + @Iteration(name = "3+6.3", "op1=3", "op2=6.3") + @Iteration(name = "6.3+3", "op1=6.3", "op2=3") fun testConvert_addTwoConstants_smallInt_largeDouble_returnsOpWithIntFirst() { val expression = parseNumericExpression("$op1 + $op2") @@ -2010,10 +1977,8 @@ class ExpressionToComparableOperationConverterTest { } @Test - @RunParameterized( - Iteration(name = "8+6.3", "op1=8", "op2=6.3"), - Iteration(name = "6.3+8", "op1=6.3", "op2=8") - ) + @Iteration(name = "8+6.3", "op1=8", "op2=6.3") + @Iteration(name = "6.3+8", "op1=6.3", "op2=8") fun testConvert_addTwoConstants_largeInt_smallDouble_returnsOpWithDoubleFirst() { val expression = parseNumericExpression("$op1 + $op2") @@ -2038,10 +2003,8 @@ class ExpressionToComparableOperationConverterTest { } @Test - @RunParameterized( - Iteration(name = "x+6", "op1=x", "op2=6"), - Iteration(name = "6+x", "op1=6", "op2=x") - ) + @Iteration(name = "x+6", "op1=x", "op2=6") + @Iteration(name = "6+x", "op1=6", "op2=x") fun testConvert_addVarAndIntConstant_returnsOpWithConstantFirst() { val expression = parseAlgebraicExpression("$op1 + $op2") @@ -2066,10 +2029,8 @@ class ExpressionToComparableOperationConverterTest { } @Test - @RunParameterized( - Iteration(name = "3.6+x", "op1=3.6", "op2=x"), - Iteration(name = "x+3.6", "op1=x", "op2=3.6") - ) + @Iteration(name = "3.6+x", "op1=3.6", "op2=x") + @Iteration(name = "x+3.6", "op1=x", "op2=3.6") fun testConvert_addVarAndDoubleConstant_returnsOpWithConstantFirst() { val expression = parseAlgebraicExpression("$op1 + $op2") @@ -2117,10 +2078,8 @@ class ExpressionToComparableOperationConverterTest { } @Test - @RunParameterized( - Iteration(name = "x+y", "op1=x", "op2=y"), - Iteration(name = "y+x", "op1=y", "op2=x") - ) + @Iteration(name = "x+y", "op1=x", "op2=y") + @Iteration(name = "y+x", "op1=y", "op2=x") fun testConvert_addTwoVariables_oneX_oneY_returnsOpWithXThenY() { val expression = parseAlgebraicExpression("$op1 + $op2") diff --git a/utility/src/test/java/org/oppia/android/util/math/MathExpressionExtensionsTest.kt b/utility/src/test/java/org/oppia/android/util/math/MathExpressionExtensionsTest.kt index 6406f3e6e70..371048728af 100644 --- a/utility/src/test/java/org/oppia/android/util/math/MathExpressionExtensionsTest.kt +++ b/utility/src/test/java/org/oppia/android/util/math/MathExpressionExtensionsTest.kt @@ -8,7 +8,6 @@ import org.oppia.android.app.model.MathExpression import org.oppia.android.testing.junit.OppiaParameterizedTestRunner import org.oppia.android.testing.junit.OppiaParameterizedTestRunner.Iteration import org.oppia.android.testing.junit.OppiaParameterizedTestRunner.Parameter -import org.oppia.android.testing.junit.OppiaParameterizedTestRunner.RunParameterized import org.oppia.android.testing.junit.OppiaParameterizedTestRunner.SelectRunnerPlatform import org.oppia.android.testing.junit.ParameterizedJunitTestRunner import org.oppia.android.testing.math.PolynomialSubject.Companion.assertThat @@ -172,17 +171,15 @@ class MathExpressionExtensionsTest { } @Test - @RunParameterized( - Iteration("2==2", "exp1=2", "exp2=2"), - Iteration("2==2.000000000000001", "exp1=2", "exp2=2.000000000000001"), - Iteration("x+1==x+1", "exp1=x+1", "exp2=x+1"), - Iteration("x-1==x-1", "exp1=x-1", "exp2=x-1"), - Iteration("x*2==x*2", "exp1=x*2", "exp2=x*2"), - Iteration("x/2==x/2", "exp1=x/2", "exp2=x/2"), - Iteration("x^2==x^2", "exp1=x^2", "exp2=x^2"), - Iteration("-x==-x", "exp1=-x", "exp2=-x"), - Iteration("sqrt(x)==sqrt(x)", "exp1=sqrt(x)", "exp2=sqrt(x)") - ) + @Iteration("2==2", "exp1=2", "exp2=2") + @Iteration("2==2.000000000000001", "exp1=2", "exp2=2.000000000000001") + @Iteration("x+1==x+1", "exp1=x+1", "exp2=x+1") + @Iteration("x-1==x-1", "exp1=x-1", "exp2=x-1") + @Iteration("x*2==x*2", "exp1=x*2", "exp2=x*2") + @Iteration("x/2==x/2", "exp1=x/2", "exp2=x/2") + @Iteration("x^2==x^2", "exp1=x^2", "exp2=x^2") + @Iteration("-x==-x", "exp1=-x", "exp2=-x") + @Iteration("sqrt(x)==sqrt(x)", "exp1=sqrt(x)", "exp2=sqrt(x)") fun testIsApproximatelyEqualTo_bothAreSingleTermsOrOperations_andSame_returnsTrue() { val first = parseAlgebraicExpression(exp1) val second = parseAlgebraicExpression(exp2) @@ -195,36 +192,34 @@ class MathExpressionExtensionsTest { } @Test - @RunParameterized( - Iteration("2!=3", "exp1=2", "exp2=3"), - Iteration("2!=3/2", "exp1=2", "exp2=3/2"), - Iteration("2!=3.14", "exp1=2", "exp2=3.14"), - Iteration("x!=y", "exp1=x", "exp2=y"), - Iteration("x!=2", "exp1=x", "exp2=2"), - // The number of terms must match. - Iteration("1+x!=1", "exp1=1+x", "exp2=1"), - Iteration("1+x!=x", "exp1=1+x", "exp2=x"), - Iteration("1+1+x!=2+x", "exp1=1+1+x", "exp2=2+x"), - // Term order must match. - Iteration("1+x!=2+x", "exp1=1+x", "exp2=2+x"), - Iteration("1+x!=x+1", "exp1=1+x", "exp2=x+1"), - Iteration("1-x!=2-x", "exp1=1-x", "exp2=2-x"), - Iteration("1-x!=x-1", "exp1=1-x", "exp2=x-1"), - Iteration("2*x!=3*x", "exp1=2*x", "exp2=3*x"), - Iteration("2*x!=x*2", "exp1=2*x", "exp2=x*2"), - Iteration("x/2!=x/3", "exp1=x/2", "exp2=x/3"), - Iteration("x/2!=2/x", "exp1=x/2", "exp2=2/x"), - Iteration("x^2!=x^3", "exp1=x^2", "exp2=x^3"), - Iteration("x^2!=2^x", "exp1=x^2", "exp2=2^x"), - Iteration("x!=-2", "exp1=x", "exp2=-2"), - Iteration("x!=-x", "exp1=x", "exp2=-x"), - Iteration("sqrt(x)!=sqrt(2)", "exp1=sqrt(x)", "exp2=sqrt(2)"), - // These checks are numerically equivalent but fail due to the expression structure not - // matching. - Iteration("2==2/1", "exp1=2", "exp2=2/1"), - Iteration("1/3==0.33333333", "exp1=1/3", "exp2=0.33333333"), - Iteration("1.5==3/2", "exp1=1.5", "exp2=3/2") - ) + @Iteration("2!=3", "exp1=2", "exp2=3") + @Iteration("2!=3/2", "exp1=2", "exp2=3/2") + @Iteration("2!=3.14", "exp1=2", "exp2=3.14") + @Iteration("x!=y", "exp1=x", "exp2=y") + @Iteration("x!=2", "exp1=x", "exp2=2") + // The number of terms must match. + @Iteration("1+x!=1", "exp1=1+x", "exp2=1") + @Iteration("1+x!=x", "exp1=1+x", "exp2=x") + @Iteration("1+1+x!=2+x", "exp1=1+1+x", "exp2=2+x") + // Term order must match. + @Iteration("1+x!=2+x", "exp1=1+x", "exp2=2+x") + @Iteration("1+x!=x+1", "exp1=1+x", "exp2=x+1") + @Iteration("1-x!=2-x", "exp1=1-x", "exp2=2-x") + @Iteration("1-x!=x-1", "exp1=1-x", "exp2=x-1") + @Iteration("2*x!=3*x", "exp1=2*x", "exp2=3*x") + @Iteration("2*x!=x*2", "exp1=2*x", "exp2=x*2") + @Iteration("x/2!=x/3", "exp1=x/2", "exp2=x/3") + @Iteration("x/2!=2/x", "exp1=x/2", "exp2=2/x") + @Iteration("x^2!=x^3", "exp1=x^2", "exp2=x^3") + @Iteration("x^2!=2^x", "exp1=x^2", "exp2=2^x") + @Iteration("x!=-2", "exp1=x", "exp2=-2") + @Iteration("x!=-x", "exp1=x", "exp2=-x") + @Iteration("sqrt(x)!=sqrt(2)", "exp1=sqrt(x)", "exp2=sqrt(2)") + // These checks are numerically equivalent but fail due to the expression structure not + // matching. + @Iteration("2==2/1", "exp1=2", "exp2=2/1") + @Iteration("1/3==0.33333333", "exp1=1/3", "exp2=0.33333333") + @Iteration("1.5==3/2", "exp1=1.5", "exp2=3/2") fun testIsApproximatelyEqualTo_bothAreSingleTermsOrOperations_butDifferent_returnsFalse() { // Some expressions may attempt normally disallowed expressions (such as '2^x'). val first = parseAlgebraicExpression(exp1, errorCheckingMode = REQUIRED_ONLY) diff --git a/utility/src/test/java/org/oppia/android/util/math/MathExpressionParserTest.kt b/utility/src/test/java/org/oppia/android/util/math/MathExpressionParserTest.kt index 89e14517e5e..3a164f810f1 100644 --- a/utility/src/test/java/org/oppia/android/util/math/MathExpressionParserTest.kt +++ b/utility/src/test/java/org/oppia/android/util/math/MathExpressionParserTest.kt @@ -13,7 +13,6 @@ import org.oppia.android.app.model.MathExpression import org.oppia.android.testing.junit.OppiaParameterizedTestRunner import org.oppia.android.testing.junit.OppiaParameterizedTestRunner.Iteration import org.oppia.android.testing.junit.OppiaParameterizedTestRunner.Parameter -import org.oppia.android.testing.junit.OppiaParameterizedTestRunner.RunParameterized import org.oppia.android.testing.junit.OppiaParameterizedTestRunner.SelectRunnerPlatform import org.oppia.android.testing.junit.ParameterizedJunitTestRunner import org.oppia.android.testing.math.MathParsingErrorSubject.Companion.assertThat @@ -542,35 +541,55 @@ class MathExpressionParserTest { } @Test - @RunParameterized( - // Note that these parameters are intentionally set up to avoid double unary operators (such as - // -- or ++) since those result in different errors due to unary operations being higher - // precedence. In general, unary operators can't appear on the right since they'll be treated as - // such. - Iteration("**", "lhsOp=*", "rhsOp=*"), Iteration("×*", "lhsOp=×", "rhsOp=*"), - Iteration("/*", "lhsOp=/", "rhsOp=*"), Iteration("÷*", "lhsOp=÷", "rhsOp=*"), - Iteration("^*", "lhsOp=^", "rhsOp=*"), Iteration("+*", "lhsOp=+", "rhsOp=*"), - Iteration("-*", "lhsOp=-", "rhsOp=*"), Iteration("−*", "lhsOp=−", "rhsOp=*"), - Iteration("–*", "lhsOp=–", "rhsOp=*"), Iteration("*×", "lhsOp=*", "rhsOp=×"), - Iteration("××", "lhsOp=×", "rhsOp=×"), Iteration("/×", "lhsOp=/", "rhsOp=×"), - Iteration("÷×", "lhsOp=÷", "rhsOp=×"), Iteration("^×", "lhsOp=^", "rhsOp=×"), - Iteration("+×", "lhsOp=+", "rhsOp=×"), Iteration("-×", "lhsOp=-", "rhsOp=×"), - Iteration("−×", "lhsOp=−", "rhsOp=×"), Iteration("–×", "lhsOp=–", "rhsOp=×"), - Iteration("*/", "lhsOp=*", "rhsOp=/"), Iteration("×/", "lhsOp=×", "rhsOp=/"), - Iteration("//", "lhsOp=/", "rhsOp=/"), Iteration("÷/", "lhsOp=÷", "rhsOp=/"), - Iteration("^/", "lhsOp=^", "rhsOp=/"), Iteration("+/", "lhsOp=+", "rhsOp=/"), - Iteration("-/", "lhsOp=-", "rhsOp=/"), Iteration("−/", "lhsOp=−", "rhsOp=/"), - Iteration("–/", "lhsOp=–", "rhsOp=/"), Iteration("*÷", "lhsOp=*", "rhsOp=÷"), - Iteration("×÷", "lhsOp=×", "rhsOp=÷"), Iteration("/÷", "lhsOp=/", "rhsOp=÷"), - Iteration("÷÷", "lhsOp=÷", "rhsOp=÷"), Iteration("^÷", "lhsOp=^", "rhsOp=÷"), - Iteration("+÷", "lhsOp=+", "rhsOp=÷"), Iteration("-÷", "lhsOp=-", "rhsOp=÷"), - Iteration("−÷", "lhsOp=−", "rhsOp=÷"), Iteration("–÷", "lhsOp=–", "rhsOp=÷"), - Iteration("*^", "lhsOp=*", "rhsOp=^"), Iteration("×^", "lhsOp=×", "rhsOp=^"), - Iteration("/^", "lhsOp=/", "rhsOp=^"), Iteration("÷^", "lhsOp=÷", "rhsOp=^"), - Iteration("^^", "lhsOp=^", "rhsOp=^"), Iteration("+^", "lhsOp=+", "rhsOp=^"), - Iteration("-^", "lhsOp=-", "rhsOp=^"), Iteration("−^", "lhsOp=−", "rhsOp=^"), - Iteration("–^", "lhsOp=–", "rhsOp=^") - ) + // Note that these parameters are intentionally set up to avoid double unary operators (such as + // -- or ++) since those result in different errors due to unary operations being higher + // precedence. In general, unary operators can't appear on the right since they'll be treated as + // such. + @Iteration("**", "lhsOp=*", "rhsOp=*") + @Iteration("×*", "lhsOp=×", "rhsOp=*") + @Iteration("/*", "lhsOp=/", "rhsOp=*") + @Iteration("÷*", "lhsOp=÷", "rhsOp=*") + @Iteration("^*", "lhsOp=^", "rhsOp=*") + @Iteration("+*", "lhsOp=+", "rhsOp=*") + @Iteration("-*", "lhsOp=-", "rhsOp=*") + @Iteration("−*", "lhsOp=−", "rhsOp=*") + @Iteration("–*", "lhsOp=–", "rhsOp=*") + @Iteration("*×", "lhsOp=*", "rhsOp=×") + @Iteration("××", "lhsOp=×", "rhsOp=×") + @Iteration("/×", "lhsOp=/", "rhsOp=×") + @Iteration("÷×", "lhsOp=÷", "rhsOp=×") + @Iteration("^×", "lhsOp=^", "rhsOp=×") + @Iteration("+×", "lhsOp=+", "rhsOp=×") + @Iteration("-×", "lhsOp=-", "rhsOp=×") + @Iteration("−×", "lhsOp=−", "rhsOp=×") + @Iteration("–×", "lhsOp=–", "rhsOp=×") + @Iteration("*/", "lhsOp=*", "rhsOp=/") + @Iteration("×/", "lhsOp=×", "rhsOp=/") + @Iteration("//", "lhsOp=/", "rhsOp=/") + @Iteration("÷/", "lhsOp=÷", "rhsOp=/") + @Iteration("^/", "lhsOp=^", "rhsOp=/") + @Iteration("+/", "lhsOp=+", "rhsOp=/") + @Iteration("-/", "lhsOp=-", "rhsOp=/") + @Iteration("−/", "lhsOp=−", "rhsOp=/") + @Iteration("–/", "lhsOp=–", "rhsOp=/") + @Iteration("*÷", "lhsOp=*", "rhsOp=÷") + @Iteration("×÷", "lhsOp=×", "rhsOp=÷") + @Iteration("/÷", "lhsOp=/", "rhsOp=÷") + @Iteration("÷÷", "lhsOp=÷", "rhsOp=÷") + @Iteration("^÷", "lhsOp=^", "rhsOp=÷") + @Iteration("+÷", "lhsOp=+", "rhsOp=÷") + @Iteration("-÷", "lhsOp=-", "rhsOp=÷") + @Iteration("−÷", "lhsOp=−", "rhsOp=÷") + @Iteration("–÷", "lhsOp=–", "rhsOp=÷") + @Iteration("*^", "lhsOp=*", "rhsOp=^") + @Iteration("×^", "lhsOp=×", "rhsOp=^") + @Iteration("/^", "lhsOp=/", "rhsOp=^") + @Iteration("÷^", "lhsOp=÷", "rhsOp=^") + @Iteration("^^", "lhsOp=^", "rhsOp=^") + @Iteration("+^", "lhsOp=+", "rhsOp=^") + @Iteration("-^", "lhsOp=-", "rhsOp=^") + @Iteration("−^", "lhsOp=−", "rhsOp=^") + @Iteration("–^", "lhsOp=–", "rhsOp=^") fun testParseNumExp_adjacentBinaryOps_returnsSubsequentBinaryOperatorsErrorWithDetails() { val expression = "1 $lhsOp$rhsOp 2" @@ -632,15 +651,13 @@ class MathExpressionParserTest { } @Test - @RunParameterized( - // Note that unary operators like '+' and '-' are excluded here since they may result in valid - // unary operations. - Iteration("nothing_times_something_asterisk", "binOp=*"), - Iteration("nothing_times_something", "binOp=×"), - Iteration("nothing_divides_something_slash", "binOp=/"), - Iteration("nothing_divides_something", "binOp=÷"), - Iteration("nothing_to_power_of_something", "binOp=^") - ) + // Note that unary operators like '+' and '-' are excluded here since they may result in valid + // unary operations. + @Iteration("nothing_times_something_asterisk", "binOp=*") + @Iteration("nothing_times_something", "binOp=×") + @Iteration("nothing_divides_something_slash", "binOp=/") + @Iteration("nothing_divides_something", "binOp=÷") + @Iteration("nothing_to_power_of_something", "binOp=^") fun testParseNumExp_binOnlyOps_noLeftValue_returnsNoVarOrNumBeforeBinOperatorErrorWithDetails() { val expression = "$binOp 2" val operator = BINARY_SYMBOL_TO_OPERATOR_MAP.getValue(binOp) @@ -673,15 +690,13 @@ class MathExpressionParserTest { } @Test - @RunParameterized( - // Note that unary operators like '+' and '-' are excluded here since they may result in valid - // unary operations. - Iteration("nothing_times_something_asterisk", "binOp=*"), - Iteration("nothing_times_something", "binOp=×"), - Iteration("nothing_divides_something_slash", "binOp=/"), - Iteration("nothing_divides_something", "binOp=÷"), - Iteration("nothing_to_power_of_something", "binOp=^") - ) + // Note that unary operators like '+' and '-' are excluded here since they may result in valid + // unary operations. + @Iteration("nothing_times_something_asterisk", "binOp=*") + @Iteration("nothing_times_something", "binOp=×") + @Iteration("nothing_divides_something_slash", "binOp=/") + @Iteration("nothing_divides_something", "binOp=÷") + @Iteration("nothing_to_power_of_something", "binOp=^") fun testParseAlgExp_binOnlyOps_noLeftValue_returnsNoVarOrNumBeforeBinOperatorErrorWithDetails() { val expression = "$binOp x" val operator = BINARY_SYMBOL_TO_OPERATOR_MAP.getValue(binOp) @@ -696,17 +711,15 @@ class MathExpressionParserTest { } @Test - @RunParameterized( - Iteration("something_times_nothing_asterisk", "binOp=*"), - Iteration("something_times_nothing", "binOp=×"), - Iteration("something_divides_nothing_slash", "binOp=/"), - Iteration("something_divides_nothing", "binOp=÷"), - Iteration("something_to_power_of_nothing", "binOp=^"), - Iteration("something_adds_nothing", "binOp=+"), - Iteration("something_subtracts_nothing_hyphen", "binOp=-"), - Iteration("something_subtracts_nothing_en_dash", "binOp=–"), - Iteration("something_subtracts_nothing", "binOp=−") - ) + @Iteration("something_times_nothing_asterisk", "binOp=*") + @Iteration("something_times_nothing", "binOp=×") + @Iteration("something_divides_nothing_slash", "binOp=/") + @Iteration("something_divides_nothing", "binOp=÷") + @Iteration("something_to_power_of_nothing", "binOp=^") + @Iteration("something_adds_nothing", "binOp=+") + @Iteration("something_subtracts_nothing_hyphen", "binOp=-") + @Iteration("something_subtracts_nothing_en_dash", "binOp=–") + @Iteration("something_subtracts_nothing", "binOp=−") fun testParseNumExp_binaryOps_noRightValue_returnsNoVarOrNumAfterBinOperatorErrorWithDetails() { val expression = "2 $binOp" val operator = BINARY_SYMBOL_TO_OPERATOR_MAP.getValue(binOp) @@ -721,17 +734,15 @@ class MathExpressionParserTest { } @Test - @RunParameterized( - Iteration("something_times_nothing_asterisk", "binOp=*"), - Iteration("something_times_nothing", "binOp=×"), - Iteration("something_divides_nothing_slash", "binOp=/"), - Iteration("something_divides_nothing", "binOp=÷"), - Iteration("something_to_power_of_nothing", "binOp=^"), - Iteration("something_adds_nothing", "binOp=+"), - Iteration("something_subtracts_nothing_hyphen", "binOp=-"), - Iteration("something_subtracts_nothing_en_dash", "binOp=–"), - Iteration("something_subtracts_nothing", "binOp=−") - ) + @Iteration("something_times_nothing_asterisk", "binOp=*") + @Iteration("something_times_nothing", "binOp=×") + @Iteration("something_divides_nothing_slash", "binOp=/") + @Iteration("something_divides_nothing", "binOp=÷") + @Iteration("something_to_power_of_nothing", "binOp=^") + @Iteration("something_adds_nothing", "binOp=+") + @Iteration("something_subtracts_nothing_hyphen", "binOp=-") + @Iteration("something_subtracts_nothing_en_dash", "binOp=–") + @Iteration("something_subtracts_nothing", "binOp=−") fun testParseAlgExp_binaryOps_noRightValue_returnsNoVarOrNumAfterBinOperatorErrorWithDetails() { val expression = "x $binOp" val operator = BINARY_SYMBOL_TO_OPERATOR_MAP.getValue(binOp) @@ -746,13 +757,11 @@ class MathExpressionParserTest { } @Test - @RunParameterized( - Iteration("var_directly_in_exp", "subExp=x"), - Iteration("var_directly_in_sub_exp", "subExp=(1+x)"), - Iteration("var_directly_in_nested_exp", "subExp=3^x"), - Iteration("var_directly_in_sqrt", "subExp=sqrt(x)"), - Iteration("var_in_unary", "subExp=-x") - ) + @Iteration("var_directly_in_exp", "subExp=x") + @Iteration("var_directly_in_sub_exp", "subExp=(1+x)") + @Iteration("var_directly_in_nested_exp", "subExp=3^x") + @Iteration("var_directly_in_sqrt", "subExp=sqrt(x)") + @Iteration("var_in_unary", "subExp=-x") fun testParseAlgExp_powersWithVariableExpressions_returnsExponentIsVariableExpressionError() { val expression = "2^$subExp" @@ -965,13 +974,20 @@ class MathExpressionParserTest { } @Test - @RunParameterized( - Iteration("exp", "func=exp"), Iteration("log", "func=log"), Iteration("log10", "func=log10"), - Iteration("ln", "func=ln"), Iteration("sin", "func=sin"), Iteration("cos", "func=cos"), - Iteration("tan", "func=tan"), Iteration("cot", "func=cot"), Iteration("csc", "func=csc"), - Iteration("sec", "func=sec"), Iteration("atan", "func=atan"), Iteration("asin", "func=asin"), - Iteration("acos", "func=acos"), Iteration("abs", "func=abs") - ) + @Iteration("exp", "func=exp") + @Iteration("log", "func=log") + @Iteration("log10", "func=log10") + @Iteration("ln", "func=ln") + @Iteration("sin", "func=sin") + @Iteration("cos", "func=cos") + @Iteration("tan", "func=tan") + @Iteration("cot", "func=cot") + @Iteration("csc", "func=csc") + @Iteration("sec", "func=sec") + @Iteration("atan", "func=atan") + @Iteration("asin", "func=asin") + @Iteration("acos", "func=acos") + @Iteration("abs", "func=abs") fun testParseNumExp_prohibitedFunctionInUse_returnsInvalidFunctionInUseErrorWithDetails() { val expression = "$func(0.5+1)" @@ -993,15 +1009,23 @@ class MathExpressionParserTest { } @Test - @RunParameterized( - Iteration("ex", "func=ex"), Iteration("lo", "func=lo"), Iteration("log1", "func=log1"), - Iteration("si", "func=si"), Iteration("co", "func=co"), Iteration("ta", "func=ta"), - Iteration("cs", "func=cs"), Iteration("se", "func=se"), Iteration("at", "func=at"), - Iteration("ata", "func=ata"), Iteration("as", "func=as"), Iteration("asi", "func=asi"), - Iteration("ac", "func=ac"), Iteration("aco", "func=aco"), Iteration("ab", "func=ab"), - Iteration("sq", "func=sq"), Iteration("sqr", "func=sqr") - - ) + @Iteration("ex", "func=ex") + @Iteration("lo", "func=lo") + @Iteration("log1", "func=log1") + @Iteration("si", "func=si") + @Iteration("co", "func=co") + @Iteration("ta", "func=ta") + @Iteration("cs", "func=cs") + @Iteration("se", "func=se") + @Iteration("at", "func=at") + @Iteration("ata", "func=ata") + @Iteration("as", "func=as") + @Iteration("asi", "func=asi") + @Iteration("ac", "func=ac") + @Iteration("aco", "func=aco") + @Iteration("ab", "func=ab") + @Iteration("sq", "func=sq") + @Iteration("sqr", "func=sqr") fun testParseAlgExp_startOfKnownFunction_returnsFunctionNameIncompleteError() { val expression = "$func(0.5+1)" val error = expectFailureWhenParsingAlgebraicExpression(expression) @@ -1011,10 +1035,12 @@ class MathExpressionParserTest { } @Test - @RunParameterized( - Iteration("a", "func=a"), Iteration("c", "func=c"), Iteration("e", "func=e"), - Iteration("l", "func=l"), Iteration("s", "func=s"), Iteration("t", "func=t") - ) + @Iteration("a", "func=a") + @Iteration("c", "func=c") + @Iteration("e", "func=e") + @Iteration("l", "func=l") + @Iteration("s", "func=s") + @Iteration("t", "func=t") fun testParseAlgExp_firstLetterOfKnownFunctions_areValidExpressions() { val expression = "$func(0.5+1)" val allowedVariables = LOWERCASE_LATIN_ALPHABET diff --git a/utility/src/test/java/org/oppia/android/util/math/MathTokenizerTest.kt b/utility/src/test/java/org/oppia/android/util/math/MathTokenizerTest.kt index 4cf512cb261..4a620f29118 100644 --- a/utility/src/test/java/org/oppia/android/util/math/MathTokenizerTest.kt +++ b/utility/src/test/java/org/oppia/android/util/math/MathTokenizerTest.kt @@ -6,7 +6,6 @@ import org.junit.runner.RunWith import org.oppia.android.testing.junit.OppiaParameterizedTestRunner import org.oppia.android.testing.junit.OppiaParameterizedTestRunner.Iteration import org.oppia.android.testing.junit.OppiaParameterizedTestRunner.Parameter -import org.oppia.android.testing.junit.OppiaParameterizedTestRunner.RunParameterized import org.oppia.android.testing.junit.OppiaParameterizedTestRunner.SelectRunnerPlatform import org.oppia.android.testing.junit.ParameterizedJunitTestRunner import org.oppia.android.testing.math.TokenSubject.Companion.assertThat @@ -160,34 +159,58 @@ class MathTokenizerTest { } @Test - @RunParameterized( - Iteration("a", "variableName=a"), Iteration("A", "variableName=A"), - Iteration("b", "variableName=b"), Iteration("B", "variableName=B"), - Iteration("c", "variableName=c"), Iteration("C", "variableName=C"), - Iteration("d", "variableName=d"), Iteration("D", "variableName=D"), - Iteration("e", "variableName=e"), Iteration("E", "variableName=E"), - Iteration("f", "variableName=f"), Iteration("F", "variableName=F"), - Iteration("g", "variableName=g"), Iteration("G", "variableName=G"), - Iteration("h", "variableName=h"), Iteration("H", "variableName=H"), - Iteration("i", "variableName=i"), Iteration("I", "variableName=I"), - Iteration("j", "variableName=j"), Iteration("J", "variableName=J"), - Iteration("k", "variableName=k"), Iteration("K", "variableName=K"), - Iteration("l", "variableName=l"), Iteration("L", "variableName=L"), - Iteration("m", "variableName=m"), Iteration("M", "variableName=M"), - Iteration("n", "variableName=n"), Iteration("N", "variableName=N"), - Iteration("o", "variableName=o"), Iteration("O", "variableName=O"), - Iteration("p", "variableName=p"), Iteration("P", "variableName=P"), - Iteration("q", "variableName=q"), Iteration("Q", "variableName=Q"), - Iteration("r", "variableName=r"), Iteration("R", "variableName=R"), - Iteration("s", "variableName=s"), Iteration("S", "variableName=S"), - Iteration("t", "variableName=t"), Iteration("T", "variableName=T"), - Iteration("u", "variableName=u"), Iteration("U", "variableName=U"), - Iteration("v", "variableName=v"), Iteration("V", "variableName=V"), - Iteration("w", "variableName=w"), Iteration("W", "variableName=W"), - Iteration("x", "variableName=x"), Iteration("X", "variableName=X"), - Iteration("y", "variableName=y"), Iteration("Y", "variableName=Y"), - Iteration("z", "variableName=z"), Iteration("Z", "variableName=Z") - ) + @Iteration("a", "variableName=a") + @Iteration("A", "variableName=A") + @Iteration("b", "variableName=b") + @Iteration("B", "variableName=B") + @Iteration("c", "variableName=c") + @Iteration("C", "variableName=C") + @Iteration("d", "variableName=d") + @Iteration("D", "variableName=D") + @Iteration("e", "variableName=e") + @Iteration("E", "variableName=E") + @Iteration("f", "variableName=f") + @Iteration("F", "variableName=F") + @Iteration("g", "variableName=g") + @Iteration("G", "variableName=G") + @Iteration("h", "variableName=h") + @Iteration("H", "variableName=H") + @Iteration("i", "variableName=i") + @Iteration("I", "variableName=I") + @Iteration("j", "variableName=j") + @Iteration("J", "variableName=J") + @Iteration("k", "variableName=k") + @Iteration("K", "variableName=K") + @Iteration("l", "variableName=l") + @Iteration("L", "variableName=L") + @Iteration("m", "variableName=m") + @Iteration("M", "variableName=M") + @Iteration("n", "variableName=n") + @Iteration("N", "variableName=N") + @Iteration("o", "variableName=o") + @Iteration("O", "variableName=O") + @Iteration("p", "variableName=p") + @Iteration("P", "variableName=P") + @Iteration("q", "variableName=q") + @Iteration("Q", "variableName=Q") + @Iteration("r", "variableName=r") + @Iteration("R", "variableName=R") + @Iteration("s", "variableName=s") + @Iteration("S", "variableName=S") + @Iteration("t", "variableName=t") + @Iteration("T", "variableName=T") + @Iteration("u", "variableName=u") + @Iteration("U", "variableName=U") + @Iteration("v", "variableName=v") + @Iteration("V", "variableName=V") + @Iteration("w", "variableName=w") + @Iteration("W", "variableName=W") + @Iteration("x", "variableName=x") + @Iteration("X", "variableName=X") + @Iteration("y", "variableName=y") + @Iteration("Y", "variableName=Y") + @Iteration("z", "variableName=z") + @Iteration("Z", "variableName=Z") fun testTokenize_variable_allLatinAlphabetCharactersAreValidVariables() { val tokens = MathTokenizer.tokenize(variableName).toList() @@ -535,14 +558,24 @@ class MathTokenizerTest { } @Test - @RunParameterized( - Iteration("aa", "funcName=aa"), Iteration("ad", "funcName=ad"), Iteration("al", "funcName=al"), - Iteration("ca", "funcName=ca"), Iteration("ce", "funcName=ce"), Iteration("cr", "funcName=cr"), - Iteration("ea", "funcName=ea"), Iteration("ef", "funcName=ef"), Iteration("er", "funcName=er"), - Iteration("la", "funcName=la"), Iteration("lz", "funcName=lz"), Iteration("le", "funcName=le"), - Iteration("sa", "funcName=sa"), Iteration("sp", "funcName=sp"), Iteration("sz", "funcName=sz"), - Iteration("te", "funcName=te"), Iteration("to", "funcName=to"), Iteration("tr", "funcName=tr") - ) + @Iteration("aa", "funcName=aa") + @Iteration("ad", "funcName=ad") + @Iteration("al", "funcName=al") + @Iteration("ca", "funcName=ca") + @Iteration("ce", "funcName=ce") + @Iteration("cr", "funcName=cr") + @Iteration("ea", "funcName=ea") + @Iteration("ef", "funcName=ef") + @Iteration("er", "funcName=er") + @Iteration("la", "funcName=la") + @Iteration("lz", "funcName=lz") + @Iteration("le", "funcName=le") + @Iteration("sa", "funcName=sa") + @Iteration("sp", "funcName=sp") + @Iteration("sz", "funcName=sz") + @Iteration("te", "funcName=te") + @Iteration("to", "funcName=to") + @Iteration("tr", "funcName=tr") fun testTokenize_twoVarsSharingOnlyFirstWithFunctionNames_shouldParseAsVariables() { val tokens = MathTokenizer.tokenize(funcName).toList() @@ -554,16 +587,22 @@ class MathTokenizerTest { } @Test - @RunParameterized( - Iteration("ab", "funcName=ab"), Iteration("ac", "funcName=ac"), - Iteration("aco", "funcName=aco"), Iteration("as", "funcName=as"), - Iteration("asi", "funcName=asi"), Iteration("at", "funcName=at"), - Iteration("ata", "funcName=ata"), Iteration("co", "funcName=co"), - Iteration("cs", "funcName=cs"), Iteration("ex", "funcName=ex"), - Iteration("lo", "funcName=lo"), Iteration("log1", "funcName=log1"), - Iteration("se", "funcName=se"), Iteration("si", "funcName=si"), - Iteration("sq", "funcName=sq"), Iteration("ta", "funcName=ta") - ) + @Iteration("ab", "funcName=ab") + @Iteration("ac", "funcName=ac") + @Iteration("aco", "funcName=aco") + @Iteration("as", "funcName=as") + @Iteration("asi", "funcName=asi") + @Iteration("at", "funcName=at") + @Iteration("ata", "funcName=ata") + @Iteration("co", "funcName=co") + @Iteration("cs", "funcName=cs") + @Iteration("ex", "funcName=ex") + @Iteration("lo", "funcName=lo") + @Iteration("log1", "funcName=log1") + @Iteration("se", "funcName=se") + @Iteration("si", "funcName=si") + @Iteration("sq", "funcName=sq") + @Iteration("ta", "funcName=ta") fun testTokenize_twoVarsSharedWithFunctionNames_shouldParseAsIncompleteFuncName() { val tokens = MathTokenizer.tokenize(funcName).toList() @@ -616,33 +655,55 @@ class MathTokenizerTest { } @Test - @RunParameterized( - Iteration("α", "token=α"), Iteration("Α", "token=Α"), - Iteration("β", "token=β"), Iteration("Β", "token=Β"), - Iteration("γ", "token=γ"), Iteration("Γ", "token=Γ"), - Iteration("δ", "token=δ"), Iteration("Δ", "token=Δ"), - Iteration("ϵ", "token=ϵ"), Iteration("Ε", "token=Ε"), - Iteration("ζ", "token=ζ"), Iteration("Ζ", "token=Ζ"), - Iteration("η", "token=η"), Iteration("Η", "token=Η"), - Iteration("θ", "token=θ"), Iteration("Θ", "token=Θ"), - Iteration("ι", "token=ι"), Iteration("Ι", "token=Ι"), - Iteration("κ", "token=κ"), Iteration("Κ", "token=Κ"), - Iteration("λ", "token=λ"), Iteration("Λ", "token=Λ"), - Iteration("μ", "token=μ"), Iteration("Μ", "token=Μ"), - Iteration("ν", "token=ν"), Iteration("Ν", "token=Ν"), - Iteration("ξ", "token=ξ"), Iteration("Ξ", "token=Ξ"), - Iteration("ο", "token=ο"), Iteration("Ο", "token=Ο"), - Iteration("π", "token=π"), Iteration("Π", "token=Π"), - Iteration("ρ", "token=ρ"), Iteration("Ρ", "token=Ρ"), - Iteration("σ", "token=σ"), Iteration("Σ", "token=Σ"), - Iteration("τ", "token=τ"), Iteration("Τ", "token=Τ"), - Iteration("υ", "token=υ"), Iteration("Υ", "token=Υ"), - Iteration("ϕ", "token=ϕ"), Iteration("Φ", "token=Φ"), - Iteration("χ", "token=χ"), Iteration("Χ", "token=Χ"), - Iteration("ψ", "token=ψ"), Iteration("Ψ", "token=Ψ"), - Iteration("ω", "token=ω"), Iteration("Ω", "token=Ω"), - Iteration("ς", "token=ς") - ) + @Iteration("α", "token=α") + @Iteration("Α", "token=Α") + @Iteration("β", "token=β") + @Iteration("Β", "token=Β") + @Iteration("γ", "token=γ") + @Iteration("Γ", "token=Γ") + @Iteration("δ", "token=δ") + @Iteration("Δ", "token=Δ") + @Iteration("ϵ", "token=ϵ") + @Iteration("Ε", "token=Ε") + @Iteration("ζ", "token=ζ") + @Iteration("Ζ", "token=Ζ") + @Iteration("η", "token=η") + @Iteration("Η", "token=Η") + @Iteration("θ", "token=θ") + @Iteration("Θ", "token=Θ") + @Iteration("ι", "token=ι") + @Iteration("Ι", "token=Ι") + @Iteration("κ", "token=κ") + @Iteration("Κ", "token=Κ") + @Iteration("λ", "token=λ") + @Iteration("Λ", "token=Λ") + @Iteration("μ", "token=μ") + @Iteration("Μ", "token=Μ") + @Iteration("ν", "token=ν") + @Iteration("Ν", "token=Ν") + @Iteration("ξ", "token=ξ") + @Iteration("Ξ", "token=Ξ") + @Iteration("ο", "token=ο") + @Iteration("Ο", "token=Ο") + @Iteration("π", "token=π") + @Iteration("Π", "token=Π") + @Iteration("ρ", "token=ρ") + @Iteration("Ρ", "token=Ρ") + @Iteration("σ", "token=σ") + @Iteration("Σ", "token=Σ") + @Iteration("τ", "token=τ") + @Iteration("Τ", "token=Τ") + @Iteration("υ", "token=υ") + @Iteration("Υ", "token=Υ") + @Iteration("ϕ", "token=ϕ") + @Iteration("Φ", "token=Φ") + @Iteration("χ", "token=χ") + @Iteration("Χ", "token=Χ") + @Iteration("ψ", "token=ψ") + @Iteration("Ψ", "token=Ψ") + @Iteration("ω", "token=ω") + @Iteration("Ω", "token=Ω") + @Iteration("ς", "token=ς") fun testTokenize_greekLetters_produceInvalidTokens() { val tokens = MathTokenizer.tokenize(token).toList() diff --git a/utility/src/test/java/org/oppia/android/util/math/PolynomialExtensionsTest.kt b/utility/src/test/java/org/oppia/android/util/math/PolynomialExtensionsTest.kt index 9711b1d0c87..1f9824e2b1d 100644 --- a/utility/src/test/java/org/oppia/android/util/math/PolynomialExtensionsTest.kt +++ b/utility/src/test/java/org/oppia/android/util/math/PolynomialExtensionsTest.kt @@ -11,7 +11,6 @@ import org.oppia.android.app.model.Real import org.oppia.android.testing.junit.OppiaParameterizedTestRunner import org.oppia.android.testing.junit.OppiaParameterizedTestRunner.Iteration import org.oppia.android.testing.junit.OppiaParameterizedTestRunner.Parameter -import org.oppia.android.testing.junit.OppiaParameterizedTestRunner.RunParameterized import org.oppia.android.testing.junit.OppiaParameterizedTestRunner.SelectRunnerPlatform import org.oppia.android.testing.junit.ParameterizedJunitTestRunner import org.oppia.android.testing.math.PolynomialSubject.Companion.assertThat @@ -1213,14 +1212,12 @@ class PolynomialExtensionsTest { } @Test - @RunParameterized( - Iteration("x+y+z", "var1=x", "var2=y", "var3=z"), - Iteration("x+z+y", "var1=x", "var2=z", "var3=y"), - Iteration("y+x+z", "var1=y", "var2=x", "var3=z"), - Iteration("y+z+x", "var1=y", "var2=z", "var3=x"), - Iteration("z+x+y", "var1=z", "var2=x", "var3=y"), - Iteration("z+y+x", "var1=z", "var2=y", "var3=x") - ) + @Iteration("x+y+z", "var1=x", "var2=y", "var3=z") + @Iteration("x+z+y", "var1=x", "var2=z", "var3=y") + @Iteration("y+x+z", "var1=y", "var2=x", "var3=z") + @Iteration("y+z+x", "var1=y", "var2=z", "var3=x") + @Iteration("z+x+y", "var1=z", "var2=x", "var3=y") + @Iteration("z+y+x", "var1=z", "var2=y", "var3=x") fun testSort_xPlusYPlusZ_inAnyOrder_returnsXPlusYPlusZ() { val polynomial = createPolynomial( createTerm(coefficient = ONE, createVariable(name = var1, power = 1)), diff --git a/utility/src/test/java/org/oppia/android/util/math/RealExtensionsTest.kt b/utility/src/test/java/org/oppia/android/util/math/RealExtensionsTest.kt index fee8d4e00e7..670b553666b 100644 --- a/utility/src/test/java/org/oppia/android/util/math/RealExtensionsTest.kt +++ b/utility/src/test/java/org/oppia/android/util/math/RealExtensionsTest.kt @@ -9,7 +9,6 @@ import org.oppia.android.testing.assertThrows import org.oppia.android.testing.junit.OppiaParameterizedTestRunner import org.oppia.android.testing.junit.OppiaParameterizedTestRunner.Iteration import org.oppia.android.testing.junit.OppiaParameterizedTestRunner.Parameter -import org.oppia.android.testing.junit.OppiaParameterizedTestRunner.RunParameterized import org.oppia.android.testing.junit.OppiaParameterizedTestRunner.SelectRunnerPlatform import org.oppia.android.testing.junit.ParameterizedJunitTestRunner import org.oppia.android.testing.math.RealSubject.Companion.assertThat @@ -329,12 +328,10 @@ class RealExtensionsTest { } @Test - @RunParameterized( - Iteration("0==0", "lhsInt=0", "rhsInt=0"), - Iteration("1==1", "lhsInt=1", "rhsInt=1"), - Iteration("2==2", "lhsInt=2", "rhsInt=2"), - Iteration("-2==-2", "lhsInt=-2", "rhsInt=-2") - ) + @Iteration("0==0", "lhsInt=0", "rhsInt=0") + @Iteration("1==1", "lhsInt=1", "rhsInt=1") + @Iteration("2==2", "lhsInt=2", "rhsInt=2") + @Iteration("-2==-2", "lhsInt=-2", "rhsInt=-2") fun testIsApproximatelyEqualTo_oneIsInt_otherIsSameInt_returnsTrue() { val first = createIntegerReal(lhsInt) val second = createIntegerReal(rhsInt) @@ -348,12 +345,10 @@ class RealExtensionsTest { } @Test - @RunParameterized( - Iteration("0!=1", "lhsInt=0", "rhsInt=1"), - Iteration("0!=2", "lhsInt=0", "rhsInt=2"), - Iteration("-2!=2", "lhsInt=-2", "rhsInt=2"), - Iteration("-2!=-1", "lhsInt=-2", "rhsInt=-1") - ) + @Iteration("0!=1", "lhsInt=0", "rhsInt=1") + @Iteration("0!=2", "lhsInt=0", "rhsInt=2") + @Iteration("-2!=2", "lhsInt=-2", "rhsInt=2") + @Iteration("-2!=-1", "lhsInt=-2", "rhsInt=-1") fun testIsApproximatelyEqualTo_oneIsInt_otherIsDifferentInt_returnsFalse() { val first = createIntegerReal(lhsInt) val second = createIntegerReal(rhsInt) @@ -366,15 +361,13 @@ class RealExtensionsTest { } @Test - @RunParameterized( - Iteration("0==0", "lhsInt=0", "rhsFrac=0"), - Iteration("2==2", "lhsInt=2", "rhsFrac=2"), - Iteration("2==2/1", "lhsInt=2", "rhsFrac=2/1"), - Iteration("2==4/2", "lhsInt=2", "rhsFrac=4/2"), - Iteration("-2==-2", "lhsInt=-2", "rhsFrac=-2"), - Iteration("-2==-2/1", "lhsInt=-2", "rhsFrac=-2/1"), - Iteration("-2==-4/2", "lhsInt=-2", "rhsFrac=-4/2") - ) + @Iteration("0==0", "lhsInt=0", "rhsFrac=0") + @Iteration("2==2", "lhsInt=2", "rhsFrac=2") + @Iteration("2==2/1", "lhsInt=2", "rhsFrac=2/1") + @Iteration("2==4/2", "lhsInt=2", "rhsFrac=4/2") + @Iteration("-2==-2", "lhsInt=-2", "rhsFrac=-2") + @Iteration("-2==-2/1", "lhsInt=-2", "rhsFrac=-2/1") + @Iteration("-2==-4/2", "lhsInt=-2", "rhsFrac=-4/2") fun testIsApproximatelyEqualTo_oneIsInt_otherIsSameFraction_returnsTrue() { val first = createIntegerReal(lhsInt) val second = createRationalReal(rhsFrac) @@ -388,12 +381,10 @@ class RealExtensionsTest { } @Test - @RunParameterized( - Iteration("0!=2", "lhsInt=0", "rhsFrac=2"), - Iteration("2!=4", "lhsInt=2", "rhsFrac=4"), - Iteration("2!=3/2", "lhsInt=2", "rhsFrac=3/2"), - Iteration("2!=-2", "lhsInt=2", "rhsFrac=-2"), - ) + @Iteration("0!=2", "lhsInt=0", "rhsFrac=2") + @Iteration("2!=4", "lhsInt=2", "rhsFrac=4") + @Iteration("2!=3/2", "lhsInt=2", "rhsFrac=3/2") + @Iteration("2!=-2", "lhsInt=2", "rhsFrac=-2") fun testIsApproximatelyEqualTo_oneIsInt_otherIsDifferentFraction_returnsFalse() { val first = createIntegerReal(lhsInt) val second = createRationalReal(rhsFrac) @@ -406,16 +397,14 @@ class RealExtensionsTest { } @Test - @RunParameterized( - Iteration("0==0.0", "lhsInt=0", "rhsDouble=0.0"), - Iteration("1==1.0", "lhsInt=1", "rhsDouble=1.0"), - Iteration("2==2.0", "lhsInt=2", "rhsDouble=2.0"), - Iteration("2==2.000000000000001", "lhsInt=2", "rhsDouble=2.000000000000001"), - Iteration("2==1.999999999999999", "lhsInt=2", "rhsDouble=1.999999999999999"), - Iteration("-2==-2.0", "lhsInt=-2", "rhsDouble=-2.0"), - Iteration("-2==-2.00000000000001", "lhsInt=-2", "rhsDouble=-2.00000000000001"), - Iteration("-2==-1.999999999999999", "lhsInt=-2", "rhsDouble=-1.999999999999999") - ) + @Iteration("0==0.0", "lhsInt=0", "rhsDouble=0.0") + @Iteration("1==1.0", "lhsInt=1", "rhsDouble=1.0") + @Iteration("2==2.0", "lhsInt=2", "rhsDouble=2.0") + @Iteration("2==2.000000000000001", "lhsInt=2", "rhsDouble=2.000000000000001") + @Iteration("2==1.999999999999999", "lhsInt=2", "rhsDouble=1.999999999999999") + @Iteration("-2==-2.0", "lhsInt=-2", "rhsDouble=-2.0") + @Iteration("-2==-2.00000000000001", "lhsInt=-2", "rhsDouble=-2.00000000000001") + @Iteration("-2==-1.999999999999999", "lhsInt=-2", "rhsDouble=-1.999999999999999") fun testIsApproximatelyEqualTo_oneIsInt_otherIsSimilarDouble_returnsTrue() { val first = createIntegerReal(lhsInt) val second = createIrrationalReal(rhsDouble) @@ -429,18 +418,16 @@ class RealExtensionsTest { } @Test - @RunParameterized( - Iteration("0!=2.0", "lhsInt=0", "rhsDouble=2.0"), - Iteration("2!=0.0", "lhsInt=2", "rhsDouble=0.0"), - Iteration("2!=4.0", "lhsInt=2", "rhsDouble=4.0"), - Iteration("3!=3.14", "lhsInt=3", "rhsDouble=3.14"), - Iteration("2!=2.001", "lhsInt=2", "rhsDouble=2.001"), - Iteration("2!=1.999", "lhsInt=2", "rhsDouble=1.999"), - Iteration("2!=-2.0", "lhsInt=2", "rhsDouble=-2.0"), - Iteration("-2!=2.0", "lhsInt=-2", "rhsDouble=2.0"), - Iteration("-2!=-2.001", "lhsInt=-2", "rhsDouble=-2.001"), - Iteration("-2!=-1.999", "lhsInt=-2", "rhsDouble=-1.999") - ) + @Iteration("0!=2.0", "lhsInt=0", "rhsDouble=2.0") + @Iteration("2!=0.0", "lhsInt=2", "rhsDouble=0.0") + @Iteration("2!=4.0", "lhsInt=2", "rhsDouble=4.0") + @Iteration("3!=3.14", "lhsInt=3", "rhsDouble=3.14") + @Iteration("2!=2.001", "lhsInt=2", "rhsDouble=2.001") + @Iteration("2!=1.999", "lhsInt=2", "rhsDouble=1.999") + @Iteration("2!=-2.0", "lhsInt=2", "rhsDouble=-2.0") + @Iteration("-2!=2.0", "lhsInt=-2", "rhsDouble=2.0") + @Iteration("-2!=-2.001", "lhsInt=-2", "rhsDouble=-2.001") + @Iteration("-2!=-1.999", "lhsInt=-2", "rhsDouble=-1.999") fun testIsApproximatelyEqualTo_oneIsInt_otherIsDifferentDouble_returnsFalse() { val first = createIntegerReal(lhsInt) val second = createIrrationalReal(rhsDouble) @@ -453,16 +440,14 @@ class RealExtensionsTest { } @Test - @RunParameterized( - Iteration("0==0", "lhsFrac=0", "rhsFrac=0"), - Iteration("2==2", "lhsFrac=2", "rhsFrac=2"), - Iteration("2==4/2", "lhsFrac=2", "rhsFrac=4/2"), - Iteration("3/2==1 1/2", "lhsFrac=3/2", "rhsFrac=1 1/2"), - Iteration("-2==-2", "lhsFrac=-2", "rhsFrac=-2"), - Iteration("-2==-4/2", "lhsFrac=-2", "rhsFrac=-4/2"), - Iteration("-3/2==-1 1/2", "lhsFrac=-3/2", "rhsFrac=-1 1/2"), - Iteration("1/3==3/9", "lhsFrac=1/3", "rhsFrac=3/9") - ) + @Iteration("0==0", "lhsFrac=0", "rhsFrac=0") + @Iteration("2==2", "lhsFrac=2", "rhsFrac=2") + @Iteration("2==4/2", "lhsFrac=2", "rhsFrac=4/2") + @Iteration("3/2==1 1/2", "lhsFrac=3/2", "rhsFrac=1 1/2") + @Iteration("-2==-2", "lhsFrac=-2", "rhsFrac=-2") + @Iteration("-2==-4/2", "lhsFrac=-2", "rhsFrac=-4/2") + @Iteration("-3/2==-1 1/2", "lhsFrac=-3/2", "rhsFrac=-1 1/2") + @Iteration("1/3==3/9", "lhsFrac=1/3", "rhsFrac=3/9") fun testIsApproximatelyEqualTo_oneIsFraction_otherIsSameFraction_returnsTrue() { val first = createRationalReal(lhsFrac) val second = createRationalReal(rhsFrac) @@ -476,15 +461,13 @@ class RealExtensionsTest { } @Test - @RunParameterized( - Iteration("0!=2", "lhsFrac=0", "rhsFrac=2"), - Iteration("3/2!=1/2", "lhsFrac=3/2", "rhsFrac=1/2"), - Iteration("3/2!=1", "lhsFrac=3/2", "rhsFrac=1"), - Iteration("3/2!=-1 1/2", "lhsFrac=3/2", "rhsFrac=-1 1/2"), - Iteration("-3/2!=1 1/2", "lhsFrac=-3/2", "rhsFrac=1 1/2"), - Iteration("-3/2!=-1/2", "lhsFrac=-3/2", "rhsFrac=-1/2"), - Iteration("1/3!=2/3", "lhsFrac=1/3", "rhsFrac=2/3") - ) + @Iteration("0!=2", "lhsFrac=0", "rhsFrac=2") + @Iteration("3/2!=1/2", "lhsFrac=3/2", "rhsFrac=1/2") + @Iteration("3/2!=1", "lhsFrac=3/2", "rhsFrac=1") + @Iteration("3/2!=-1 1/2", "lhsFrac=3/2", "rhsFrac=-1 1/2") + @Iteration("-3/2!=1 1/2", "lhsFrac=-3/2", "rhsFrac=1 1/2") + @Iteration("-3/2!=-1/2", "lhsFrac=-3/2", "rhsFrac=-1/2") + @Iteration("1/3!=2/3", "lhsFrac=1/3", "rhsFrac=2/3") fun testIsApproximatelyEqualTo_oneIsFraction_otherIsDifferentFraction_returnsFalse() { val first = createRationalReal(lhsFrac) val second = createRationalReal(rhsFrac) @@ -497,16 +480,14 @@ class RealExtensionsTest { } @Test - @RunParameterized( - Iteration("0==0.0", "lhsFrac=0", "rhsDouble=0.0"), - Iteration("2==2.0", "lhsFrac=2", "rhsDouble=2.0"), - Iteration("2/1==2.0", "lhsFrac=2/1", "rhsDouble=2.0"), - Iteration("3/2==1.5", "lhsFrac=3/2", "rhsDouble=1.5"), - Iteration("1/3==0.33333333333333333", "lhsFrac=1/3", "rhsDouble=0.33333333333333333"), - Iteration("1 2/3==1.66666666666666666", "lhsFrac=1 2/3", "rhsDouble=1.66666666666666666"), - Iteration("-2==-2.0", "lhsFrac=-2", "rhsDouble=-2.0"), - Iteration("-3/2==-1.5", "lhsFrac=-3/2", "rhsDouble=-1.5") - ) + @Iteration("0==0.0", "lhsFrac=0", "rhsDouble=0.0") + @Iteration("2==2.0", "lhsFrac=2", "rhsDouble=2.0") + @Iteration("2/1==2.0", "lhsFrac=2/1", "rhsDouble=2.0") + @Iteration("3/2==1.5", "lhsFrac=3/2", "rhsDouble=1.5") + @Iteration("1/3==0.33333333333333333", "lhsFrac=1/3", "rhsDouble=0.33333333333333333") + @Iteration("1 2/3==1.66666666666666666", "lhsFrac=1 2/3", "rhsDouble=1.66666666666666666") + @Iteration("-2==-2.0", "lhsFrac=-2", "rhsDouble=-2.0") + @Iteration("-3/2==-1.5", "lhsFrac=-3/2", "rhsDouble=-1.5") fun testIsApproximatelyEqualTo_oneIsFraction_otherIsSimilarDouble_returnsTrue() { val first = createRationalReal(lhsFrac) val second = createIrrationalReal(rhsDouble) @@ -520,19 +501,17 @@ class RealExtensionsTest { } @Test - @RunParameterized( - Iteration("0!=2.0", "lhsFrac=0", "rhsDouble=2.0"), - Iteration("2!=0.0", "lhsFrac=2", "rhsDouble=0.0"), - Iteration("2/2!=2.0", "lhsFrac=2/2", "rhsDouble=2.0"), - Iteration("1/3!=0.333", "lhsFrac=1/3", "rhsDouble=0.333"), - Iteration("1 2/3!=1.667", "lhsFrac=1 2/3", "rhsDouble=1.667"), - Iteration("22/7!=3.14", "lhsFrac=22/7", "rhsDouble=3.14"), - Iteration("-2!=2.0", "lhsFrac=-2", "rhsDouble=2.0"), - Iteration("2!=-2.0", "lhsFrac=2", "rhsDouble=-2.0"), - Iteration("-2/2!=-2.0", "lhsFrac=-2/2", "rhsDouble=-2.0"), - Iteration("-1/3!=-0.333", "lhsFrac=-1/3", "rhsDouble=-0.333"), - Iteration("-1 2/3!=-1.667", "lhsFrac=-1 2/3", "rhsDouble=-1.667") - ) + @Iteration("0!=2.0", "lhsFrac=0", "rhsDouble=2.0") + @Iteration("2!=0.0", "lhsFrac=2", "rhsDouble=0.0") + @Iteration("2/2!=2.0", "lhsFrac=2/2", "rhsDouble=2.0") + @Iteration("1/3!=0.333", "lhsFrac=1/3", "rhsDouble=0.333") + @Iteration("1 2/3!=1.667", "lhsFrac=1 2/3", "rhsDouble=1.667") + @Iteration("22/7!=3.14", "lhsFrac=22/7", "rhsDouble=3.14") + @Iteration("-2!=2.0", "lhsFrac=-2", "rhsDouble=2.0") + @Iteration("2!=-2.0", "lhsFrac=2", "rhsDouble=-2.0") + @Iteration("-2/2!=-2.0", "lhsFrac=-2/2", "rhsDouble=-2.0") + @Iteration("-1/3!=-0.333", "lhsFrac=-1/3", "rhsDouble=-0.333") + @Iteration("-1 2/3!=-1.667", "lhsFrac=-1 2/3", "rhsDouble=-1.667") fun testIsApproximatelyEqualTo_oneIsFraction_firstIsDifferentDouble_returnsFalse() { val first = createRationalReal(lhsFrac) val second = createIrrationalReal(rhsDouble) @@ -545,23 +524,21 @@ class RealExtensionsTest { } @Test - @RunParameterized( - Iteration("0.0==0.0", "lhsDouble=0.0", "rhsDouble=0.0"), - Iteration("2.0==2.0", "lhsDouble=2.0", "rhsDouble=2.0"), - Iteration( - "2.000000000000001==1.999999999999999", - "lhsDouble=2.000000000000001", - "rhsDouble=1.999999999999999" - ), - Iteration("3.14==3.14", "lhsDouble=3.14", "rhsDouble=3.14"), - Iteration("-2.0==-2.0", "lhsDouble=-2.0", "rhsDouble=-2.0"), - Iteration( - "-2.000000000000001==-1.999999999999999", - "lhsDouble=-2.000000000000001", - "rhsDouble=-1.999999999999999" - ), - Iteration("-3.14==-3.14", "lhsDouble=-3.14", "rhsDouble=-3.14") + @Iteration("0.0==0.0", "lhsDouble=0.0", "rhsDouble=0.0") + @Iteration("2.0==2.0", "lhsDouble=2.0", "rhsDouble=2.0") + @Iteration( + "2.000000000000001==1.999999999999999", + "lhsDouble=2.000000000000001", + "rhsDouble=1.999999999999999" + ) + @Iteration("3.14==3.14", "lhsDouble=3.14", "rhsDouble=3.14") + @Iteration("-2.0==-2.0", "lhsDouble=-2.0", "rhsDouble=-2.0") + @Iteration( + "-2.000000000000001==-1.999999999999999", + "lhsDouble=-2.000000000000001", + "rhsDouble=-1.999999999999999" ) + @Iteration("-3.14==-3.14", "lhsDouble=-3.14", "rhsDouble=-3.14") fun testIsApproximatelyEqualTo_oneIsDouble_otherIsSimilarDouble_returnsTrue() { val first = createIrrationalReal(lhsDouble) val second = createIrrationalReal(rhsDouble) @@ -575,15 +552,13 @@ class RealExtensionsTest { } @Test - @RunParameterized( - Iteration("0.0!=2.0", "lhsDouble=0.0", "rhsDouble=2.0"), - Iteration("2.001!=1.999", "lhsDouble=2.001", "rhsDouble=1.999"), - Iteration("2.7!=3.14", "lhsDouble=2.7", "rhsDouble=3.14"), - Iteration("2.7!=-3.14", "lhsDouble=2.7", "rhsDouble=-3.14"), - Iteration("-2.7!=3.14", "lhsDouble=-2.7", "rhsDouble=3.14"), - Iteration("-2.0!=2.0", "lhsDouble=-2.0", "rhsDouble=2.0"), - Iteration("-3.14!=3.14", "lhsDouble=-3.14", "rhsDouble=3.14") - ) + @Iteration("0.0!=2.0", "lhsDouble=0.0", "rhsDouble=2.0") + @Iteration("2.001!=1.999", "lhsDouble=2.001", "rhsDouble=1.999") + @Iteration("2.7!=3.14", "lhsDouble=2.7", "rhsDouble=3.14") + @Iteration("2.7!=-3.14", "lhsDouble=2.7", "rhsDouble=-3.14") + @Iteration("-2.7!=3.14", "lhsDouble=-2.7", "rhsDouble=3.14") + @Iteration("-2.0!=2.0", "lhsDouble=-2.0", "rhsDouble=2.0") + @Iteration("-3.14!=3.14", "lhsDouble=-3.14", "rhsDouble=3.14") fun testIsApproximatelyEqualTo_oneIsDouble_otherIsDifferentDouble_returnsFalse() { val first = createIrrationalReal(lhsDouble) val second = createIrrationalReal(rhsDouble) @@ -1033,15 +1008,13 @@ class RealExtensionsTest { // Addition tests. @Test - @RunParameterized( - Iteration("identity+identity", "lhsInt=0", "rhsInt=0", "expInt=0"), - Iteration("int+identity", "lhsInt=1", "rhsInt=0", "expInt=1"), - Iteration("int+int", "lhsInt=1", "rhsInt=2", "expInt=3"), - Iteration("commutativity", "lhsInt=2", "rhsInt=1", "expInt=3"), - Iteration("int+-int", "lhsInt=1", "rhsInt=-2", "expInt=-1"), - Iteration("-int+int", "lhsInt=-1", "rhsInt=2", "expInt=1"), - Iteration("-int+-int", "lhsInt=-1", "rhsInt=-2", "expInt=-3") - ) + @Iteration("identity+identity", "lhsInt=0", "rhsInt=0", "expInt=0") + @Iteration("int+identity", "lhsInt=1", "rhsInt=0", "expInt=1") + @Iteration("int+int", "lhsInt=1", "rhsInt=2", "expInt=3") + @Iteration("commutativity", "lhsInt=2", "rhsInt=1", "expInt=3") + @Iteration("int+-int", "lhsInt=1", "rhsInt=-2", "expInt=-1") + @Iteration("-int+int", "lhsInt=-1", "rhsInt=2", "expInt=1") + @Iteration("-int+-int", "lhsInt=-1", "rhsInt=-2", "expInt=-3") fun testPlus_intAndInt_returnsInt() { val lhsReal = createIntegerReal(lhsInt) val rhsReal = createIntegerReal(rhsInt) @@ -1052,16 +1025,14 @@ class RealExtensionsTest { } @Test - @RunParameterized( - Iteration("identity+identity", "lhsInt=0", "rhsFrac=0/1", "expFrac=0/1"), - Iteration("int+identity", "lhsInt=1", "rhsFrac=0/1", "expFrac=1"), - Iteration("int+fraction", "lhsInt=2", "rhsFrac=1/3", "expFrac=2 1/3"), - Iteration("int+wholeNumberFraction", "lhsInt=2", "rhsFrac=3/1", "expFrac=5"), - Iteration("commutativity", "lhsInt=3", "rhsFrac=2/1", "expFrac=5"), - Iteration("int+-fraction", "lhsInt=2", "rhsFrac=-1/3", "expFrac=1 2/3"), - Iteration("-int+fraction", "lhsInt=-2", "rhsFrac=1/3", "expFrac=-1 2/3"), - Iteration("-int+-fraction", "lhsInt=-2", "rhsFrac=-1/3", "expFrac=-2 1/3") - ) + @Iteration("identity+identity", "lhsInt=0", "rhsFrac=0/1", "expFrac=0/1") + @Iteration("int+identity", "lhsInt=1", "rhsFrac=0/1", "expFrac=1") + @Iteration("int+fraction", "lhsInt=2", "rhsFrac=1/3", "expFrac=2 1/3") + @Iteration("int+wholeNumberFraction", "lhsInt=2", "rhsFrac=3/1", "expFrac=5") + @Iteration("commutativity", "lhsInt=3", "rhsFrac=2/1", "expFrac=5") + @Iteration("int+-fraction", "lhsInt=2", "rhsFrac=-1/3", "expFrac=1 2/3") + @Iteration("-int+fraction", "lhsInt=-2", "rhsFrac=1/3", "expFrac=-1 2/3") + @Iteration("-int+-fraction", "lhsInt=-2", "rhsFrac=-1/3", "expFrac=-2 1/3") fun testPlus_intAndFraction_returnsFraction() { val lhsReal = createIntegerReal(lhsInt) val rhsReal = createRationalReal(rhsFrac) @@ -1073,16 +1044,14 @@ class RealExtensionsTest { } @Test - @RunParameterized( - Iteration("identity+identity", "lhsInt=0", "rhsDouble=0.0", "expDouble=0.0"), - Iteration("int+identity", "lhsInt=1", "rhsDouble=0.0", "expDouble=1.0"), - Iteration("int+double", "lhsInt=1", "rhsDouble=3.14", "expDouble=4.14"), - Iteration("int+wholeNumberDouble", "lhsInt=1", "rhsDouble=3.0", "expDouble=4.0"), - Iteration("commutativity", "lhsInt=3", "rhsDouble=1.0", "expDouble=4.0"), - Iteration("int+-double", "lhsInt=1", "rhsDouble=-3.14", "expDouble=-2.14"), - Iteration("-int+double", "lhsInt=-1", "rhsDouble=3.14", "expDouble=2.14"), - Iteration("-int+-double", "lhsInt=-1", "rhsDouble=-3.14", "expDouble=-4.14") - ) + @Iteration("identity+identity", "lhsInt=0", "rhsDouble=0.0", "expDouble=0.0") + @Iteration("int+identity", "lhsInt=1", "rhsDouble=0.0", "expDouble=1.0") + @Iteration("int+double", "lhsInt=1", "rhsDouble=3.14", "expDouble=4.14") + @Iteration("int+wholeNumberDouble", "lhsInt=1", "rhsDouble=3.0", "expDouble=4.0") + @Iteration("commutativity", "lhsInt=3", "rhsDouble=1.0", "expDouble=4.0") + @Iteration("int+-double", "lhsInt=1", "rhsDouble=-3.14", "expDouble=-2.14") + @Iteration("-int+double", "lhsInt=-1", "rhsDouble=3.14", "expDouble=2.14") + @Iteration("-int+-double", "lhsInt=-1", "rhsDouble=-3.14", "expDouble=-4.14") fun testPlus_intAndDouble_returnsDouble() { val lhsReal = createIntegerReal(lhsInt) val rhsReal = createIrrationalReal(rhsDouble) @@ -1093,16 +1062,14 @@ class RealExtensionsTest { } @Test - @RunParameterized( - Iteration("identity+identity", "lhsFrac=0/1", "rhsInt=0", "expFrac=0/1"), - Iteration("fraction+identity", "lhsFrac=1/1", "rhsInt=0", "expFrac=1"), - Iteration("fraction+int", "lhsFrac=1/3", "rhsInt=2", "expFrac=2 1/3"), - Iteration("wholeNumberFraction+int", "lhsFrac=3/1", "rhsInt=2", "expFrac=5"), - Iteration("commutativity", "lhsFrac=2/1", "rhsInt=3", "expFrac=5"), - Iteration("fraction+-int", "lhsFrac=1/3", "rhsInt=-2", "expFrac=-1 2/3"), - Iteration("-fraction+int", "lhsFrac=-1/3", "rhsInt=2", "expFrac=1 2/3"), - Iteration("-fraction+-int", "lhsFrac=-1/3", "rhsInt=-2", "expFrac=-2 1/3") - ) + @Iteration("identity+identity", "lhsFrac=0/1", "rhsInt=0", "expFrac=0/1") + @Iteration("fraction+identity", "lhsFrac=1/1", "rhsInt=0", "expFrac=1") + @Iteration("fraction+int", "lhsFrac=1/3", "rhsInt=2", "expFrac=2 1/3") + @Iteration("wholeNumberFraction+int", "lhsFrac=3/1", "rhsInt=2", "expFrac=5") + @Iteration("commutativity", "lhsFrac=2/1", "rhsInt=3", "expFrac=5") + @Iteration("fraction+-int", "lhsFrac=1/3", "rhsInt=-2", "expFrac=-1 2/3") + @Iteration("-fraction+int", "lhsFrac=-1/3", "rhsInt=2", "expFrac=1 2/3") + @Iteration("-fraction+-int", "lhsFrac=-1/3", "rhsInt=-2", "expFrac=-2 1/3") fun testPlus_fractionAndInt_returnsFraction() { val lhsReal = createRationalReal(lhsFrac) val rhsReal = createIntegerReal(rhsInt) @@ -1114,15 +1081,13 @@ class RealExtensionsTest { } @Test - @RunParameterized( - Iteration("identity+identity", "lhsFrac=0/1", "rhsFrac=0/1", "expFrac=0/1"), - Iteration("fraction+identity", "lhsFrac=3/2", "rhsFrac=0/1", "expFrac=1 1/2"), - Iteration("fraction+fraction", "lhsFrac=3/2", "rhsFrac=1/3", "expFrac=1 5/6"), - Iteration("commutativity", "lhsFrac=1/3", "rhsFrac=3/2", "expFrac=1 5/6"), - Iteration("fraction+-fraction", "lhsFrac=1/2", "rhsFrac=-1/3", "expFrac=1/6"), - Iteration("-fraction+fraction", "lhsFrac=-1/2", "rhsFrac=1/3", "expFrac=-1/6"), - Iteration("-fraction+-fraction", "lhsFrac=-1/2", "rhsFrac=-1/3", "expFrac=-5/6") - ) + @Iteration("identity+identity", "lhsFrac=0/1", "rhsFrac=0/1", "expFrac=0/1") + @Iteration("fraction+identity", "lhsFrac=3/2", "rhsFrac=0/1", "expFrac=1 1/2") + @Iteration("fraction+fraction", "lhsFrac=3/2", "rhsFrac=1/3", "expFrac=1 5/6") + @Iteration("commutativity", "lhsFrac=1/3", "rhsFrac=3/2", "expFrac=1 5/6") + @Iteration("fraction+-fraction", "lhsFrac=1/2", "rhsFrac=-1/3", "expFrac=1/6") + @Iteration("-fraction+fraction", "lhsFrac=-1/2", "rhsFrac=1/3", "expFrac=-1/6") + @Iteration("-fraction+-fraction", "lhsFrac=-1/2", "rhsFrac=-1/3", "expFrac=-5/6") fun testPlus_fractionAndFraction_returnsFraction() { val lhsReal = createRationalReal(lhsFrac) val rhsReal = createRationalReal(rhsFrac) @@ -1134,16 +1099,14 @@ class RealExtensionsTest { } @Test - @RunParameterized( - Iteration("identity+identity", "lhsFrac=0/1", "rhsDouble=0.0", "expDouble=0.0"), - Iteration("fraction+identity", "lhsFrac=3/2", "rhsDouble=0.0", "expDouble=1.5"), - Iteration("fraction+double", "lhsFrac=3/2", "rhsDouble=3.14", "expDouble=4.64"), - Iteration("wholeNumberFraction+double", "lhsFrac=3/1", "rhsDouble=2.0", "expDouble=5.0"), - Iteration("commutativity", "lhsFrac=2/1", "rhsDouble=3.0", "expDouble=5.0"), - Iteration("fraction+-double", "lhsFrac=3/2", "rhsDouble=-3.14", "expDouble=-1.64"), - Iteration("-fraction+double", "lhsFrac=-3/2", "rhsDouble=3.14", "expDouble=1.64"), - Iteration("-fraction+-double", "lhsFrac=-3/2", "rhsDouble=-3.14", "expDouble=-4.64") - ) + @Iteration("identity+identity", "lhsFrac=0/1", "rhsDouble=0.0", "expDouble=0.0") + @Iteration("fraction+identity", "lhsFrac=3/2", "rhsDouble=0.0", "expDouble=1.5") + @Iteration("fraction+double", "lhsFrac=3/2", "rhsDouble=3.14", "expDouble=4.64") + @Iteration("wholeNumberFraction+double", "lhsFrac=3/1", "rhsDouble=2.0", "expDouble=5.0") + @Iteration("commutativity", "lhsFrac=2/1", "rhsDouble=3.0", "expDouble=5.0") + @Iteration("fraction+-double", "lhsFrac=3/2", "rhsDouble=-3.14", "expDouble=-1.64") + @Iteration("-fraction+double", "lhsFrac=-3/2", "rhsDouble=3.14", "expDouble=1.64") + @Iteration("-fraction+-double", "lhsFrac=-3/2", "rhsDouble=-3.14", "expDouble=-4.64") fun testPlus_fractionAndDouble_returnsDouble() { val lhsReal = createRationalReal(lhsFrac) val rhsReal = createIrrationalReal(rhsDouble) @@ -1154,16 +1117,14 @@ class RealExtensionsTest { } @Test - @RunParameterized( - Iteration("identity+identity", "lhsDouble=0.0", "rhsInt=0", "expDouble=0.0"), - Iteration("double+identity", "lhsDouble=1.0", "rhsInt=0", "expDouble=1.0"), - Iteration("double+int", "lhsDouble=3.14", "rhsInt=1", "expDouble=4.14"), - Iteration("wholeNumberDouble+int", "lhsDouble=3.0", "rhsInt=1", "expDouble=4.0"), - Iteration("commutativity", "lhsDouble=1.0", "rhsInt=3", "expDouble=4.0"), - Iteration("double+-int", "lhsDouble=3.14", "rhsInt=-1", "expDouble=2.14"), - Iteration("-double+int", "lhsDouble=-3.14", "rhsInt=1", "expDouble=-2.14"), - Iteration("-double+-int", "lhsDouble=-3.14", "rhsInt=-1", "expDouble=-4.14") - ) + @Iteration("identity+identity", "lhsDouble=0.0", "rhsInt=0", "expDouble=0.0") + @Iteration("double+identity", "lhsDouble=1.0", "rhsInt=0", "expDouble=1.0") + @Iteration("double+int", "lhsDouble=3.14", "rhsInt=1", "expDouble=4.14") + @Iteration("wholeNumberDouble+int", "lhsDouble=3.0", "rhsInt=1", "expDouble=4.0") + @Iteration("commutativity", "lhsDouble=1.0", "rhsInt=3", "expDouble=4.0") + @Iteration("double+-int", "lhsDouble=3.14", "rhsInt=-1", "expDouble=2.14") + @Iteration("-double+int", "lhsDouble=-3.14", "rhsInt=1", "expDouble=-2.14") + @Iteration("-double+-int", "lhsDouble=-3.14", "rhsInt=-1", "expDouble=-4.14") fun testPlus_doubleAndInt_returnsDouble() { val lhsReal = createIrrationalReal(lhsDouble) val rhsReal = createIntegerReal(rhsInt) @@ -1174,16 +1135,14 @@ class RealExtensionsTest { } @Test - @RunParameterized( - Iteration("identity+identity", "lhsDouble=0.0", "rhsFrac=0/1", "expDouble=0.0"), - Iteration("double+identity", "lhsDouble=3.14", "rhsFrac=0/1", "expDouble=3.14"), - Iteration("double+fraction", "lhsDouble=3.14", "rhsFrac=3/2", "expDouble=4.64"), - Iteration("double+wholeNumberFraction", "lhsDouble=2.0", "rhsFrac=3/1", "expDouble=5.0"), - Iteration("commutativity", "lhsDouble=3.0", "rhsFrac=2/1", "expDouble=5.0"), - Iteration("double+-fraction", "lhsDouble=3.14", "rhsFrac=-3/2", "expDouble=1.64"), - Iteration("-double+fraction", "lhsDouble=-3.14", "rhsFrac=3/2", "expDouble=-1.64"), - Iteration("-double+-fraction", "lhsDouble=-3.14", "rhsFrac=-3/2", "expDouble=-4.64") - ) + @Iteration("identity+identity", "lhsDouble=0.0", "rhsFrac=0/1", "expDouble=0.0") + @Iteration("double+identity", "lhsDouble=3.14", "rhsFrac=0/1", "expDouble=3.14") + @Iteration("double+fraction", "lhsDouble=3.14", "rhsFrac=3/2", "expDouble=4.64") + @Iteration("double+wholeNumberFraction", "lhsDouble=2.0", "rhsFrac=3/1", "expDouble=5.0") + @Iteration("commutativity", "lhsDouble=3.0", "rhsFrac=2/1", "expDouble=5.0") + @Iteration("double+-fraction", "lhsDouble=3.14", "rhsFrac=-3/2", "expDouble=1.64") + @Iteration("-double+fraction", "lhsDouble=-3.14", "rhsFrac=3/2", "expDouble=-1.64") + @Iteration("-double+-fraction", "lhsDouble=-3.14", "rhsFrac=-3/2", "expDouble=-4.64") fun testPlus_doubleAndFraction_returnsDouble() { val lhsReal = createIrrationalReal(lhsDouble) val rhsReal = createRationalReal(rhsFrac) @@ -1194,15 +1153,13 @@ class RealExtensionsTest { } @Test - @RunParameterized( - Iteration("identity+identity", "lhsDouble=0.0", "rhsDouble=0.0", "expDouble=0.0"), - Iteration("double+identity", "lhsDouble=1.0", "rhsDouble=0.0", "expDouble=1.0"), - Iteration("double+double", "lhsDouble=3.14", "rhsDouble=2.7", "expDouble=5.84"), - Iteration("commutativity", "lhsDouble=2.7", "rhsDouble=3.14", "expDouble=5.84"), - Iteration("double+-double", "lhsDouble=3.14", "rhsDouble=-2.7", "expDouble=0.44"), - Iteration("-double+double", "lhsDouble=-3.14", "rhsDouble=2.7", "expDouble=-0.44"), - Iteration("-double+-double", "lhsDouble=-3.14", "rhsDouble=-2.7", "expDouble=-5.84") - ) + @Iteration("identity+identity", "lhsDouble=0.0", "rhsDouble=0.0", "expDouble=0.0") + @Iteration("double+identity", "lhsDouble=1.0", "rhsDouble=0.0", "expDouble=1.0") + @Iteration("double+double", "lhsDouble=3.14", "rhsDouble=2.7", "expDouble=5.84") + @Iteration("commutativity", "lhsDouble=2.7", "rhsDouble=3.14", "expDouble=5.84") + @Iteration("double+-double", "lhsDouble=3.14", "rhsDouble=-2.7", "expDouble=0.44") + @Iteration("-double+double", "lhsDouble=-3.14", "rhsDouble=2.7", "expDouble=-0.44") + @Iteration("-double+-double", "lhsDouble=-3.14", "rhsDouble=-2.7", "expDouble=-5.84") fun testPlus_doubleAndDouble_returnsDouble() { val lhsReal = createIrrationalReal(lhsDouble) val rhsReal = createIrrationalReal(rhsDouble) @@ -1215,15 +1172,13 @@ class RealExtensionsTest { // Subtraction tests. @Test - @RunParameterized( - Iteration("identity-identity", "lhsInt=0", "rhsInt=0", "expInt=0"), - Iteration("int-identity", "lhsInt=1", "rhsInt=0", "expInt=1"), - Iteration("int-int", "lhsInt=1", "rhsInt=2", "expInt=-1"), - Iteration("anticommutativity", "lhsInt=2", "rhsInt=1", "expInt=1"), - Iteration("int--int", "lhsInt=1", "rhsInt=-2", "expInt=3"), - Iteration("-int-int", "lhsInt=-1", "rhsInt=2", "expInt=-3"), - Iteration("-int--int", "lhsInt=-1", "rhsInt=-2", "expInt=1") - ) + @Iteration("identity-identity", "lhsInt=0", "rhsInt=0", "expInt=0") + @Iteration("int-identity", "lhsInt=1", "rhsInt=0", "expInt=1") + @Iteration("int-int", "lhsInt=1", "rhsInt=2", "expInt=-1") + @Iteration("anticommutativity", "lhsInt=2", "rhsInt=1", "expInt=1") + @Iteration("int--int", "lhsInt=1", "rhsInt=-2", "expInt=3") + @Iteration("-int-int", "lhsInt=-1", "rhsInt=2", "expInt=-3") + @Iteration("-int--int", "lhsInt=-1", "rhsInt=-2", "expInt=1") fun testMinus_intAndInt_returnsInt() { val lhsReal = createIntegerReal(lhsInt) val rhsReal = createIntegerReal(rhsInt) @@ -1234,16 +1189,14 @@ class RealExtensionsTest { } @Test - @RunParameterized( - Iteration("identity-identity", "lhsInt=0", "rhsFrac=0/1", "expFrac=0/1"), - Iteration("int-identity", "lhsInt=1", "rhsFrac=0/1", "expFrac=1"), - Iteration("int-fraction", "lhsInt=2", "rhsFrac=1/3", "expFrac=1 2/3"), - Iteration("int-wholeNumberFraction", "lhsInt=2", "rhsFrac=3/1", "expFrac=-1"), - Iteration("anticommutativity", "lhsInt=3", "rhsFrac=2/1", "expFrac=1"), - Iteration("int--fraction", "lhsInt=2", "rhsFrac=-1/3", "expFrac=2 1/3"), - Iteration("-int-fraction", "lhsInt=-2", "rhsFrac=1/3", "expFrac=-2 1/3"), - Iteration("-int--fraction", "lhsInt=-2", "rhsFrac=-1/3", "expFrac=-1 2/3") - ) + @Iteration("identity-identity", "lhsInt=0", "rhsFrac=0/1", "expFrac=0/1") + @Iteration("int-identity", "lhsInt=1", "rhsFrac=0/1", "expFrac=1") + @Iteration("int-fraction", "lhsInt=2", "rhsFrac=1/3", "expFrac=1 2/3") + @Iteration("int-wholeNumberFraction", "lhsInt=2", "rhsFrac=3/1", "expFrac=-1") + @Iteration("anticommutativity", "lhsInt=3", "rhsFrac=2/1", "expFrac=1") + @Iteration("int--fraction", "lhsInt=2", "rhsFrac=-1/3", "expFrac=2 1/3") + @Iteration("-int-fraction", "lhsInt=-2", "rhsFrac=1/3", "expFrac=-2 1/3") + @Iteration("-int--fraction", "lhsInt=-2", "rhsFrac=-1/3", "expFrac=-1 2/3") fun testMinus_intAndFraction_returnsFraction() { val lhsReal = createIntegerReal(lhsInt) val rhsReal = createRationalReal(rhsFrac) @@ -1255,16 +1208,14 @@ class RealExtensionsTest { } @Test - @RunParameterized( - Iteration("identity-identity", "lhsInt=0", "rhsDouble=0.0", "expDouble=0.0"), - Iteration("int-identity", "lhsInt=1", "rhsDouble=0.0", "expDouble=1.0"), - Iteration("int-double", "lhsInt=1", "rhsDouble=3.14", "expDouble=-2.14"), - Iteration("int-wholeNumberDouble", "lhsInt=1", "rhsDouble=3.0", "expDouble=-2.0"), - Iteration("anticommutativity", "lhsInt=3", "rhsDouble=1.0", "expDouble=2.0"), - Iteration("int--double", "lhsInt=1", "rhsDouble=-3.14", "expDouble=4.14"), - Iteration("-int-double", "lhsInt=-1", "rhsDouble=3.14", "expDouble=-4.14"), - Iteration("-int--double", "lhsInt=-1", "rhsDouble=-3.14", "expDouble=2.14") - ) + @Iteration("identity-identity", "lhsInt=0", "rhsDouble=0.0", "expDouble=0.0") + @Iteration("int-identity", "lhsInt=1", "rhsDouble=0.0", "expDouble=1.0") + @Iteration("int-double", "lhsInt=1", "rhsDouble=3.14", "expDouble=-2.14") + @Iteration("int-wholeNumberDouble", "lhsInt=1", "rhsDouble=3.0", "expDouble=-2.0") + @Iteration("anticommutativity", "lhsInt=3", "rhsDouble=1.0", "expDouble=2.0") + @Iteration("int--double", "lhsInt=1", "rhsDouble=-3.14", "expDouble=4.14") + @Iteration("-int-double", "lhsInt=-1", "rhsDouble=3.14", "expDouble=-4.14") + @Iteration("-int--double", "lhsInt=-1", "rhsDouble=-3.14", "expDouble=2.14") fun testMinus_intAndDouble_returnsDouble() { val lhsReal = createIntegerReal(lhsInt) val rhsReal = createIrrationalReal(rhsDouble) @@ -1275,16 +1226,14 @@ class RealExtensionsTest { } @Test - @RunParameterized( - Iteration("identity-identity", "lhsFrac=0/1", "rhsInt=0", "expFrac=0/1"), - Iteration("fraction-identity", "lhsFrac=1/1", "rhsInt=0", "expFrac=1"), - Iteration("fraction-int", "lhsFrac=1/3", "rhsInt=2", "expFrac=-1 2/3"), - Iteration("wholeNumberFraction-int", "lhsFrac=3/1", "rhsInt=2", "expFrac=1"), - Iteration("anticommutativity", "lhsFrac=2/1", "rhsInt=3", "expFrac=-1"), - Iteration("fraction--int", "lhsFrac=1/3", "rhsInt=-2", "expFrac=2 1/3"), - Iteration("-fraction-int", "lhsFrac=-1/3", "rhsInt=2", "expFrac=-2 1/3"), - Iteration("-fraction--int", "lhsFrac=-1/3", "rhsInt=-2", "expFrac=1 2/3") - ) + @Iteration("identity-identity", "lhsFrac=0/1", "rhsInt=0", "expFrac=0/1") + @Iteration("fraction-identity", "lhsFrac=1/1", "rhsInt=0", "expFrac=1") + @Iteration("fraction-int", "lhsFrac=1/3", "rhsInt=2", "expFrac=-1 2/3") + @Iteration("wholeNumberFraction-int", "lhsFrac=3/1", "rhsInt=2", "expFrac=1") + @Iteration("anticommutativity", "lhsFrac=2/1", "rhsInt=3", "expFrac=-1") + @Iteration("fraction--int", "lhsFrac=1/3", "rhsInt=-2", "expFrac=2 1/3") + @Iteration("-fraction-int", "lhsFrac=-1/3", "rhsInt=2", "expFrac=-2 1/3") + @Iteration("-fraction--int", "lhsFrac=-1/3", "rhsInt=-2", "expFrac=1 2/3") fun testMinus_fractionAndInt_returnsFraction() { val lhsReal = createRationalReal(lhsFrac) val rhsReal = createIntegerReal(rhsInt) @@ -1296,15 +1245,13 @@ class RealExtensionsTest { } @Test - @RunParameterized( - Iteration("identity-identity", "lhsFrac=0/1", "rhsFrac=0/1", "expFrac=0/1"), - Iteration("fraction-identity", "lhsFrac=3/2", "rhsFrac=0/1", "expFrac=1 1/2"), - Iteration("fraction-fraction", "lhsFrac=3/2", "rhsFrac=1/3", "expFrac=1 1/6"), - Iteration("anticommutativity", "lhsFrac=1/3", "rhsFrac=3/2", "expFrac=-1 1/6"), - Iteration("fraction--fraction", "lhsFrac=1/2", "rhsFrac=-1/3", "expFrac=5/6"), - Iteration("-fraction-fraction", "lhsFrac=-1/2", "rhsFrac=1/3", "expFrac=-5/6"), - Iteration("-fraction--fraction", "lhsFrac=-1/2", "rhsFrac=-1/3", "expFrac=-1/6") - ) + @Iteration("identity-identity", "lhsFrac=0/1", "rhsFrac=0/1", "expFrac=0/1") + @Iteration("fraction-identity", "lhsFrac=3/2", "rhsFrac=0/1", "expFrac=1 1/2") + @Iteration("fraction-fraction", "lhsFrac=3/2", "rhsFrac=1/3", "expFrac=1 1/6") + @Iteration("anticommutativity", "lhsFrac=1/3", "rhsFrac=3/2", "expFrac=-1 1/6") + @Iteration("fraction--fraction", "lhsFrac=1/2", "rhsFrac=-1/3", "expFrac=5/6") + @Iteration("-fraction-fraction", "lhsFrac=-1/2", "rhsFrac=1/3", "expFrac=-5/6") + @Iteration("-fraction--fraction", "lhsFrac=-1/2", "rhsFrac=-1/3", "expFrac=-1/6") fun testMinus_fractionAndFraction_returnsFraction() { val lhsReal = createRationalReal(lhsFrac) val rhsReal = createRationalReal(rhsFrac) @@ -1316,16 +1263,14 @@ class RealExtensionsTest { } @Test - @RunParameterized( - Iteration("identity-identity", "lhsFrac=0/1", "rhsDouble=0.0", "expDouble=0.0"), - Iteration("fraction-identity", "lhsFrac=3/2", "rhsDouble=0.0", "expDouble=1.5"), - Iteration("fraction-double", "lhsFrac=3/2", "rhsDouble=3.14", "expDouble=-1.64"), - Iteration("wholeNumberFraction-double", "lhsFrac=3/1", "rhsDouble=2.0", "expDouble=1.0"), - Iteration("anticommutativity", "lhsFrac=2/1", "rhsDouble=3.0", "expDouble=-1.0"), - Iteration("fraction--double", "lhsFrac=3/2", "rhsDouble=-3.14", "expDouble=4.64"), - Iteration("-fraction-double", "lhsFrac=-3/2", "rhsDouble=3.14", "expDouble=-4.64"), - Iteration("-fraction--double", "lhsFrac=-3/2", "rhsDouble=-3.14", "expDouble=1.64") - ) + @Iteration("identity-identity", "lhsFrac=0/1", "rhsDouble=0.0", "expDouble=0.0") + @Iteration("fraction-identity", "lhsFrac=3/2", "rhsDouble=0.0", "expDouble=1.5") + @Iteration("fraction-double", "lhsFrac=3/2", "rhsDouble=3.14", "expDouble=-1.64") + @Iteration("wholeNumberFraction-double", "lhsFrac=3/1", "rhsDouble=2.0", "expDouble=1.0") + @Iteration("anticommutativity", "lhsFrac=2/1", "rhsDouble=3.0", "expDouble=-1.0") + @Iteration("fraction--double", "lhsFrac=3/2", "rhsDouble=-3.14", "expDouble=4.64") + @Iteration("-fraction-double", "lhsFrac=-3/2", "rhsDouble=3.14", "expDouble=-4.64") + @Iteration("-fraction--double", "lhsFrac=-3/2", "rhsDouble=-3.14", "expDouble=1.64") fun testMinus_fractionAndDouble_returnsDouble() { val lhsReal = createRationalReal(lhsFrac) val rhsReal = createIrrationalReal(rhsDouble) @@ -1336,16 +1281,14 @@ class RealExtensionsTest { } @Test - @RunParameterized( - Iteration("identity-identity", "lhsDouble=0.0", "rhsInt=0", "expDouble=0.0"), - Iteration("double-identity", "lhsDouble=1.0", "rhsInt=0", "expDouble=1.0"), - Iteration("double-int", "lhsDouble=3.14", "rhsInt=1", "expDouble=2.14"), - Iteration("wholeNumberDouble-int", "lhsDouble=3.0", "rhsInt=1", "expDouble=2.0"), - Iteration("anticommutativity", "lhsDouble=1.0", "rhsInt=3", "expDouble=-2.0"), - Iteration("double--int", "lhsDouble=3.14", "rhsInt=-1", "expDouble=4.14"), - Iteration("-double-int", "lhsDouble=-3.14", "rhsInt=1", "expDouble=-4.14"), - Iteration("-double--int", "lhsDouble=-3.14", "rhsInt=-1", "expDouble=-2.14") - ) + @Iteration("identity-identity", "lhsDouble=0.0", "rhsInt=0", "expDouble=0.0") + @Iteration("double-identity", "lhsDouble=1.0", "rhsInt=0", "expDouble=1.0") + @Iteration("double-int", "lhsDouble=3.14", "rhsInt=1", "expDouble=2.14") + @Iteration("wholeNumberDouble-int", "lhsDouble=3.0", "rhsInt=1", "expDouble=2.0") + @Iteration("anticommutativity", "lhsDouble=1.0", "rhsInt=3", "expDouble=-2.0") + @Iteration("double--int", "lhsDouble=3.14", "rhsInt=-1", "expDouble=4.14") + @Iteration("-double-int", "lhsDouble=-3.14", "rhsInt=1", "expDouble=-4.14") + @Iteration("-double--int", "lhsDouble=-3.14", "rhsInt=-1", "expDouble=-2.14") fun testMinus_doubleAndInt_returnsDouble() { val lhsReal = createIrrationalReal(lhsDouble) val rhsReal = createIntegerReal(rhsInt) @@ -1356,16 +1299,14 @@ class RealExtensionsTest { } @Test - @RunParameterized( - Iteration("identity-identity", "lhsDouble=0.0", "rhsFrac=0/1", "expDouble=0.0"), - Iteration("double-identity", "lhsDouble=3.14", "rhsFrac=0/1", "expDouble=3.14"), - Iteration("double-fraction", "lhsDouble=3.14", "rhsFrac=3/2", "expDouble=1.64"), - Iteration("double-wholeNumberFraction", "lhsDouble=2.0", "rhsFrac=3/1", "expDouble=-1.0"), - Iteration("anticommutativity", "lhsDouble=3.0", "rhsFrac=2/1", "expDouble=1.0"), - Iteration("double--fraction", "lhsDouble=3.14", "rhsFrac=-3/2", "expDouble=4.64"), - Iteration("-double-fraction", "lhsDouble=-3.14", "rhsFrac=3/2", "expDouble=-4.64"), - Iteration("-double--fraction", "lhsDouble=-3.14", "rhsFrac=-3/2", "expDouble=-1.64") - ) + @Iteration("identity-identity", "lhsDouble=0.0", "rhsFrac=0/1", "expDouble=0.0") + @Iteration("double-identity", "lhsDouble=3.14", "rhsFrac=0/1", "expDouble=3.14") + @Iteration("double-fraction", "lhsDouble=3.14", "rhsFrac=3/2", "expDouble=1.64") + @Iteration("double-wholeNumberFraction", "lhsDouble=2.0", "rhsFrac=3/1", "expDouble=-1.0") + @Iteration("anticommutativity", "lhsDouble=3.0", "rhsFrac=2/1", "expDouble=1.0") + @Iteration("double--fraction", "lhsDouble=3.14", "rhsFrac=-3/2", "expDouble=4.64") + @Iteration("-double-fraction", "lhsDouble=-3.14", "rhsFrac=3/2", "expDouble=-4.64") + @Iteration("-double--fraction", "lhsDouble=-3.14", "rhsFrac=-3/2", "expDouble=-1.64") fun testMinus_doubleAndFraction_returnsDouble() { val lhsReal = createIrrationalReal(lhsDouble) val rhsReal = createRationalReal(rhsFrac) @@ -1376,15 +1317,13 @@ class RealExtensionsTest { } @Test - @RunParameterized( - Iteration("identity-identity", "lhsDouble=0.0", "rhsDouble=0.0", "expDouble=0.0"), - Iteration("double-identity", "lhsDouble=1.0", "rhsDouble=0.0", "expDouble=1.0"), - Iteration("double-double", "lhsDouble=3.14", "rhsDouble=2.7", "expDouble=0.44"), - Iteration("anticommutativity", "lhsDouble=2.7", "rhsDouble=3.14", "expDouble=-0.44"), - Iteration("double--double", "lhsDouble=3.14", "rhsDouble=-2.7", "expDouble=5.84"), - Iteration("-double-double", "lhsDouble=-3.14", "rhsDouble=2.7", "expDouble=-5.84"), - Iteration("-double--double", "lhsDouble=-3.14", "rhsDouble=-2.7", "expDouble=-0.44") - ) + @Iteration("identity-identity", "lhsDouble=0.0", "rhsDouble=0.0", "expDouble=0.0") + @Iteration("double-identity", "lhsDouble=1.0", "rhsDouble=0.0", "expDouble=1.0") + @Iteration("double-double", "lhsDouble=3.14", "rhsDouble=2.7", "expDouble=0.44") + @Iteration("anticommutativity", "lhsDouble=2.7", "rhsDouble=3.14", "expDouble=-0.44") + @Iteration("double--double", "lhsDouble=3.14", "rhsDouble=-2.7", "expDouble=5.84") + @Iteration("-double-double", "lhsDouble=-3.14", "rhsDouble=2.7", "expDouble=-5.84") + @Iteration("-double--double", "lhsDouble=-3.14", "rhsDouble=-2.7", "expDouble=-0.44") fun testMinus_doubleAndDouble_returnsDouble() { val lhsReal = createIrrationalReal(lhsDouble) val rhsReal = createIrrationalReal(rhsDouble) @@ -1397,15 +1336,13 @@ class RealExtensionsTest { // Multiplication tests. @Test - @RunParameterized( - Iteration("identity*identity", "lhsInt=1", "rhsInt=1", "expInt=1"), - Iteration("int*identity", "lhsInt=2", "rhsInt=1", "expInt=2"), - Iteration("int*int", "lhsInt=3", "rhsInt=2", "expInt=6"), - Iteration("commutativity", "lhsInt=2", "rhsInt=3", "expInt=6"), - Iteration("int*-int", "lhsInt=3", "rhsInt=-2", "expInt=-6"), - Iteration("-int*int", "lhsInt=-3", "rhsInt=2", "expInt=-6"), - Iteration("-int*-int", "lhsInt=-3", "rhsInt=-2", "expInt=6") - ) + @Iteration("identity*identity", "lhsInt=1", "rhsInt=1", "expInt=1") + @Iteration("int*identity", "lhsInt=2", "rhsInt=1", "expInt=2") + @Iteration("int*int", "lhsInt=3", "rhsInt=2", "expInt=6") + @Iteration("commutativity", "lhsInt=2", "rhsInt=3", "expInt=6") + @Iteration("int*-int", "lhsInt=3", "rhsInt=-2", "expInt=-6") + @Iteration("-int*int", "lhsInt=-3", "rhsInt=2", "expInt=-6") + @Iteration("-int*-int", "lhsInt=-3", "rhsInt=-2", "expInt=6") fun testTimes_intAndInt_returnsInt() { val lhsReal = createIntegerReal(lhsInt) val rhsReal = createIntegerReal(rhsInt) @@ -1416,16 +1353,14 @@ class RealExtensionsTest { } @Test - @RunParameterized( - Iteration("identity*identity", "lhsInt=1", "rhsFrac=1", "expFrac=1"), - Iteration("int*identity", "lhsInt=2", "rhsFrac=1", "expFrac=2"), - Iteration("int*fraction", "lhsInt=2", "rhsFrac=1/3", "expFrac=2/3"), - Iteration("int*wholeNumberFraction", "lhsInt=2", "rhsFrac=3/1", "expFrac=6"), - Iteration("commutativity", "lhsInt=3", "rhsFrac=2/1", "expFrac=6"), - Iteration("int*-fraction", "lhsInt=2", "rhsFrac=-1/3", "expFrac=-2/3"), - Iteration("-int*fraction", "lhsInt=-2", "rhsFrac=1/3", "expFrac=-2/3"), - Iteration("-int*-fraction", "lhsInt=-2", "rhsFrac=-1/3", "expFrac=2/3") - ) + @Iteration("identity*identity", "lhsInt=1", "rhsFrac=1", "expFrac=1") + @Iteration("int*identity", "lhsInt=2", "rhsFrac=1", "expFrac=2") + @Iteration("int*fraction", "lhsInt=2", "rhsFrac=1/3", "expFrac=2/3") + @Iteration("int*wholeNumberFraction", "lhsInt=2", "rhsFrac=3/1", "expFrac=6") + @Iteration("commutativity", "lhsInt=3", "rhsFrac=2/1", "expFrac=6") + @Iteration("int*-fraction", "lhsInt=2", "rhsFrac=-1/3", "expFrac=-2/3") + @Iteration("-int*fraction", "lhsInt=-2", "rhsFrac=1/3", "expFrac=-2/3") + @Iteration("-int*-fraction", "lhsInt=-2", "rhsFrac=-1/3", "expFrac=2/3") fun testTimes_intAndFraction_returnsFraction() { val lhsReal = createIntegerReal(lhsInt) val rhsReal = createRationalReal(rhsFrac) @@ -1437,16 +1372,14 @@ class RealExtensionsTest { } @Test - @RunParameterized( - Iteration("identity*identity", "lhsInt=1", "rhsDouble=1.0", "expDouble=1.0"), - Iteration("int*identity", "lhsInt=2", "rhsDouble=1.0", "expDouble=2.0"), - Iteration("int*double", "lhsInt=2", "rhsDouble=3.14", "expDouble=6.28"), - Iteration("int*wholeNumberDouble", "lhsInt=2", "rhsDouble=3.0", "expDouble=6.0"), - Iteration("commutativity", "lhsInt=3", "rhsDouble=2.0", "expDouble=6.0"), - Iteration("int*-double", "lhsInt=2", "rhsDouble=-3.14", "expDouble=-6.28"), - Iteration("-int*double", "lhsInt=-2", "rhsDouble=3.14", "expDouble=-6.28"), - Iteration("-int*-double", "lhsInt=-2", "rhsDouble=-3.14", "expDouble=6.28") - ) + @Iteration("identity*identity", "lhsInt=1", "rhsDouble=1.0", "expDouble=1.0") + @Iteration("int*identity", "lhsInt=2", "rhsDouble=1.0", "expDouble=2.0") + @Iteration("int*double", "lhsInt=2", "rhsDouble=3.14", "expDouble=6.28") + @Iteration("int*wholeNumberDouble", "lhsInt=2", "rhsDouble=3.0", "expDouble=6.0") + @Iteration("commutativity", "lhsInt=3", "rhsDouble=2.0", "expDouble=6.0") + @Iteration("int*-double", "lhsInt=2", "rhsDouble=-3.14", "expDouble=-6.28") + @Iteration("-int*double", "lhsInt=-2", "rhsDouble=3.14", "expDouble=-6.28") + @Iteration("-int*-double", "lhsInt=-2", "rhsDouble=-3.14", "expDouble=6.28") fun testTimes_intAndDouble_returnsDouble() { val lhsReal = createIntegerReal(lhsInt) val rhsReal = createIrrationalReal(rhsDouble) @@ -1457,16 +1390,14 @@ class RealExtensionsTest { } @Test - @RunParameterized( - Iteration("identity*identity", "lhsFrac=1/1", "rhsInt=1", "expFrac=1"), - Iteration("fraction*identity", "lhsFrac=2/1", "rhsInt=1", "expFrac=2"), - Iteration("fraction*int", "lhsFrac=1/3", "rhsInt=2", "expFrac=2/3"), - Iteration("wholeNumberFraction*int", "lhsFrac=3/1", "rhsInt=2", "expFrac=6"), - Iteration("commutativity", "lhsFrac=2/1", "rhsInt=3", "expFrac=6"), - Iteration("fraction*-int", "lhsFrac=1/3", "rhsInt=-2", "expFrac=-2/3"), - Iteration("-fraction*int", "lhsFrac=-1/3", "rhsInt=2", "expFrac=-2/3"), - Iteration("-fraction*-int", "lhsFrac=-1/3", "rhsInt=-2", "expFrac=2/3") - ) + @Iteration("identity*identity", "lhsFrac=1/1", "rhsInt=1", "expFrac=1") + @Iteration("fraction*identity", "lhsFrac=2/1", "rhsInt=1", "expFrac=2") + @Iteration("fraction*int", "lhsFrac=1/3", "rhsInt=2", "expFrac=2/3") + @Iteration("wholeNumberFraction*int", "lhsFrac=3/1", "rhsInt=2", "expFrac=6") + @Iteration("commutativity", "lhsFrac=2/1", "rhsInt=3", "expFrac=6") + @Iteration("fraction*-int", "lhsFrac=1/3", "rhsInt=-2", "expFrac=-2/3") + @Iteration("-fraction*int", "lhsFrac=-1/3", "rhsInt=2", "expFrac=-2/3") + @Iteration("-fraction*-int", "lhsFrac=-1/3", "rhsInt=-2", "expFrac=2/3") fun testTimes_fractionAndInt_returnsFraction() { val lhsReal = createRationalReal(lhsFrac) val rhsReal = createIntegerReal(rhsInt) @@ -1478,15 +1409,13 @@ class RealExtensionsTest { } @Test - @RunParameterized( - Iteration("identity*identity", "lhsFrac=1/1", "rhsFrac=1/1", "expFrac=1"), - Iteration("fraction*identity", "lhsFrac=3/2", "rhsFrac=1/1", "expFrac=1 1/2"), - Iteration("fraction*fraction", "lhsFrac=3/2", "rhsFrac=4/7", "expFrac=6/7"), - Iteration("commutativity", "lhsFrac=4/7", "rhsFrac=3/2", "expFrac=6/7"), - Iteration("fraction*-fraction", "lhsFrac=1 3/9", "rhsFrac=-8/11", "expFrac=-32/33"), - Iteration("-fraction*fraction", "lhsFrac=-1 3/9", "rhsFrac=8/11", "expFrac=-32/33"), - Iteration("-fraction*-fraction", "lhsFrac=-1 3/9", "rhsFrac=-8/11", "expFrac=32/33") - ) + @Iteration("identity*identity", "lhsFrac=1/1", "rhsFrac=1/1", "expFrac=1") + @Iteration("fraction*identity", "lhsFrac=3/2", "rhsFrac=1/1", "expFrac=1 1/2") + @Iteration("fraction*fraction", "lhsFrac=3/2", "rhsFrac=4/7", "expFrac=6/7") + @Iteration("commutativity", "lhsFrac=4/7", "rhsFrac=3/2", "expFrac=6/7") + @Iteration("fraction*-fraction", "lhsFrac=1 3/9", "rhsFrac=-8/11", "expFrac=-32/33") + @Iteration("-fraction*fraction", "lhsFrac=-1 3/9", "rhsFrac=8/11", "expFrac=-32/33") + @Iteration("-fraction*-fraction", "lhsFrac=-1 3/9", "rhsFrac=-8/11", "expFrac=32/33") fun testTimes_fractionAndFraction_returnsFraction() { val lhsReal = createRationalReal(lhsFrac) val rhsReal = createRationalReal(rhsFrac) @@ -1498,16 +1427,14 @@ class RealExtensionsTest { } @Test - @RunParameterized( - Iteration("identity*identity", "lhsFrac=1/1", "rhsDouble=1.0", "expDouble=1.0"), - Iteration("fraction*identity", "lhsFrac=3/2", "rhsDouble=1.0", "expDouble=1.5"), - Iteration("fraction*double", "lhsFrac=3/2", "rhsDouble=3.14", "expDouble=4.71"), - Iteration("wholeNumberFraction*double", "lhsFrac=3/1", "rhsDouble=2.0", "expDouble=6.0"), - Iteration("commutativity", "lhsFrac=2/1", "rhsDouble=3.0", "expDouble=6.0"), - Iteration("fraction*-double", "lhsFrac=1 3/2", "rhsDouble=-3.14", "expDouble=-7.85"), - Iteration("-fraction*double", "lhsFrac=-1 3/2", "rhsDouble=3.14", "expDouble=-7.85"), - Iteration("-fraction*-double", "lhsFrac=-1 3/2", "rhsDouble=-3.14", "expDouble=7.85") - ) + @Iteration("identity*identity", "lhsFrac=1/1", "rhsDouble=1.0", "expDouble=1.0") + @Iteration("fraction*identity", "lhsFrac=3/2", "rhsDouble=1.0", "expDouble=1.5") + @Iteration("fraction*double", "lhsFrac=3/2", "rhsDouble=3.14", "expDouble=4.71") + @Iteration("wholeNumberFraction*double", "lhsFrac=3/1", "rhsDouble=2.0", "expDouble=6.0") + @Iteration("commutativity", "lhsFrac=2/1", "rhsDouble=3.0", "expDouble=6.0") + @Iteration("fraction*-double", "lhsFrac=1 3/2", "rhsDouble=-3.14", "expDouble=-7.85") + @Iteration("-fraction*double", "lhsFrac=-1 3/2", "rhsDouble=3.14", "expDouble=-7.85") + @Iteration("-fraction*-double", "lhsFrac=-1 3/2", "rhsDouble=-3.14", "expDouble=7.85") fun testTimes_fractionAndDouble_returnsDouble() { val lhsReal = createRationalReal(lhsFrac) val rhsReal = createIrrationalReal(rhsDouble) @@ -1518,16 +1445,14 @@ class RealExtensionsTest { } @Test - @RunParameterized( - Iteration("identity*identity", "lhsDouble=1.0", "rhsInt=1", "expDouble=1.0"), - Iteration("double*identity", "lhsDouble=2.0", "rhsInt=1", "expDouble=2.0"), - Iteration("double*int", "lhsDouble=3.14", "rhsInt=2", "expDouble=6.28"), - Iteration("wholeNumberDouble*int", "lhsDouble=3.0", "rhsInt=2", "expDouble=6"), - Iteration("commutativity", "lhsDouble=2.0", "rhsInt=3", "expDouble=6.0"), - Iteration("double*-int", "lhsDouble=3.14", "rhsInt=-2", "expDouble=-6.28"), - Iteration("-double*int", "lhsDouble=-3.14", "rhsInt=2", "expDouble=-6.28"), - Iteration("-double*-int", "lhsDouble=-3.14", "rhsInt=-2", "expDouble=6.28") - ) + @Iteration("identity*identity", "lhsDouble=1.0", "rhsInt=1", "expDouble=1.0") + @Iteration("double*identity", "lhsDouble=2.0", "rhsInt=1", "expDouble=2.0") + @Iteration("double*int", "lhsDouble=3.14", "rhsInt=2", "expDouble=6.28") + @Iteration("wholeNumberDouble*int", "lhsDouble=3.0", "rhsInt=2", "expDouble=6") + @Iteration("commutativity", "lhsDouble=2.0", "rhsInt=3", "expDouble=6.0") + @Iteration("double*-int", "lhsDouble=3.14", "rhsInt=-2", "expDouble=-6.28") + @Iteration("-double*int", "lhsDouble=-3.14", "rhsInt=2", "expDouble=-6.28") + @Iteration("-double*-int", "lhsDouble=-3.14", "rhsInt=-2", "expDouble=6.28") fun testTimes_doubleAndInt_returnsDouble() { val lhsReal = createIrrationalReal(lhsDouble) val rhsReal = createIntegerReal(rhsInt) @@ -1538,16 +1463,14 @@ class RealExtensionsTest { } @Test - @RunParameterized( - Iteration("identity*identity", "lhsDouble=1.0", "rhsFrac=1/1", "expDouble=1.0"), - Iteration("double*identity", "lhsDouble=2.0", "rhsFrac=1/1", "expDouble=2.0"), - Iteration("double*fraction", "lhsDouble=3.14", "rhsFrac=3/2", "expDouble=4.71"), - Iteration("double*wholeNumberFraction", "lhsDouble=2.0", "rhsFrac=3/1", "expDouble=6.0"), - Iteration("commutativity", "lhsDouble=3.0", "rhsFrac=2/1", "expDouble=6.0"), - Iteration("double*-fraction", "lhsDouble=3.14", "rhsFrac=-1 3/2", "expDouble=-7.85"), - Iteration("-double*fraction", "lhsDouble=-3.14", "rhsFrac=1 3/2", "expDouble=-7.85"), - Iteration("-double*-fraction", "lhsDouble=-3.14", "rhsFrac=-1 3/2", "expDouble=7.85") - ) + @Iteration("identity*identity", "lhsDouble=1.0", "rhsFrac=1/1", "expDouble=1.0") + @Iteration("double*identity", "lhsDouble=2.0", "rhsFrac=1/1", "expDouble=2.0") + @Iteration("double*fraction", "lhsDouble=3.14", "rhsFrac=3/2", "expDouble=4.71") + @Iteration("double*wholeNumberFraction", "lhsDouble=2.0", "rhsFrac=3/1", "expDouble=6.0") + @Iteration("commutativity", "lhsDouble=3.0", "rhsFrac=2/1", "expDouble=6.0") + @Iteration("double*-fraction", "lhsDouble=3.14", "rhsFrac=-1 3/2", "expDouble=-7.85") + @Iteration("-double*fraction", "lhsDouble=-3.14", "rhsFrac=1 3/2", "expDouble=-7.85") + @Iteration("-double*-fraction", "lhsDouble=-3.14", "rhsFrac=-1 3/2", "expDouble=7.85") fun testTimes_doubleAndFraction_returnsDouble() { val lhsReal = createIrrationalReal(lhsDouble) val rhsReal = createRationalReal(rhsFrac) @@ -1558,15 +1481,13 @@ class RealExtensionsTest { } @Test - @RunParameterized( - Iteration("identity*identity", "lhsDouble=1.0", "rhsDouble=1.0", "expDouble=1.0"), - Iteration("double*identity", "lhsDouble=2.0", "rhsDouble=1.0", "expDouble=2.0"), - Iteration("double*double", "lhsDouble=3.14", "rhsDouble=2.7", "expDouble=8.478"), - Iteration("commutativity", "lhsDouble=2.7", "rhsDouble=3.14", "expDouble=8.478"), - Iteration("double*-double", "lhsDouble=3.14", "rhsDouble=-2.7", "expDouble=-8.478"), - Iteration("-double*double", "lhsDouble=-3.14", "rhsDouble=2.7", "expDouble=-8.478"), - Iteration("-double*-double", "lhsDouble=-3.14", "rhsDouble=-2.7", "expDouble=8.478") - ) + @Iteration("identity*identity", "lhsDouble=1.0", "rhsDouble=1.0", "expDouble=1.0") + @Iteration("double*identity", "lhsDouble=2.0", "rhsDouble=1.0", "expDouble=2.0") + @Iteration("double*double", "lhsDouble=3.14", "rhsDouble=2.7", "expDouble=8.478") + @Iteration("commutativity", "lhsDouble=2.7", "rhsDouble=3.14", "expDouble=8.478") + @Iteration("double*-double", "lhsDouble=3.14", "rhsDouble=-2.7", "expDouble=-8.478") + @Iteration("-double*double", "lhsDouble=-3.14", "rhsDouble=2.7", "expDouble=-8.478") + @Iteration("-double*-double", "lhsDouble=-3.14", "rhsDouble=-2.7", "expDouble=8.478") fun testTimes_doubleAndDouble_returnsDouble() { val lhsReal = createIrrationalReal(lhsDouble) val rhsReal = createIrrationalReal(rhsDouble) @@ -1579,14 +1500,12 @@ class RealExtensionsTest { // Division tests. @Test - @RunParameterized( - Iteration("identity/identity", "lhsInt=1", "rhsInt=1", "expInt=1"), - Iteration("int/identity", "lhsInt=2", "rhsInt=1", "expInt=2"), - Iteration("int/int", "lhsInt=8", "rhsInt=2", "expInt=4"), - Iteration("int/-int", "lhsInt=8", "rhsInt=-2", "expInt=-4"), - Iteration("-int/int", "lhsInt=-8", "rhsInt=2", "expInt=-4"), - Iteration("-int/-int", "lhsInt=-8", "rhsInt=-2", "expInt=4") - ) + @Iteration("identity/identity", "lhsInt=1", "rhsInt=1", "expInt=1") + @Iteration("int/identity", "lhsInt=2", "rhsInt=1", "expInt=2") + @Iteration("int/int", "lhsInt=8", "rhsInt=2", "expInt=4") + @Iteration("int/-int", "lhsInt=8", "rhsInt=-2", "expInt=-4") + @Iteration("-int/int", "lhsInt=-8", "rhsInt=2", "expInt=-4") + @Iteration("-int/-int", "lhsInt=-8", "rhsInt=-2", "expInt=4") fun testDiv_intAndInt_divides_returnsInt() { val lhsReal = createIntegerReal(lhsInt) val rhsReal = createIntegerReal(rhsInt) @@ -1598,13 +1517,11 @@ class RealExtensionsTest { } @Test - @RunParameterized( - Iteration("int/int", "lhsInt=7", "rhsInt=2", "expFrac=3 1/2"), - Iteration("anticommutativity", "lhsInt=2", "rhsInt=7", "expFrac=2/7"), - Iteration("int/-int", "lhsInt=7", "rhsInt=-2", "expFrac=-3 1/2"), - Iteration("-int/int", "lhsInt=-7", "rhsInt=2", "expFrac=-3 1/2"), - Iteration("-int/-int", "lhsInt=-7", "rhsInt=-2", "expFrac=3 1/2") - ) + @Iteration("int/int", "lhsInt=7", "rhsInt=2", "expFrac=3 1/2") + @Iteration("anticommutativity", "lhsInt=2", "rhsInt=7", "expFrac=2/7") + @Iteration("int/-int", "lhsInt=7", "rhsInt=-2", "expFrac=-3 1/2") + @Iteration("-int/int", "lhsInt=-7", "rhsInt=2", "expFrac=-3 1/2") + @Iteration("-int/-int", "lhsInt=-7", "rhsInt=-2", "expFrac=3 1/2") fun testDiv_intAndInt_doesNotDivide_returnsFraction() { val lhsReal = createIntegerReal(lhsInt) val rhsReal = createIntegerReal(rhsInt) @@ -1617,16 +1534,14 @@ class RealExtensionsTest { } @Test - @RunParameterized( - Iteration("identity/identity", "lhsInt=1", "rhsFrac=1", "expFrac=1"), - Iteration("int/identity", "lhsInt=2", "rhsFrac=1", "expFrac=2"), - Iteration("int/fraction", "lhsInt=4", "rhsFrac=1/3", "expFrac=12"), - Iteration("int/wholeNumberFraction", "lhsInt=2", "rhsFrac=3/1", "expFrac=2/3"), - Iteration("anticommutativity", "lhsInt=3", "rhsFrac=2/1", "expFrac=1 1/2"), - Iteration("int/-fraction", "lhsInt=5", "rhsFrac=-2/3", "expFrac=-7 1/2"), - Iteration("-int/fraction", "lhsInt=-5", "rhsFrac=2/3", "expFrac=-7 1/2"), - Iteration("-int/-fraction", "lhsInt=-5", "rhsFrac=-2/3", "expFrac=7 1/2") - ) + @Iteration("identity/identity", "lhsInt=1", "rhsFrac=1", "expFrac=1") + @Iteration("int/identity", "lhsInt=2", "rhsFrac=1", "expFrac=2") + @Iteration("int/fraction", "lhsInt=4", "rhsFrac=1/3", "expFrac=12") + @Iteration("int/wholeNumberFraction", "lhsInt=2", "rhsFrac=3/1", "expFrac=2/3") + @Iteration("anticommutativity", "lhsInt=3", "rhsFrac=2/1", "expFrac=1 1/2") + @Iteration("int/-fraction", "lhsInt=5", "rhsFrac=-2/3", "expFrac=-7 1/2") + @Iteration("-int/fraction", "lhsInt=-5", "rhsFrac=2/3", "expFrac=-7 1/2") + @Iteration("-int/-fraction", "lhsInt=-5", "rhsFrac=-2/3", "expFrac=7 1/2") fun testDiv_intAndFraction_returnsFraction() { val lhsReal = createIntegerReal(lhsInt) val rhsReal = createRationalReal(rhsFrac) @@ -1638,16 +1553,14 @@ class RealExtensionsTest { } @Test - @RunParameterized( - Iteration("identity/identity", "lhsInt=1", "rhsDouble=1.0", "expDouble=1.0"), - Iteration("int/identity", "lhsInt=2", "rhsDouble=1.0", "expDouble=2.0"), - Iteration("int/double", "lhsInt=2", "rhsDouble=3.14", "expDouble=0.636942675"), - Iteration("int/wholeNumberDouble", "lhsInt=2", "rhsDouble=3.0", "expDouble=0.666666667"), - Iteration("anticommutativity", "lhsInt=3", "rhsDouble=2.0", "expDouble=1.5"), - Iteration("int/-double", "lhsInt=2", "rhsDouble=-3.14", "expDouble=-0.636942675"), - Iteration("-int/double", "lhsInt=-2", "rhsDouble=3.14", "expDouble=-0.636942675"), - Iteration("-int/-double", "lhsInt=-2", "rhsDouble=-3.14", "expDouble=0.636942675") - ) + @Iteration("identity/identity", "lhsInt=1", "rhsDouble=1.0", "expDouble=1.0") + @Iteration("int/identity", "lhsInt=2", "rhsDouble=1.0", "expDouble=2.0") + @Iteration("int/double", "lhsInt=2", "rhsDouble=3.14", "expDouble=0.636942675") + @Iteration("int/wholeNumberDouble", "lhsInt=2", "rhsDouble=3.0", "expDouble=0.666666667") + @Iteration("anticommutativity", "lhsInt=3", "rhsDouble=2.0", "expDouble=1.5") + @Iteration("int/-double", "lhsInt=2", "rhsDouble=-3.14", "expDouble=-0.636942675") + @Iteration("-int/double", "lhsInt=-2", "rhsDouble=3.14", "expDouble=-0.636942675") + @Iteration("-int/-double", "lhsInt=-2", "rhsDouble=-3.14", "expDouble=0.636942675") fun testDiv_intAndDouble_returnsDouble() { val lhsReal = createIntegerReal(lhsInt) val rhsReal = createIrrationalReal(rhsDouble) @@ -1658,16 +1571,14 @@ class RealExtensionsTest { } @Test - @RunParameterized( - Iteration("identity/identity", "lhsFrac=1/1", "rhsInt=1", "expFrac=1"), - Iteration("fraction/identity", "lhsFrac=2/1", "rhsInt=1", "expFrac=2"), - Iteration("fraction/int", "lhsFrac=1/3", "rhsInt=2", "expFrac=1/6"), - Iteration("wholeNumberFraction/int", "lhsFrac=3/1", "rhsInt=2", "expFrac=1 1/2"), - Iteration("anticommutativity", "lhsFrac=2/1", "rhsInt=3", "expFrac=2/3"), - Iteration("fraction/-int", "lhsFrac=-1 1/3", "rhsInt=2", "expFrac=-2/3"), - Iteration("-fraction/int", "lhsFrac=1 1/3", "rhsInt=-2", "expFrac=-2/3"), - Iteration("-fraction/-int", "lhsFrac=-1 1/3", "rhsInt=-2", "expFrac=2/3") - ) + @Iteration("identity/identity", "lhsFrac=1/1", "rhsInt=1", "expFrac=1") + @Iteration("fraction/identity", "lhsFrac=2/1", "rhsInt=1", "expFrac=2") + @Iteration("fraction/int", "lhsFrac=1/3", "rhsInt=2", "expFrac=1/6") + @Iteration("wholeNumberFraction/int", "lhsFrac=3/1", "rhsInt=2", "expFrac=1 1/2") + @Iteration("anticommutativity", "lhsFrac=2/1", "rhsInt=3", "expFrac=2/3") + @Iteration("fraction/-int", "lhsFrac=-1 1/3", "rhsInt=2", "expFrac=-2/3") + @Iteration("-fraction/int", "lhsFrac=1 1/3", "rhsInt=-2", "expFrac=-2/3") + @Iteration("-fraction/-int", "lhsFrac=-1 1/3", "rhsInt=-2", "expFrac=2/3") fun testDiv_fractionAndInt_returnsFraction() { val lhsReal = createRationalReal(lhsFrac) val rhsReal = createIntegerReal(rhsInt) @@ -1679,15 +1590,13 @@ class RealExtensionsTest { } @Test - @RunParameterized( - Iteration("identity/identity", "lhsFrac=1/1", "rhsFrac=1/1", "expFrac=1"), - Iteration("fraction/identity", "lhsFrac=3/2", "rhsFrac=1/1", "expFrac=1 1/2"), - Iteration("fraction/fraction", "lhsFrac=3/2", "rhsFrac=4/7", "expFrac=2 5/8"), - Iteration("anticommutativity", "lhsFrac=4/7", "rhsFrac=3/2", "expFrac=8/21"), - Iteration("fraction/-fraction", "lhsFrac=1 3/9", "rhsFrac=-8/11", "expFrac=-1 5/6"), - Iteration("-fraction/fraction", "lhsFrac=-1 3/9", "rhsFrac=8/11", "expFrac=-1 5/6"), - Iteration("-fraction/-fraction", "lhsFrac=-1 3/9", "rhsFrac=-8/11", "expFrac=1 5/6") - ) + @Iteration("identity/identity", "lhsFrac=1/1", "rhsFrac=1/1", "expFrac=1") + @Iteration("fraction/identity", "lhsFrac=3/2", "rhsFrac=1/1", "expFrac=1 1/2") + @Iteration("fraction/fraction", "lhsFrac=3/2", "rhsFrac=4/7", "expFrac=2 5/8") + @Iteration("anticommutativity", "lhsFrac=4/7", "rhsFrac=3/2", "expFrac=8/21") + @Iteration("fraction/-fraction", "lhsFrac=1 3/9", "rhsFrac=-8/11", "expFrac=-1 5/6") + @Iteration("-fraction/fraction", "lhsFrac=-1 3/9", "rhsFrac=8/11", "expFrac=-1 5/6") + @Iteration("-fraction/-fraction", "lhsFrac=-1 3/9", "rhsFrac=-8/11", "expFrac=1 5/6") fun testDiv_fractionAndFraction_returnsFraction() { val lhsReal = createRationalReal(lhsFrac) val rhsReal = createRationalReal(rhsFrac) @@ -1699,16 +1608,14 @@ class RealExtensionsTest { } @Test - @RunParameterized( - Iteration("identity/identity", "lhsFrac=1/1", "rhsDouble=1.0", "expDouble=1.0"), - Iteration("fraction/identity", "lhsFrac=3/2", "rhsDouble=1.0", "expDouble=1.5"), - Iteration("fraction/double", "lhsFrac=3/2", "rhsDouble=3.14", "expDouble=0.477707006"), - Iteration("wholeNumberFraction/double", "lhsFrac=3/1", "rhsDouble=2.0", "expDouble=1.5"), - Iteration("anticommutativity", "lhsFrac=2/1", "rhsDouble=3.0", "expDouble=0.666666667"), - Iteration("fraction/-double", "lhsFrac=1 3/2", "rhsDouble=-3.14", "expDouble=-0.796178344"), - Iteration("-fraction/double", "lhsFrac=-1 3/2", "rhsDouble=3.14", "expDouble=-0.796178344"), - Iteration("-fraction/-double", "lhsFrac=-1 3/2", "rhsDouble=-3.14", "expDouble=0.796178344") - ) + @Iteration("identity/identity", "lhsFrac=1/1", "rhsDouble=1.0", "expDouble=1.0") + @Iteration("fraction/identity", "lhsFrac=3/2", "rhsDouble=1.0", "expDouble=1.5") + @Iteration("fraction/double", "lhsFrac=3/2", "rhsDouble=3.14", "expDouble=0.477707006") + @Iteration("wholeNumberFraction/double", "lhsFrac=3/1", "rhsDouble=2.0", "expDouble=1.5") + @Iteration("anticommutativity", "lhsFrac=2/1", "rhsDouble=3.0", "expDouble=0.666666667") + @Iteration("fraction/-double", "lhsFrac=1 3/2", "rhsDouble=-3.14", "expDouble=-0.796178344") + @Iteration("-fraction/double", "lhsFrac=-1 3/2", "rhsDouble=3.14", "expDouble=-0.796178344") + @Iteration("-fraction/-double", "lhsFrac=-1 3/2", "rhsDouble=-3.14", "expDouble=0.796178344") fun testDiv_fractionAndDouble_returnsDouble() { val lhsReal = createRationalReal(lhsFrac) val rhsReal = createIrrationalReal(rhsDouble) @@ -1719,16 +1626,14 @@ class RealExtensionsTest { } @Test - @RunParameterized( - Iteration("identity/identity", "lhsDouble=1.0", "rhsInt=1", "expDouble=1.0"), - Iteration("double/identity", "lhsDouble=2.0", "rhsInt=1", "expDouble=2.0"), - Iteration("double/int", "lhsDouble=3.14", "rhsInt=2", "expDouble=1.57"), - Iteration("wholeNumberDouble/int", "lhsDouble=3.0", "rhsInt=2", "expDouble=1.5"), - Iteration("anticommutativity", "lhsDouble=2.0", "rhsInt=3", "expDouble=0.666666667"), - Iteration("double/-int", "lhsDouble=3.14", "rhsInt=-2", "expDouble=-1.57"), - Iteration("-double/int", "lhsDouble=-3.14", "rhsInt=2", "expDouble=-1.57"), - Iteration("-double/-int", "lhsDouble=-3.14", "rhsInt=-2", "expDouble=1.57") - ) + @Iteration("identity/identity", "lhsDouble=1.0", "rhsInt=1", "expDouble=1.0") + @Iteration("double/identity", "lhsDouble=2.0", "rhsInt=1", "expDouble=2.0") + @Iteration("double/int", "lhsDouble=3.14", "rhsInt=2", "expDouble=1.57") + @Iteration("wholeNumberDouble/int", "lhsDouble=3.0", "rhsInt=2", "expDouble=1.5") + @Iteration("anticommutativity", "lhsDouble=2.0", "rhsInt=3", "expDouble=0.666666667") + @Iteration("double/-int", "lhsDouble=3.14", "rhsInt=-2", "expDouble=-1.57") + @Iteration("-double/int", "lhsDouble=-3.14", "rhsInt=2", "expDouble=-1.57") + @Iteration("-double/-int", "lhsDouble=-3.14", "rhsInt=-2", "expDouble=1.57") fun testDiv_doubleAndInt_returnsDouble() { val lhsReal = createIrrationalReal(lhsDouble) val rhsReal = createIntegerReal(rhsInt) @@ -1739,16 +1644,14 @@ class RealExtensionsTest { } @Test - @RunParameterized( - Iteration("identity/identity", "lhsDouble=1.0", "rhsFrac=1/1", "expDouble=1.0"), - Iteration("double/identity", "lhsDouble=2.0", "rhsFrac=1/1", "expDouble=2.0"), - Iteration("double/fraction", "lhsDouble=3.14", "rhsFrac=3/2", "expDouble=2.093333333"), - Iteration("double/wholeNumberFraction", "lhsDouble=2.0", "rhsFrac=3/1", "expDouble=0.66666667"), - Iteration("anticommutativity", "lhsDouble=3.0", "rhsFrac=2/1", "expDouble=1.5"), - Iteration("double/-fraction", "lhsDouble=3.14", "rhsFrac=-1 3/2", "expDouble=-1.256"), - Iteration("-double/fraction", "lhsDouble=-3.14", "rhsFrac=1 3/2", "expDouble=-1.256"), - Iteration("-double/-fraction", "lhsDouble=-3.14", "rhsFrac=-1 3/2", "expDouble=1.256") - ) + @Iteration("identity/identity", "lhsDouble=1.0", "rhsFrac=1/1", "expDouble=1.0") + @Iteration("double/identity", "lhsDouble=2.0", "rhsFrac=1/1", "expDouble=2.0") + @Iteration("double/fraction", "lhsDouble=3.14", "rhsFrac=3/2", "expDouble=2.093333333") + @Iteration("double/wholeNumberFraction", "lhsDouble=2.0", "rhsFrac=3/1", "expDouble=0.66666667") + @Iteration("anticommutativity", "lhsDouble=3.0", "rhsFrac=2/1", "expDouble=1.5") + @Iteration("double/-fraction", "lhsDouble=3.14", "rhsFrac=-1 3/2", "expDouble=-1.256") + @Iteration("-double/fraction", "lhsDouble=-3.14", "rhsFrac=1 3/2", "expDouble=-1.256") + @Iteration("-double/-fraction", "lhsDouble=-3.14", "rhsFrac=-1 3/2", "expDouble=1.256") fun testDiv_doubleAndFraction_returnsDouble() { val lhsReal = createIrrationalReal(lhsDouble) val rhsReal = createRationalReal(rhsFrac) @@ -1759,15 +1662,13 @@ class RealExtensionsTest { } @Test - @RunParameterized( - Iteration("identity/identity", "lhsDouble=1.0", "rhsDouble=1.0", "expDouble=1.0"), - Iteration("double/identity", "lhsDouble=2.0", "rhsDouble=1.0", "expDouble=2.0"), - Iteration("double/double", "lhsDouble=3.14", "rhsDouble=2.7", "expDouble=1.162962963"), - Iteration("anticommutativity", "lhsDouble=2.7", "rhsDouble=3.14", "expDouble=0.859872611"), - Iteration("double/-double", "lhsDouble=3.14", "rhsDouble=-2.7", "expDouble=-1.162962963"), - Iteration("-double/double", "lhsDouble=-3.14", "rhsDouble=2.7", "expDouble=-1.162962963"), - Iteration("-double/-double", "lhsDouble=-3.14", "rhsDouble=-2.7", "expDouble=1.162962963") - ) + @Iteration("identity/identity", "lhsDouble=1.0", "rhsDouble=1.0", "expDouble=1.0") + @Iteration("double/identity", "lhsDouble=2.0", "rhsDouble=1.0", "expDouble=2.0") + @Iteration("double/double", "lhsDouble=3.14", "rhsDouble=2.7", "expDouble=1.162962963") + @Iteration("anticommutativity", "lhsDouble=2.7", "rhsDouble=3.14", "expDouble=0.859872611") + @Iteration("double/-double", "lhsDouble=3.14", "rhsDouble=-2.7", "expDouble=-1.162962963") + @Iteration("-double/double", "lhsDouble=-3.14", "rhsDouble=2.7", "expDouble=-1.162962963") + @Iteration("-double/-double", "lhsDouble=-3.14", "rhsDouble=-2.7", "expDouble=1.162962963") fun testDiv_doubleAndDouble_returnsDouble() { val lhsReal = createIrrationalReal(lhsDouble) val rhsReal = createIrrationalReal(rhsDouble) @@ -1862,17 +1763,15 @@ class RealExtensionsTest { // Exponentiation tests. @Test - @RunParameterized( - Iteration("0^0", "lhsInt=0", "rhsInt=0", "expInt=1"), - Iteration("identity^0", "lhsInt=1", "rhsInt=0", "expInt=1"), - Iteration("identity^identity", "lhsInt=1", "rhsInt=1", "expInt=1"), - Iteration("int^0", "lhsInt=2", "rhsInt=0", "expInt=1"), - Iteration("int^identity", "lhsInt=2", "rhsInt=1", "expInt=2"), - Iteration("int^int", "lhsInt=2", "rhsInt=3", "expInt=8"), - Iteration("noncommutativity", "lhsInt=3", "rhsInt=2", "expInt=9"), - Iteration("-int^even int", "lhsInt=-2", "rhsInt=4", "expInt=16"), - Iteration("-int^odd int", "lhsInt=-2", "rhsInt=3", "expInt=-8") - ) + @Iteration("0^0", "lhsInt=0", "rhsInt=0", "expInt=1") + @Iteration("identity^0", "lhsInt=1", "rhsInt=0", "expInt=1") + @Iteration("identity^identity", "lhsInt=1", "rhsInt=1", "expInt=1") + @Iteration("int^0", "lhsInt=2", "rhsInt=0", "expInt=1") + @Iteration("int^identity", "lhsInt=2", "rhsInt=1", "expInt=2") + @Iteration("int^int", "lhsInt=2", "rhsInt=3", "expInt=8") + @Iteration("noncommutativity", "lhsInt=3", "rhsInt=2", "expInt=9") + @Iteration("-int^even int", "lhsInt=-2", "rhsInt=4", "expInt=16") + @Iteration("-int^odd int", "lhsInt=-2", "rhsInt=3", "expInt=-8") fun testPow_intAndInt_positivePower_returnsInt() { val lhsReal = createIntegerReal(lhsInt) val rhsReal = createIntegerReal(rhsInt) @@ -1884,11 +1783,9 @@ class RealExtensionsTest { } @Test - @RunParameterized( - Iteration("int^-int", "lhsInt=2", "rhsInt=-3", "expFrac=1/8"), - Iteration("-int^-even int", "lhsInt=-2", "rhsInt=-4", "expFrac=1/16"), - Iteration("-int^-odd int", "lhsInt=-2", "rhsInt=-3", "expFrac=-1/8") - ) + @Iteration("int^-int", "lhsInt=2", "rhsInt=-3", "expFrac=1/8") + @Iteration("-int^-even int", "lhsInt=-2", "rhsInt=-4", "expFrac=1/16") + @Iteration("-int^-odd int", "lhsInt=-2", "rhsInt=-3", "expFrac=-1/8") fun testPow_intAndInt_negativePower_returnsFraction() { val lhsReal = createIntegerReal(lhsInt) val rhsReal = createIntegerReal(rhsInt) @@ -1901,21 +1798,19 @@ class RealExtensionsTest { } @Test - @RunParameterized( - Iteration("0^0", "lhsInt=0", "rhsFrac=0/1", "expFrac=1"), - Iteration("identity^0", "lhsInt=1", "rhsFrac=0/1", "expFrac=1"), - Iteration("identity^identity", "lhsInt=1", "rhsFrac=1", "expFrac=1"), - Iteration("int^0", "lhsInt=2", "rhsFrac=0/1", "expFrac=1"), - Iteration("int^identity", "lhsInt=2", "rhsFrac=1", "expFrac=2"), - Iteration("int^fraction", "lhsInt=16", "rhsFrac=3/2", "expFrac=64"), - Iteration("int^wholeNumberFraction", "lhsInt=2", "rhsFrac=3/1", "expFrac=8"), - Iteration("noncommutativity", "lhsInt=3", "rhsFrac=2/1", "expFrac=9"), - Iteration("int^odd fraction", "lhsInt=8", "rhsFrac=5/3", "expFrac=32"), - Iteration("int^-fraction", "lhsInt=8", "rhsFrac=-4/2", "expFrac=1/64"), - Iteration("-int^odd fraction", "lhsInt=-8", "rhsFrac=5/3", "expFrac=-32"), - Iteration("-int^-fraction", "lhsInt=-4", "rhsFrac=-4/2", "expFrac=1/16"), - Iteration("-int^-odd fraction", "lhsInt=-8", "rhsFrac=-5/3", "expFrac=-1/32") - ) + @Iteration("0^0", "lhsInt=0", "rhsFrac=0/1", "expFrac=1") + @Iteration("identity^0", "lhsInt=1", "rhsFrac=0/1", "expFrac=1") + @Iteration("identity^identity", "lhsInt=1", "rhsFrac=1", "expFrac=1") + @Iteration("int^0", "lhsInt=2", "rhsFrac=0/1", "expFrac=1") + @Iteration("int^identity", "lhsInt=2", "rhsFrac=1", "expFrac=2") + @Iteration("int^fraction", "lhsInt=16", "rhsFrac=3/2", "expFrac=64") + @Iteration("int^wholeNumberFraction", "lhsInt=2", "rhsFrac=3/1", "expFrac=8") + @Iteration("noncommutativity", "lhsInt=3", "rhsFrac=2/1", "expFrac=9") + @Iteration("int^odd fraction", "lhsInt=8", "rhsFrac=5/3", "expFrac=32") + @Iteration("int^-fraction", "lhsInt=8", "rhsFrac=-4/2", "expFrac=1/64") + @Iteration("-int^odd fraction", "lhsInt=-8", "rhsFrac=5/3", "expFrac=-32") + @Iteration("-int^-fraction", "lhsInt=-4", "rhsFrac=-4/2", "expFrac=1/16") + @Iteration("-int^-odd fraction", "lhsInt=-8", "rhsFrac=-5/3", "expFrac=-1/32") fun testPow_intAndFraction_denominatorCanRootInt_returnsFraction() { val lhsReal = createIntegerReal(lhsInt) val rhsReal = createRationalReal(rhsFrac) @@ -1927,12 +1822,10 @@ class RealExtensionsTest { } @Test - @RunParameterized( - Iteration("int^fraction", "lhsInt=3", "rhsFrac=2/3", "expDouble=2.080083823"), - Iteration("-int^fraction", "lhsInt=-4", "rhsFrac=2/3", "expDouble=2.5198421"), - Iteration("int^-fraction", "lhsInt=2", "rhsFrac=-2/3", "expDouble=0.629960525"), - Iteration("-int^-fraction", "lhsInt=-4", "rhsFrac=-2/3", "expDouble=0.396850263") - ) + @Iteration("int^fraction", "lhsInt=3", "rhsFrac=2/3", "expDouble=2.080083823") + @Iteration("-int^fraction", "lhsInt=-4", "rhsFrac=2/3", "expDouble=2.5198421") + @Iteration("int^-fraction", "lhsInt=2", "rhsFrac=-2/3", "expDouble=0.629960525") + @Iteration("-int^-fraction", "lhsInt=-4", "rhsFrac=-2/3", "expDouble=0.396850263") fun testPow_intAndFraction_denominatorCannotRootInt_returnsDouble() { val lhsReal = createIntegerReal(lhsInt) val rhsReal = createRationalReal(rhsFrac) @@ -1943,17 +1836,15 @@ class RealExtensionsTest { } @Test - @RunParameterized( - Iteration("0^0", "lhsInt=0", "rhsDouble=0.0", "expDouble=1.0"), - Iteration("identity^0", "lhsInt=1", "rhsDouble=0.0", "expDouble=1.0"), - Iteration("identity^identity", "lhsInt=1", "rhsDouble=1.0", "expDouble=1.0"), - Iteration("int^0", "lhsInt=2", "rhsDouble=0.0", "expDouble=1.0"), - Iteration("int^identity", "lhsInt=2", "rhsDouble=1.0", "expDouble=2.0"), - Iteration("int^double", "lhsInt=2", "rhsDouble=3.14", "expDouble=8.815240927"), - Iteration("int^wholeNumberDouble", "lhsInt=2", "rhsDouble=3.0", "expDouble=8.0"), - Iteration("noncommutativity", "lhsInt=3", "rhsDouble=2.0", "expDouble=9.0"), - Iteration("int^-double", "lhsInt=2", "rhsDouble=-3.14", "expDouble=0.113439894") - ) + @Iteration("0^0", "lhsInt=0", "rhsDouble=0.0", "expDouble=1.0") + @Iteration("identity^0", "lhsInt=1", "rhsDouble=0.0", "expDouble=1.0") + @Iteration("identity^identity", "lhsInt=1", "rhsDouble=1.0", "expDouble=1.0") + @Iteration("int^0", "lhsInt=2", "rhsDouble=0.0", "expDouble=1.0") + @Iteration("int^identity", "lhsInt=2", "rhsDouble=1.0", "expDouble=2.0") + @Iteration("int^double", "lhsInt=2", "rhsDouble=3.14", "expDouble=8.815240927") + @Iteration("int^wholeNumberDouble", "lhsInt=2", "rhsDouble=3.0", "expDouble=8.0") + @Iteration("noncommutativity", "lhsInt=3", "rhsDouble=2.0", "expDouble=9.0") + @Iteration("int^-double", "lhsInt=2", "rhsDouble=-3.14", "expDouble=0.113439894") fun testPow_intAndDouble_returnsDouble() { val lhsReal = createIntegerReal(lhsInt) val rhsReal = createIrrationalReal(rhsDouble) @@ -1964,19 +1855,17 @@ class RealExtensionsTest { } @Test - @RunParameterized( - Iteration("0^0", "lhsFrac=0", "rhsInt=0", "expFrac=1"), - Iteration("identity^0", "lhsFrac=1", "rhsInt=0", "expFrac=1"), - Iteration("identity^identity", "lhsFrac=1", "rhsInt=1", "expFrac=1"), - Iteration("fraction^0", "lhsFrac=1/3", "rhsInt=0", "expFrac=1"), - Iteration("fraction^identity", "lhsFrac=1/3", "rhsInt=1", "expFrac=1/3"), - Iteration("fraction^int", "lhsFrac=2/3", "rhsInt=3", "expFrac=8/27"), - Iteration("wholeNumberFraction^int", "lhsFrac=3", "rhsInt=2", "expFrac=9"), - Iteration("noncommutativity", "lhsFrac=2", "rhsInt=3", "expFrac=8"), - Iteration("fraction^-int", "lhsFrac=4/3", "rhsInt=-2", "expFrac=9/16"), - Iteration("-fraction^int", "lhsFrac=-4/3", "rhsInt=2", "expFrac=1 7/9"), - Iteration("-fraction^-int", "lhsFrac=-4/3", "rhsInt=-2", "expFrac=9/16") - ) + @Iteration("0^0", "lhsFrac=0", "rhsInt=0", "expFrac=1") + @Iteration("identity^0", "lhsFrac=1", "rhsInt=0", "expFrac=1") + @Iteration("identity^identity", "lhsFrac=1", "rhsInt=1", "expFrac=1") + @Iteration("fraction^0", "lhsFrac=1/3", "rhsInt=0", "expFrac=1") + @Iteration("fraction^identity", "lhsFrac=1/3", "rhsInt=1", "expFrac=1/3") + @Iteration("fraction^int", "lhsFrac=2/3", "rhsInt=3", "expFrac=8/27") + @Iteration("wholeNumberFraction^int", "lhsFrac=3", "rhsInt=2", "expFrac=9") + @Iteration("noncommutativity", "lhsFrac=2", "rhsInt=3", "expFrac=8") + @Iteration("fraction^-int", "lhsFrac=4/3", "rhsInt=-2", "expFrac=9/16") + @Iteration("-fraction^int", "lhsFrac=-4/3", "rhsInt=2", "expFrac=1 7/9") + @Iteration("-fraction^-int", "lhsFrac=-4/3", "rhsInt=-2", "expFrac=9/16") fun testPow_fractionAndInt_returnsFraction() { val lhsReal = createRationalReal(lhsFrac) val rhsReal = createIntegerReal(rhsInt) @@ -1988,17 +1877,15 @@ class RealExtensionsTest { } @Test - @RunParameterized( - Iteration("0^0", "lhsFrac=0", "rhsFrac=0", "expFrac=1"), - Iteration("identity^0", "lhsFrac=1", "rhsFrac=0", "expFrac=1"), - Iteration("identity^identity", "lhsFrac=1", "rhsFrac=1", "expFrac=1"), - Iteration("fraction^0", "lhsFrac=3/2", "rhsFrac=0", "expFrac=1"), - Iteration("fraction^identity", "lhsFrac=3/2", "rhsFrac=1", "expFrac=1 1/2"), - Iteration("fraction^fraction", "lhsFrac=32/243", "rhsFrac=3/5", "expFrac=8/27"), - Iteration("fraction^wholeNumberFraction", "lhsFrac=3", "rhsFrac=2", "expFrac=9"), - Iteration("noncommutativity", "lhsFrac=2", "rhsFrac=3", "expFrac=8"), - Iteration("fraction^-fraction", "lhsFrac=32/243", "rhsFrac=-3/5", "expFrac=3 3/8") - ) + @Iteration("0^0", "lhsFrac=0", "rhsFrac=0", "expFrac=1") + @Iteration("identity^0", "lhsFrac=1", "rhsFrac=0", "expFrac=1") + @Iteration("identity^identity", "lhsFrac=1", "rhsFrac=1", "expFrac=1") + @Iteration("fraction^0", "lhsFrac=3/2", "rhsFrac=0", "expFrac=1") + @Iteration("fraction^identity", "lhsFrac=3/2", "rhsFrac=1", "expFrac=1 1/2") + @Iteration("fraction^fraction", "lhsFrac=32/243", "rhsFrac=3/5", "expFrac=8/27") + @Iteration("fraction^wholeNumberFraction", "lhsFrac=3", "rhsFrac=2", "expFrac=9") + @Iteration("noncommutativity", "lhsFrac=2", "rhsFrac=3", "expFrac=8") + @Iteration("fraction^-fraction", "lhsFrac=32/243", "rhsFrac=-3/5", "expFrac=3 3/8") fun testPow_fractionAndFraction_denominatorCanRootFraction_returnsFraction() { val lhsReal = createRationalReal(lhsFrac) val rhsReal = createRationalReal(rhsFrac) @@ -2010,11 +1897,9 @@ class RealExtensionsTest { } @Test - @RunParameterized( - Iteration("fraction^fraction", "lhsFrac=3/2", "rhsFrac=2/3", "expDouble=1.310370697"), - Iteration("noncommutativity", "lhsFrac=2/3", "rhsFrac=3/2", "expDouble=0.544331054"), - Iteration("fraction^-fraction", "lhsFrac=3/2", "rhsFrac=-2/3", "expDouble=0.763142828") - ) + @Iteration("fraction^fraction", "lhsFrac=3/2", "rhsFrac=2/3", "expDouble=1.310370697") + @Iteration("noncommutativity", "lhsFrac=2/3", "rhsFrac=3/2", "expDouble=0.544331054") + @Iteration("fraction^-fraction", "lhsFrac=3/2", "rhsFrac=-2/3", "expDouble=0.763142828") fun testPow_fractionAndFraction_denominatorCannotRootFraction_returnsDouble() { val lhsReal = createRationalReal(lhsFrac) val rhsReal = createRationalReal(rhsFrac) @@ -2025,17 +1910,15 @@ class RealExtensionsTest { } @Test - @RunParameterized( - Iteration("0^0", "lhsFrac=0", "rhsDouble=0.0", "expDouble=1.0"), - Iteration("identity^0", "lhsFrac=1", "rhsDouble=0.0", "expDouble=1.0"), - Iteration("identity^identity", "lhsFrac=1", "rhsDouble=1.0", "expDouble=1.0"), - Iteration("fraction^0", "lhsFrac=3/2", "rhsDouble=0.0", "expDouble=1.0"), - Iteration("fraction^identity", "lhsFrac=3/2", "rhsDouble=1.0", "expDouble=1.5"), - Iteration("fraction^double", "lhsFrac=3/2", "rhsDouble=3.14", "expDouble=3.572124224"), - Iteration("wholeNumberFraction^double", "lhsFrac=3", "rhsDouble=2.0", "expDouble=9.0"), - Iteration("noncommutativity", "lhsFrac=2", "rhsDouble=3.0", "expDouble=8.0"), - Iteration("fraction^-double", "lhsFrac=1 3/2", "rhsDouble=-3.14", "expDouble=0.056294812") - ) + @Iteration("0^0", "lhsFrac=0", "rhsDouble=0.0", "expDouble=1.0") + @Iteration("identity^0", "lhsFrac=1", "rhsDouble=0.0", "expDouble=1.0") + @Iteration("identity^identity", "lhsFrac=1", "rhsDouble=1.0", "expDouble=1.0") + @Iteration("fraction^0", "lhsFrac=3/2", "rhsDouble=0.0", "expDouble=1.0") + @Iteration("fraction^identity", "lhsFrac=3/2", "rhsDouble=1.0", "expDouble=1.5") + @Iteration("fraction^double", "lhsFrac=3/2", "rhsDouble=3.14", "expDouble=3.572124224") + @Iteration("wholeNumberFraction^double", "lhsFrac=3", "rhsDouble=2.0", "expDouble=9.0") + @Iteration("noncommutativity", "lhsFrac=2", "rhsDouble=3.0", "expDouble=8.0") + @Iteration("fraction^-double", "lhsFrac=1 3/2", "rhsDouble=-3.14", "expDouble=0.056294812") fun testPow_fractionAndDouble_returnsDouble() { val lhsReal = createRationalReal(lhsFrac) val rhsReal = createIrrationalReal(rhsDouble) @@ -2046,19 +1929,17 @@ class RealExtensionsTest { } @Test - @RunParameterized( - Iteration("0^0", "lhsDouble=0.0", "rhsInt=0", "expDouble=1.0"), - Iteration("identity^0", "lhsDouble=1.0", "rhsInt=0", "expDouble=1.0"), - Iteration("identity^identity", "lhsDouble=1.0", "rhsInt=1", "expDouble=1.0"), - Iteration("double^0", "lhsDouble=3.14", "rhsInt=0", "expDouble=1.0"), - Iteration("double^identity", "lhsDouble=3.14", "rhsInt=1", "expDouble=3.14"), - Iteration("double^int", "lhsDouble=3.14", "rhsInt=2", "expDouble=9.8596"), - Iteration("wholeNumberDouble^int", "lhsDouble=3.0", "rhsInt=2", "expDouble=9.0"), - Iteration("noncommutativity", "lhsDouble=2.0", "rhsInt=3", "expDouble=8.0"), - Iteration("double^-int", "lhsDouble=3.14", "rhsInt=-3", "expDouble=0.032300635"), - Iteration("-double^int", "lhsDouble=-3.14", "rhsInt=3", "expDouble=-30.959144"), - Iteration("-double^-int", "lhsDouble=-3.14", "rhsInt=-3", "expDouble=-0.032300635") - ) + @Iteration("0^0", "lhsDouble=0.0", "rhsInt=0", "expDouble=1.0") + @Iteration("identity^0", "lhsDouble=1.0", "rhsInt=0", "expDouble=1.0") + @Iteration("identity^identity", "lhsDouble=1.0", "rhsInt=1", "expDouble=1.0") + @Iteration("double^0", "lhsDouble=3.14", "rhsInt=0", "expDouble=1.0") + @Iteration("double^identity", "lhsDouble=3.14", "rhsInt=1", "expDouble=3.14") + @Iteration("double^int", "lhsDouble=3.14", "rhsInt=2", "expDouble=9.8596") + @Iteration("wholeNumberDouble^int", "lhsDouble=3.0", "rhsInt=2", "expDouble=9.0") + @Iteration("noncommutativity", "lhsDouble=2.0", "rhsInt=3", "expDouble=8.0") + @Iteration("double^-int", "lhsDouble=3.14", "rhsInt=-3", "expDouble=0.032300635") + @Iteration("-double^int", "lhsDouble=-3.14", "rhsInt=3", "expDouble=-30.959144") + @Iteration("-double^-int", "lhsDouble=-3.14", "rhsInt=-3", "expDouble=-0.032300635") fun testPow_doubleAndInt_returnsDouble() { val lhsReal = createIrrationalReal(lhsDouble) val rhsReal = createIntegerReal(rhsInt) @@ -2069,17 +1950,15 @@ class RealExtensionsTest { } @Test - @RunParameterized( - Iteration("0^0", "lhsDouble=0.0", "rhsFrac=0/1", "expDouble=1.0"), - Iteration("identity^0", "lhsDouble=1.0", "rhsFrac=0/1", "expDouble=1.0"), - Iteration("identity^identity", "lhsDouble=1.0", "rhsFrac=1", "expDouble=1.0"), - Iteration("double^0", "lhsDouble=3.14", "rhsFrac=0/1", "expDouble=1.0"), - Iteration("double^identity", "lhsDouble=3.14", "rhsFrac=1", "expDouble=3.14"), - Iteration("double^fraction", "lhsDouble=3.14", "rhsFrac=3/2", "expDouble=5.564094176"), - Iteration("double^wholeNumberFraction", "lhsDouble=2.0", "rhsFrac=3/1", "expDouble=8.0"), - Iteration("noncommutativity", "lhsDouble=3.0", "rhsFrac=2/1", "expDouble=9.0"), - Iteration("double^-fraction", "lhsDouble=3.14", "rhsFrac=-3/2", "expDouble=0.179723773") - ) + @Iteration("0^0", "lhsDouble=0.0", "rhsFrac=0/1", "expDouble=1.0") + @Iteration("identity^0", "lhsDouble=1.0", "rhsFrac=0/1", "expDouble=1.0") + @Iteration("identity^identity", "lhsDouble=1.0", "rhsFrac=1", "expDouble=1.0") + @Iteration("double^0", "lhsDouble=3.14", "rhsFrac=0/1", "expDouble=1.0") + @Iteration("double^identity", "lhsDouble=3.14", "rhsFrac=1", "expDouble=3.14") + @Iteration("double^fraction", "lhsDouble=3.14", "rhsFrac=3/2", "expDouble=5.564094176") + @Iteration("double^wholeNumberFraction", "lhsDouble=2.0", "rhsFrac=3/1", "expDouble=8.0") + @Iteration("noncommutativity", "lhsDouble=3.0", "rhsFrac=2/1", "expDouble=9.0") + @Iteration("double^-fraction", "lhsDouble=3.14", "rhsFrac=-3/2", "expDouble=0.179723773") fun testPow_doubleAndFraction_returnsDouble() { val lhsReal = createIrrationalReal(lhsDouble) val rhsReal = createRationalReal(rhsFrac) @@ -2090,16 +1969,14 @@ class RealExtensionsTest { } @Test - @RunParameterized( - Iteration("0^0", "lhsDouble=0.0", "rhsDouble=0.0", "expDouble=1.0"), - Iteration("identity^0", "lhsDouble=1.0", "rhsDouble=0.0", "expDouble=1.0"), - Iteration("identity^identity", "lhsDouble=1.0", "rhsDouble=1.0", "expDouble=1.0"), - Iteration("double^0", "lhsDouble=3.14", "rhsDouble=0.0", "expDouble=1.0"), - Iteration("double^identity", "lhsDouble=3.14", "rhsDouble=1.0", "expDouble=3.14"), - Iteration("double^double", "lhsDouble=3.14", "rhsDouble=2.7", "expDouble=21.963929943"), - Iteration("noncommutativity", "lhsDouble=2.7", "rhsDouble=3.14", "expDouble=22.619459311"), - Iteration("double^-double", "lhsDouble=3.14", "rhsDouble=-2.7", "expDouble=0.045529193") - ) + @Iteration("0^0", "lhsDouble=0.0", "rhsDouble=0.0", "expDouble=1.0") + @Iteration("identity^0", "lhsDouble=1.0", "rhsDouble=0.0", "expDouble=1.0") + @Iteration("identity^identity", "lhsDouble=1.0", "rhsDouble=1.0", "expDouble=1.0") + @Iteration("double^0", "lhsDouble=3.14", "rhsDouble=0.0", "expDouble=1.0") + @Iteration("double^identity", "lhsDouble=3.14", "rhsDouble=1.0", "expDouble=3.14") + @Iteration("double^double", "lhsDouble=3.14", "rhsDouble=2.7", "expDouble=21.963929943") + @Iteration("noncommutativity", "lhsDouble=2.7", "rhsDouble=3.14", "expDouble=22.619459311") + @Iteration("double^-double", "lhsDouble=3.14", "rhsDouble=-2.7", "expDouble=0.045529193") fun testPow_doubleAndDouble_returnsDouble() { val lhsReal = createIrrationalReal(lhsDouble) val rhsReal = createIrrationalReal(rhsDouble) @@ -2346,17 +2223,15 @@ class RealExtensionsTest { */ @Test - @RunParameterized( - Iteration("0==0", "lhsInt=0", "rhsInt=0", "expInt=0"), - Iteration("-2<0", "lhsInt=-2", "rhsInt=0", "expInt=-1"), - Iteration("-5<-2", "lhsInt=-5", "rhsInt=-2", "expInt=-1"), - Iteration("-2>-5", "lhsInt=-2", "rhsInt=-5", "expInt=1"), - Iteration("2>0", "lhsInt=2", "rhsInt=0", "expInt=1"), - Iteration("5>2", "lhsInt=5", "rhsInt=2", "expInt=1"), - Iteration("2<5", "lhsInt=2", "rhsInt=5", "expInt=-1"), - Iteration("-2<5", "lhsInt=-2", "rhsInt=5", "expInt=-1"), - Iteration("5>-2", "lhsInt=5", "rhsInt=-2", "expInt=1") - ) + @Iteration("0==0", "lhsInt=0", "rhsInt=0", "expInt=0") + @Iteration("-2<0", "lhsInt=-2", "rhsInt=0", "expInt=-1") + @Iteration("-5<-2", "lhsInt=-5", "rhsInt=-2", "expInt=-1") + @Iteration("-2>-5", "lhsInt=-2", "rhsInt=-5", "expInt=1") + @Iteration("2>0", "lhsInt=2", "rhsInt=0", "expInt=1") + @Iteration("5>2", "lhsInt=5", "rhsInt=2", "expInt=1") + @Iteration("2<5", "lhsInt=2", "rhsInt=5", "expInt=-1") + @Iteration("-2<5", "lhsInt=-2", "rhsInt=5", "expInt=-1") + @Iteration("5>-2", "lhsInt=5", "rhsInt=-2", "expInt=1") fun testComparator_intAndInt_returnsCorrectComparisonInt() { val lhsValue = createIntegerReal(lhsInt) val rhsValue = createIntegerReal(rhsInt) @@ -2367,23 +2242,21 @@ class RealExtensionsTest { } @Test - @RunParameterized( - Iteration("0==0", "lhsInt=0", "rhsFrac=0", "expInt=0"), - Iteration("-2<0", "lhsInt=-2", "rhsFrac=0", "expInt=-1"), - Iteration("-5<-2", "lhsInt=-5", "rhsFrac=-2", "expInt=-1"), - Iteration("-5<-1/2", "lhsInt=-5", "rhsFrac=-1/2", "expInt=-1"), - Iteration("-2>-5", "lhsInt=-2", "rhsFrac=-5", "expInt=1"), - Iteration("-1>-3/2", "lhsInt=-1", "rhsFrac=-3/2", "expInt=1"), - Iteration("2>0", "lhsInt=2", "rhsFrac=0", "expInt=1"), - Iteration("5>2", "lhsInt=5", "rhsFrac=2", "expInt=1"), - Iteration("2<5", "lhsInt=2", "rhsFrac=5", "expInt=-1"), - Iteration("2<7/2", "lhsInt=2", "rhsFrac=7/2", "expInt=-1"), - Iteration("5>3/2", "lhsInt=5", "rhsFrac=3/2", "expInt=1"), - Iteration("-2<5", "lhsInt=-2", "rhsFrac=5", "expInt=-1"), - Iteration("-2<3/2", "lhsInt=-2", "rhsFrac=3/2", "expInt=-1"), - Iteration("5>-2", "lhsInt=5", "rhsFrac=-2", "expInt=1"), - Iteration("5>-3/2", "lhsInt=5", "rhsFrac=-3/2", "expInt=1") - ) + @Iteration("0==0", "lhsInt=0", "rhsFrac=0", "expInt=0") + @Iteration("-2<0", "lhsInt=-2", "rhsFrac=0", "expInt=-1") + @Iteration("-5<-2", "lhsInt=-5", "rhsFrac=-2", "expInt=-1") + @Iteration("-5<-1/2", "lhsInt=-5", "rhsFrac=-1/2", "expInt=-1") + @Iteration("-2>-5", "lhsInt=-2", "rhsFrac=-5", "expInt=1") + @Iteration("-1>-3/2", "lhsInt=-1", "rhsFrac=-3/2", "expInt=1") + @Iteration("2>0", "lhsInt=2", "rhsFrac=0", "expInt=1") + @Iteration("5>2", "lhsInt=5", "rhsFrac=2", "expInt=1") + @Iteration("2<5", "lhsInt=2", "rhsFrac=5", "expInt=-1") + @Iteration("2<7/2", "lhsInt=2", "rhsFrac=7/2", "expInt=-1") + @Iteration("5>3/2", "lhsInt=5", "rhsFrac=3/2", "expInt=1") + @Iteration("-2<5", "lhsInt=-2", "rhsFrac=5", "expInt=-1") + @Iteration("-2<3/2", "lhsInt=-2", "rhsFrac=3/2", "expInt=-1") + @Iteration("5>-2", "lhsInt=5", "rhsFrac=-2", "expInt=1") + @Iteration("5>-3/2", "lhsInt=5", "rhsFrac=-3/2", "expInt=1") fun testComparator_intAndFraction_returnsCorrectComparisonInt() { val lhsValue = createIntegerReal(lhsInt) val rhsValue = createRationalReal(rhsFrac) @@ -2394,17 +2267,15 @@ class RealExtensionsTest { } @Test - @RunParameterized( - Iteration("0==0", "lhsInt=0", "rhsDouble=0.0", "expInt=0"), - Iteration("-2<0", "lhsInt=-2", "rhsDouble=0.0", "expInt=-1"), - Iteration("-5<-3.14", "lhsInt=-5", "rhsDouble=-3.14", "expInt=-1"), - Iteration("-2>-6.28", "lhsInt=-2", "rhsDouble=-6.28", "expInt=1"), - Iteration("2>0", "lhsInt=2", "rhsDouble=0.0", "expInt=1"), - Iteration("5>3.14", "lhsInt=5", "rhsDouble=3.14", "expInt=1"), - Iteration("2<6.28", "lhsInt=2", "rhsDouble=6.28", "expInt=-1"), - Iteration("-2<3.14", "lhsInt=-2", "rhsDouble=3.14", "expInt=-1"), - Iteration("2>-3.14", "lhsInt=2", "rhsDouble=-3.14", "expInt=1") - ) + @Iteration("0==0", "lhsInt=0", "rhsDouble=0.0", "expInt=0") + @Iteration("-2<0", "lhsInt=-2", "rhsDouble=0.0", "expInt=-1") + @Iteration("-5<-3.14", "lhsInt=-5", "rhsDouble=-3.14", "expInt=-1") + @Iteration("-2>-6.28", "lhsInt=-2", "rhsDouble=-6.28", "expInt=1") + @Iteration("2>0", "lhsInt=2", "rhsDouble=0.0", "expInt=1") + @Iteration("5>3.14", "lhsInt=5", "rhsDouble=3.14", "expInt=1") + @Iteration("2<6.28", "lhsInt=2", "rhsDouble=6.28", "expInt=-1") + @Iteration("-2<3.14", "lhsInt=-2", "rhsDouble=3.14", "expInt=-1") + @Iteration("2>-3.14", "lhsInt=2", "rhsDouble=-3.14", "expInt=1") fun testComparator_intAndDouble_returnsCorrectComparisonInt() { val lhsValue = createIntegerReal(lhsInt) val rhsValue = createIrrationalReal(rhsDouble) @@ -2415,17 +2286,15 @@ class RealExtensionsTest { } @Test - @RunParameterized( - Iteration("0==0", "lhsFrac=0", "rhsInt=0", "expInt=0"), - Iteration("-3/2<0", "lhsFrac=-3/2", "rhsInt=0", "expInt=-1"), - Iteration("-7/2<-3", "lhsFrac=-7/2", "rhsInt=-3", "expInt=-1"), - Iteration("-3/2>-5", "lhsFrac=-3/2", "rhsInt=-5", "expInt=1"), - Iteration("3/2>0", "lhsFrac=3/2", "rhsInt=0", "expInt=1"), - Iteration("7/2>3", "lhsFrac=7/2", "rhsInt=3", "expInt=1"), - Iteration("3/2<5", "lhsFrac=3/2", "rhsInt=5", "expInt=-1"), - Iteration("-3/2<3", "lhsFrac=-3/2", "rhsInt=3", "expInt=-1"), - Iteration("3/2>-3", "lhsFrac=3/2", "rhsInt=-3", "expInt=1") - ) + @Iteration("0==0", "lhsFrac=0", "rhsInt=0", "expInt=0") + @Iteration("-3/2<0", "lhsFrac=-3/2", "rhsInt=0", "expInt=-1") + @Iteration("-7/2<-3", "lhsFrac=-7/2", "rhsInt=-3", "expInt=-1") + @Iteration("-3/2>-5", "lhsFrac=-3/2", "rhsInt=-5", "expInt=1") + @Iteration("3/2>0", "lhsFrac=3/2", "rhsInt=0", "expInt=1") + @Iteration("7/2>3", "lhsFrac=7/2", "rhsInt=3", "expInt=1") + @Iteration("3/2<5", "lhsFrac=3/2", "rhsInt=5", "expInt=-1") + @Iteration("-3/2<3", "lhsFrac=-3/2", "rhsInt=3", "expInt=-1") + @Iteration("3/2>-3", "lhsFrac=3/2", "rhsInt=-3", "expInt=1") fun testComparator_fractionAndInt_returnsCorrectComparisonInt() { val lhsValue = createRationalReal(lhsFrac) val rhsValue = createIntegerReal(rhsInt) @@ -2436,16 +2305,14 @@ class RealExtensionsTest { } @Test - @RunParameterized( - Iteration("0==0", "lhsFrac=0", "rhsFrac=0", "expInt=0"), - Iteration("-3/2<0", "lhsFrac=-3/2", "rhsFrac=0", "expInt=-1"), - Iteration("-7/2<-3/2", "lhsFrac=-7/2", "rhsFrac=-3/2", "expInt=-1"), - Iteration("3/2>0", "lhsFrac=3/2", "rhsFrac=0", "expInt=1"), - Iteration("7/2>3/2", "lhsFrac=7/2", "rhsFrac=3/2", "expInt=1"), - Iteration("3/2<7/2", "lhsFrac=3/2", "rhsFrac=7/2", "expInt=-1"), - Iteration("-3/2<3/2", "lhsFrac=-3/2", "rhsFrac=3/2", "expInt=-1"), - Iteration("3/2>-3/2", "lhsFrac=3/2", "rhsFrac=-3/2", "expInt=1") - ) + @Iteration("0==0", "lhsFrac=0", "rhsFrac=0", "expInt=0") + @Iteration("-3/2<0", "lhsFrac=-3/2", "rhsFrac=0", "expInt=-1") + @Iteration("-7/2<-3/2", "lhsFrac=-7/2", "rhsFrac=-3/2", "expInt=-1") + @Iteration("3/2>0", "lhsFrac=3/2", "rhsFrac=0", "expInt=1") + @Iteration("7/2>3/2", "lhsFrac=7/2", "rhsFrac=3/2", "expInt=1") + @Iteration("3/2<7/2", "lhsFrac=3/2", "rhsFrac=7/2", "expInt=-1") + @Iteration("-3/2<3/2", "lhsFrac=-3/2", "rhsFrac=3/2", "expInt=-1") + @Iteration("3/2>-3/2", "lhsFrac=3/2", "rhsFrac=-3/2", "expInt=1") fun testComparator_fractionAndFraction_returnsCorrectComparisonInt() { val lhsValue = createRationalReal(lhsFrac) val rhsValue = createRationalReal(rhsFrac) @@ -2456,16 +2323,14 @@ class RealExtensionsTest { } @Test - @RunParameterized( - Iteration("0==0", "lhsFrac=0", "rhsDouble=0.0", "expInt=0"), - Iteration("-3/2<0", "lhsFrac=-3/2", "rhsDouble=0.0", "expInt=-1"), - Iteration("-7/2<-3.14", "lhsFrac=-7/2", "rhsDouble=-3.14", "expInt=-1"), - Iteration("3/2>0", "lhsFrac=3/2", "rhsDouble=0.0", "expInt=1"), - Iteration("7/2>3.14", "lhsFrac=7/2", "rhsDouble=3.14", "expInt=1"), - Iteration("3/2<3.14", "lhsFrac=3/2", "rhsDouble=3.14", "expInt=-1"), - Iteration("-3/2<3.14", "lhsFrac=-3/2", "rhsDouble=3.14", "expInt=-1"), - Iteration("3/2>-3.14", "lhsFrac=3/2", "rhsDouble=-3.14", "expInt=1") - ) + @Iteration("0==0", "lhsFrac=0", "rhsDouble=0.0", "expInt=0") + @Iteration("-3/2<0", "lhsFrac=-3/2", "rhsDouble=0.0", "expInt=-1") + @Iteration("-7/2<-3.14", "lhsFrac=-7/2", "rhsDouble=-3.14", "expInt=-1") + @Iteration("3/2>0", "lhsFrac=3/2", "rhsDouble=0.0", "expInt=1") + @Iteration("7/2>3.14", "lhsFrac=7/2", "rhsDouble=3.14", "expInt=1") + @Iteration("3/2<3.14", "lhsFrac=3/2", "rhsDouble=3.14", "expInt=-1") + @Iteration("-3/2<3.14", "lhsFrac=-3/2", "rhsDouble=3.14", "expInt=-1") + @Iteration("3/2>-3.14", "lhsFrac=3/2", "rhsDouble=-3.14", "expInt=1") fun testComparator_fractionAndDouble_returnsCorrectComparisonInt() { val lhsValue = createRationalReal(lhsFrac) val rhsValue = createIrrationalReal(rhsDouble) @@ -2476,16 +2341,14 @@ class RealExtensionsTest { } @Test - @RunParameterized( - Iteration("0==0", "lhsDouble=0.0", "rhsInt=0", "expInt=0"), - Iteration("-3.14<0", "lhsDouble=-3.14", "rhsInt=0", "expInt=-1"), - Iteration("-6.28<-4", "lhsDouble=-6.28", "rhsInt=-4", "expInt=-1"), - Iteration("3.14>0", "lhsDouble=3.14", "rhsInt=0", "expInt=1"), - Iteration("6.28>4", "lhsDouble=6.28", "rhsInt=4", "expInt=1"), - Iteration("3.14<4", "lhsDouble=3.14", "rhsInt=4", "expInt=-1"), - Iteration("-3.14<4", "lhsDouble=-3.14", "rhsInt=4", "expInt=-1"), - Iteration("3.14>-4", "lhsDouble=3.14", "rhsInt=-4", "expInt=1") - ) + @Iteration("0==0", "lhsDouble=0.0", "rhsInt=0", "expInt=0") + @Iteration("-3.14<0", "lhsDouble=-3.14", "rhsInt=0", "expInt=-1") + @Iteration("-6.28<-4", "lhsDouble=-6.28", "rhsInt=-4", "expInt=-1") + @Iteration("3.14>0", "lhsDouble=3.14", "rhsInt=0", "expInt=1") + @Iteration("6.28>4", "lhsDouble=6.28", "rhsInt=4", "expInt=1") + @Iteration("3.14<4", "lhsDouble=3.14", "rhsInt=4", "expInt=-1") + @Iteration("-3.14<4", "lhsDouble=-3.14", "rhsInt=4", "expInt=-1") + @Iteration("3.14>-4", "lhsDouble=3.14", "rhsInt=-4", "expInt=1") fun testComparator_doubleAndInt_returnsCorrectComparisonInt() { val lhsValue = createIrrationalReal(lhsDouble) val rhsValue = createIntegerReal(rhsInt) @@ -2496,16 +2359,14 @@ class RealExtensionsTest { } @Test - @RunParameterized( - Iteration("0==0", "lhsDouble=0.0", "rhsFrac=0", "expInt=0"), - Iteration("-3.14<0", "lhsDouble=-3.14", "rhsFrac=0", "expInt=-1"), - Iteration("-6.28<-7/2", "lhsDouble=-6.28", "rhsFrac=-7/2", "expInt=-1"), - Iteration("3.14>0", "lhsDouble=3.14", "rhsFrac=0", "expInt=1"), - Iteration("6.28>7/2", "lhsDouble=6.28", "rhsFrac=7/2", "expInt=1"), - Iteration("3.14<7/2", "lhsDouble=3.14", "rhsFrac=7/2", "expInt=-1"), - Iteration("-3.14<7/2", "lhsDouble=-3.14", "rhsFrac=7/2", "expInt=-1"), - Iteration("3.14>-7/2", "lhsDouble=3.14", "rhsFrac=-7/2", "expInt=1") - ) + @Iteration("0==0", "lhsDouble=0.0", "rhsFrac=0", "expInt=0") + @Iteration("-3.14<0", "lhsDouble=-3.14", "rhsFrac=0", "expInt=-1") + @Iteration("-6.28<-7/2", "lhsDouble=-6.28", "rhsFrac=-7/2", "expInt=-1") + @Iteration("3.14>0", "lhsDouble=3.14", "rhsFrac=0", "expInt=1") + @Iteration("6.28>7/2", "lhsDouble=6.28", "rhsFrac=7/2", "expInt=1") + @Iteration("3.14<7/2", "lhsDouble=3.14", "rhsFrac=7/2", "expInt=-1") + @Iteration("-3.14<7/2", "lhsDouble=-3.14", "rhsFrac=7/2", "expInt=-1") + @Iteration("3.14>-7/2", "lhsDouble=3.14", "rhsFrac=-7/2", "expInt=1") fun testComparator_doubleAndFraction_returnsCorrectComparisonInt() { val lhsValue = createIrrationalReal(lhsDouble) val rhsValue = createRationalReal(rhsFrac) @@ -2516,16 +2377,14 @@ class RealExtensionsTest { } @Test - @RunParameterized( - Iteration("0==0", "lhsDouble=0.0", "rhsDouble=0.0", "expInt=0"), - Iteration("-3.14<0", "lhsDouble=-3.14", "rhsDouble=0.0", "expInt=-1"), - Iteration("-6.28<-3.14", "lhsDouble=-6.28", "rhsDouble=-3.14", "expInt=-1"), - Iteration("3.14>0", "lhsDouble=3.14", "rhsDouble=0.0", "expInt=1"), - Iteration("6.28>3.14", "lhsDouble=6.28", "rhsDouble=3.14", "expInt=1"), - Iteration("3.14<6.28", "lhsDouble=3.14", "rhsDouble=6.28", "expInt=-1"), - Iteration("-3.14<6.28", "lhsDouble=-3.14", "rhsDouble=6.28", "expInt=-1"), - Iteration("3.14>-6.28", "lhsDouble=3.14", "rhsDouble=-6.28", "expInt=1") - ) + @Iteration("0==0", "lhsDouble=0.0", "rhsDouble=0.0", "expInt=0") + @Iteration("-3.14<0", "lhsDouble=-3.14", "rhsDouble=0.0", "expInt=-1") + @Iteration("-6.28<-3.14", "lhsDouble=-6.28", "rhsDouble=-3.14", "expInt=-1") + @Iteration("3.14>0", "lhsDouble=3.14", "rhsDouble=0.0", "expInt=1") + @Iteration("6.28>3.14", "lhsDouble=6.28", "rhsDouble=3.14", "expInt=1") + @Iteration("3.14<6.28", "lhsDouble=3.14", "rhsDouble=6.28", "expInt=-1") + @Iteration("-3.14<6.28", "lhsDouble=-3.14", "rhsDouble=6.28", "expInt=-1") + @Iteration("3.14>-6.28", "lhsDouble=3.14", "rhsDouble=-6.28", "expInt=1") fun testComparator_doubleAndDouble_returnsCorrectComparisonInt() { val lhsValue = createIrrationalReal(lhsDouble) val rhsValue = createIrrationalReal(rhsDouble) diff --git a/utility/src/test/java/org/oppia/android/util/profile/ProfileNameValidatorTest.kt b/utility/src/test/java/org/oppia/android/util/profile/ProfileNameValidatorTest.kt index 7dbbceee779..2875834c868 100644 --- a/utility/src/test/java/org/oppia/android/util/profile/ProfileNameValidatorTest.kt +++ b/utility/src/test/java/org/oppia/android/util/profile/ProfileNameValidatorTest.kt @@ -11,7 +11,6 @@ import org.junit.runner.RunWith import org.oppia.android.testing.junit.OppiaParameterizedTestRunner import org.oppia.android.testing.junit.OppiaParameterizedTestRunner.Iteration import org.oppia.android.testing.junit.OppiaParameterizedTestRunner.Parameter -import org.oppia.android.testing.junit.OppiaParameterizedTestRunner.RunParameterized import org.oppia.android.testing.junit.OppiaParameterizedTestRunner.SelectRunnerPlatform import org.oppia.android.testing.junit.ParameterizedRobolectricTestRunner import org.oppia.android.testing.robolectric.RobolectricModule @@ -50,32 +49,26 @@ class ProfileNameValidatorTest { } @Test - @RunParameterized( - Iteration("Ben#Henning", "name=Ben#Henning"), - Iteration("Rajay@T", "name=Rajay@T"), - Iteration("جيشنو^&&", "name=جيشنو^&&"), - Iteration("_Jishnu", "name=_Jishnu") - ) + @Iteration("Ben#Henning", "name=Ben#Henning") + @Iteration("Rajay@T", "name=Rajay@T") + @Iteration("جيشنو^&&", "name=جيشنو^&&") + @Iteration("_Jishnu", "name=_Jishnu") fun testIsNameValid_nameWithDisallowedSymbol_returnsFalse() { assertThat(profileNameValidator.isNameValid(name)).isFalse() } @Test - @RunParameterized( - Iteration("Ben-Henning", "name=Ben-Henning"), - Iteration("Rajat.T", "name=Rajat.T"), - Iteration("G'Jishnu", "name=G'Jishnu") - ) + @Iteration("Ben-Henning", "name=Ben-Henning") + @Iteration("Rajat.T", "name=Rajat.T") + @Iteration("G'Jishnu", "name=G'Jishnu") fun testIsNameValid_nameWithAllowedSymbols_returnsTrue() { assertThat(profileNameValidator.isNameValid(name)).isTrue() } @Test - @RunParameterized( - Iteration("Ben-.Henning", "name=Ben-.Henning"), - Iteration("Rajat..T", "name=Rajat..T"), - Iteration("Name WithTooManySpaces", "name=Name WithTooManySpaces") - ) + @Iteration("Ben-.Henning", "name=Ben-.Henning") + @Iteration("Rajat..T", "name=Rajat..T") + @Iteration("Name WithTooManySpaces", "name=Name WithTooManySpaces") fun testIsNameValid_nameWithRepeatedAllowedSymbols_returnsFalse() { assertThat(profileNameValidator.isNameValid(name)).isFalse() }