5
* Copyright (c) 2002-2010, Sebastian Bergmann <sb@sebastian-bergmann.de>.
8
* Redistribution and use in source and binary forms, with or without
9
* modification, are permitted provided that the following conditions
12
* * Redistributions of source code must retain the above copyright
13
* notice, this list of conditions and the following disclaimer.
15
* * Redistributions in binary form must reproduce the above copyright
16
* notice, this list of conditions and the following disclaimer in
17
* the documentation and/or other materials provided with the
20
* * Neither the name of Sebastian Bergmann nor the names of his
21
* contributors may be used to endorse or promote products derived
22
* from this software without specific prior written permission.
24
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
25
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
26
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
27
* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
28
* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
29
* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
30
* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
31
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
32
* CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
33
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
34
* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
35
* POSSIBILITY OF SUCH DAMAGE.
39
* @author Mike Lively <m@digitalsandwich.com>
40
* @copyright 2002-2010 Sebastian Bergmann <sb@sebastian-bergmann.de>
41
* @license http://www.opensource.org/licenses/bsd-license.php BSD License
42
* @link http://www.phpunit.de/
43
* @since File available since Release 3.4.0
46
require_once ('PHPUnit/Extensions/Database/DataSet/ISpec.php');
47
require_once ('PHPUnit/Extensions/Database/DB/DefaultDatabaseConnection.php');
48
require_once ('PHPUnit/Extensions/Database/IDatabaseListConsumer.php');
51
* Creates a database dataset based off of a spec string.
53
* This spec class requires a list of databases to be set to the object before
54
* it can return a list of databases.
56
* The format of the spec string is as follows:
58
* <db label>:<schema>:<tables>
60
* The db label should be equal to one of the keys in the array of databases
61
* passed to setDatabases().
63
* The schema should be the primary schema you will be choosing tables from.
65
* The tables should be a comma delimited list of all tables you would like to
68
* The sql is the query you want to use to generate the table columns and data.
69
* The column names in the table will be identical to the column aliases in the
74
* @author Mike Lively <m@digitalsandwich.com>
75
* @copyright 2010 Mike Lively <m@digitalsandwich.com>
76
* @license http://www.opensource.org/licenses/bsd-license.php BSD License
77
* @version Release: 3.4.14
78
* @link http://www.phpunit.de//**
79
* @since Class available since Release 3.4.0
81
class PHPUnit_Extensions_Database_DataSet_Specs_DbTable implements PHPUnit_Extensions_Database_DataSet_ISpec, PHPUnit_Extensions_Database_IDatabaseListConsumer
86
protected $databases = array();
89
* Sets the database for the spec
91
* @param array $databases
93
public function setDatabases(array $databases)
95
$this->databases = $databases;
99
* Creates a DB Data Set from a data set spec.
101
* @param string $dataSetSpec
102
* @return PHPUnit_Extensions_Database_DataSet_IDataSet
104
public function getDataSet($dataSetSpec)
106
$pdoRflc = new ReflectionClass('PDO');
107
list($dbLabel, $schema, $tables) = explode(':', $dataSetSpec, 3);
109
$databaseInfo = $this->databases[$dbLabel];
110
$pdo = $pdoRflc->newInstanceArgs(explode('|', $databaseInfo));
112
$dbConnection = new PHPUnit_Extensions_Database_DB_DefaultDatabaseConnection($pdo, $schema);
113
return !empty($tables) ? $dbConnection->createDataSet(explode(',', $tables)) : $dbConnection->createDataSet();
b'\\ No newline at end of file'