2 /*********************************************************************************
3 * SugarCRM Community Edition is a customer relationship management program developed by
4 * SugarCRM, Inc. Copyright (C) 2004-2013 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 class Bug48652Test extends Sugar_PHPUnit_Framework_TestCase
44 * Name of test option set
48 protected $options = 'bug_48652_options';
51 * Sets up the fixture, for example, open a network connection.
52 * This method is called before a test is executed.
54 public function setUp()
56 global $app_list_strings;
57 SugarTestHelper::setUp('app_strings');
58 SugarTestHelper::setUp('app_list_strings');
59 SugarTestHelper::setUp('mod_strings', array('Home'));
61 // populate test options with blank value
62 $app_list_strings[$this->options] = array(
68 * Tears down the fixture, for example, close a network connection.
69 * This method is called after a test is executed.
71 public function tearDown()
73 SugarTestHelper::tearDown();
77 * Ensure that module labels are built correctly
79 public function testBlankOptionsAreNotFiltered()
84 $field_name = 'bug_48652_field';
86 // create a bean with minimal needed set of field definitions
87 $seedBean = new SugarBean();
88 $seedBean->field_defs = array(
93 'remove_blank' => false,
94 'options' => $this->options,
98 // create a dashlet containing bean
99 require_once 'include/Dashlets/DashletGeneric.php';
100 $dashlet = new DashletGeneric(null);
101 $dashlet->seedBean = $seedBean;
102 $dashlet->columns = array();
103 $dashlet->searchFields = array(
104 $field_name => array(),
107 // generate dashlet setup form
108 $dashlet->processDisplayOptions();
110 // ensure that the generated element contains blank option
111 $search_fields = $dashlet->currentSearchFields;
112 $this->assertArrayHasKey($field_name, $search_fields);
113 $this->assertArrayHasKey('input', $search_fields[$field_name]);
114 $this->assertContains('>' . $app_strings['LBL_NONE'] . '<', $search_fields[$field_name]['input']);