All Data Structures Functions Variables Pages
SQLQueryUtilTest.php
1 <?php
2  /*********************************************************************************
3  * Zurmo is a customer relationship management program developed by
4  * Zurmo, Inc. Copyright (C) 2017 Zurmo Inc.
5  *
6  * Zurmo 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 ZURMO, ZURMO DISCLAIMS THE WARRANTY
11  * OF NON INFRINGEMENT OF THIRD PARTY RIGHTS.
12  *
13  * Zurmo 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 Zurmo, Inc. with a mailing address at 27 North Wacker Drive
24  * Suite 370 Chicago, IL 60606. or at email address contact@zurmo.com.
25  *
26  * The interactive user interfaces in original and modified 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 Zurmo
32  * logo and Zurmo copyright notice. If the display of the logo is not reasonably
33  * feasible for technical reasons, the Appropriate Legal Notices must display the words
34  * "Copyright Zurmo Inc. 2017. All rights reserved".
35  ********************************************************************************/
36 
37  class SQLQueryUtilTest extends BaseTest
38  {
39  public function testMakeQuery()
40  {
42  //Test simple query
43  $selectQueryAdapter = new RedBeanModelSelectQueryAdapter();
44  $selectQueryAdapter->addClause('a', 'b', 'c');
45  $joinTablesAdapter = new RedBeanModelJoinTablesQueryAdapter('A');
46  $sql = SQLQueryUtil::
47  makeQuery('myTable', $selectQueryAdapter, $joinTablesAdapter, 2, 4, 'a = x', 'something asc');
48  $compareSql = "select {$quote}a{$quote}.{$quote}b{$quote} c ";
49  $compareSql .= "from {$quote}myTable{$quote} ";
50  $compareSql .= "where a = x ";
51  $compareSql .= "order by something asc ";
52  $compareSql .= 'limit 4 offset 2';
53  $this->assertEquals($compareSql, $sql);
54  }
55 
56  public function testMakeQueryWithGroupBy()
57  {
59  //Test simple query
60  $selectQueryAdapter = new RedBeanModelSelectQueryAdapter();
61  $selectQueryAdapter->addClause('a', 'b', 'c');
62  $joinTablesAdapter = new RedBeanModelJoinTablesQueryAdapter('A');
63  $sql = SQLQueryUtil::
64  makeQuery('myTable', $selectQueryAdapter, $joinTablesAdapter, 2, 4, 'a = x', null, 'a.group');
65  $compareSql = "select {$quote}a{$quote}.{$quote}b{$quote} c ";
66  $compareSql .= "from {$quote}myTable{$quote} ";
67  $compareSql .= "where a = x ";
68  $compareSql .= "group by a.group ";
69  $compareSql .= 'limit 4 offset 2';
70  $this->assertEquals($compareSql, $sql);
71  }
72  }
73 ?>
Generated on Fri Jun 5 2020 07:10:28