ManagerTestCase.php 5.08 KB
Newer Older
doctrine's avatar
doctrine committed
1
<?php
zYne's avatar
zYne committed
2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18
/*
 *  $Id$
 *
 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
 * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
 * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
 *
 * This software consists of voluntary contributions made by many individuals
 * and is licensed under the LGPL. For more information, see
19
 * <http://www.phpdoctrine.org>.
zYne's avatar
zYne committed
20 21 22 23 24 25 26 27 28
 */

/**
 * Doctrine_Manager_TestCase
 *
 * @package     Doctrine
 * @author      Konsta Vesterinen <kvesteri@cc.hut.fi>
 * @license     http://www.opensource.org/licenses/lgpl-license.php LGPL
 * @category    Object Relational Mapping
29
 * @link        www.phpdoctrine.org
zYne's avatar
zYne committed
30 31 32 33
 * @since       1.0
 * @version     $Revision$
 */
class Doctrine_Manager_TestCase extends Doctrine_UnitTestCase {
doctrine's avatar
doctrine committed
34 35 36
    public function testGetInstance() {
        $this->assertTrue(Doctrine_Manager::getInstance() instanceOf Doctrine_Manager);
    }
zYne's avatar
zYne committed
37 38
    public function testOpenConnection() {
        $this->assertTrue($this->connection instanceOf Doctrine_Connection);
doctrine's avatar
doctrine committed
39 40 41 42 43
    }
    public function testGetIterator() {
        $this->assertTrue($this->manager->getIterator() instanceof ArrayIterator);
    }
    public function testCount() {
44
        $this->assertTrue(is_integer(count($this->manager)));
doctrine's avatar
doctrine committed
45
    }
zYne's avatar
zYne committed
46
    public function testGetCurrentConnection() {
47
        $this->assertTrue($this->manager->getCurrentConnection() === $this->connection);
doctrine's avatar
doctrine committed
48
    }
zYne's avatar
zYne committed
49
    public function testGetConnections() {
50
        $this->assertTrue(is_integer(count($this->manager->getConnections())));
51 52 53 54 55 56 57
    }
    public function testClassifyTableize() {
        $name = "Forum_Category";
        $this->assertEqual(Doctrine::tableize($name), "forum__category");
        $this->assertEqual(Doctrine::classify(Doctrine::tableize($name)), $name);
        
        
Jonathan.Wage's avatar
Jonathan.Wage committed
58 59 60 61 62 63 64 65 66 67
    }
    public function testDsnParser()
    {
        $mysql = 'mysql://user:pass@localhost/dbname';
        
        // This is what is specified in the manul
        // I think it should be this for parse_url() to work
        // sqlite://full/unix/path/to/file.db
        // It expects only // since it thinks it is parsing a url
        // The problem after that is that the dns is not valid when being passed to PDO
68 69
        $sqlite = 'sqlite:////full/unix/path/to/file.db';
        $sqlitewin = 'sqlite:///c:/full/windows/path/to/file.db';
Jonathan.Wage's avatar
Jonathan.Wage committed
70 71 72 73
        
        $manager = Doctrine_Manager::getInstance();
        
        try {
74 75 76 77 78 79 80 81 82 83 84 85 86
            $res = $manager->parseDsn($mysql);
            $expectedMysqlDsn = array(
                "scheme" => "mysql",
                "host" => "localhost",
                "user" => "user",
                "pass" => "pass",
                "path" => "/dbname",
                "dsn" => "mysql:host=localhost;dbname=dbname",
                "port" => NULL,
                "query" => NULL, 
                "fragment" => NULL,
                "database" => "dbname");
            $this->assertEqual($expectedMysqlDsn, $res);
Jonathan.Wage's avatar
Jonathan.Wage committed
87
        } catch (Exception $e) {
88
            $this->fail($e->getMessage());
Jonathan.Wage's avatar
Jonathan.Wage committed
89 90 91
        }
        
        try {
92 93 94 95 96 97 98 99 100 101 102 103 104 105
            $expectedDsn = array(
                "scheme" => "sqlite",
                "host" => null,
                "user" => null,
                "pass" => null,
                "path" => "/full/unix/path/to/file.db",
                "dsn" => "sqlite:/full/unix/path/to/file.db",
                "port" => NULL,
                "query" => NULL, 
                "fragment" => NULL,
                "database" => "/full/unix/path/to/file.db");
              
            $res = $manager->parseDsn($sqlite);
            $this->assertEqual($expectedDsn, $res);
Jonathan.Wage's avatar
Jonathan.Wage committed
106
        } catch (Exception $e) {
107
            $this->fail($e->getMessage());
Jonathan.Wage's avatar
Jonathan.Wage committed
108 109 110
        }
        
        try {
111 112
             $expectedDsn = array(
                "scheme" => "sqlite",
113
                "host" => null,
114 115 116 117 118 119 120 121 122 123
                "path" => "c:/full/windows/path/to/file.db",
                "dsn" => "sqlite:c:/full/windows/path/to/file.db",
                "port" => NULL,
                "user" => null,
                "pass" => null,
                "query" => NULL, 
                "fragment" => NULL,
                "database" => "c:/full/windows/path/to/file.db");
            $res = $manager->parseDsn($sqlitewin);
            $this->assertEqual($expectedDsn, $res);
Jonathan.Wage's avatar
Jonathan.Wage committed
124
        } catch (Exception $e) {
125
            $this->fail($e->getMessage());
Jonathan.Wage's avatar
Jonathan.Wage committed
126
        }
doctrine's avatar
doctrine committed
127
    }
128 129
    public function prepareData() { }
    public function prepareTables() { }
doctrine's avatar
doctrine committed
130
}