TYPO3 API  SVNRelease
IntegerValidatorTest.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 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 ?>