1
|
|
|
<?php |
2
|
|
|
namespace StefanoTreeTest; |
3
|
|
|
|
4
|
|
|
use \PDO; |
5
|
|
|
|
6
|
|
|
class TestUtil |
7
|
|
|
{ |
8
|
|
|
private static $dbConnection; |
9
|
|
|
|
10
|
|
|
public static function createDbScheme() |
11
|
|
|
{ |
12
|
|
|
$connection = self::getPDOConnection(); |
13
|
|
|
|
14
|
|
|
$queries = array(); |
15
|
|
|
|
16
|
|
|
if ('mysql' == TEST_STEFANO_DB_ADAPTER) { |
17
|
|
|
$queries[] = 'DROP TABLE IF EXISTS `tree_traversal`'; |
18
|
|
|
|
19
|
|
|
$queries[] = 'CREATE TABLE `tree_traversal` ( |
20
|
|
|
`tree_traversal_id` int(11) NOT NULL AUTO_INCREMENT, |
21
|
|
|
`name` varchar(255) COLLATE utf8_bin DEFAULT NULL, |
22
|
|
|
`lft` int(11) NOT NULL, |
23
|
|
|
`rgt` int(11) NOT NULL, |
24
|
|
|
`parent_id` int(11) DEFAULT NULL, |
25
|
|
|
`level` int(11) DEFAULT NULL, |
26
|
|
|
PRIMARY KEY (`tree_traversal_id`), |
27
|
|
|
KEY `parent_id` (`parent_id`), |
28
|
|
|
KEY `level` (`level`), |
29
|
|
|
KEY `lft` (`lft`), |
30
|
|
|
KEY `rgt` (`rgt`) |
31
|
|
|
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin'; |
32
|
|
|
} elseif ('pgsql' == TEST_STEFANO_DB_ADAPTER) { |
33
|
|
|
$queries[] = 'DROP TABLE IF EXISTS tree_traversal'; |
34
|
|
|
|
35
|
|
|
$queries[] = 'CREATE TABLE tree_traversal ( |
36
|
|
|
tree_traversal_id serial NOT NULL, |
37
|
|
|
name character varying(255), |
38
|
|
|
lft integer NOT NULL, |
39
|
|
|
rgt integer NOT NULL, |
40
|
|
|
parent_id integer, |
41
|
|
|
level integer, |
42
|
|
|
CONSTRAINT tree_traversal_pkey PRIMARY KEY (tree_traversal_id) |
43
|
|
|
)'; |
44
|
|
|
} else { |
45
|
|
|
throw new \Exception(sprintf('Unsupported vendor %s', TEST_STEFANO_DB_ADAPTER)); |
46
|
|
|
} |
47
|
|
|
|
48
|
|
|
foreach ($queries as $query) { |
49
|
|
|
$connection->query($query); |
50
|
|
|
} |
51
|
|
|
} |
52
|
|
|
|
53
|
|
|
/** |
54
|
|
|
* Singleton |
55
|
|
|
* @return PDO |
56
|
|
|
*/ |
57
|
|
|
public static function getPDOConnection() |
58
|
|
|
{ |
59
|
|
|
if (null == self::$dbConnection) { |
60
|
|
|
$adapter = strtolower(TEST_STEFANO_DB_ADAPTER); |
61
|
|
|
$hostname = TEST_STEFANO_DB_HOSTNAME; |
62
|
|
|
$dbName = TEST_STEFANO_DB_DB_NAME; |
63
|
|
|
$user = TEST_STEFANO_DB_USER; |
64
|
|
|
$password = TEST_STEFANO_DB_PASSWORD; |
65
|
|
|
|
66
|
|
|
self::$dbConnection = new PDO( |
67
|
|
|
$adapter . ':host=' . $hostname . ';dbname=' |
68
|
|
|
. $dbName, $user, $password |
69
|
|
|
); |
70
|
|
|
} |
71
|
|
|
return self::$dbConnection; |
72
|
|
|
} |
73
|
|
|
} |
74
|
|
|
|