395 lines
12 KiB
PHP
395 lines
12 KiB
PHP
|
<?php
|
||
|
/**
|
||
|
* Zend Framework
|
||
|
*
|
||
|
* LICENSE
|
||
|
*
|
||
|
* This source file is subject to the new BSD license that is bundled
|
||
|
* with this package in the file LICENSE.txt.
|
||
|
* It is also available through the world-wide-web at this URL:
|
||
|
* http://framework.zend.com/license/new-bsd
|
||
|
* If you did not receive a copy of the license and are unable to
|
||
|
* obtain it through the world-wide-web, please send an email
|
||
|
* to license@zend.com so we can send you a copy immediately.
|
||
|
*
|
||
|
* @category Zend
|
||
|
* @package Zend_Measure
|
||
|
* @subpackage UnitTests
|
||
|
* @copyright Copyright (c) 2005-2009 Zend Technologies USA Inc. (http://www.zend.com)
|
||
|
* @license http://framework.zend.com/license/new-bsd New BSD License
|
||
|
* @version $Id: FrequencyTest.php 17363 2009-08-03 07:40:18Z bkarwin $
|
||
|
*/
|
||
|
|
||
|
|
||
|
/**
|
||
|
* Zend_Measure_Frequency
|
||
|
*/
|
||
|
require_once 'Zend/Measure/Frequency.php';
|
||
|
|
||
|
/**
|
||
|
* PHPUnit test case
|
||
|
*/
|
||
|
require_once 'PHPUnit/Framework/TestCase.php';
|
||
|
|
||
|
/**
|
||
|
* @category Zend
|
||
|
* @package Zend_Measure
|
||
|
* @subpackage UnitTests
|
||
|
* @copyright Copyright (c) 2005-2009 Zend Technologies USA Inc. (http://www.zend.com)
|
||
|
* @license http://framework.zend.com/license/new-bsd New BSD License
|
||
|
* @group Zend_Measure
|
||
|
*/
|
||
|
class Zend_Measure_FrequencyTest extends PHPUnit_Framework_TestCase
|
||
|
{
|
||
|
/**
|
||
|
* test for Frequency initialisation
|
||
|
* expected instance
|
||
|
*/
|
||
|
public function testFrequencyInit()
|
||
|
{
|
||
|
$value = new Zend_Measure_Frequency('100',Zend_Measure_Frequency::STANDARD,'de');
|
||
|
$this->assertTrue($value instanceof Zend_Measure_Frequency,'Zend_Measure_Frequency Object not returned');
|
||
|
}
|
||
|
|
||
|
|
||
|
/**
|
||
|
* test for exception unknown type
|
||
|
* expected exception
|
||
|
*/
|
||
|
public function testFrequencyUnknownType()
|
||
|
{
|
||
|
try {
|
||
|
$value = new Zend_Measure_Frequency('100','Frequency::UNKNOWN','de');
|
||
|
$this->fail('Exception expected because of unknown type');
|
||
|
} catch (Zend_Measure_Exception $e) {
|
||
|
// success
|
||
|
}
|
||
|
}
|
||
|
|
||
|
|
||
|
/**
|
||
|
* test for exception unknown value
|
||
|
* expected exception
|
||
|
*/
|
||
|
public function testFrequencyUnknownValue()
|
||
|
{
|
||
|
try {
|
||
|
$value = new Zend_Measure_Frequency('novalue',Zend_Measure_Frequency::STANDARD,'de');
|
||
|
$this->fail('Exception expected because of empty value');
|
||
|
} catch (Zend_Measure_Exception $e) {
|
||
|
// success
|
||
|
}
|
||
|
}
|
||
|
|
||
|
|
||
|
/**
|
||
|
* test for exception unknown locale
|
||
|
* expected root value
|
||
|
*/
|
||
|
public function testFrequencyUnknownLocale()
|
||
|
{
|
||
|
try {
|
||
|
$value = new Zend_Measure_Frequency('100',Zend_Measure_Frequency::STANDARD,'nolocale');
|
||
|
$this->fail('Exception expected because of unknown locale');
|
||
|
} catch (Zend_Measure_Exception $e) {
|
||
|
// success
|
||
|
}
|
||
|
}
|
||
|
|
||
|
|
||
|
/**
|
||
|
* test for standard locale
|
||
|
* expected integer
|
||
|
*/
|
||
|
public function testFrequencyNoLocale()
|
||
|
{
|
||
|
$value = new Zend_Measure_Frequency('100',Zend_Measure_Frequency::STANDARD);
|
||
|
$this->assertEquals(100, $value->getValue(),'Zend_Measure_Frequency value expected');
|
||
|
}
|
||
|
|
||
|
|
||
|
/**
|
||
|
* test for positive value
|
||
|
* expected integer
|
||
|
*/
|
||
|
public function testFrequencyValuePositive()
|
||
|
{
|
||
|
$value = new Zend_Measure_Frequency('100',Zend_Measure_Frequency::STANDARD,'de');
|
||
|
$this->assertEquals(100, $value->getValue(), 'Zend_Measure_Frequency value expected to be a positive integer');
|
||
|
}
|
||
|
|
||
|
|
||
|
/**
|
||
|
* test for negative value
|
||
|
* expected integer
|
||
|
*/
|
||
|
public function testFrequencyValueNegative()
|
||
|
{
|
||
|
$value = new Zend_Measure_Frequency('-100',Zend_Measure_Frequency::STANDARD,'de');
|
||
|
$this->assertEquals(-100, $value->getValue(), 'Zend_Measure_Frequency value expected to be a negative integer');
|
||
|
}
|
||
|
|
||
|
|
||
|
/**
|
||
|
* test for decimal value
|
||
|
* expected float
|
||
|
*/
|
||
|
public function testFrequencyValueDecimal()
|
||
|
{
|
||
|
$value = new Zend_Measure_Frequency('-100,200',Zend_Measure_Frequency::STANDARD,'de');
|
||
|
$this->assertEquals(-100.200, $value->getValue(), 'Zend_Measure_Frequency value expected to be a decimal value');
|
||
|
}
|
||
|
|
||
|
|
||
|
/**
|
||
|
* test for decimal seperated value
|
||
|
* expected float
|
||
|
*/
|
||
|
public function testFrequencyValueDecimalSeperated()
|
||
|
{
|
||
|
$value = new Zend_Measure_Frequency('-100.100,200',Zend_Measure_Frequency::STANDARD,'de');
|
||
|
$this->assertEquals(-100100.200, $value->getValue(),'Zend_Measure_Frequency Object not returned');
|
||
|
}
|
||
|
|
||
|
|
||
|
/**
|
||
|
* test for string with integrated value
|
||
|
* expected float
|
||
|
*/
|
||
|
public function testFrequencyValueString()
|
||
|
{
|
||
|
$value = new Zend_Measure_Frequency('-100.100,200',Zend_Measure_Frequency::STANDARD,'de');
|
||
|
$this->assertEquals(-100100.200, $value->getValue(),'Zend_Measure_Frequency Object not returned');
|
||
|
}
|
||
|
|
||
|
|
||
|
/**
|
||
|
* test for equality
|
||
|
* expected true
|
||
|
*/
|
||
|
public function testFrequencyEquality()
|
||
|
{
|
||
|
$value = new Zend_Measure_Frequency('-100.100,200',Zend_Measure_Frequency::STANDARD,'de');
|
||
|
$newvalue = new Zend_Measure_Frequency('-100.100,200',Zend_Measure_Frequency::STANDARD,'de');
|
||
|
$this->assertTrue($value->equals($newvalue),'Zend_Measure_Frequency Object should be equal');
|
||
|
}
|
||
|
|
||
|
|
||
|
/**
|
||
|
* test for no equality
|
||
|
* expected false
|
||
|
*/
|
||
|
public function testFrequencyNoEquality()
|
||
|
{
|
||
|
$value = new Zend_Measure_Frequency('-100.100,200',Zend_Measure_Frequency::STANDARD,'de');
|
||
|
$newvalue = new Zend_Measure_Frequency('-100,200',Zend_Measure_Frequency::STANDARD,'de');
|
||
|
$this->assertFalse($value->equals($newvalue),'Zend_Measure_Frequency Object should be not equal');
|
||
|
}
|
||
|
|
||
|
|
||
|
/**
|
||
|
* test for set positive value
|
||
|
* expected integer
|
||
|
*/
|
||
|
public function testFrequencySetPositive()
|
||
|
{
|
||
|
$value = new Zend_Measure_Frequency('100',Zend_Measure_Frequency::STANDARD,'de');
|
||
|
$value->setValue('200',Zend_Measure_Frequency::STANDARD,'de');
|
||
|
$this->assertEquals(200, $value->getValue(), 'Zend_Measure_Frequency value expected to be a positive integer');
|
||
|
}
|
||
|
|
||
|
|
||
|
/**
|
||
|
* test for set negative value
|
||
|
* expected integer
|
||
|
*/
|
||
|
public function testFrequencySetNegative()
|
||
|
{
|
||
|
$value = new Zend_Measure_Frequency('-100',Zend_Measure_Frequency::STANDARD,'de');
|
||
|
$value->setValue('-200',Zend_Measure_Frequency::STANDARD,'de');
|
||
|
$this->assertEquals(-200, $value->getValue(), 'Zend_Measure_Frequency value expected to be a negative integer');
|
||
|
}
|
||
|
|
||
|
|
||
|
/**
|
||
|
* test for set decimal value
|
||
|
* expected float
|
||
|
*/
|
||
|
public function testFrequencySetDecimal()
|
||
|
{
|
||
|
$value = new Zend_Measure_Frequency('-100,200',Zend_Measure_Frequency::STANDARD,'de');
|
||
|
$value->setValue('-200,200',Zend_Measure_Frequency::STANDARD,'de');
|
||
|
$this->assertEquals(-200.200, $value->getValue(), 'Zend_Measure_Frequency value expected to be a decimal value');
|
||
|
}
|
||
|
|
||
|
|
||
|
/**
|
||
|
* test for set decimal seperated value
|
||
|
* expected float
|
||
|
*/
|
||
|
public function testFrequencySetDecimalSeperated()
|
||
|
{
|
||
|
$value = new Zend_Measure_Frequency('-100.100,200',Zend_Measure_Frequency::STANDARD,'de');
|
||
|
$value->setValue('-200.200,200',Zend_Measure_Frequency::STANDARD,'de');
|
||
|
$this->assertEquals(-200200.200, $value->getValue(),'Zend_Measure_Frequency Object not returned');
|
||
|
}
|
||
|
|
||
|
|
||
|
/**
|
||
|
* test for set string with integrated value
|
||
|
* expected float
|
||
|
*/
|
||
|
public function testFrequencySetString()
|
||
|
{
|
||
|
$value = new Zend_Measure_Frequency('-100.100,200',Zend_Measure_Frequency::STANDARD,'de');
|
||
|
$value->setValue('-200.200,200',Zend_Measure_Frequency::STANDARD,'de');
|
||
|
$this->assertEquals(-200200.200, $value->getValue(),'Zend_Measure_Frequency Object not returned');
|
||
|
}
|
||
|
|
||
|
|
||
|
/**
|
||
|
* test for exception unknown type
|
||
|
* expected exception
|
||
|
*/
|
||
|
public function testFrequencySetUnknownType()
|
||
|
{
|
||
|
try {
|
||
|
$value = new Zend_Measure_Frequency('100',Zend_Measure_Frequency::STANDARD,'de');
|
||
|
$value->setValue('-200.200,200','Frequency::UNKNOWN','de');
|
||
|
$this->fail('Exception expected because of unknown type');
|
||
|
} catch (Zend_Measure_Exception $e) {
|
||
|
// success
|
||
|
}
|
||
|
}
|
||
|
|
||
|
|
||
|
/**
|
||
|
* test for exception unknown value
|
||
|
* expected exception
|
||
|
*/
|
||
|
public function testFrequencySetUnknownValue()
|
||
|
{
|
||
|
try {
|
||
|
$value = new Zend_Measure_Frequency('100',Zend_Measure_Frequency::STANDARD,'de');
|
||
|
$value->setValue('novalue',Zend_Measure_Frequency::STANDARD,'de');
|
||
|
$this->fail('Exception expected because of empty value');
|
||
|
} catch (Zend_Measure_Exception $e) {
|
||
|
// success
|
||
|
}
|
||
|
}
|
||
|
|
||
|
|
||
|
/**
|
||
|
* test for exception unknown locale
|
||
|
* expected exception
|
||
|
*/
|
||
|
public function testFrequencySetUnknownLocale()
|
||
|
{
|
||
|
try {
|
||
|
$value = new Zend_Measure_Frequency('100',Zend_Measure_Frequency::STANDARD,'de');
|
||
|
$value->setValue('200',Zend_Measure_Frequency::STANDARD,'nolocale');
|
||
|
$this->fail('Exception expected because of unknown locale');
|
||
|
} catch (Zend_Measure_Exception $e) {
|
||
|
// success
|
||
|
}
|
||
|
}
|
||
|
|
||
|
|
||
|
/**
|
||
|
* test for exception unknown locale
|
||
|
* expected exception
|
||
|
*/
|
||
|
public function testFrequencySetWithNoLocale()
|
||
|
{
|
||
|
$value = new Zend_Measure_Frequency('100', Zend_Measure_Frequency::STANDARD, 'de');
|
||
|
$value->setValue('200', Zend_Measure_Frequency::STANDARD);
|
||
|
$this->assertEquals(200, $value->getValue(), 'Zend_Measure_Frequency value expected to be a positive integer');
|
||
|
}
|
||
|
|
||
|
|
||
|
/**
|
||
|
* test setting type
|
||
|
* expected new type
|
||
|
*/
|
||
|
public function testFrequencySetType()
|
||
|
{
|
||
|
$value = new Zend_Measure_Frequency('-100',Zend_Measure_Frequency::STANDARD,'de');
|
||
|
$value->setType(Zend_Measure_Frequency::KILOHERTZ);
|
||
|
$this->assertEquals(Zend_Measure_Frequency::KILOHERTZ, $value->getType(), 'Zend_Measure_Frequency type expected');
|
||
|
}
|
||
|
|
||
|
|
||
|
/**
|
||
|
* test setting computed type
|
||
|
* expected new type
|
||
|
*/
|
||
|
public function testFrequencySetComputedType1()
|
||
|
{
|
||
|
$value = new Zend_Measure_Frequency('-100',Zend_Measure_Frequency::RADIAN_PER_HOUR,'de');
|
||
|
$value->setType(Zend_Measure_Frequency::RPM);
|
||
|
$this->assertEquals(Zend_Measure_Frequency::RPM, $value->getType(), 'Zend_Measure_Frequency type expected');
|
||
|
}
|
||
|
|
||
|
|
||
|
/**
|
||
|
* test setting computed type
|
||
|
* expected new type
|
||
|
*/
|
||
|
public function testFrequencySetComputedType2()
|
||
|
{
|
||
|
$value = new Zend_Measure_Frequency('-100',Zend_Measure_Frequency::RPM,'de');
|
||
|
$value->setType(Zend_Measure_Frequency::RADIAN_PER_HOUR);
|
||
|
$this->assertEquals(Zend_Measure_Frequency::RADIAN_PER_HOUR, $value->getType(), 'Zend_Measure_Frequency type expected');
|
||
|
}
|
||
|
|
||
|
|
||
|
/**
|
||
|
* test setting unknown type
|
||
|
* expected new type
|
||
|
*/
|
||
|
public function testFrequencySetTypeFailed()
|
||
|
{
|
||
|
try {
|
||
|
$value = new Zend_Measure_Frequency('-100',Zend_Measure_Frequency::STANDARD,'de');
|
||
|
$value->setType('Frequency::UNKNOWN');
|
||
|
$this->fail('Exception expected because of unknown type');
|
||
|
} catch (Zend_Measure_Exception $e) {
|
||
|
// success
|
||
|
}
|
||
|
}
|
||
|
|
||
|
|
||
|
/**
|
||
|
* test toString
|
||
|
* expected string
|
||
|
*/
|
||
|
public function testFrequencyToString()
|
||
|
{
|
||
|
$value = new Zend_Measure_Frequency('-100',Zend_Measure_Frequency::STANDARD,'de');
|
||
|
$this->assertEquals('-100 Hz', $value->toString(), 'Value -100 Hz expected');
|
||
|
}
|
||
|
|
||
|
|
||
|
/**
|
||
|
* test __toString
|
||
|
* expected string
|
||
|
*/
|
||
|
public function testFrequency_ToString()
|
||
|
{
|
||
|
$value = new Zend_Measure_Frequency('-100',Zend_Measure_Frequency::STANDARD,'de');
|
||
|
$this->assertEquals('-100 Hz', $value->__toString(), 'Value -100 Hz expected');
|
||
|
}
|
||
|
|
||
|
|
||
|
/**
|
||
|
* test getConversionList
|
||
|
* expected array
|
||
|
*/
|
||
|
public function testFrequencyConversionList()
|
||
|
{
|
||
|
$value = new Zend_Measure_Frequency('-100',Zend_Measure_Frequency::STANDARD,'de');
|
||
|
$unit = $value->getConversionList();
|
||
|
$this->assertTrue(is_array($unit), 'Array expected');
|
||
|
}
|
||
|
}
|