]> CyberLeo.Net >> Repos - Github/sugarcrm.git/blob - tests/include/ValidDBNameTest.php
Release 6.3.0
[Github/sugarcrm.git] / tests / include / ValidDBNameTest.php
1 <?php
2 /*********************************************************************************
3  * SugarCRM Community Edition is a customer relationship management program developed by
4  * SugarCRM, Inc. Copyright (C) 2004-2011 SugarCRM Inc.
5  * 
6  * This program is free software; you can redistribute it and/or modify it under
7  * the terms of the GNU Affero General Public License version 3 as published by the
8  * Free Software Foundation with the addition of the following permission added
9  * to Section 15 as permitted in Section 7(a): FOR ANY PART OF THE COVERED WORK
10  * IN WHICH THE COPYRIGHT IS OWNED BY SUGARCRM, SUGARCRM DISCLAIMS THE WARRANTY
11  * OF NON INFRINGEMENT OF THIRD PARTY RIGHTS.
12  * 
13  * This program is distributed in the hope that it will be useful, but WITHOUT
14  * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
15  * FOR A PARTICULAR PURPOSE.  See the GNU Affero General Public License for more
16  * details.
17  * 
18  * You should have received a copy of the GNU Affero General Public License along with
19  * this program; if not, see http://www.gnu.org/licenses or write to the Free
20  * Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
21  * 02110-1301 USA.
22  * 
23  * You can contact SugarCRM, Inc. headquarters at 10050 North Wolfe Road,
24  * SW2-130, Cupertino, CA 95014, USA. or at email address contact@sugarcrm.com.
25  * 
26  * The interactive user interfaces in modified source and object code versions
27  * of this program must display Appropriate Legal Notices, as required under
28  * Section 5 of the GNU Affero General Public License version 3.
29  * 
30  * In accordance with Section 7(b) of the GNU Affero General Public License version 3,
31  * these Appropriate Legal Notices must retain the display of the "Powered by
32  * SugarCRM" logo. If the display of the logo is not reasonably feasible for
33  * technical reasons, the Appropriate Legal Notices must display the words
34  * "Powered by SugarCRM".
35  ********************************************************************************/
36
37  
38 require_once("include/utils.php");
39
40 class ValidDBNameTest extends Sugar_PHPUnit_Framework_TestCase
41 {
42     public function testShortNameUneffected()
43     {
44         $this->assertEquals(
45             'idx_test_123_id',
46             getValidDBName('idx_test_123_id')
47         );
48     }
49
50     public function testmaxLengthParam()
51     {
52         $this->assertEquals(
53             'idx_test_123_456_789_foo_bar_id',
54             getValidDBName('idx_test_123_456_789_foo_bar_id', false, 40)
55         );
56     }
57
58     public function testEnsureUnique()
59     {
60         $this->assertEquals(
61             getValidDBName('idx_test_123_456_789_foo_bar_id', true),
62             getValidDBName('idx_test_123_456_789_foo_bar_id', true)
63         );
64
65         $this->assertNotEquals(
66             getValidDBName('idx_test_123_456_789_foo_bar_id', true),
67             getValidDBName('idx_test_123_446_789_foo_bar_id', true)
68         );
69     }
70
71     public function testValidMySQLNameReturnsTrue()
72     {
73         $this->assertTrue(isValidDBName('sugarCRM', 'mysql'));
74         $this->assertTrue(isValidDBName('sugar-crm', 'mysql'));
75         $this->assertTrue(isValidDBName('sugar_crm', 'mysql'));
76         $this->assertTrue(isValidDBName('sugar-crm', 'mysql'));
77         $this->assertTrue(isValidDBName('sugar-CRM_ver6', 'mysql'));
78     }
79
80     public function testInvalidMySQLNameReturnsFalse()
81     {
82         $this->assertFalse(isValidDBName('sugar/crm', 'mysql'));
83         $this->assertFalse(isValidDBName('sugar\crm', 'mysql'));
84         $this->assertFalse(isValidDBName('sugar.crm', 'mysql'));
85     }
86
87     public function testValidOracleNameReturnsTrue()
88     {
89         $this->assertTrue(isValidDBName('sugarCRM', 'oci8'));
90         $this->assertTrue(isValidDBName('sugar_crm', 'oci8'));
91         $this->assertTrue(isValidDBName('sugarCRM_ver6', 'oci8'));
92     }
93
94     public function testInvalidOracleNameReturnsFalse()
95     {
96         $this->assertFalse(isValidDBName('sugar\CRM', 'oci8'));
97         $this->assertFalse(isValidDBName('sugar crm', 'oci8'));
98         $this->assertFalse(isValidDBName('sugarCRM_ver#63', 'oci8'));
99     }
100
101     public function testValidMSSQLNameReturnsTrue()
102     {
103         $this->assertTrue(isValidDBName('sugarCRM', 'mssql'));
104         $this->assertTrue(isValidDBName('sugar_crm', 'mssql'));
105         $this->assertTrue(isValidDBName('sugarCRM_ver6', 'mssql'));
106     }
107
108     public function testInvalidMSSQLNameReturnsFalse()
109     {
110         $this->assertFalse(isValidDBName('622sugarCRM', 'mssql'));
111         $this->assertFalse(isValidDBName('sugar crm', 'mssql'));
112         $this->assertFalse(isValidDBName('#sugarCRM_ver6', 'mssql'));
113     }
114     
115     public function testLongNameEffected()
116     {
117         $this->assertNotEquals(
118             getValidDBName('eeeee_eeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeee_opportunities', true),
119             getValidDBName('eeeee_eeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeee1_opportunities', true)
120         );
121     }
122 }