PageRenderTime 47ms CodeModel.GetById 22ms RepoModel.GetById 0ms app.codeStats 0ms

/tests/SugarTestLeadUtilities.php

https://github.com/mikmagic/sugarcrm_dev
PHP | 94 lines | 51 code | 9 blank | 34 comment | 1 complexity | 81b649bfb40cf185175c549aba35df49 MD5 | raw file
Possible License(s): MPL-2.0-no-copyleft-exception, LGPL-2.1, BSD-3-Clause, AGPL-3.0
  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. require_once 'modules/Leads/Lead.php';
  37. class SugarTestLeadUtilities
  38. {
  39. private static $_createdLeads = array();
  40. private function __construct() {}
  41. public static function createLead($id = '')
  42. {
  43. $time = mt_rand();
  44. $first_name = 'SugarLeadFirst';
  45. $last_name = 'SugarLeadLast';
  46. $email1 = 'lead@sugar.com';
  47. $lead = new Lead();
  48. $lead->first_name = $first_name . $time;
  49. $lead->last_name = $last_name ;
  50. $lead->email1 = 'lead@'. $time. 'sugar.com';
  51. if(!empty($id))
  52. {
  53. $lead->new_with_id = true;
  54. $lead->id = $id;
  55. }
  56. $lead->save();
  57. self::$_createdLeads[] = $lead;
  58. return $lead;
  59. }
  60. public static function setCreatedLead($lead_ids) {
  61. foreach($lead_ids as $lead_id) {
  62. $lead = new Lead();
  63. $lead->id = $lead_id;
  64. self::$_createdLeads[] = $lead;
  65. } // foreach
  66. } // fn
  67. public static function removeAllCreatedLeads()
  68. {
  69. $lead_ids = self::getCreatedLeadIds();
  70. $GLOBALS['db']->query('DELETE FROM leads WHERE id IN (\'' . implode("', '", $lead_ids) . '\')');
  71. }
  72. public static function removeCreatedLeadsUsersRelationships(){
  73. $lead_ids = self::getCreatedLeadIds();
  74. $GLOBALS['db']->query('DELETE FROM leads_users WHERE lead_id IN (\'' . implode("', '", $lead_ids) . '\')');
  75. }
  76. public static function getCreatedLeadIds()
  77. {
  78. $lead_ids = array();
  79. foreach (self::$_createdLeads as $lead) {
  80. $lead_ids[] = $lead->id;
  81. }
  82. return $lead_ids;
  83. }
  84. }
  85. ?>