]> CyberLeo.Net >> Repos - Github/sugarcrm.git/blob - tests/include/SugarFolders/Bug33404Test.php
Release 6.4.0
[Github/sugarcrm.git] / tests / include / SugarFolders / Bug33404Test.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/SugarFolders/SugarFolders.php');
39
40 /**
41  * @ticket 33404
42  */
43 class Bug33404Test extends Sugar_PHPUnit_Framework_TestCase
44 {
45         var $folder = null;
46     var $_user = null;
47     
48     
49         public function setUp()
50     {
51         global $current_user, $currentModule;
52
53         $this->_user = SugarTestUserUtilities::createAnonymousUser();
54         $GLOBALS['db']->query("DELETE FROM folders_subscriptions WHERE assigned_user_id='{$this->_user->id}'");
55                 $this->folder = new SugarFolder(); 
56         }
57
58     public function tearDown()
59     {
60         SugarTestUserUtilities::removeAllCreatedAnonymousUsers();
61         unset($GLOBALS['current_user']);
62         
63         $GLOBALS['db']->query("DELETE FROM folders_subscriptions WHERE assigned_user_id='{$this->_user->id}'");
64         
65         unset($this->folder);
66     }
67     
68         function testInsertFolderSubscription(){
69             global $current_user;
70            
71             $id1 = create_guid();
72             $id2 = create_guid();
73             
74             $this->folder->insertFolderSubscription($id1,$this->_user->id);
75             $this->folder->insertFolderSubscription($id2,$this->_user->id);
76             
77             $result = $GLOBALS['db']->query("SELECT count(*) as cnt FROM folders_subscriptions where assigned_user_id='{$this->_user->id}'");
78                 $rs = $GLOBALS['db']->fetchByAssoc($result);
79                 
80                 $this->assertEquals(2, $rs['cnt'], "Could not insert folder subscriptions properly" );
81     }
82     
83     
84     
85     function testClearSubscriptionsForFolder()
86     {
87         global $current_user;
88            
89         $random_user_id1 = create_guid();
90         $random_user_id2 = create_guid();
91         $random_user_id3 = create_guid();
92         
93             $folderID = create_guid();
94             
95             $this->folder->insertFolderSubscription($folderID,$random_user_id1);
96         $this->folder->insertFolderSubscription($folderID,$random_user_id2);
97         $this->folder->insertFolderSubscription($folderID,$random_user_id3);
98             
99         $result1 = $GLOBALS['db']->query("SELECT count(*) as cnt FROM folders_subscriptions where folder_id='{$folderID}' ");
100                 $rs1 = $GLOBALS['db']->fetchByAssoc($result1);
101         $this->assertEquals(3, $rs1['cnt'], "Could not clear folder subscriptions, test setup failed while inserting folder subscriptionss");
102         
103         //Test deletion of subscriptions.
104         $this->folder->clearSubscriptionsForFolder($folderID);
105             $result = $GLOBALS['db']->query("SELECT count(*) as cnt FROM folders_subscriptions where folder_id='{$folderID}' ");
106                 $rs = $GLOBALS['db']->fetchByAssoc($result);
107          
108                 $this->assertEquals(0, $rs['cnt'], "Could not clear folder subscriptions");
109     }
110 }
111 ?>