]> CyberLeo.Net >> Repos - Github/sugarcrm.git/blob - tests/include/Smarty/plugins/FunctionMultienumToArrayTest.php
Release 6.2.0
[Github/sugarcrm.git] / tests / include / Smarty / plugins / FunctionMultienumToArrayTest.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/Smarty/plugins/function.multienum_to_array.php');
39 require_once 'include/Sugar_Smarty.php';
40
41 class FunctionMultienumToArrayTest extends Sugar_PHPUnit_Framework_TestCase
42 {
43     public function setUp()
44     {
45         $this->_smarty = new Sugar_Smarty;
46     }
47     
48     public function providerPassedString()
49     {
50         return array(
51             array("Employee^,^Boss","Cold Call",array('Employee','Boss')),
52             array("^Employee^,^Boss^","Cold Call",array('Employee','Boss')),
53             array("^Employee^","Cold Call",array('Employee')),
54             array("Employee","Cold Call",array('Employee')),
55             array("","^Cold Call^",array("Cold Call")),
56             array(array("Employee"),"Cold Call",array("Employee")),
57             array(NULL,array("Employee"),array("Employee")),
58             );
59     }
60     
61     /**
62      * @ticket 21574
63      * @dataProvider providerPassedString
64      */
65         public function testPassedString(
66         $string,
67         $default,
68         $result
69         )
70     {
71         $params = array();
72         $params['string']  = $string;
73         $params['default'] = $default;
74         
75         $this->assertEquals($result, smarty_function_multienum_to_array($params, $this->_smarty));
76     }
77         
78         public function testAssignSmartyVariable()
79     {
80         $params = array();
81         $params['string']  = "^Employee^";
82         $params['default'] = "Cold Call";
83                 $params['assign'] = "multi";
84                 smarty_function_multienum_to_array($params, $this->_smarty);
85         
86         $this->assertEquals(
87             $this->_smarty->get_template_vars($params['assign']),
88             array("Employee")
89         );
90     }
91 }