%PDF-1.5 %���� ºaâÚÎΞ-ÌE1ÍØÄ÷{òò2ÿ ÛÖ^ÔÀá TÎ{¦?§®¥kuµùÕ5sLOšuY
| Server IP : 122.154.253.140  /  Your IP : 216.73.216.49 Web Server : Microsoft-IIS/7.5 System : Windows NT SERVER02 6.1 build 7601 (Windows Server 2008 R2 Standard Edition Service Pack 1) i586 User : IUSR ( 0) PHP Version : 5.6.31 Disable Function : NONE MySQL : ON | cURL : ON | WGET : OFF | Perl : OFF | Python : OFF | Sudo : OFF | Pkexec : OFF Directory : C:/inetpub/wwwroot-25650203-BK/wwwroot/phpMyAdmin/test/classes/plugin/export/  | 
Upload File :  | 
<?php
/* vim: set expandtab sw=4 ts=4 sts=4: */
/**
 * tests for PMA\libraries\plugins\export\TableProperty class
 *
 * @package PhpMyAdmin-test
 */
use PMA\libraries\plugins\export\TableProperty;
require_once 'libraries/config.default.php';
require_once 'test/PMATestCase.php';
/**
 * tests for PMA\libraries\plugins\export\TableProperty class
 *
 * @package PhpMyAdmin-test
 */
class TablePropertyTest extends PMATestCase
{
    protected $object;
    /**
     * Configures global environment.
     *
     * @return void
     */
    function setup()
    {
        $GLOBALS['server'] = 0;
        $row = array(' name ', 'int ', true, ' PRI', '0', 'mysql');
        $this->object = new TableProperty($row);
    }
    /**
     * tearDown for test cases
     *
     * @return void
     */
    public function tearDown()
    {
        unset($this->object);
    }
    /**
     * Test for PMA\libraries\plugins\export\TableProperty::__construct
     *
     * @return void
    */
    public function testConstructor()
    {
        $this->assertEquals(
            'name',
            $this->object->name
        );
        $this->assertEquals(
            'int',
            $this->object->type
        );
        $this->assertEquals(
            1,
            $this->object->nullable
        );
        $this->assertEquals(
            'PRI',
            $this->object->key
        );
        $this->assertEquals(
            '0',
            $this->object->defaultValue
        );
        $this->assertEquals(
            'mysql',
            $this->object->ext
        );
    }
    /**
     * Test for PMA\libraries\plugins\export\TableProperty::getPureType
     *
     * @return void
    */
    public function testGetPureType()
    {
        $this->object->type = "int(10)";
        $this->assertEquals(
            "int",
            $this->object->getPureType()
        );
        $this->object->type = "char";
        $this->assertEquals(
            "char",
            $this->object->getPureType()
        );
    }
    /**
     * Test for PMA\libraries\plugins\export\TableProperty::isNotNull
     *
     * @param string $nullable nullable value
     * @param string $expected expected output
     *
     * @return void
     * @dataProvider isNotNullProvider
     */
    public function testIsNotNull($nullable, $expected)
    {
        $this->object->nullable = $nullable;
        $this->assertEquals(
            $expected,
            $this->object->isNotNull()
        );
    }
    /**
     * Data provider for testIsNotNull
     *
     * @return array Test Data
     */
    public function isNotNullProvider()
    {
        return array(
            array("NO", "true"),
            array("", "false"),
            array("no", "false")
        );
    }
    /**
     * Test for PMA\libraries\plugins\export\TableProperty::isUnique
     *
     * @param string $key      key value
     * @param string $expected expected output
     *
     * @return void
     * @dataProvider isUniqueProvider
     */
    public function testIsUnique($key, $expected)
    {
        $this->object->key = $key;
        $this->assertEquals(
            $expected,
            $this->object->isUnique()
        );
    }
    /**
     * Data provider for testIsUnique
     *
     * @return array Test Data
     */
    public function isUniqueProvider()
    {
        return array(
            array("PRI", "true"),
            array("UNI", "true"),
            array("", "false"),
            array("pri", "false"),
            array("uni", "false"),
        );
    }
    /**
     * Test for PMA\libraries\plugins\export\TableProperty::getDotNetPrimitiveType
     *
     * @param string $type     type value
     * @param string $expected expected output
     *
     * @return void
     * @dataProvider getDotNetPrimitiveTypeProvider
     */
    public function testGetDotNetPrimitiveType($type, $expected)
    {
        $this->object->type = $type;
        $this->assertEquals(
            $expected,
            $this->object->getDotNetPrimitiveType()
        );
    }
    /**
     * Data provider for testGetDotNetPrimitiveType
     *
     * @return array Test Data
     */
    public function getDotNetPrimitiveTypeProvider()
    {
        return array(
            array("int", "int"),
            array("long", "long"),
            array("char", "string"),
            array("varchar", "string"),
            array("text", "string"),
            array("longtext", "string"),
            array("tinyint", "bool"),
            array("datetime", "DateTime"),
            array("", "unknown"),
            array("dummy", "unknown"),
            array("INT", "unknown")
        );
    }
    /**
     * Test for PMA\libraries\plugins\export\TableProperty::getDotNetObjectType
     *
     * @param string $type     type value
     * @param string $expected expected output
     *
     * @return void
     * @dataProvider getDotNetObjectTypeProvider
     */
    public function testGetDotNetObjectType($type, $expected)
    {
        $this->object->type = $type;
        $this->assertEquals(
            $expected,
            $this->object->getDotNetObjectType()
        );
    }
    /**
     * Data provider for testGetDotNetObjectType
     *
     * @return array Test Data
     */
    public function getDotNetObjectTypeProvider()
    {
        return array(
            array("int", "Int32"),
            array("long", "Long"),
            array("char", "String"),
            array("varchar", "String"),
            array("text", "String"),
            array("longtext", "String"),
            array("tinyint", "Boolean"),
            array("datetime", "DateTime"),
            array("", "Unknown"),
            array("dummy", "Unknown"),
            array("INT", "Unknown")
        );
    }
    /**
     * Test for PMA\libraries\plugins\export\TableProperty::getIndexName
     *
     * @return void
     */
    public function testGetIndexName()
    {
        $this->object->name = "ä'7<ab>";
        $this->object->key = "PRI";
        $this->assertEquals(
            "index=\"ä'7<ab>\"",
            $this->object->getIndexName()
        );
        $this->object->key = "";
        $this->assertEquals(
            "",
            $this->object->getIndexName()
        );
    }
    /**
     * Test for PMA\libraries\plugins\export\TableProperty::isPK
     *
     * @return void
     */
    public function testIsPK()
    {
        $this->object->key = "PRI";
        $this->assertTrue(
            $this->object->isPK()
        );
        $this->object->key = "";
        $this->assertFalse(
            $this->object->isPK()
        );
    }
    /**
     * Test for PMA\libraries\plugins\export\TableProperty::formatCs
     *
     * @return void
    */
    public function testFormatCs()
    {
        $this->object->name = 'Name#name#123';
        $this->assertEquals(
            'text123Namename',
            $this->object->formatCs("text123#name#")
        );
    }
    /**
     * Test for PMA\libraries\plugins\export\TableProperty::formatXml
     *
     * @return void
    */
    public function testFormatXml()
    {
        $this->object->name = '"a\'';
        $this->assertEquals(
            '"a\'index=""a\'"',
            $this->object->formatXml("#name##indexName#")
        );
    }
    /**
     * Test for PMA\libraries\plugins\export\TableProperty::format
     *
     * @return void
    */
    public function testFormat()
    {
        $this->assertEquals(
            'NameintInt32intfalsetrue',
            $this->object->format(
                "#ucfirstName##dotNetPrimitiveType##dotNetObjectType##type#" .
                "#notNull##unique#"
            )
        );
    }
}