2 /*********************************************************************************
3 * SugarCRM Community Edition is a customer relationship management program developed by
4 * SugarCRM, Inc. Copyright (C) 2004-2012 SugarCRM Inc.
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.
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
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
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.
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.
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 ********************************************************************************/
41 * This class contains the unit test to check that the repairSearchFields method will create a SearchFields.php file
42 * to correctly handle range searching for date fields.
46 require_once('modules/UpgradeWizard/uw_utils.php');
48 class Bug46028Test extends Sugar_PHPUnit_Framework_TestCase
51 var $customOpportunitiesSearchFields;
52 var $opportunitiesSearchFields;
54 public function setUp()
56 if(file_exists('custom/modules/Opportunities/metadata/SearchFields.php'))
58 $this->customOpportunitiesSearchFields = file_get_contents('custom/modules/Opportunities/metadata/SearchFields.php');
59 unlink('custom/modules/Opportunities/metadata/SearchFields.php');
62 if(file_exists('modules/Opportunities/metadata/SearchFields.php'))
64 $this->opportunitiesSearchFields = file_get_contents('modules/Opportunities/metadata/SearchFields.php');
65 unlink('modules/Opportunities/metadata/SearchFields.php');
68 $searchFieldContents = <<<EOQ
70 \$searchFields['Opportunities'] =
72 'name' => array( 'query_type'=>'default'),
73 'account_name'=> array('query_type'=>'default','db_field'=>array('accounts.name')),
74 'amount'=> array('query_type'=>'default'),
75 'next_step'=> array('query_type'=>'default'),
76 'probability'=> array('query_type'=>'default'),
77 'lead_source'=> array('query_type'=>'default', 'operator'=>'=', 'options' => 'lead_source_dom', 'template_var' => 'LEAD_SOURCE_OPTIONS'),
78 'opportunity_type'=> array('query_type'=>'default', 'operator'=>'=', 'options' => 'opportunity_type_dom', 'template_var' => 'TYPE_OPTIONS'),
79 'sales_stage'=> array('query_type'=>'default', 'operator'=>'=', 'options' => 'sales_stage_dom', 'template_var' => 'SALES_STAGE_OPTIONS', 'options_add_blank' => true),
80 'current_user_only'=> array('query_type'=>'default','db_field'=>array('assigned_user_id'),'my_items'=>true, 'vname' => 'LBL_CURRENT_USER_FILTER', 'type' => 'bool'),
81 'assigned_user_id'=> array('query_type'=>'default'),
82 'favorites_only' => array(
83 'query_type'=>'format',
84 'operator' => 'subquery',
85 'subquery' => 'SELECT sugarfavorites.record_id FROM sugarfavorites
86 WHERE sugarfavorites.deleted=0
87 and sugarfavorites.module = \'Opportunities\'
88 and sugarfavorites.assigned_user_id = \'{0}\'',
89 'db_field'=>array('id')),
94 file_put_contents('modules/Opportunities/metadata/SearchFields.php', $searchFieldContents);
97 public function tearDow()
99 if(!empty($this->customOpportunitiesSearchFields))
101 file_put_contents('custom/modules/Opportunities/metadata/SearchFields.php', $this->customOpportunitiesSearchFields);
102 } else if(file_exists('custom/modules/Opportunities/metadata/SearchFields.php')) {
103 unlink('custom/modules/Opportunities/metadata/SearchFields.php');
106 if(!empty($this->opportunitiesSearchFields))
108 file_put_contents('modules/Opportunities/metadata/SearchFields.php', $this->opportunitiesSearchFields);
112 public function testRepairSearchFields()
114 repairSearchFields('modules/Opportunities/metadata/SearchFields.php');
115 $this->assertTrue(file_exists('custom/modules/Opportunities/metadata/SearchFields.php'));
116 require('custom/modules/Opportunities/metadata/SearchFields.php');
117 $this->assertArrayHasKey('range_date_entered', $searchFields['Opportunities']);
118 $this->assertArrayHasKey('start_range_date_entered', $searchFields['Opportunities']);
119 $this->assertArrayHasKey('end_range_date_entered', $searchFields['Opportunities']);
120 $this->assertArrayHasKey('range_date_modified', $searchFields['Opportunities']);
121 $this->assertArrayHasKey('start_range_date_modified', $searchFields['Opportunities']);
122 $this->assertArrayHasKey('end_range_date_modified', $searchFields['Opportunities']);