2 /*********************************************************************************
3 * SugarCRM Community Edition is a customer relationship management program developed by
4 * SugarCRM, Inc. Copyright (C) 2004-2011 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 ********************************************************************************/
38 require_once('modules/Configurator/Configurator.php');
39 require_once('modules/EmailMan/EmailMan.php');
42 * Test cases for Bug 44113
44 class Bug44113Test extends Sugar_PHPUnit_Framework_TestCase
46 private $cfg; // configurator
48 private $email_xss; // the security settings to be saved in config_ovverride
49 private $original_email_xss = null;
51 public function setUp()
53 $GLOBALS['current_user'] = SugarTestUserUtilities::createAnonymousUser();
54 $GLOBALS['current_user']->is_admin = '1';
55 require("config.php");
56 if(isset($sugar_config['email_xss']))
58 $this->_original_email_xss = $sugar_config['email_xss'];
59 $this->cfg = new Configurator();
60 $this->cfg->config['email_xss'] = getDefaultXssTags();
61 $this->cfg->handleOverride();
64 // email_xss settings to be saved using config_override
65 $this->email_xss = array(
66 //'applet' => 'applet',
74 public function tearDown()
76 if(isset($this->original_email_xss))
78 $this->cfg = new Configurator();
79 $this->cfg->config['email_xss'] = $this->original_email_xss;
80 $this->cfg->handleOverride();
83 unset($this->emailMan);
84 unset($this->email_xss);
85 unset($GLOBALS['current_user']);
89 public function testEmailManController()
93 require_once('modules/EmailMan/controller.php');
94 require_once('include/MVC/Controller/SugarController.php');
97 $conn = new EmailManController();
99 // populate the REQUEST array because configurator will read that to write config_override
100 foreach ($this->email_xss as $key=>$val) {
101 $_REQUEST["$key"] = $val;
104 $new_security_settings = base64_encode(serialize($this->email_xss));
106 // make sure that settings from config.php are untouched
107 $original_security_settings = getDefaultXssTags();
108 $this->assertNotEquals($original_security_settings, $new_security_settings, "ensure that original email_xss is not touched");
110 $conn->action_Save(); // testing the save,
111 // it should use the above request vars
112 // to create a new config_override.php
114 // now check to make sure that config_override received the updated settings
115 require("config_override.php");
116 $this->assertEquals($new_security_settings, $sugar_config['email_xss'],
117 "testing that new email_xss settings got saved");
124 * make sure that new configs are saved using handleOverride
126 public function testSavingToConfigOverride()
128 $this->cfg = new Configurator();
129 global $sugar_config;
131 $new_security_settings = base64_encode(serialize($this->email_xss));
133 $this->cfg->config['email_xss'] = $new_security_settings;
134 $this->cfg->handleOverride();
136 // just test to make sure that configuration is saved
137 $this->assertEquals($sugar_config['email_xss'], $new_security_settings, "testing configurator");