aboutsummaryrefslogtreecommitdiff
path: root/tests
diff options
context:
space:
mode:
authorBruce Wells <brucekwells@gmail.com>2022-04-27 00:31:50 +0300
committerGitHub <noreply@github.com>2022-04-27 00:31:50 +0300
commitb7b46bfc476ea0d22e0e92144f68aa81d390fff0 (patch)
treeb89329b67b35a90a59373acfd25f2774b82008a6 /tests
parentc396a882ffa5f7467947a6a19c2435a7b4cbad22 (diff)
Phpcs fixer (#103)
* Configuring PHP CS Fixer Dropping PHP 7,3 support * Fixing merge issue
Diffstat (limited to 'tests')
-rw-r--r--tests/MathTest.php648
-rw-r--r--tests/bootstrap.php6
2 files changed, 328 insertions, 326 deletions
diff --git a/tests/MathTest.php b/tests/MathTest.php
index 07b94fa..9567dd2 100644
--- a/tests/MathTest.php
+++ b/tests/MathTest.php
@@ -26,18 +26,19 @@ class MathTest extends TestCase
/**
* @dataProvider providerExpressions
*/
- public function testCalculating($expression)
+ public function testCalculating($expression) : void
{
$calculator = new MathExecutor();
/** @var float $phpResult */
eval('$phpResult = ' . $expression . ';');
+
try {
$result = $calculator->execute($expression);
} catch (Exception $e) {
- $this->fail(sprintf("Exception: %s (%s:%d), expression was: %s", get_class($e), $e->getFile(), $e->getLine(), $expression));
+ $this->fail(\sprintf('Exception: %s (%s:%d), expression was: %s', \get_class($e), $e->getFile(), $e->getLine(), $expression));
}
- $this->assertEquals($phpResult, $result, "Expression was: ${expression}");
+ $this->assertEquals($phpResult, $result, "Expression was: {$expression}");
}
/**
@@ -50,223 +51,223 @@ class MathTest extends TestCase
public function providerExpressions()
{
return [
- ['-5'],
- ['-5+10'],
- ['4-5'],
- ['4 -5'],
- ['(4*2)-5'],
- ['(4*2) - 5'],
- ['4*-5'],
- ['4 * -5'],
- ['+5'],
- ['+(3+2)'],
- ['+(+3+2)'],
- ['+(-3+2)'],
- ['-5'],
- ['-(-5)'],
- ['-(+5)'],
- ['+(-5)'],
- ['+(+5)'],
- ['-(3+2)'],
- ['-(-3+-2)'],
-
- ['abs(1.5)'],
- ['acos(0.15)'],
- ['acosh(1.5)'],
- ['asin(0.15)'],
- ['atan(0.15)'],
- ['atan2(1.5, 3.5)'],
- ['atanh(0.15)'],
- ['bindec("10101")'],
- ['ceil(1.5)'],
- ['cos(1.5)'],
- ['cosh(1.5)'],
- ['decbin("15")'],
- ['dechex("15")'],
- ['decoct("15")'],
- ['deg2rad(1.5)'],
- ['exp(1.5)'],
- ['expm1(1.5)'],
- ['floor(1.5)'],
- ['fmod(1.5, 3.5)'],
- ['hexdec("abcdef")'],
- ['hypot(1.5, 3.5)'],
- ['intdiv(10, 2)'],
- ['log(1.5)'],
- ['log10(1.5)'],
- ['log1p(1.5)'],
- ['max(1.5, 3.5)'],
- ['min(1.5, 3.5)'],
- ['octdec("15")'],
- ['pi()'],
- ['pow(1.5, 3.5)'],
- ['rad2deg(1.5)'],
- ['round(1.5)'],
- ['sin(1.5)'],
- ['sin(12)'],
- ['+sin(12)'],
- ['-sin(12)'],
- ['sinh(1.5)'],
- ['sqrt(1.5)'],
- ['tan(1.5)'],
- ['tanh(1.5)'],
-
- ['0.1 + 0.2'],
- ['1 + 2'],
-
- ['0.1 - 0.2'],
- ['1 - 2'],
-
- ['0.1 * 2'],
- ['1 * 2'],
-
- ['0.1 / 0.2'],
- ['1 / 2'],
-
- ['2 * 2 + 3 * 3'],
- ['2 * 2 / 3 * 3'],
- ['2 / 2 / 3 / 3'],
- ['2 / 2 * 3 / 3'],
- ['2 / 2 * 3 * 3'],
-
- ['1 + 0.6 - 3 * 2 / 50'],
-
- ['(5 + 3) * -1'],
-
- ['-2- 2*2'],
- ['2- 2*2'],
- ['2-(2*2)'],
- ['(2- 2)*2'],
- ['2 + 2*2'],
- ['2+ 2*2'],
- ['2+2*2'],
- ['(2+2)*2'],
- ['(2 + 2)*-2'],
- ['(2+-2)*2'],
-
- ['1 + 2 * 3 / (min(1, 5) + 2 + 1)'],
- ['1 + 2 * 3 / (min(1, 5) - 2 + 5)'],
- ['1 + 2 * 3 / (min(1, 5) * 2 + 1)'],
- ['1 + 2 * 3 / (min(1, 5) / 2 + 1)'],
- ['1 + 2 * 3 / (min(1, 5) / 2 * 1)'],
- ['1 + 2 * 3 / (min(1, 5) / 2 / 1)'],
- ['1 + 2 * 3 / (3 + min(1, 5) + 2 + 1)'],
- ['1 + 2 * 3 / (3 - min(1, 5) - 2 + 1)'],
- ['1 + 2 * 3 / (3 * min(1, 5) * 2 + 1)'],
- ['1 + 2 * 3 / (3 / min(1, 5) / 2 + 1)'],
-
- ['(1 + 2) * 3 / (3 / min(1, 5) / 2 + 1)'],
-
- ['sin(10) * cos(50) / min(10, 20/2)'],
- ['sin(10) * cos(50) / min(10, (20/2))'],
- ['sin(10) * cos(50) / min(10, (max(10,20)/2))'],
-
- ['100500 * 3.5e5'],
- ['100500 * 3.5e-5'],
- ['100500 * 3.5E5'],
- ['100500 * 3.5E-5'],
-
- ['1 + "2" / 3'],
- ["1.5 + '2.5' / 4"],
- ['1.5 + "2.5" * ".5"'],
-
- ['-1 + -2'],
- ['-1+-2'],
- ['-1- -2'],
- ['-1/-2'],
- ['-1*-2'],
-
- ['(1+2+3+4-5)*7/100'],
- ['(-1+2+3+4- 5)*7/100'],
- ['(1+2+3+4- 5)*7/100'],
- ['( 1 + 2 + 3 + 4 - 5 ) * 7 / 100'],
-
- ['1 && 0'],
- ['1 && 0 && 1'],
- ['1 || 0'],
- ['1 && 0 || 1'],
-
- ['5 == 3'],
- ['5 == 5'],
- ['5 != 3'],
- ['5 != 5'],
- ['5 > 3'],
- ['3 > 5'],
- ['3 >= 5'],
- ['3 >= 3'],
- ['3 < 5'],
- ['5 < 3'],
- ['3 <= 5'],
- ['5 <= 5'],
- ['10 < 9 || 4 > (2+1)'],
- ['10 < 9 || 4 > (-2+1)'],
- ['10 < 9 || 4 > (2+1) && 5 == 5 || 4 != 6 || 3 >= 4 || 3 <= 7'],
-
- ['1 + 5 == 3 + 1'],
- ['1 + 5 == 5 + 1'],
- ['1 + 5 != 3 + 1'],
- ['1 + 5 != 5 + 1'],
- ['1 + 5 > 3 + 1'],
- ['1 + 3 > 5 + 1'],
- ['1 + 3 >= 5 + 1'],
- ['1 + 3 >= 3 + 1'],
- ['1 + 3 < 5 + 1'],
- ['1 + 5 < 3 + 1'],
- ['1 + 3 <= 5 + 1'],
- ['1 + 5 <= 5 + 1'],
-
- ['(-4)'],
- ['(-4 + 5)'],
- ['(3 * 1)'],
- ['(-3 * -1)'],
- ['1 + (-3 * -1)'],
- ['1 + ( -3 * 1)'],
- ['1 + (3 *-1)'],
- ['1 - 0'],
- ['1-0'],
-
- ['-(1.5)'],
- ['-log(4)'],
- ['0-acosh(1.5)'],
- ['-acosh(1.5)'],
- ['-(-4)'],
- ['-(-4 + 5)'],
- ['-(3 * 1)'],
- ['-(-3 * -1)'],
- ['-1 + (-3 * -1)'],
- ['-1 + ( -3 * 1)'],
- ['-1 + (3 *-1)'],
- ['-1 - 0'],
- ['-1-0'],
- ['-(4*2)-5'],
- ['-(4*-2)-5'],
- ['-(-4*2) - 5'],
- ['-4*-5'],
+ ['-5'],
+ ['-5+10'],
+ ['4-5'],
+ ['4 -5'],
+ ['(4*2)-5'],
+ ['(4*2) - 5'],
+ ['4*-5'],
+ ['4 * -5'],
+ ['+5'],
+ ['+(3+2)'],
+ ['+(+3+2)'],
+ ['+(-3+2)'],
+ ['-5'],
+ ['-(-5)'],
+ ['-(+5)'],
+ ['+(-5)'],
+ ['+(+5)'],
+ ['-(3+2)'],
+ ['-(-3+-2)'],
+
+ ['abs(1.5)'],
+ ['acos(0.15)'],
+ ['acosh(1.5)'],
+ ['asin(0.15)'],
+ ['atan(0.15)'],
+ ['atan2(1.5, 3.5)'],
+ ['atanh(0.15)'],
+ ['bindec("10101")'],
+ ['ceil(1.5)'],
+ ['cos(1.5)'],
+ ['cosh(1.5)'],
+ ['decbin("15")'],
+ ['dechex("15")'],
+ ['decoct("15")'],
+ ['deg2rad(1.5)'],
+ ['exp(1.5)'],
+ ['expm1(1.5)'],
+ ['floor(1.5)'],
+ ['fmod(1.5, 3.5)'],
+ ['hexdec("abcdef")'],
+ ['hypot(1.5, 3.5)'],
+ ['intdiv(10, 2)'],
+ ['log(1.5)'],
+ ['log10(1.5)'],
+ ['log1p(1.5)'],
+ ['max(1.5, 3.5)'],
+ ['min(1.5, 3.5)'],
+ ['octdec("15")'],
+ ['pi()'],
+ ['pow(1.5, 3.5)'],
+ ['rad2deg(1.5)'],
+ ['round(1.5)'],
+ ['sin(1.5)'],
+ ['sin(12)'],
+ ['+sin(12)'],
+ ['-sin(12)'],
+ ['sinh(1.5)'],
+ ['sqrt(1.5)'],
+ ['tan(1.5)'],
+ ['tanh(1.5)'],
+
+ ['0.1 + 0.2'],
+ ['1 + 2'],
+
+ ['0.1 - 0.2'],
+ ['1 - 2'],
+
+ ['0.1 * 2'],
+ ['1 * 2'],
+
+ ['0.1 / 0.2'],
+ ['1 / 2'],
+
+ ['2 * 2 + 3 * 3'],
+ ['2 * 2 / 3 * 3'],
+ ['2 / 2 / 3 / 3'],
+ ['2 / 2 * 3 / 3'],
+ ['2 / 2 * 3 * 3'],
+
+ ['1 + 0.6 - 3 * 2 / 50'],
+
+ ['(5 + 3) * -1'],
+
+ ['-2- 2*2'],
+ ['2- 2*2'],
+ ['2-(2*2)'],
+ ['(2- 2)*2'],
+ ['2 + 2*2'],
+ ['2+ 2*2'],
+ ['2+2*2'],
+ ['(2+2)*2'],
+ ['(2 + 2)*-2'],
+ ['(2+-2)*2'],
+
+ ['1 + 2 * 3 / (min(1, 5) + 2 + 1)'],
+ ['1 + 2 * 3 / (min(1, 5) - 2 + 5)'],
+ ['1 + 2 * 3 / (min(1, 5) * 2 + 1)'],
+ ['1 + 2 * 3 / (min(1, 5) / 2 + 1)'],
+ ['1 + 2 * 3 / (min(1, 5) / 2 * 1)'],
+ ['1 + 2 * 3 / (min(1, 5) / 2 / 1)'],
+ ['1 + 2 * 3 / (3 + min(1, 5) + 2 + 1)'],
+ ['1 + 2 * 3 / (3 - min(1, 5) - 2 + 1)'],
+ ['1 + 2 * 3 / (3 * min(1, 5) * 2 + 1)'],
+ ['1 + 2 * 3 / (3 / min(1, 5) / 2 + 1)'],
+
+ ['(1 + 2) * 3 / (3 / min(1, 5) / 2 + 1)'],
+
+ ['sin(10) * cos(50) / min(10, 20/2)'],
+ ['sin(10) * cos(50) / min(10, (20/2))'],
+ ['sin(10) * cos(50) / min(10, (max(10,20)/2))'],
+
+ ['100500 * 3.5e5'],
+ ['100500 * 3.5e-5'],
+ ['100500 * 3.5E5'],
+ ['100500 * 3.5E-5'],
+
+ ['1 + "2" / 3'],
+ ["1.5 + '2.5' / 4"],
+ ['1.5 + "2.5" * ".5"'],
+
+ ['-1 + -2'],
+ ['-1+-2'],
+ ['-1- -2'],
+ ['-1/-2'],
+ ['-1*-2'],
+
+ ['(1+2+3+4-5)*7/100'],
+ ['(-1+2+3+4- 5)*7/100'],
+ ['(1+2+3+4- 5)*7/100'],
+ ['( 1 + 2 + 3 + 4 - 5 ) * 7 / 100'],
+
+ ['1 && 0'],
+ ['1 && 0 && 1'],
+ ['1 || 0'],
+ ['1 && 0 || 1'],
+
+ ['5 == 3'],
+ ['5 == 5'],
+ ['5 != 3'],
+ ['5 != 5'],
+ ['5 > 3'],
+ ['3 > 5'],
+ ['3 >= 5'],
+ ['3 >= 3'],
+ ['3 < 5'],
+ ['5 < 3'],
+ ['3 <= 5'],
+ ['5 <= 5'],
+ ['10 < 9 || 4 > (2+1)'],
+ ['10 < 9 || 4 > (-2+1)'],
+ ['10 < 9 || 4 > (2+1) && 5 == 5 || 4 != 6 || 3 >= 4 || 3 <= 7'],
+
+ ['1 + 5 == 3 + 1'],
+ ['1 + 5 == 5 + 1'],
+ ['1 + 5 != 3 + 1'],
+ ['1 + 5 != 5 + 1'],
+ ['1 + 5 > 3 + 1'],
+ ['1 + 3 > 5 + 1'],
+ ['1 + 3 >= 5 + 1'],
+ ['1 + 3 >= 3 + 1'],
+ ['1 + 3 < 5 + 1'],
+ ['1 + 5 < 3 + 1'],
+ ['1 + 3 <= 5 + 1'],
+ ['1 + 5 <= 5 + 1'],
+
+ ['(-4)'],
+ ['(-4 + 5)'],
+ ['(3 * 1)'],
+ ['(-3 * -1)'],
+ ['1 + (-3 * -1)'],
+ ['1 + ( -3 * 1)'],
+ ['1 + (3 *-1)'],
+ ['1 - 0'],
+ ['1-0'],
+
+ ['-(1.5)'],
+ ['-log(4)'],
+ ['0-acosh(1.5)'],
+ ['-acosh(1.5)'],
+ ['-(-4)'],
+ ['-(-4 + 5)'],
+ ['-(3 * 1)'],
+ ['-(-3 * -1)'],
+ ['-1 + (-3 * -1)'],
+ ['-1 + ( -3 * 1)'],
+ ['-1 + (3 *-1)'],
+ ['-1 - 0'],
+ ['-1-0'],
+ ['-(4*2)-5'],
+ ['-(4*-2)-5'],
+ ['-(-4*2) - 5'],
+ ['-4*-5'],
];
}
- public function testUnknownFunctionException()
+ public function testUnknownFunctionException() : void
{
$calculator = new MathExecutor();
$this->expectException(UnknownFunctionException::class);
$calculator->execute('1 * fred("wilma") + 3');
}
- public function testIncorrectExpressionException()
+ public function testIncorrectExpressionException() : void
{
$calculator = new MathExecutor();
$this->expectException(IncorrectExpressionException::class);
$calculator->execute('1 * + ');
}
- public function testZeroDivision()
+ public function testZeroDivision() : void
{
$calculator = new MathExecutor();
$calculator->setDivisionByZeroIsZero();
$this->assertEquals(0, $calculator->execute('10 / 0'));
}
- public function testUnaryOperators()
+ public function testUnaryOperators() : void
{
$calculator = new MathExecutor();
$this->assertEquals(5, $calculator->execute('+5'));
@@ -277,7 +278,7 @@ class MathTest extends TestCase
$this->assertEquals(-5, $calculator->execute('-(3+2)'));
}
- public function testZeroDivisionException()
+ public function testZeroDivisionException() : void
{
$calculator = new MathExecutor();
$this->expectException(DivisionByZeroException::class);
@@ -286,7 +287,7 @@ class MathTest extends TestCase
$this->assertEquals(0.0, $calculator->execute('$one / $zero'));
}
- public function testVariableIncorrectExpressionException()
+ public function testVariableIncorrectExpressionException() : void
{
$calculator = new MathExecutor();
$calculator->setVar('four', 4);
@@ -296,85 +297,85 @@ class MathTest extends TestCase
$this->assertEquals(0.0, $calculator->execute('$ + $four'));
}
- public function testExponentiation()
+ public function testExponentiation() : void
{
$calculator = new MathExecutor();
$this->assertEquals(100, $calculator->execute('10 ^ 2'));
}
- public function testFunctionParameterOrder()
+ public function testFunctionParameterOrder() : void
{
$calculator = new MathExecutor();
- $calculator->addFunction('concat', function ($arg1, $arg2) {
+ $calculator->addFunction('concat', static function($arg1, $arg2) {
return $arg1 . $arg2;
});
$this->assertEquals('testing', $calculator->execute('concat("test","ing")'));
$this->assertEquals('testing', $calculator->execute("concat('test','ing')"));
}
- public function testFunction()
+ public function testFunction() : void
{
$calculator = new MathExecutor();
- $calculator->addFunction('round', function ($arg) {
- return round($arg);
+ $calculator->addFunction('round', static function($arg) {
+ return \round($arg);
});
- $this->assertEquals(round(100 / 30), $calculator->execute('round(100/30)'));
+ $this->assertEquals(\round(100 / 30), $calculator->execute('round(100/30)'));
}
- public function testFunctionIf()
+ public function testFunctionIf() : void
{
$calculator = new MathExecutor();
$this->assertEquals(30, $calculator->execute(
- 'if(100 > 99, 30, 0)'
+ 'if(100 > 99, 30, 0)'
));
$this->assertEquals(0, $calculator->execute(
- 'if(100 < 99, 30, 0)'
+ 'if(100 < 99, 30, 0)'
));
$this->assertEquals(30, $calculator->execute(
- 'if(98 < 99 && sin(1) < 1, 30, 0)'
+ 'if(98 < 99 && sin(1) < 1, 30, 0)'
));
$this->assertEquals(40, $calculator->execute(
- 'if(98 < 99 && sin(1) < 1, max(30, 40), 0)'
+ 'if(98 < 99 && sin(1) < 1, max(30, 40), 0)'
));
$this->assertEquals(40, $calculator->execute(
- 'if(98 < 99 && sin(1) < 1, if(10 > 5, max(30, 40), 1), 0)'
+ 'if(98 < 99 && sin(1) < 1, if(10 > 5, max(30, 40), 1), 0)'
));
$this->assertEquals(20, $calculator->execute(
- 'if(98 < 99 && sin(1) > 1, if(10 > 5, max(30, 40), 1), if(4 <= 4, 20, 21))'
+ 'if(98 < 99 && sin(1) > 1, if(10 > 5, max(30, 40), 1), if(4 <= 4, 20, 21))'
));
- $this->assertEquals(cos(2), $calculator->execute(
- 'if(98 < 99 && sin(1) >= 1, max(30, 40), cos(2))'
+ $this->assertEquals(\cos(2), $calculator->execute(
+ 'if(98 < 99 && sin(1) >= 1, max(30, 40), cos(2))'
));
- $this->assertEquals(cos(2), $calculator->execute(
- 'if(cos(2), cos(2), 0)'
+ $this->assertEquals(\cos(2), $calculator->execute(
+ 'if(cos(2), cos(2), 0)'
));
$trx_amount = 100000;
$calculator->setVar('trx_amount', $trx_amount);
$this->assertEquals($trx_amount, $calculator->execute('$trx_amount'));
$this->assertEquals($trx_amount * 0.03, $calculator->execute(
- 'if($trx_amount < 40000, $trx_amount * 0.06, $trx_amount * 0.03)'
+ 'if($trx_amount < 40000, $trx_amount * 0.06, $trx_amount * 0.03)'
));
$this->assertEquals($trx_amount * 0.03, $calculator->execute(
- 'if($trx_amount < 40000, $trx_amount * 0.06, if($trx_amount < 60000, $trx_amount * 0.05, $trx_amount * 0.03))'
+ 'if($trx_amount < 40000, $trx_amount * 0.06, if($trx_amount < 60000, $trx_amount * 0.05, $trx_amount * 0.03))'
));
$trx_amount = 39000;
$calculator->setVar('trx_amount', $trx_amount);
$this->assertEquals($trx_amount * 0.06, $calculator->execute(
- 'if($trx_amount < 40000, $trx_amount * 0.06, if($trx_amount < 60000, $trx_amount * 0.05, $trx_amount * 0.03))'
+ 'if($trx_amount < 40000, $trx_amount * 0.06, if($trx_amount < 60000, $trx_amount * 0.05, $trx_amount * 0.03))'
));
$trx_amount = 59000;
$calculator->setVar('trx_amount', $trx_amount);
$this->assertEquals($trx_amount * 0.05, $calculator->execute(
- 'if($trx_amount < 40000, $trx_amount * 0.06, if($trx_amount < 60000, $trx_amount * 0.05, $trx_amount * 0.03))'
+ 'if($trx_amount < 40000, $trx_amount * 0.06, if($trx_amount < 60000, $trx_amount * 0.05, $trx_amount * 0.03))'
));
$this->expectException(IncorrectNumberOfFunctionParametersException::class);
$this->assertEquals(0.0, $calculator->execute(
- 'if($trx_amount < 40000, $trx_amount * 0.06)'
+ 'if($trx_amount < 40000, $trx_amount * 0.06)'
));
}
- public function testVariables()
+ public function testVariables() : void
{
$calculator = new MathExecutor();
$this->assertEquals(3.14159265359, $calculator->execute('$pi'));
@@ -382,19 +383,19 @@ class MathTest extends TestCase
$this->assertEquals(2.71828182846, $calculator->execute('$e'));
$this->assertEquals(2.71828182846, $calculator->execute('e'));
$calculator->setVars([
- 'trx_amount' => 100000.01,
- 'ten' => 10,
- 'nine' => 9,
- 'eight' => 8,
- 'seven' => 7,
- 'six' => 6,
- 'five' => 5,
- 'four' => 4,
- 'three' => 3,
- 'two' => 2,
- 'one' => 1,
- 'zero' => 0,
- ]);
+ 'trx_amount' => 100000.01,
+ 'ten' => 10,
+ 'nine' => 9,
+ 'eight' => 8,
+ 'seven' => 7,
+ 'six' => 6,
+ 'five' => 5,
+ 'four' => 4,
+ 'three' => 3,
+ 'two' => 2,
+ 'one' => 1,
+ 'zero' => 0,
+ ]);
$this->assertEquals(100000.01, $calculator->execute('$trx_amount'));
$this->assertEquals(10 - 9, $calculator->execute('$ten - $nine'));
$this->assertEquals(9 - 10, $calculator->execute('$nine - $ten'));
@@ -413,13 +414,13 @@ class MathTest extends TestCase
$this->assertEquals(10 / (9 / 5), $calculator->execute('ten / (nine / five)'));
}
- public function testEvaluateFunctionParameters()
+ public function testEvaluateFunctionParameters() : void
{
$calculator = new MathExecutor();
$calculator->addFunction(
- 'round',
- function ($value, $decimals) {
- return round($value, $decimals);
+ 'round',
+ static function($value, $decimals) {
+ return \round($value, $decimals);
}
);
$expression = 'round(100 * 1.111111, 2)';
@@ -431,24 +432,25 @@ class MathTest extends TestCase
$this->assertEquals($phpResult, $calculator->execute($expression));
}
- public function testFunctionsWithQuotes()
+ public function testFunctionsWithQuotes() : void
{
$calculator = new MathExecutor();
- $calculator->addFunction('concat', function ($first, $second) {
+ $calculator->addFunction('concat', static function($first, $second) {
return $first . $second;
});
$this->assertEquals('testing', $calculator->execute('concat("test", "ing")'));
$this->assertEquals('testing', $calculator->execute("concat('test', 'ing')"));
}
- public function testQuotes()
+ public function testQuotes() : void
{
$calculator = new MathExecutor();
- $testString = "some, long. arg; with: different-separators!";
+ $testString = 'some, long. arg; with: different-separators!';
$calculator->addFunction(
- 'test',
- function ($arg) use ($testString) {
+ 'test',
+ function($arg) use ($testString) {
$this->assertEquals($testString, $arg);
+
return 0;
}
);
@@ -456,14 +458,14 @@ class MathTest extends TestCase
$calculator->execute("test('" . $testString . "')"); // double quotes
}
- public function testBeginWithBracketAndMinus()
+ public function testBeginWithBracketAndMinus() : void
{
$calculator = new MathExecutor();
$this->assertEquals(-4, $calculator->execute('(-4)'));
$this->assertEquals(1, $calculator->execute('(-4 + 5)'));
}
- public function testStringComparison()
+ public function testStringComparison() : void
{
$calculator = new MathExecutor();
$this->assertEquals(true, $calculator->execute('"a" == \'a\''));
@@ -477,7 +479,7 @@ class MathTest extends TestCase
$this->assertEquals(true, $calculator->execute('"A" != "a"'));
}
- public function testVarStringComparison()
+ public function testVarStringComparison() : void
{
$calculator = new MathExecutor();
$calculator->setVar('var', 97);
@@ -487,15 +489,15 @@ class MathTest extends TestCase
$this->assertEquals(true, $calculator->execute('$var == "a"'));
}
- public function testOnVarNotFound()
+ public function testOnVarNotFound() : void
{
$calculator = new MathExecutor();
$calculator->setVarNotFoundHandler(
- function ($varName) {
- if ($varName == 'undefined') {
+ static function($varName) {
+ if ('undefined' == $varName) {
return 3;
}
- return null;
+
}
);
$this->assertEquals(15, $calculator->execute('5 * undefined'));
@@ -503,21 +505,21 @@ class MathTest extends TestCase
$this->assertNull($calculator->getVar('Lucy'));
}
- public function testGetVarException()
+ public function testGetVarException() : void
{
$calculator = new MathExecutor();
$this->expectException(UnknownVariableException::class);
$this->assertNull($calculator->getVar('Lucy'));
}
- public function testMinusZero()
+ public function testMinusZero() : void
{
$calculator = new MathExecutor();
$this->assertEquals(1, $calculator->execute('1 - 0'));
$this->assertEquals(1, $calculator->execute('1-0'));
}
- public function testScientificNotation()
+ public function testScientificNotation() : void
{
$calculator = new MathExecutor();
$this->assertEquals(1.5e9, $calculator->execute('1.5e9'));
@@ -525,39 +527,39 @@ class MathTest extends TestCase
$this->assertEquals(1.5e+9, $calculator->execute('1.5e+9'));
}
- public function testGetFunctionsReturnsArray()
+ public function testGetFunctionsReturnsArray() : void
{
$calculator = new MathExecutor();
$this->assertIsArray($calculator->getFunctions());
}
- public function testGetFunctionsReturnsFunctions()
+ public function testGetFunctionsReturnsFunctions() : void
{
$calculator = new MathExecutor();
- $this->assertGreaterThan(40, count($calculator->getFunctions()));
+ $this->assertGreaterThan(40, \count($calculator->getFunctions()));
}
- public function testGetVarsReturnsArray()
+ public function testGetVarsReturnsArray() : void
{
$calculator = new MathExecutor();
$this->assertIsArray($calculator->getVars());
}
- public function testGetVarsReturnsCount()
+ public function testGetVarsReturnsCount() : void
{
$calculator = new MathExecutor();
- $this->assertGreaterThan(1, count($calculator->getVars()));
+ $this->assertGreaterThan(1, \count($calculator->getVars()));
}
- public function testUndefinedVarThrowsExecption()
+ public function testUndefinedVarThrowsExecption() : void
{
$calculator = new MathExecutor();
- $this->assertGreaterThan(1, count($calculator->getVars()));
+ $this->assertGreaterThan(1, \count($calculator->getVars()));
$this->expectException(UnknownVariableException::class);
$calculator->execute('5 * undefined');
}
- public function testSetVarsAcceptsAllScalars()
+ public function testSetVarsAcceptsAllScalars() : void
{
$calculator = new MathExecutor();
$calculator->setVar('boolTrue', true);
@@ -566,7 +568,7 @@ class MathTest extends TestCase
$calculator->setVar('null', null);
$calculator->setVar('float', 1.1);
$calculator->setVar('string', 'string');
- $this->assertEquals(8, count($calculator->getVars()));
+ $this->assertEquals(8, \count($calculator->getVars()));
$this->assertEquals(true, $calculator->getVar('boolTrue'));
$this->assertEquals(false, $calculator->getVar('boolFalse'));
$this->assertEquals(1, $calculator->getVar('int'));
@@ -578,31 +580,31 @@ class MathTest extends TestCase
$calculator->setVar('validVar', new \DateTime());
}
- public function testSetVarsDoesNotAcceptObject()
+ public function testSetVarsDoesNotAcceptObject() : void
{
$calculator = new MathExecutor();
$this->expectException(MathExecutorException::class);
$calculator->setVar('object', $this);
}
- public function testSetVarsDoesNotAcceptResource()
+ public function testSetVarsDoesNotAcceptResource() : void
{
$calculator = new MathExecutor();
$this->expectException(MathExecutorException::class);
- $calculator->setVar('resource', tmpfile());
+ $calculator->setVar('resource', \tmpfile());
}
- public function testSetCustomVarValidator()
+ public function testSetCustomVarValidator() : void
{
$calculator = new MathExecutor();
- $calculator->setVarValidationHandler(function (string $name, $variable) {
+ $calculator->setVarValidationHandler(static function(string $name, $variable) : void {
// allow all scalars and null
- if (is_scalar($variable) || $variable === null) {
+ if (\is_scalar($variable) || null === $variable) {
return;
}
// Allow variables of type DateTime, but not others
if (! $variable instanceof \DateTime) {
- throw new MathExecutorException("Invalid variable type");
+ throw new MathExecutorException('Invalid variable type');
}
});
@@ -618,13 +620,13 @@ class MathTest extends TestCase
$calculator->setVar('validVar', $this);
}
- public function testSetCustomVarNameValidator()
+ public function testSetCustomVarNameValidator() : void
{
$calculator = new MathExecutor();
- $calculator->setVarValidationHandler(function (string $name, $variable) {
+ $calculator->setVarValidationHandler(static function(string $name, $variable) : void {
// don't allow variable names with the word invalid in them
- if (str_contains($name, 'invalid')) {
- throw new MathExecutorException("Invalid variable name");
+ if (\str_contains($name, 'invalid')) {
+ throw new MathExecutorException('Invalid variable name');
}
});
@@ -640,7 +642,7 @@ class MathTest extends TestCase
$calculator->setVar('invalidVar', 12);
}
- public function testVarExists()
+ public function testVarExists() : void
{
$calculator = new MathExecutor();
$varName = 'Eythel';
@@ -652,16 +654,16 @@ class MathTest extends TestCase
/**
* @dataProvider providerExpressionValues
*/
- public function testCalculatingValues($expression, $value)
+ public function testCalculatingValues($expression, $value) : void
{
$calculator = new MathExecutor();
try {
$result = $calculator->execute($expression);
} catch (Exception $e) {
- $this->fail(sprintf("Exception: %s (%s:%d), expression was: %s", get_class($e), $e->getFile(), $e->getLine(), $expression));
+ $this->fail(\sprintf('Exception: %s (%s:%d), expression was: %s', \get_class($e), $e->getFile(), $e->getLine(), $expression));
}
- $this->assertEquals($value, $result, "${expression} did not evaluate to {$value}");
+ $this->assertEquals($value, $result, "{$expression} did not evaluate to {$value}");
}
/**
@@ -674,62 +676,62 @@ class MathTest extends TestCase
public function providerExpressionValues()
{
return [
- ['arccos(0.5)', 1.0471975511966],
- ['arccos(0.5)', acos(0.5)],
- ['arccosec(4)', 0.2526802551421],
- ['arccosec(4)', asin(1/4)],
- ['arccot(3)', M_PI/2 - atan(3)],
- ['arccotan(4)', 0.2449786631269],
- ['arccotan(4)', M_PI/2 - atan(4)],
- ['arccsc(4)', 0.2526802551421],
- ['arccsc(4)', asin(1/4)],
- ['arcctg(3)', M_PI/2 - atan(3)],
- ['arcsec(4)', 1.3181160716528],
- ['arcsec(4)', acos(1/4)],
- ['arcsin(0.5)', 0.5235987755983],
- ['arcsin(0.5)', asin(0.5)],
- ['arctan(0.5)', atan(0.5)],
- ['arctan(4)', 1.3258176636680],
- ['arctg(0.5)', atan(0.5)],
- ['cosec(12)', 1 / sin(12)],
- ['cosec(4)', -1.3213487088109],
- ['cosh(12)', cosh(12)],
- ['cot(12)', cos(12) / sin(12)],
- ['cotan(12)', cos(12) / sin(12)],
- ['cotan(4)', 0.8636911544506],
- ['cotg(3)', cos(3) / sin(3)],
- ['csc(4)', 1 / sin(4)],
- ['ctg(4)', cos(4) / sin(4)],
- ['ctn(4)', cos(4) / sin(4)],
- ['decbin(10)', decbin(10)],
- ['lg(2)', 0.3010299956639],
- ['lg(2)', log10(2)],
- ['ln(2)', 0.6931471805599],
- ['ln(2)', log(2)],
- ['sec(4)', -1.5298856564664],
- ['tg(4)', 1.1578212823496],
+ ['arccos(0.5)', 1.0471975511966],
+ ['arccos(0.5)', \acos(0.5)],
+ ['arccosec(4)', 0.2526802551421],
+ ['arccosec(4)', \asin(1 / 4)],
+ ['arccot(3)', M_PI / 2 - \atan(3)],
+ ['arccotan(4)', 0.2449786631269],
+ ['arccotan(4)', M_PI / 2 - \atan(4)],
+ ['arccsc(4)', 0.2526802551421],
+ ['arccsc(4)', \asin(1 / 4)],
+ ['arcctg(3)', M_PI / 2 - \atan(3)],
+ ['arcsec(4)', 1.3181160716528],
+ ['arcsec(4)', \acos(1 / 4)],
+ ['arcsin(0.5)', 0.5235987755983],
+ ['arcsin(0.5)', \asin(0.5)],
+ ['arctan(0.5)', \atan(0.5)],
+ ['arctan(4)', 1.3258176636680],
+ ['arctg(0.5)', \atan(0.5)],
+ ['cosec(12)', 1 / \sin(12)],
+ ['cosec(4)', -1.3213487088109],
+ ['cosh(12)', \cosh(12)],
+ ['cot(12)', \cos(12) / \sin(12)],
+ ['cotan(12)', \cos(12) / \sin(12)],
+ ['cotan(4)', 0.8636911544506],
+ ['cotg(3)', \cos(3) / \sin(3)],
+ ['csc(4)', 1 / \sin(4)],
+ ['ctg(4)', \cos(4) / \sin(4)],
+ ['ctn(4)', \cos(4) / \sin(4)],
+ ['decbin(10)', \decbin(10)],
+ ['lg(2)', 0.3010299956639],
+ ['lg(2)', \log10(2)],
+ ['ln(2)', 0.6931471805599],
+ ['ln(2)', \log(2)],
+ ['sec(4)', -1.5298856564664],
+ ['tg(4)', 1.1578212823496],
];
}
- public function testCache()
+ public function testCache() : void
{
$calculator = new MathExecutor();
$this->assertEquals(256, $calculator->execute('2 ^ 8')); // second arg $cache is true by default
$this->assertIsArray($calculator->getCache());
- $this->assertEquals(1, count($calculator->getCache()));
+ $this->assertEquals(1, \count($calculator->getCache()));
$this->assertEquals(512, $calculator->execute('2 ^ 9', true));
- $this->assertEquals(2, count($calculator->getCache()));
+ $this->assertEquals(2, \count($calculator->getCache()));
$this->assertEquals(1024, $calculator->execute('2 ^ 10', false));
- $this->assertEquals(2, count($calculator->getCache()));
+ $this->assertEquals(2, \count($calculator->getCache()));
$calculator->clearCache();
$this->assertIsArray($calculator->getCache());
- $this->assertEquals(0, count($calculator->getCache()));
+ $this->assertEquals(0, \count($calculator->getCache()));
$this->assertEquals(2048, $calculator->execute('2 ^ 11', false));
- $this->assertEquals(0, count($calculator->getCache()));
+ $this->assertEquals(0, \count($calculator->getCache()));
}
}
diff --git a/tests/bootstrap.php b/tests/bootstrap.php
index 9c6e09c..85cee64 100644
--- a/tests/bootstrap.php
+++ b/tests/bootstrap.php
@@ -2,10 +2,10 @@
$vendorDir = __DIR__ . '/../../..';
-if (file_exists($file = $vendorDir . '/autoload.php')) {
+if (\file_exists($file = $vendorDir . '/autoload.php')) {
require_once $file;
-} elseif (file_exists($file = './vendor/autoload.php')) {
+} elseif (\file_exists($file = './vendor/autoload.php')) {
require_once $file;
} else {
- throw new \RuntimeException("Not found composer autoload");
+ throw new \RuntimeException('Not found composer autoload');
}