4 * File for the TestActionSchedule class
8 * CiviCRM is free software; you can redistribute it and/or
9 * modify it under the terms of the GNU Affero General Public License
10 * as published by the Free Software Foundation; either version 3 of
11 * the License, or (at your option) any later version.
13 * CiviCRM is distributed in the hope that it will be useful,
14 * but WITHOUT ANY WARRANTY; without even the implied warranty of
15 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16 * GNU Affero General Public License for more details.
18 * You should have received a copy of the GNU Affero General Public
19 * License along with this program. If not, see
20 * <http://www.gnu.org/licenses/>.
24 * Include class definitions
28 * Test APIv3 civicrm_action_schedule functions
30 * @package CiviCRM_APIv3
31 * @subpackage API_ActionSchedule
34 class api_v3_ActionScheduleTest
extends CiviUnitTestCase
{
37 protected $_entity = 'action_schedule';
38 protected $_apiversion = 3;
41 * Test setup for every test.
43 public function setUp() {
45 $this->useTransaction(TRUE);
49 * Test simple create action schedule.
51 public function testSimpleActionScheduleCreate() {
52 $oldCount = CRM_Core_DAO
::singleValueQuery('select count(*) from civicrm_action_schedule');
53 $activityContacts = CRM_Activity_BAO_ActivityContact
::buildOptions('record_type_id', 'validate');
54 $assigneeID = CRM_Utils_Array
::key('Activity Assignees', $activityContacts);
55 $title = "simpleActionSchedule" . substr(sha1(rand()), 0, 7);
58 'recipient' => $assigneeID,
60 'entity_value' => 'Meeting',
61 'entity_status' => 'Scheduled',
63 'record_activity' => 1,
64 'start_action_date' => 'activity_date_time',
65 'mapping_id' => CRM_Activity_ActionMapping
::ACTIVITY_MAPPING_ID
,
67 $actionSchedule = $this->callAPISuccess('action_schedule', 'create', $params);
68 $this->assertTrue(is_numeric($actionSchedule['id']));
69 $this->assertTrue($actionSchedule['id'] > 0);
70 $newCount = CRM_Core_DAO
::singleValueQuery('select count(*) from civicrm_action_schedule');
71 $this->assertEquals($oldCount +
1, $newCount);
75 * Check if required fields are not passed.
77 public function testActionScheduleCreateWithoutRequired() {
79 'subject' => 'this case should fail',
80 'scheduled_date_time' => date('Ymd'),
82 $this->callAPIFailure('activity', 'create', $params);
86 * Test create with scheduled dates.
88 public function testActionScheduleWithScheduledDatesCreate() {
89 $oldCount = CRM_Core_DAO
::singleValueQuery('select count(*) from civicrm_action_schedule');
90 $activityContacts = CRM_Activity_BAO_ActivityContact
::buildOptions('record_type_id', 'validate');
91 $assigneeID = CRM_Utils_Array
::key('Activity Assignees', $activityContacts);
92 $title = "simpleActionSchedule" . substr(sha1(rand()), 0, 7);
95 'recipient' => $assigneeID,
97 'entity_value' => 'Meeting',
98 'entity_status' => 'Scheduled',
100 'record_activity' => 1,
101 'mapping_id' => CRM_Activity_ActionMapping
::ACTIVITY_MAPPING_ID
,
102 'start_action_offset' => 3,
103 'start_action_unit' => 'day',
104 'start_action_condition' => 'before',
105 'start_action_date' => 'activity_date_time',
107 'repetition_frequency_unit' => 'day',
108 'repetition_frequency_interval' => 3,
109 'end_frequency_unit' => 'hour',
110 'end_frequency_interval' => 0,
111 'end_action' => 'before',
112 'end_date' => 'activity_date_time',
113 'body_html' => 'Test description',
114 'subject' => 'Test subject',
116 $actionSchedule = $this->callAPISuccess('action_schedule', 'create', $params);
117 $this->assertTrue(is_numeric($actionSchedule['id']));
118 $this->assertTrue($actionSchedule['id'] > 0);
119 $this->assertEquals($actionSchedule['values'][$actionSchedule['id']]['start_action_offset'][0], $params['start_action_offset']);
120 $newCount = CRM_Core_DAO
::singleValueQuery('select count(*) from civicrm_action_schedule');
121 $this->assertEquals($oldCount +
1, $newCount);