TYPO3 API  SVNRelease
RegularExpressionValidatorTest.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 regular expression validator
00030  *
00031  * @package Extbase
00032  * @subpackage extbase
00033  * @version $Id: RegularExpressionValidator_testcase.php 2428 2010-07-20 10:18:51Z jocrau $
00034  */
00035 class Tx_Extbase_Tests_Unit_Validation_Validator_RegularExpressionValidatorTest extends Tx_Extbase_Tests_Unit_BaseTestCase {
00036 
00037     /**
00038      * @test
00039      */
00040     public function regularExpressionValidatorMatchesABasicExpressionCorrectly() {
00041         $regularExpressionValidator = $this->getMock('Tx_Extbase_Validation_Validator_RegularExpressionValidator', array('addError'), array(), '', FALSE);
00042         $regularExpressionValidator->setOptions(array('regularExpression' => '/^simple[0-9]expression$/'));
00043 
00044         $this->assertTrue($regularExpressionValidator->isValid('simple1expression'));
00045         $this->assertFalse($regularExpressionValidator->isValid('simple1expressions'));
00046     }
00047 
00048     /**
00049      * @test
00050      */
00051     public function regularExpressionValidatorCreatesTheCorrectErrorIfTheExpressionDidNotMatch() {
00052         $regularExpressionValidator = $this->getMock('Tx_Extbase_Validation_Validator_RegularExpressionValidator', array('addError'), array(), '', FALSE);
00053         $regularExpressionValidator->expects($this->once())->method('addError')->with('The given subject did not match the pattern.', 1221565130);
00054         $regularExpressionValidator->setOptions(array('regularExpression' => '/^simple[0-9]expression$/'));
00055         $regularExpressionValidator->isValid('some subject that will not match');
00056     }
00057 }
00058 
00059 ?>