cacert-testmgr/external/ZendFramework-1.9.5/tests/Zend/Form/Element/CheckboxTest.php
Markus Warg 8398c9048d initially import ZendFramework-1.9.5 into repository
code was modified slightly, so the code differs from the original downloadable 1.9.5 version
2010-03-31 10:12:32 +02:00

264 lines
8.7 KiB
PHP

<?php
/**
* Zend Framework
*
* LICENSE
*
* This source file is subject to the new BSD license that is bundled
* with this package in the file LICENSE.txt.
* It is also available through the world-wide-web at this URL:
* http://framework.zend.com/license/new-bsd
* If you did not receive a copy of the license and are unable to
* obtain it through the world-wide-web, please send an email
* to license@zend.com so we can send you a copy immediately.
*
* @category Zend
* @package Zend_Form
* @subpackage UnitTests
* @copyright Copyright (c) 2005-2009 Zend Technologies USA Inc. (http://www.zend.com)
* @license http://framework.zend.com/license/new-bsd New BSD License
* @version $Id: CheckboxTest.php 17363 2009-08-03 07:40:18Z bkarwin $
*/
// Call Zend_Form_Element_CheckboxTest::main() if this source file is executed directly.
if (!defined("PHPUnit_MAIN_METHOD")) {
define("PHPUnit_MAIN_METHOD", "Zend_Form_Element_CheckboxTest::main");
}
require_once dirname(__FILE__) . '/../../../TestHelper.php';
require_once 'Zend/Form/Element/Checkbox.php';
/**
* Test class for Zend_Form_Element_Checkbox
*
* @category Zend
* @package Zend_Form
* @subpackage UnitTests
* @copyright Copyright (c) 2005-2009 Zend Technologies USA Inc. (http://www.zend.com)
* @license http://framework.zend.com/license/new-bsd New BSD License
* @group Zend_Form
*/
class Zend_Form_Element_CheckboxTest extends PHPUnit_Framework_TestCase
{
/**
* Runs the test methods of this class.
*
* @return void
*/
public static function main()
{
$suite = new PHPUnit_Framework_TestSuite("Zend_Form_Element_CheckboxTest");
$result = PHPUnit_TextUI_TestRunner::run($suite);
}
/**
* Sets up the fixture, for example, open a network connection.
* This method is called before a test is executed.
*
* @return void
*/
public function setUp()
{
$this->element = new Zend_Form_Element_Checkbox('foo');
}
/**
* Tears down the fixture, for example, close a network connection.
* This method is called after a test is executed.
*
* @return void
*/
public function tearDown()
{
}
public function getView()
{
require_once 'Zend/View.php';
return new Zend_View();
}
public function testCheckboxElementSubclassesXhtmlElement()
{
$this->assertTrue($this->element instanceof Zend_Form_Element_Xhtml);
}
public function testCheckboxElementInstanceOfBaseElement()
{
$this->assertTrue($this->element instanceof Zend_Form_Element);
}
public function testCheckboxElementUsesCheckboxHelperInViewHelperDecoratorByDefault()
{
$this->_checkZf2794();
$decorator = $this->element->getDecorator('viewHelper');
$this->assertTrue($decorator instanceof Zend_Form_Decorator_ViewHelper);
$decorator->setElement($this->element);
$helper = $decorator->getHelper();
$this->assertEquals('formCheckbox', $helper);
}
public function testCheckedFlagIsFalseByDefault()
{
$this->assertFalse($this->element->checked);
}
public function testCheckedAttributeNotRenderedByDefault()
{
require_once 'Zend/View.php';
$view = new Zend_View();
$html = $this->element->render($view);
$this->assertNotContains('checked="checked"', $html);
}
public function testCheckedAttributeRenderedWhenCheckedFlagTrue()
{
require_once 'Zend/View.php';
$view = new Zend_View();
$this->element->checked = true;
$html = $this->element->render($view);
$this->assertContains('checked="checked"', $html);
}
public function testCheckedValueDefaultsToOne()
{
$this->assertEquals(1, $this->element->getCheckedValue());
}
public function testUncheckedValueDefaultsToZero()
{
$this->assertEquals(0, $this->element->getUncheckedValue());
}
public function testCanSetCheckedValue()
{
$this->testCheckedValueDefaultsToOne();
$this->element->setCheckedValue('foo');
$this->assertEquals('foo', $this->element->getCheckedValue());
}
public function testCanSetUncheckedValue()
{
$this->testUncheckedValueDefaultsToZero();
$this->element->setUncheckedValue('foo');
$this->assertEquals('foo', $this->element->getUncheckedValue());
}
public function testValueInitiallyUncheckedValue()
{
$this->assertEquals($this->element->getUncheckedValue(), $this->element->getValue());
}
public function testSettingValueToCheckedValueSetsWithEquivalentValue()
{
$this->testValueInitiallyUncheckedValue();
$this->element->setValue($this->element->getCheckedValue());
$this->assertEquals($this->element->getCheckedValue(), $this->element->getValue());
}
public function testSettingValueToAnythingOtherThanCheckedValueSetsAsUncheckedValue()
{
$this->testSettingValueToCheckedValueSetsWithEquivalentValue();
$this->element->setValue('bogus');
$this->assertEquals($this->element->getUncheckedValue(), $this->element->getValue());
}
public function testSettingCheckedFlagToTrueSetsValueToCheckedValue()
{
$this->testValueInitiallyUncheckedValue();
$this->element->setChecked(true);
$this->assertEquals($this->element->getCheckedValue(), $this->element->getValue());
}
public function testSettingCheckedFlagToFalseSetsValueToUncheckedValue()
{
$this->testSettingCheckedFlagToTrueSetsValueToCheckedValue();
$this->element->setChecked(false);
$this->assertEquals($this->element->getUncheckedValue(), $this->element->getValue());
}
public function testSettingValueToCheckedValueMarksElementAsChecked()
{
$this->testValueInitiallyUncheckedValue();
$this->element->setValue($this->element->getCheckedValue());
$this->assertTrue($this->element->checked);
}
public function testSettingValueToUncheckedValueMarksElementAsNotChecked()
{
$this->testSettingValueToCheckedValueMarksElementAsChecked();
$this->element->setValue($this->element->getUncheckedValue());
$this->assertFalse($this->element->checked);
}
public function testSetOptionsSetsInitialValueAccordingToCheckedAndUncheckedValues()
{
$options = array(
'checkedValue' => 'foo',
'uncheckedValue' => 'bar',
);
$element = new Zend_Form_Element_Checkbox('test', $options);
$this->assertEquals($options['uncheckedValue'], $element->getValue());
}
public function testSetOptionsSetsInitialValueAccordingToSubmittedValues()
{
$options = array(
'test1' => array(
'value' => 'foo',
'checkedValue' => 'foo',
'uncheckedValue' => 'bar',
),
'test2' => array(
'value' => 'bar',
'checkedValue' => 'foo',
'uncheckedValue' => 'bar',
),
);
foreach ($options as $current) {
$element = new Zend_Form_Element_Checkbox('test', $current);
$this->assertEquals($current['value'], $element->getValue());
$this->assertEquals($current['checkedValue'], $element->getCheckedValue());
$this->assertEquals($current['uncheckedValue'], $element->getUncheckedValue());
}
}
public function testCheckedValueAlwaysRenderedAsCheckboxValue()
{
$this->element->setValue($this->element->getUncheckedValue());
$html = $this->element->render($this->getView());
if (!preg_match_all('/(<input[^>]+>)/', $html, $matches)) {
$this->fail('Unexpected generated HTML: ' . $html);
}
$this->assertEquals(2, count($matches[1]));
foreach ($matches[1] as $element) {
if (strstr($element, 'hidden')) {
$this->assertContains($this->element->getUncheckedValue(), $element);
} else {
$this->assertContains($this->element->getCheckedValue(), $element);
}
}
}
/**
* Used by test methods susceptible to ZF-2794, marks a test as incomplete
*
* @link http://framework.zend.com/issues/browse/ZF-2794
* @return void
*/
protected function _checkZf2794()
{
if (strtolower(substr(PHP_OS, 0, 3)) == 'win' && version_compare(PHP_VERSION, '5.1.4', '=')) {
$this->markTestIncomplete('Error occurs for PHP 5.1.4 on Windows');
}
}
}
// Call Zend_Form_Element_CheckboxTest::main() if this source file is executed directly.
if (PHPUnit_MAIN_METHOD == "Zend_Form_Element_CheckboxTest::main") {
Zend_Form_Element_CheckboxTest::main();
}