|
TYPO3 API
SVNRelease
|
00001 <?php 00002 /*************************************************************** 00003 * Copyright notice 00004 * 00005 * (c) 2009 Jochen Rau <jochen.rau@typoplanet.de> 00006 * All rights reserved 00007 * 00008 * This class is a backport of the corresponding class of FLOW3. 00009 * All credits go to the v5 team. 00010 * 00011 * This script is part of the TYPO3 project. The TYPO3 project is 00012 * free software; you can redistribute it and/or modify 00013 * it under the terms of the GNU General Public License as published by 00014 * the Free Software Foundation; either version 2 of the License, or 00015 * (at your option) any later version. 00016 * 00017 * The GNU General Public License can be found at 00018 * http://www.gnu.org/copyleft/gpl.html. 00019 * 00020 * This script is distributed in the hope that it will be useful, 00021 * but WITHOUT ANY WARRANTY; without even the implied warranty of 00022 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 00023 * GNU General Public License for more details. 00024 * 00025 * This copyright notice MUST APPEAR in all copies of the script! 00026 ***************************************************************/ 00027 00028 /** 00029 * Testcase for the float validator 00030 * 00031 * @package Extbase 00032 * @subpackage extbase 00033 * @version $Id: FloatValidator_testcase.php 2428 2010-07-20 10:18:51Z jocrau $ 00034 */ 00035 class Tx_Extbase_Tests_Unit_Validation_Validator_FloatValidatorTest extends Tx_Extbase_Tests_Unit_BaseTestCase { 00036 00037 /** 00038 * An array of valid floating point numbers addresses 00039 * @var array 00040 */ 00041 protected $validFloatingPointNumbers; 00042 00043 /** 00044 * An array of invalid floating point numbers addresses 00045 * @var array 00046 */ 00047 protected $invalidFloatingPointNumbers; 00048 00049 public function setUp() { 00050 $this->validFloatingPointNumbers = array( 00051 1029437.234726, 00052 '123.45', 00053 '+123.45', 00054 '-123.45', 00055 '123.45e3', 00056 123.45e3 00057 ); 00058 00059 $this->invalidFloatingPointNumbers = array( 00060 1029437, 00061 '1029437', 00062 'not a number' 00063 ); 00064 } 00065 00066 /** 00067 * @test 00068 */ 00069 public function floatValidatorReturnsTrueForAValidFloat() { 00070 $floatValidator = new Tx_Extbase_Validation_Validator_FloatValidator(); 00071 foreach ($this->validFloatingPointNumbers as $floatingPointNumber) { 00072 $this->assertTrue($floatValidator->isValid($floatingPointNumber), "$floatingPointNumber was declared to be invalid, but it is valid."); 00073 } 00074 } 00075 00076 /** 00077 * @test 00078 */ 00079 public function floatValidatorReturnsFalseForAnInvalidFloat() { 00080 $floatValidator = $this->getMock('Tx_Extbase_Validation_Validator_FloatValidator', array('addError'), array(), '', FALSE); 00081 foreach ($this->invalidFloatingPointNumbers as $floatingPointNumber) { 00082 $this->assertFalse($floatValidator->isValid($floatingPointNumber), "$floatingPointNumber was declared to be valid, but it is invalid."); 00083 } 00084 } 00085 00086 /** 00087 * @test 00088 */ 00089 public function floatValidatorCreatesTheCorrectErrorForAnInvalidSubject() { 00090 $floatValidator = new Tx_Extbase_Validation_Validator_FloatValidator(); 00091 $floatValidator = $this->getMock('Tx_Extbase_Validation_Validator_FloatValidator', array('addError'), array(), '', FALSE); 00092 $floatValidator->expects($this->once())->method('addError')->with('The given subject was not a valid float.', 1221560288); 00093 $floatValidator->isValid(123456); 00094 } 00095 00096 } 00097 00098 ?>
1.8.0