aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--src/NXP/Classes/Calculator.php4
-rw-r--r--src/NXP/MathExecutor.php2
-rw-r--r--tests/MathTest.php42
3 files changed, 23 insertions, 25 deletions
diff --git a/src/NXP/Classes/Calculator.php b/src/NXP/Classes/Calculator.php
index 49142df..4785a8f 100644
--- a/src/NXP/Classes/Calculator.php
+++ b/src/NXP/Classes/Calculator.php
@@ -64,9 +64,7 @@ class Calculator
$value = $variables[$variable];
} elseif ($onVarNotFound) {
$value = call_user_func($onVarNotFound, $variable);
- }
-
- if (!isset($value)) {
+ } else {
throw new UnknownVariableException($variable);
}
diff --git a/src/NXP/MathExecutor.php b/src/NXP/MathExecutor.php
index 434246a..f45335c 100644
--- a/src/NXP/MathExecutor.php
+++ b/src/NXP/MathExecutor.php
@@ -416,7 +416,7 @@ class MathExecutor
*/
public function getVar(string $variable)
{
- if (!isset($this->variables[$variable])) {
+ if (!array_key_exists($variable, $this->variables)) {
throw new UnknownVariableException("Variable ({$variable}) not set");
}
return $this->variables[$variable];
diff --git a/tests/MathTest.php b/tests/MathTest.php
index 8f5665b..c519c5c 100644
--- a/tests/MathTest.php
+++ b/tests/MathTest.php
@@ -237,8 +237,8 @@ class MathTest extends TestCase
$calculator = new MathExecutor();
$this->expectException(DivisionByZeroException::class);
$calculator->execute('10 / 0');
- $calculator->setVar('one', 1)->setVar('zero', 0);
- $this->assertEquals(0.0, $calculator->execute('$one / $zero'));
+ $calculator->setVar('one', 1)->setVar('zero', 0);
+ $this->assertEquals(0.0, $calculator->execute('$one / $zero'));
}
public function testVariableIncorrectExpressionException()
@@ -337,19 +337,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'));
@@ -374,8 +374,8 @@ class MathTest extends TestCase
$calculator->addFunction(
'round',
function ($value, $decimals) {
- return round($value, $decimals);
- }
+ return round($value, $decimals);
+ }
);
$expression = 'round(100 * 1.111111, 2)';
$phpResult = 0;
@@ -403,9 +403,9 @@ class MathTest extends TestCase
$calculator->addFunction(
'test',
function ($arg) use ($testString) {
- $this->assertEquals($testString, $arg);
- return 0;
- }
+ $this->assertEquals($testString, $arg);
+ return 0;
+ }
);
$calculator->execute('test("' . $testString . '")'); // single quotes
$calculator->execute("test('" . $testString . "')"); // double quotes
@@ -526,4 +526,4 @@ class MathTest extends TestCase
$this->expectException(MathExecutorException::class);
$calculator->setVar('resource', tmpfile());
}
-}
+} \ No newline at end of file