TYPO3 API  SVNRelease
FloatValidatorTest.php
Go to the documentation of this file.
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 ?>