|
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 integer validator 00030 * 00031 * @package Extbase 00032 * @subpackage extbase 00033 * @version $Id: IntegerValidator_testcase.php 2428 2010-07-20 10:18:51Z jocrau $ 00034 */ 00035 class Tx_Extbase_Tests_Unit_Validation_Validator_IntegerValidatorTest extends Tx_Extbase_Tests_Unit_BaseTestCase { 00036 00037 /** 00038 * An array of valid floating point numbers addresses 00039 * @var array 00040 */ 00041 protected $validIntegerNumbers; 00042 00043 /** 00044 * An array of invalid floating point numbers addresses 00045 * @var array 00046 */ 00047 protected $invalidIntegerNumbers; 00048 00049 public function setUp() { 00050 $this->validIntegerNumbers = array( 00051 1029437, 00052 '12345', 00053 '+12345', 00054 '-12345' 00055 ); 00056 00057 $this->invalidIntegerNumbers = array( 00058 'not a number', 00059 3.1415, 00060 '12345.987' 00061 ); 00062 } 00063 00064 /** 00065 * @test 00066 */ 00067 public function integerValidatorReturnsTrueForAValidInteger() { 00068 $integerValidator = new Tx_Extbase_Validation_Validator_IntegerValidator(); 00069 foreach ($this->validIntegerNumbers as $integerNumber) { 00070 $this->assertTrue($integerValidator->isValid($integerNumber), "$integerNumber was declared to be invalid, but it is valid."); 00071 } 00072 } 00073 00074 /** 00075 * Data provider with invalid email addresses 00076 * 00077 * @return array 00078 */ 00079 public function invalidIntegers() { 00080 return array( 00081 array('not a number'), 00082 array(3.1415), 00083 array('12345.987') 00084 ); 00085 } 00086 00087 /** 00088 * @test 00089 * @dataProvider invalidIntegers 00090 */ 00091 public function integerValidatorReturnsTrueForAnInvalidInteger() { 00092 $integerValidator = $this->getMock('Tx_Extbase_Validation_Validator_IntegerValidator', array('addError'), array(), '', FALSE); 00093 foreach ($this->invalidIntegerNumbers as $integerNumber) { 00094 $this->assertFalse($integerValidator->isValid($integerNumber), "$integerNumber was declared to be valid, but it is invalid."); 00095 } 00096 } 00097 00098 /** 00099 * @test 00100 */ 00101 public function integerValidatorCreatesTheCorrectErrorForAnInvalidSubject() { 00102 $integerValidator = $this->getMock('Tx_Extbase_Validation_Validator_IntegerValidator', array('addError'), array(), '', FALSE); 00103 $integerValidator->expects($this->once())->method('addError')->with('The given subject was not a valid integer.', 1221560494); 00104 $integerValidator->isValid('not a number'); 00105 } 00106 00107 } 00108 00109 ?>
1.8.0