This repository was archived by the owner on Aug 19, 2022. It is now read-only.
-
-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy pathTruncateTest.php
117 lines (99 loc) · 2.67 KB
/
TruncateTest.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
<?php
/**
* SQL database management to be used by several providers at the same time.
*
* @author Josantonius <[email protected]>
* @copyright 2017 - 2018 (c) Josantonius - PHP-Database
* @license https://opensource.org/licenses/MIT - The MIT License (MIT)
* @link https://github.com/Josantonius/PHP-Database
* @since 1.1.6
*/
namespace Josantonius\Database;
use PHPUnit\Framework\TestCase;
/**
* Test class for "TRUNCATE" query.
*/
final class TruncateTest extends TestCase
{
/**
* Database instance.
*
* @since 1.1.7
*
* @var object
*/
private $db;
/**
* Setup.
*
* @since 1.1.7
*/
public function setUp()
{
parent::setUp();
$this->db = Database::getConnection(
'identifier',
'PDOprovider',
$GLOBALS['DB_HOST'],
$GLOBALS['DB_USER'],
$GLOBALS['DB_NAME'],
$GLOBALS['DB_PASSWORD'],
['charset' => 'utf8']
);
}
/**
* [QUERY] [TRUNCATE TABLE]
*/
public function testTruncateTableQuery()
{
$result = $this->db->query(
'INSERT INTO test_table_three (name, email)
VALUES ("Isis", "[email protected]")'
);
$this->assertSame(1, $result);
$result = $this->db->query('TRUNCATE TABLE `test_table_three`');
$this->assertTrue($result);
}
/**
* [QUERY] [TRUNCATE TABLE] [EXCEPTION]
*
* @expectedException \Josantonius\Database\Exception\DBException
*
* @expectedExceptionMessageRegExp (table|not|found|Table|exists)
*/
public function testTruncateTableQueryTableNameError()
{
$result = $this->db->query('TRUNCATE TABLE `xxxx`');
}
/**
* [METHOD] [TRUNCATE TABLE]
*/
public function testTruncateTableMethod()
{
$data = [
'name' => 'Isis',
'email' => '[email protected]',
];
$query = $this->db->insert($data)
->in('test_table_three');
$result = $query->execute();
$this->assertSame(1, $result);
$query = $this->db->truncate()
->table('test_table_three');
$result = $query->execute();
$this->assertTrue($result);
}
/**
* [METHOD] [TRUNCATE TABLE] [EXCEPTION]
*
* @expectedException \Josantonius\Database\Exception\DBException
*
* @expectedExceptionMessageRegExp (table|not|found|Table|exists)
*/
public function testTruncateTableMethodTableNameError()
{
$query = $this->db->truncate()
->table('xxxx');
$result = $query->execute();
}
}