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 "include/export_utils.php";
40 class Bug36422Test extends Sugar_PHPUnit_Framework_TestCase
43 * Contains created prospect lists' ids
46 protected static $_createdProspectListsIds = array();
49 * Instance of ProspectList
52 protected $_prospectList;
58 protected $_contacts = array();
61 * Create contact instance (with account)
63 public static function createContact()
65 $contact = SugarTestContactUtilities::createContact();
66 $account = SugarTestAccountUtilities::createAccount();
67 $contact->account_id = $account->id;
73 * Create ProspectList instance
74 * @param Contact instance to attach to prospect list
76 public static function createProspectList($contact = null)
78 $prospectList = new ProspectList();
79 $prospectList->name = "test";
80 $prospectList->save();
81 self::$_createdProspectListsIds[] = $prospectList->id;
83 if ($contact instanceof Contact) {
84 self::attachContactToProspectList($prospectList, $contact);
92 * Attach Contact to prospect list
93 * @param ProspectList $prospectList prospect list instance
94 * @param Contact $contact contact instance
96 public static function attachContactToProspectList($prospectList, $contact)
98 $prospectList->load_relationship('contacts');
99 $prospectList->contacts->add($contact->id,array());
103 * Set up - create prospect list with 2 contacts
105 public function setUp()
107 global $current_user;
108 $current_user = SugarTestUserUtilities::createAnonymousUser();;
109 $this->_contacts[] = self::createContact();
110 $this->_contacts[] = self::createContact();
111 $this->_prospectList = self::createProspectList($this->_contacts[0]);
112 self::attachContactToProspectList($this->_prospectList, $this->_contacts[1]);
116 * Clear all created data
117 * @see PHPUnit_Framework_TestCase::tearDown()
119 public function tearDown()
121 SugarTestContactUtilities::removeAllCreatedContacts();
122 SugarTestAccountUtilities::removeAllCreatedAccounts();
123 SugarTestUserUtilities::removeAllCreatedAnonymousUsers();
124 $this->_clearProspects();
128 * Test if email exists within report
130 public function testEmailExistsExportList()
132 $content = export("ProspectLists", $this->_prospectList->id, true);
133 $this->assertContains($this->_contacts[0]->email1, $content, "Report should contain email of created contact");
134 $this->assertContains($this->_contacts[1]->email1, $content, "Report should contain email of created contact");
136 $this->_contacts[0]->email1 = "changed" . $this->_contacts[0]->email1;
137 $this->_contacts[0]->save();
139 $this->_contacts[1]->email1 = "changed" . $this->_contacts[1]->email1;
140 $this->_contacts[1]->save();
142 $content = export("ProspectLists", $this->_prospectList->id, true);
143 $this->assertContains($this->_contacts[0]->email1, $content, "Report should contain email of created contact");
144 $this->assertContains($this->_contacts[1]->email1, $content, "Report should contain email of created contact");
147 private function _clearProspects()
149 $ids = implode("', '", self::$_createdProspectListsIds);
150 $GLOBALS['db']->query('DELETE FROM prospect_list_campaigns WHERE prospect_list_id IN (\'' . $ids . '\')');
151 $GLOBALS['db']->query('DELETE FROM prospect_lists_prospects WHERE prospect_list_id IN (\'' . $ids . '\')');
152 $GLOBALS['db']->query('DELETE FROM prospect_lists WHERE id IN (\'' . $ids . '\')');