moodle/lib/simpletest/testmathslib.php
Jamie Pratt 1e257a3a54 NOBUG if we are going to reuse the functions used within the evalmath code then
the calling api should not be weird with reversed parameters etc.
2011-06-30 17:50:05 +01:00

231 lines
7.8 KiB
PHP

<?php
// This file is part of Moodle - http://moodle.org/
//
// Moodle is free software: you can redistribute it and/or modify
// it under the terms of the GNU General Public License as published by
// the Free Software Foundation, either version 3 of the License, or
// (at your option) any later version.
//
// Moodle is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU General Public License for more details.
//
// You should have received a copy of the GNU General Public License
// along with Moodle. If not, see <http://www.gnu.org/licenses/>.
if (!defined('MOODLE_INTERNAL')) {
die('Direct access to this script is forbidden.');/// It must be included from a Moodle page
}
require_once($CFG->libdir . '/mathslib.php');
/**
* Unit tests of mathslib wrapper and underlying EvalMath library.
*
* @author Petr Skoda (skodak)
* @version $Id$
*/
class mathsslib_test extends UnitTestCase {
public static $includecoverage = array('lib/mathslib.php');
/**
* Tests the basic formula evaluation
*/
public function test__basic() {
$formula = new calc_formula('=1+2');
$res = $formula->evaluate();
$this->assertEqual($res, 3, '3+1 is: %s');
}
/**
* Tests the formula params
*/
public function test__params() {
$formula = new calc_formula('=a+b+c', array('a'=>10, 'b'=>20, 'c'=>30));
$res = $formula->evaluate();
$this->assertEqual($res, 60, '10+20+30 is: %s');
}
/**
* Tests the changed params
*/
public function test__changing_params() {
$formula = new calc_formula('=a+b+c', array('a'=>10, 'b'=>20, 'c'=>30));
$res = $formula->evaluate();
$this->assertEqual($res, 60, '10+20+30 is: %s');
$formula->set_params(array('a'=>1, 'b'=>2, 'c'=>3));
$res = $formula->evaluate();
$this->assertEqual($res, 6, 'changed params 1+2+3 is: %s');
}
/**
* Tests the spreadsheet emulation function in formula
*/
public function test__calc_function() {
$formula = new calc_formula('=sum(a, b, c)', array('a'=>10, 'b'=>20, 'c'=>30));
$res = $formula->evaluate();
$this->assertEqual($res, 60, 'sum(a, b, c) is: %s');
}
public function test_other_functions() {
$formula = new calc_formula('=average(1,2,3)');
$this->assertEqual($formula->evaluate(), 2);
$formula = new calc_formula('=mod(10,3)');
$this->assertEqual($formula->evaluate(), 1);
$formula = new calc_formula('=power(2,3)');
$this->assertEqual($formula->evaluate(), 8);
}
/**
* Tests the min and max functions
*/
public function test__minmax_function() {
$formula = new calc_formula('=min(a, b, c)', array('a'=>10, 'b'=>20, 'c'=>30));
$res = $formula->evaluate();
$this->assertEqual($res, 10, 'minimum is: %s');
$formula = new calc_formula('=max(a, b, c)', array('a'=>10, 'b'=>20, 'c'=>30));
$res = $formula->evaluate();
$this->assertEqual($res, 30, 'maximum is: %s');
}
/**
* Tests special chars
*/
public function test__specialchars() {
$formula = new calc_formula('=gi1 + gi2 + gi11', array('gi1'=>10, 'gi2'=>20, 'gi11'=>30));
$res = $formula->evaluate();
$this->assertEqual($res, 60, 'sum is: %s');
}
/**
* Tests some slightly more complex expressions
*/
public function test__more_complex_expressions() {
$formula = new calc_formula('=pi() + a', array('a'=>10));
$res = $formula->evaluate();
$this->assertEqual($res, pi()+10);
$formula = new calc_formula('=pi()^a', array('a'=>10));
$res = $formula->evaluate();
$this->assertEqual($res, pow(pi(), 10));
$formula = new calc_formula('=-8*(5/2)^2*(1-sqrt(4))-8');
$res = $formula->evaluate();
$this->assertEqual($res, -8*pow((5/2), 2)*(1-sqrt(4))-8);
}
/**
* Tests some slightly more complex expressions
*/
public function test__error_handling() {
if (debugging('', DEBUG_DEVELOPER)) {
$this->expectError();
}
$formula = new calc_formula('=pi( + a', array('a'=>10));
$res = $formula->evaluate();
$this->assertEqual($res, false);
$this->assertEqual($formula->get_error(),
get_string('unexpectedoperator', 'mathslib', '+'));
if (debugging('', DEBUG_DEVELOPER)) {
$this->expectError();
}
$formula = new calc_formula('=pi(');
$res = $formula->evaluate();
$this->assertEqual($res, false);
$this->assertEqual($formula->get_error(),
get_string('expectingaclosingbracket', 'mathslib'));
if (debugging('', DEBUG_DEVELOPER)) {
$this->expectError();
}
$formula = new calc_formula('=pi()^');
$res = $formula->evaluate();
$this->assertEqual($res, false);
$this->assertEqual($formula->get_error(),
get_string('operatorlacksoperand', 'mathslib', '^'));
}
public function test_rounding_function() {
$formula = new calc_formula('=round(2.5)');
$this->assertEqual($formula->evaluate(), 3);
$formula = new calc_formula('=round(1.5)');
$this->assertEqual($formula->evaluate(), 2);
$formula = new calc_formula('=round(-1.49)');
$this->assertEqual($formula->evaluate(), -1);
$formula = new calc_formula('=round(-2.49)');
$this->assertEqual($formula->evaluate(), -2);
$formula = new calc_formula('=round(-1.5)');
$this->assertEqual($formula->evaluate(), -2);
$formula = new calc_formula('=round(-2.5)');
$this->assertEqual($formula->evaluate(), -3);
$formula = new calc_formula('=ceil(2.5)');
$this->assertEqual($formula->evaluate(), 3);
$formula = new calc_formula('=ceil(1.5)');
$this->assertEqual($formula->evaluate(), 2);
$formula = new calc_formula('=ceil(-1.49)');
$this->assertEqual($formula->evaluate(), -1);
$formula = new calc_formula('=ceil(-2.49)');
$this->assertEqual($formula->evaluate(), -2);
$formula = new calc_formula('=ceil(-1.5)');
$this->assertEqual($formula->evaluate(), -1);
$formula = new calc_formula('=ceil(-2.5)');
$this->assertEqual($formula->evaluate(), -2);
$formula = new calc_formula('=floor(2.5)');
$this->assertEqual($formula->evaluate(), 2);
$formula = new calc_formula('=floor(1.5)');
$this->assertEqual($formula->evaluate(), 1);
$formula = new calc_formula('=floor(-1.49)');
$this->assertEqual($formula->evaluate(), -2);
$formula = new calc_formula('=floor(-2.49)');
$this->assertEqual($formula->evaluate(), -3);
$formula = new calc_formula('=floor(-1.5)');
$this->assertEqual($formula->evaluate(), -2);
$formula = new calc_formula('=floor(-2.5)');
$this->assertEqual($formula->evaluate(), -3);
}
public function test_scientific_notation() {
$formula = new calc_formula('=10e10');
$this->assertWithinMargin($formula->evaluate(), 1e11, 1e11*1e-15);
$formula = new calc_formula('=10e-10');
$this->assertWithinMargin($formula->evaluate(), 1e-9, 1e11*1e-15);
$formula = new calc_formula('=10e+10');
$this->assertWithinMargin($formula->evaluate(), 1e11, 1e11*1e-15);
$formula = new calc_formula('=10e10*5');
$this->assertWithinMargin($formula->evaluate(), 5e11, 1e11*1e-15);
$formula = new calc_formula('=10e10^2');
$this->assertWithinMargin($formula->evaluate(), 1e22, 1e22*1e-15);
}
}