mirror of
https://github.com/danog/math.git
synced 2025-01-22 21:51:22 +01:00
45e3c3a463
This improves overall consistency of method names in the project. For example, it does not make sense to get the reciprocal of a BigRational using reciprocal(), but get its numerator using getNumerator(). List of renamed methods: - BigNumber::getSign() => sign() - BigDecimal::getUnscaledValue() => unscaledValue() - BigDecimal::getScale() => scale() - BigDecimal::getIntegral() => integral() - BigDecimal::getFraction() => fraction() - BigRational::getNumerator() => numerator() - BigRational::getDenominator() => denominator()
78 lines
2.5 KiB
PHP
78 lines
2.5 KiB
PHP
<?php
|
|
|
|
namespace Brick\Math\Tests;
|
|
|
|
use Brick\Math\BigDecimal;
|
|
use Brick\Math\BigInteger;
|
|
use Brick\Math\BigRational;
|
|
|
|
/**
|
|
* Base class for math tests.
|
|
*/
|
|
abstract class AbstractTestCase extends \PHPUnit_Framework_TestCase
|
|
{
|
|
/**
|
|
* @param string $expected The expected value, as a string.
|
|
* @param BigInteger $actual The BigInteger instance to test.
|
|
*/
|
|
final protected function assertBigIntegerEquals($expected, $actual)
|
|
{
|
|
$this->assertInstanceOf(BigInteger::class, $actual);
|
|
$this->assertSame($expected, (string) $actual);
|
|
}
|
|
|
|
/**
|
|
* @param string $expected The expected string representation.
|
|
* @param BigDecimal $actual The BigDecimal instance to test.
|
|
*/
|
|
final protected function assertBigDecimalEquals($expected, $actual)
|
|
{
|
|
$this->assertInstanceOf(BigDecimal::class, $actual);
|
|
$this->assertSame($expected, (string) $actual);
|
|
}
|
|
|
|
/**
|
|
* @param string $expected The expected string representation.
|
|
* @param BigRational $actual The BigRational instance to test.
|
|
*/
|
|
final protected function assertBigRationalEquals($expected, $actual)
|
|
{
|
|
$this->assertInstanceOf(BigRational::class, $actual);
|
|
$this->assertSame($expected, (string) $actual);
|
|
}
|
|
|
|
/**
|
|
* @param string $unscaledValue The expected unscaled value, as a string.
|
|
* @param int $scale The expected scale.
|
|
* @param BigDecimal $actual The BigDecimal instance to test.
|
|
*/
|
|
final protected function assertBigDecimalInternalValues($unscaledValue, $scale, $actual)
|
|
{
|
|
$this->assertInstanceOf(BigDecimal::class, $actual);
|
|
$this->assertSame($unscaledValue, $actual->unscaledValue());
|
|
$this->assertSame($scale, $actual->scale());
|
|
}
|
|
|
|
/**
|
|
* @param string $numerator The expected numerator, as a string.
|
|
* @param string $denominator The expected denominator, as a string.
|
|
* @param BigRational $actual The BigRational instance to test.
|
|
*/
|
|
final protected function assertBigRationalInternalValues($numerator, $denominator, $actual)
|
|
{
|
|
$this->assertInstanceOf(BigRational::class, $actual);
|
|
$this->assertSame($numerator, (string) $actual->numerator());
|
|
$this->assertSame($denominator, (string) $actual->denominator());
|
|
}
|
|
|
|
/**
|
|
* @param string $name
|
|
*
|
|
* @return bool
|
|
*/
|
|
final protected function isException($name)
|
|
{
|
|
return substr($name, -9) === 'Exception';
|
|
}
|
|
}
|