Build query using CRM_Utils_SQL_Select.
[civicrm-core.git] / tests / phpunit / api / v3 / MembershipTest.php
CommitLineData
6a488035
TO
1<?php
2/*
3 +--------------------------------------------------------------------+
39de6fd5 4 | CiviCRM version 4.6 |
6a488035 5 +--------------------------------------------------------------------+
e7112fa7 6 | Copyright CiviCRM LLC (c) 2004-2015 |
6a488035
TO
7 +--------------------------------------------------------------------+
8 | This file is a part of CiviCRM. |
9 | |
10 | CiviCRM is free software; you can copy, modify, and distribute it |
11 | under the terms of the GNU Affero General Public License |
12 | Version 3, 19 November 2007 and the CiviCRM Licensing Exception. |
13 | |
14 | CiviCRM is distributed in the hope that it will be useful, but |
15 | WITHOUT ANY WARRANTY; without even the implied warranty of |
16 | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. |
17 | See the GNU Affero General Public License for more details. |
18 | |
19 | You should have received a copy of the GNU Affero General Public |
20 | License and the CiviCRM Licensing Exception along |
21 | with this program; if not, contact CiviCRM LLC |
22 | at info[AT]civicrm[DOT]org. If you have questions about the |
23 | GNU Affero General Public License or the licensing of CiviCRM, |
24 | see the CiviCRM license FAQ at http://civicrm.org/licensing |
25 +--------------------------------------------------------------------+
d25dd0ee 26 */
6a488035
TO
27
28/**
29 * Test APIv3 civicrm_membership functions
30 *
6c6e6187
TO
31 * @package CiviCRM_APIv3
32 * @subpackage API_Member
6a488035
TO
33 */
34
35
36require_once 'CiviTest/CiviUnitTestCase.php';
37
4cbe18b8
EM
38/**
39 * Class api_v3_MembershipTest
40 */
6a488035
TO
41class api_v3_MembershipTest extends CiviUnitTestCase {
42 protected $_apiversion;
43 protected $_contactID;
d54576ed
EM
44 protected $_membershipID;
45 protected $_membershipID2;
46 protected $_membershipID3;
6a488035 47 protected $_membershipTypeID;
8c33a68c 48 protected $_membershipTypeID2;
6a488035 49 protected $_membershipStatusID;
6a488035
TO
50 protected $_entity;
51 protected $_params;
b7c9bc4c 52
6a488035
TO
53
54 public function setUp() {
2ea0abec 55 // Connect to the database.
6a488035
TO
56 parent::setUp();
57 $this->_apiversion = 3;
58 $this->_contactID = $this->individualCreate();
75638074 59 $this->_membershipTypeID = $this->membershipTypeCreate(array('member_of_contact_id' => $this->_contactID));
5896d037
TO
60 $this->_membershipTypeID2 = $this->membershipTypeCreate(array(
61 'period_type' => 'fixed',
2ea0abec 62 // Ie. 1 March.
5896d037 63 'fixed_period_start_day' => '301',
2ea0abec 64 // Ie. 11 Nov.
21dfd5f5 65 'fixed_period_rollover_day' => '1111',
5896d037 66 ));
6a488035
TO
67 $this->_membershipStatusID = $this->membershipStatusCreate('test status');
68
6a488035
TO
69 CRM_Member_PseudoConstant::membershipType(NULL, TRUE);
70 CRM_Member_PseudoConstant::membershipStatus(NULL, NULL, 'name', TRUE);
71 CRM_Core_PseudoConstant::activityType(TRUE, TRUE, TRUE, 'name');
72
73 $this->_entity = 'Membership';
74 $this->_params = array(
75 'contact_id' => $this->_contactID,
76 'membership_type_id' => $this->_membershipTypeID,
77 'join_date' => '2009-01-21',
78 'start_date' => '2009-01-21',
79 'end_date' => '2009-12-21',
80 'source' => 'Payment',
81 'is_override' => 1,
82 'status_id' => $this->_membershipStatusID,
6a488035
TO
83 );
84 }
85
00be9182 86 public function tearDown() {
6a488035 87 $this->quickCleanup(array(
5896d037
TO
88 'civicrm_membership',
89 'civicrm_membership_payment',
90 'civicrm_membership_log',
771f3245 91 ),
92 TRUE
6a488035
TO
93 );
94 $this->membershipStatusDelete($this->_membershipStatusID);
8c33a68c 95 $this->membershipTypeDelete(array('id' => $this->_membershipTypeID2));
6a488035
TO
96 $this->membershipTypeDelete(array('id' => $this->_membershipTypeID));
97 $this->contactDelete($this->_contactID);
98
99 }
100
101 /**
2ea0abec 102 * Test membership deletion.
6a488035 103 */
00be9182 104 public function testMembershipDelete() {
6a488035 105 $membershipID = $this->contactMembershipCreate($this->_params);
3506b6cd 106 $this->assertDBRowExist('CRM_Member_DAO_Membership', $membershipID);
6a488035 107 $params = array(
21dfd5f5 108 'id' => $membershipID,
6a488035 109 );
d54576ed 110 $this->callAPIAndDocument('membership', 'delete', $params, __FUNCTION__, __FILE__);
3506b6cd 111 $this->assertDBRowNotExist('CRM_Member_DAO_Membership', $membershipID);
6a488035
TO
112 }
113
00be9182 114 public function testMembershipDeleteEmpty() {
d54576ed 115 $this->callAPIFailure('membership', 'delete', array());
6a488035
TO
116 }
117
00be9182 118 public function testMembershipDeleteInvalidID() {
d54576ed 119 $this->callAPIFailure('membership', 'delete', array('id' => 'blah'));
6a488035
TO
120 }
121
122 /**
2ea0abec 123 * Test civicrm_membership_delete() with invalid Membership Id.
6a488035 124 */
00be9182 125 public function testMembershipDeleteWithInvalidMembershipId() {
6a488035 126 $membershipId = 'membership';
d54576ed 127 $this->callAPIFailure('membership', 'delete', $membershipId);
6a488035
TO
128 }
129
130 /**
2ea0abec 131 * Test membership get.
6a488035 132 */
00be9182 133 public function testContactMembershipsGet() {
6a488035 134 $this->_membershipID = $this->contactMembershipCreate($this->_params);
2ea0abec 135 $this->callAPISuccess('membership', 'get', array());
6c6e6187 136 $this->callAPISuccess('Membership', 'Delete', array('id' => $this->_membershipID));
6a488035
TO
137 }
138
139 /**
140 * Test civicrm_membership_get with params not array.
2ea0abec 141 *
6a488035
TO
142 * Gets treated as contact_id, memberships expected.
143 */
00be9182 144 public function testGetWithParamsContactId() {
6a488035
TO
145 $this->_membershipID = $this->contactMembershipCreate($this->_params);
146 $params = array(
147 'contact_id' => $this->_contactID,
6a488035 148 );
771f3245 149 $membership = $this->callAPISuccess('membership', 'get', $params);
6a488035
TO
150
151 $result = $membership['values'][$this->_membershipID];
771f3245 152 $this->callAPISuccess('Membership', 'Delete', array(
6a488035 153 'id' => $this->_membershipID,
5896d037 154 ));
6a488035
TO
155 $this->assertEquals($result['contact_id'], $this->_contactID, "In line " . __LINE__);
156 $this->assertEquals($result['membership_type_id'], $this->_membershipTypeID, "In line " . __LINE__);
157 $this->assertEquals($result['status_id'], $this->_membershipStatusID, "In line " . __LINE__);
158 $this->assertEquals($result['join_date'], '2009-01-21', "In line " . __LINE__);
159 $this->assertEquals($result['start_date'], '2009-01-21', "In line " . __LINE__);
160 $this->assertEquals($result['end_date'], '2009-12-21', "In line " . __LINE__);
161 $this->assertEquals($result['source'], 'Payment', "In line " . __LINE__);
162 $this->assertEquals($result['is_override'], 1, "In line " . __LINE__);
163 }
164
b4529041 165 /**
166 * Test civicrm_membership_get with params not array.
2ea0abec 167 *
b4529041 168 * Gets treated as contact_id, memberships expected.
169 */
00be9182 170 public function testGetInSyntax() {
b4529041 171 $this->_membershipID = $this->contactMembershipCreate($this->_params);
172 $this->_membershipID2 = $this->contactMembershipCreate($this->_params);
173 $this->_membershipID3 = $this->contactMembershipCreate($this->_params);
174 $params = array(
175 'id' => array('IN' => array($this->_membershipID, $this->_membershipID3)),
176 );
177 $membership = $this->callAPISuccess('membership', 'get', $params);
178 $this->assertEquals(2, $membership['count']);
179 $this->assertEquals(array($this->_membershipID, $this->_membershipID3), array_keys($membership['values']));
180 $params = array(
181 'id' => array('NOT IN' => array($this->_membershipID, $this->_membershipID3)),
182 );
183 $membership = $this->callAPISuccess('membership', 'get', $params);
184 $this->assertEquals(1, $membership['count']);
185 $this->assertEquals(array($this->_membershipID2), array_keys($membership['values']));
b4529041 186 }
187
caca32ba 188 /**
189 * Test civicrm_membership_get with params not array.
190 * Gets treated as contact_id, memberships expected.
191 */
00be9182 192 public function testGetInSyntaxOnContactID() {
caca32ba 193 $this->_membershipID = $this->contactMembershipCreate($this->_params);
194 $contact2 = $this->individualCreate();
195 $contact3 = $this->individualCreate(array('first_name' => 'Scout', 'last_name' => 'Canine'));
196 $this->_membershipID2 = $this->contactMembershipCreate(array_merge($this->_params, array('contact_id' => $contact2)));
197 $this->_membershipID3 = $this->contactMembershipCreate(array_merge($this->_params, array('contact_id' => $contact3)));
198 $params = array(
199 'contact_id' => array('IN' => array($this->_contactID, $contact3)),
200 );
201 $membership = $this->callAPISuccess('membership', 'get', $params);
202 $this->assertEquals(2, $membership['count']);
203 $this->assertEquals(array($this->_membershipID, $this->_membershipID3), array_keys($membership['values']));
204 $params = array(
205 'contact_id' => array('NOT IN' => array($this->_contactID, $contact3)),
206 );
207 $membership = $this->callAPISuccess('membership', 'get', $params);
208 $this->assertEquals(1, $membership['count']);
209 $this->assertEquals(array($this->_membershipID2), array_keys($membership['values']));
210 }
5896d037 211
caca32ba 212 /**
213 * Test civicrm_membership_get with params not array.
214 * Gets treated as contact_id, memberships expected.
215 */
00be9182 216 public function testGetWithParamsMemberShipTypeId() {
d54576ed 217 $this->callAPISuccess($this->_entity, 'create', $this->_params);
6a488035
TO
218 $params = array(
219 'membership_type_id' => $this->_membershipTypeID,
6a488035 220 );
771f3245 221 $membership = $this->callAPISuccess('membership', 'get', $params);
d54576ed 222 $this->callAPISuccess('Membership', 'Delete', array(
6a488035 223 'id' => $membership['id'],
771f3245 224 ));
6a488035
TO
225 $result = $membership['values'][$membership['id']];
226 $this->assertEquals($result['contact_id'], $this->_contactID, "In line " . __LINE__);
227 $this->assertEquals($result['membership_type_id'], $this->_membershipTypeID, "In line " . __LINE__);
228 $this->assertEquals($result['status_id'], $this->_membershipStatusID, "In line " . __LINE__);
229 $this->assertEquals($result['join_date'], '2009-01-21', "In line " . __LINE__);
230 $this->assertEquals($result['start_date'], '2009-01-21', "In line " . __LINE__);
231 $this->assertEquals($result['end_date'], '2009-12-21', "In line " . __LINE__);
232 $this->assertEquals($result['source'], 'Payment', "In line " . __LINE__);
233 $this->assertEquals($result['is_override'], 1, "In line " . __LINE__);
234 $this->assertEquals($result['id'], $membership['id']);
235 }
5896d037 236
a73daeff
E
237 /**
238 * Test civicrm_membership_get with params not array.
239 * Gets treated as contact_id, memberships expected.
240 */
00be9182 241 public function testGetWithParamsMemberShipTypeIdContactID() {
a73daeff
E
242 $params = $this->_params;
243 $this->callAPISuccess($this->_entity, 'create', $params);
244 $params['membership_type_id'] = $this->_membershipTypeID2;
245 $this->callAPISuccess($this->_entity, 'create', $params);
246 $this->callAPISuccessGetCount('membership', array('contact_id' => $this->_contactID), 2);
247 $params = array(
248 'membership_type_id' => $this->_membershipTypeID,
249 'contact_id' => $this->_contactID,
250 );
251 $result = $this->callAPISuccess('membership', 'getsingle', $params);
252 $this->assertEquals($result['contact_id'], $this->_contactID);
253 $this->assertEquals($result['membership_type_id'], $this->_membershipTypeID);
6a488035 254
a73daeff
E
255 $params = array(
256 'membership_type_id' => $this->_membershipTypeID2,
257 'contact_id' => $this->_contactID,
258 );
259 $result = $this->callAPISuccess('membership', 'getsingle', $params);
260 $this->assertEquals($result['contact_id'], $this->_contactID);
261 $this->assertEquals($result['membership_type_id'], $this->_membershipTypeID2);
262 }
5896d037 263
6a488035 264 /**
100fef9d 265 * Check with complete array + custom field
6a488035
TO
266 * Note that the test is written on purpose without any
267 * variables specific to participant so it can be replicated into other entities
268 * and / or moved to the automated test suite
269 */
00be9182 270 public function testGetWithParamsMemberShipIdAndCustom() {
6a488035
TO
271 $ids = $this->entityCustomGroupWithSingleFieldCreate(__FUNCTION__, __FILE__);
272
273 $params = $this->_params;
274 $params['custom_' . $ids['custom_field_id']] = "custom string";
275
771f3245 276 $result = $this->callAPISuccess($this->_entity, 'create', $params);
6a488035 277
771f3245 278 $getParams = array('membership_type_id' => $params['membership_type_id']);
279 $check = $this->callAPIAndDocument($this->_entity, 'get', $getParams, __FUNCTION__, __FILE__);
6a488035
TO
280 $this->assertEquals("custom string", $check['values'][$result['id']]['custom_' . $ids['custom_field_id']], ' in line ' . __LINE__);
281
d54576ed 282 $this->callAPISuccess('Membership', 'Delete', array(
6a488035 283 'id' => $result['id'],
771f3245 284 ));
6a488035
TO
285 }
286
287 /**
288 * Test civicrm_membership_get with proper params.
289 * Memberships expected.
290 */
00be9182 291 public function testGet() {
6a488035
TO
292 $membershipID = $this->contactMembershipCreate($this->_params);
293 $params = array(
294 'contact_id' => $this->_contactID,
6a488035
TO
295 );
296
771f3245 297 $membership = $this->callAPISuccess('membership', 'get', $params);
6a488035 298 $result = $membership['values'][$membershipID];
771f3245 299 $this->callAPISuccess('Membership', 'Delete', array(
6a488035 300 'id' => $membership['id'],
771f3245 301 ));
6a488035
TO
302 $this->assertEquals($result['join_date'], '2009-01-21', "In line " . __LINE__);
303 $this->assertEquals($result['contact_id'], $this->_contactID, "In line " . __LINE__);
304 $this->assertEquals($result['membership_type_id'], $this->_membershipTypeID, "In line " . __LINE__);
305 $this->assertEquals($result['status_id'], $this->_membershipStatusID, "In line " . __LINE__);
306
307 $this->assertEquals($result['start_date'], '2009-01-21', "In line " . __LINE__);
308 $this->assertEquals($result['end_date'], '2009-12-21', "In line " . __LINE__);
309 $this->assertEquals($result['source'], 'Payment', "In line " . __LINE__);
310 $this->assertEquals($result['is_override'], 1, "In line " . __LINE__);
311 }
312
313
314 /**
315 * Test civicrm_membership_get with proper params.
316 * Memberships expected.
317 */
00be9182 318 public function testGetWithId() {
6a488035
TO
319 $membershipID = $this->contactMembershipCreate($this->_params);
320 $params = array(
321 'contact_id' => $this->_contactID,
d54576ed 322 'id' => $this->_membershipID,
6a488035
TO
323 'return' => 'id',
324 );
771f3245 325 $result = $this->callAPISuccess('membership', 'get', $params);
6a488035
TO
326 $this->assertEquals($membershipID, $result['id']);
327 $params = array(
328 'contact_id' => $this->_contactID,
d54576ed 329 'membership_id' => $this->_membershipID,
6a488035
TO
330 'return' => 'membership_id',
331 );
771f3245 332 $result = $this->callAPISuccess('membership', 'get', $params);
6a488035 333 $this->assertEquals($membershipID, $result['id']);
6a488035
TO
334 }
335
336 /**
337 * Test civicrm_membership_get for only active.
338 * Memberships expected.
339 */
00be9182 340 public function testGetOnlyActive() {
5c49fee0 341 $description = "Demonstrates use of 'filter' active_only' param.";
6a488035 342 $this->_membershipID = $this->contactMembershipCreate($this->_params);
5896d037 343 $params = array(
6a488035
TO
344 'contact_id' => $this->_contactID,
345 'active_only' => 1,
6a488035
TO
346 );
347
771f3245 348 $membership = $this->callAPISuccess('membership', 'get', $params);
a73daeff
E
349 $this->assertEquals($membership['values'][$this->_membershipID]['status_id'], $this->_membershipStatusID);
350 $this->assertEquals($membership['values'][$this->_membershipID]['contact_id'], $this->_contactID);
6a488035
TO
351 $params = array(
352 'contact_id' => $this->_contactID,
353 'filters' => array(
354 'is_current' => 1,
355 ),
6a488035
TO
356 );
357
a828d7b8 358 $membership = $this->callAPIAndDocument('membership', 'get', $params, __FUNCTION__, __FILE__, $description, 'FilterIsCurrent');
a73daeff
E
359 $this->assertEquals($membership['values'][$this->_membershipID]['status_id'], $this->_membershipStatusID);
360 $this->assertEquals($membership['values'][$this->_membershipID]['contact_id'], $this->_contactID);
6a488035 361
6c6e6187 362 $this->callAPISuccess('Membership', 'Delete', array('id' => $this->_membershipID));
6a488035
TO
363 }
364
365 /**
366 * Test civicrm_membership_get for non exist contact.
367 * empty Memberships.
368 */
00be9182 369 public function testGetNoContactExists() {
6a488035
TO
370 $params = array(
371 'contact_id' => 55555,
6a488035
TO
372 );
373
771f3245 374 $membership = $this->callAPISuccess('membership', 'get', $params);
6a488035
TO
375 $this->assertEquals($membership['count'], 0, "In line " . __LINE__);
376 }
377
378 /**
379 * Test civicrm_membership_get with relationship.
380 * get Memberships.
381 */
00be9182 382 public function testGetWithRelationship() {
6a488035 383 $membershipOrgId = $this->organizationCreate(NULL);
e4d5f1e2 384 $memberContactId = $this->individualCreate();
6a488035
TO
385
386 $relTypeParams = array(
387 'name_a_b' => 'Relation 1',
388 'name_b_a' => 'Relation 2',
389 'description' => 'Testing relationship type',
390 'contact_type_a' => 'Organization',
391 'contact_type_b' => 'Individual',
392 'is_reserved' => 1,
393 'is_active' => 1,
6a488035
TO
394 );
395 $relTypeID = $this->relationshipTypeCreate($relTypeParams);
396
397 $params = array(
398 'name' => 'test General',
399 'duration_unit' => 'year',
400 'duration_interval' => 1,
401 'period_type' => 'rolling',
402 'member_of_contact_id' => $membershipOrgId,
403 'domain_id' => 1,
5896d037 404 'financial_type_id' => 1,
6a488035
TO
405 'relationship_type_id' => $relTypeID,
406 'relationship_direction' => 'b_a',
407 'is_active' => 1,
6a488035 408 );
771f3245 409 $memType = $this->callAPISuccess('membership_type', 'create', $params);
6a488035
TO
410
411 $params = array(
412 'contact_id' => $memberContactId,
413 'membership_type_id' => $memType['id'],
414 'join_date' => '2009-01-21',
415 'start_date' => '2009-01-21',
416 'end_date' => '2009-12-21',
417 'source' => 'Payment',
418 'is_override' => 1,
419 'status_id' => $this->_membershipStatusID,
6a488035
TO
420 );
421 $membershipID = $this->contactMembershipCreate($params);
422
423 $params = array(
424 'contact_id' => $memberContactId,
425 'membership_type_id' => $memType['id'],
6a488035
TO
426 );
427
771f3245 428 $result = $this->callAPISuccess('membership', 'get', $params);
6a488035
TO
429
430 $membership = $result['values'][$membershipID];
771f3245 431 $this->assertEquals($this->_membershipStatusID, $membership['status_id']);
d54576ed 432 $this->callAPISuccess('Membership', 'Delete', array(
6a488035 433 'id' => $membership['id'],
5896d037 434 ));
6a488035
TO
435 $this->membershipTypeDelete(array('id' => $memType['id']));
436 $this->relationshipTypeDelete($relTypeID);
437 $this->contactDelete($membershipOrgId);
438 $this->contactDelete($memberContactId);
439 }
440
4cc99d00 441 /**
442 * Test civicrm_membership_create with relationships.
443 * create/get Memberships.
444 *
445 * Test suite for CRM-14758: API ( contact, create ) does not always create related membership
446 * and max_related property for Membership_Type and Membership entities
447 */
00be9182 448 public function testCreateWithRelationship() {
4cc99d00 449 // Create membership type: inherited through employment, max_related = 2
450 $params = array(
451 'name_a_b' => 'Employee of',
452 );
453 $result = $this->callAPISuccess('relationship_type', 'get', $params);
454 $relationshipTypeId = $result['id'];
455 $membershipOrgId = $this->organizationCreate();
456 $params = array(
457 'name' => 'Corporate Membership',
458 'duration_unit' => 'year',
459 'duration_interval' => 1,
460 'period_type' => 'rolling',
461 'member_of_contact_id' => $membershipOrgId,
462 'domain_id' => 1,
463 'financial_type_id' => 1,
464 'relationship_type_id' => $relationshipTypeId,
465 'relationship_direction' => 'b_a',
466 'max_related' => 2,
467 'is_active' => 1,
468 );
469 $result = $this->callAPISuccess('membership_type', 'create', $params);
470 $membershipTypeId = $result['id'];
471
472 // Create employer and first employee
473 $employerId[0] = $this->organizationCreate(array(), 1);
474 $memberContactId[0] = $this->individualCreate(array('employer_id' => $employerId[0]), 0);
475
476 // Create organization's membership
477 $params = array(
478 'contact_id' => $employerId[0],
479 'membership_type_id' => $membershipTypeId,
480 'source' => 'Test suite',
481 'start_date' => date('Y-m-d'),
482 'end_date' => "+1 year",
483 );
484 $OrganizationMembershipID = $this->contactMembershipCreate($params);
485
486 // Check that the employee inherited the membership
487 $params = array(
488 'contact_id' => $memberContactId[0],
489 'membership_type_id' => $membershipTypeId,
490 );
491
492 $result = $this->callAPISuccess('membership', 'get', $params);
493
494 $this->assertEquals(1, $result['count']);
495 $result = $result['values'][$result['id']];
496 $this->assertEquals($OrganizationMembershipID, $result['owner_membership_id']);
497
498 // Create second employee
499 $memberContactId[1] = $this->individualCreate(array('employer_id' => $employerId[0]), 1);
500
501 // Check that the employee inherited the membership
502 $params = array(
503 'contact_id' => $memberContactId[1],
504 'membership_type_id' => $membershipTypeId,
505 );
506 $result = $this->callAPISuccess('membership', 'get', $params);
4cc99d00 507 // If it fails here CRM-14758 is not fixed
508 $this->assertEquals(1, $result['count']);
509 $result = $result['values'][$result['id']];
510 $this->assertEquals($OrganizationMembershipID, $result['owner_membership_id']);
511
512 // Create third employee
932a6904 513 $memberContactId[2] = $this->individualCreate(array('employer_id' => $employerId[0]), 2);
4cc99d00 514
515 // Check that employee does NOT inherit the membership (max_related = 2)
516 $params = array(
517 'contact_id' => $memberContactId[2],
518 'membership_type_id' => $membershipTypeId,
519 );
520 $result = $this->callAPISuccess('membership', 'get', $params);
521 $this->assertEquals(0, $result['count']);
522
523 // Increase max_related for the employer's membership
524 $params = array(
525 'id' => $OrganizationMembershipID,
526 'max_related' => 3,
527 );
528 $this->contactMembershipCreate($params);
529
530 // Check that the employee inherited the membership
531 $params = array(
532 'contact_id' => $memberContactId[2],
533 'membership_type_id' => $membershipTypeId,
534 );
535 $result = $this->callAPISuccess('membership', 'get', $params);
536 $this->assertEquals(1, $result['count']);
537 $result = $result['values'][$result['id']];
538 $this->assertEquals($OrganizationMembershipID, $result['owner_membership_id']);
539
540 // First employee moves to a new job
541 $employerId[1] = $this->organizationCreate(array(), 2);
542 $params = array(
543 'id' => $memberContactId[0],
544 'employer_id' => $employerId[1],
545 );
546 $this->callAPISuccess('contact', 'create', $params);
547
548 // Check that employee does NO LONGER inherit the membership
549 $params = array(
550 'contact_id' => $memberContactId[0],
551 'membership_type_id' => $membershipTypeId,
552 );
553 $result = $this->callAPISuccess('membership', 'get', $params);
554 $this->assertEquals(0, $result['count']);
555
4a009ccf
CW
556 // Set up params for enable/disable checks
557 $relationship1 = $this->callAPISuccess('relationship', 'get', array('contact_id_a' => $memberContactId[1]));
558 $params = array(
559 'contact_id' => $memberContactId[1],
560 'membership_type_id' => $membershipTypeId,
561 );
562
563 // Deactivate relationship using create and assert membership is not inherited
564 $this->callAPISuccess('relationship', 'create', array('id' => $relationship1['id'], 'is_active' => 0));
565 $result = $this->callAPISuccess('membership', 'get', $params);
566 $this->assertEquals(0, $result['count']);
567
568 // Re-enable relationship using create and assert membership is inherited
569 $this->callAPISuccess('relationship', 'create', array('id' => $relationship1['id'], 'is_active' => 1));
570 $result = $this->callAPISuccess('membership', 'get', $params);
571 $this->assertEquals(1, $result['count']);
572
573 // Deactivate relationship using setvalue and assert membership is not inherited
574 $this->callAPISuccess('relationship', 'setvalue', array('id' => $relationship1['id'], 'field' => 'is_active', 'value' => 0));
575 $result = $this->callAPISuccess('membership', 'get', $params);
576 $this->assertEquals(0, $result['count']);
577
578 // Re-enable relationship using setvalue and assert membership is inherited
579 $this->callAPISuccess('relationship', 'setvalue', array('id' => $relationship1['id'], 'field' => 'is_active', 'value' => 1));
580 $result = $this->callAPISuccess('membership', 'get', $params);
581 $this->assertEquals(1, $result['count']);
582
1b5fad8a
CW
583 // Delete relationship and assert membership is not inherited
584 $this->callAPISuccess('relationship', 'delete', array('id' => $relationship1['id']));
585 $result = $this->callAPISuccess('membership', 'get', $params);
586 $this->assertEquals(0, $result['count']);
587
4cc99d00 588 // Tear down - reverse of creation to be safe
589 $this->contactDelete($memberContactId[2]);
590 $this->contactDelete($memberContactId[1]);
591 $this->contactDelete($memberContactId[0]);
592 $this->contactDelete($employerId[1]);
593 $this->contactDelete($employerId[0]);
594 $this->membershipTypeDelete(array('id' => $membershipTypeId));
595 $this->contactDelete($membershipOrgId);
596 }
597
37eda84b 598 /**
599 * We are checking for no enotices + only id & end_date returned
600 */
00be9182 601 public function testMembershipGetWithReturn() {
d54576ed 602 $this->contactMembershipCreate($this->_params);
37eda84b 603 $result = $this->callAPISuccess('membership', 'get', array('return' => 'end_date'));
6c6e6187 604 foreach ($result['values'] as $membership) {
37eda84b 605 $this->assertEquals(array('id', 'end_date'), array_keys($membership));
606 }
607 }
6a488035
TO
608 ///////////////// civicrm_membership_create methods
609
610 /**
611 * Test civicrm_contact_memberships_create with empty params.
612 * Error expected.
613 */
00be9182 614 public function testCreateWithEmptyParams() {
6a488035 615 $params = array();
d54576ed 616 $this->callAPIFailure('membership', 'create', $params);
6a488035
TO
617 }
618
619 /**
fe482240 620 * If is_overide is passed in status must also be passed in.
6a488035 621 */
00be9182 622 public function testCreateOverrideNoStatus() {
6a488035
TO
623 $params = $this->_params;
624 unset($params['status_id']);
d54576ed 625 $this->callAPIFailure('membership', 'create', $params);
6a488035
TO
626 }
627
00be9182 628 public function testMembershipCreateMissingRequired() {
6a488035
TO
629 $params = array(
630 'membership_type_id' => '1',
631 'join_date' => '2006-01-21',
632 'start_date' => '2006-01-21',
633 'end_date' => '2006-12-21',
634 'source' => 'Payment',
635 'status_id' => '2',
6a488035
TO
636 );
637
d54576ed 638 $this->callAPIFailure('membership', 'create', $params);
6a488035
TO
639 }
640
00be9182 641 public function testMembershipCreate() {
6a488035
TO
642 $params = array(
643 'contact_id' => $this->_contactID,
644 'membership_type_id' => $this->_membershipTypeID,
645 'join_date' => '2006-01-21',
646 'start_date' => '2006-01-21',
647 'end_date' => '2006-12-21',
648 'source' => 'Payment',
649 'is_override' => 1,
650 'status_id' => $this->_membershipStatusID,
6a488035
TO
651 );
652
771f3245 653 $result = $this->callAPIAndDocument('membership', 'create', $params, __FUNCTION__, __FILE__);
6a488035 654 $this->getAndCheck($params, $result['id'], $this->_entity);
6a488035
TO
655 $this->assertNotNull($result['id']);
656 $this->assertEquals($this->_contactID, $result['values'][$result['id']]['contact_id'], " in line " . __LINE__);
657 $this->assertEquals($result['id'], $result['values'][$result['id']]['id'], " in line " . __LINE__);
658 }
5896d037 659
28a04ea9 660 /**
661 * Check for useful message if contact doesn't exist
662 */
00be9182 663 public function testMembershipCreateWithInvalidContact() {
6a488035
TO
664 $params = array(
665 'contact_id' => 999,
666 'membership_type_id' => $this->_membershipTypeID,
667 'join_date' => '2006-01-21',
668 'start_date' => '2006-01-21',
669 'end_date' => '2006-12-21',
670 'source' => 'Payment',
671 'is_override' => 1,
672 'status_id' => $this->_membershipStatusID,
6a488035
TO
673 );
674
d54576ed 675 $this->callAPIFailure('membership', 'create', $params,
771f3245 676 'contact_id is not valid : 999'
677 );
6a488035 678 }
5896d037 679
00be9182 680 public function testMembershipCreateWithInvalidStatus() {
6a488035
TO
681 $params = $this->_params;
682 $params['status_id'] = 999;
d54576ed 683 $this->callAPIFailure('membership', 'create', $params,
771f3245 684 "'999' is not a valid option for field status_id"
685 );
6a488035
TO
686 }
687
00be9182 688 public function testMembershipCreateWithInvalidType() {
6a488035
TO
689 $params = $this->_params;
690 $params['membership_type_id'] = 999;
691
d54576ed 692 $this->callAPIFailure('membership', 'create', $params,
771f3245 693 "'999' is not a valid option for field membership_type_id"
694 );
6a488035
TO
695 }
696
697 /**
100fef9d 698 * Check with complete array + custom field
6a488035
TO
699 * Note that the test is written on purpose without any
700 * variables specific to participant so it can be replicated into other entities
701 * and / or moved to the automated test suite
702 */
00be9182 703 public function testCreateWithCustom() {
6a488035
TO
704 $ids = $this->entityCustomGroupWithSingleFieldCreate(__FUNCTION__, __FILE__);
705
706 $params = $this->_params;
707 $params['custom_' . $ids['custom_field_id']] = "custom string";
708
a828d7b8 709 $result = $this->callAPIAndDocument($this->_entity, 'create', $params, __FUNCTION__, __FILE__, NULL, 'CreateWithCustomData');
5896d037
TO
710 $check = $this->callAPISuccess($this->_entity, 'get', array(
711 'id' => $result['id'],
21dfd5f5 712 'contact_id' => $this->_contactID,
5896d037 713 ));
6a488035 714 $this->assertEquals("custom string", $check['values'][$result['id']]['custom_' . $ids['custom_field_id']], ' in line ' . __LINE__);
6a488035
TO
715 }
716
717 /**
718 * Test civicrm_contact_memberships_create with membership id (edit
719 * membership).
720 * success expected.
721 */
00be9182 722 public function testMembershipCreateWithId() {
6a488035
TO
723 $membershipID = $this->contactMembershipCreate($this->_params);
724 $params = array(
725 'id' => $membershipID,
726 'contact_id' => $this->_contactID,
727 'membership_type_id' => $this->_membershipTypeID,
728 'join_date' => '2006-01-21',
729 'start_date' => '2006-01-21',
730 'end_date' => '2006-12-21',
731 'source' => 'Payment',
732 'is_override' => 1,
733 'status_id' => $this->_membershipStatusID,
6a488035
TO
734 );
735
771f3245 736 $result = $this->callAPISuccess('membership', 'create', $params);
737 $this->callAPISuccess('Membership', 'Delete', array(
6a488035 738 'id' => $result['id'],
771f3245 739 ));
6a488035
TO
740 $this->assertEquals($result['id'], $membershipID, "in line " . __LINE__);
741 }
742
743 /**
744 * Test civicrm_contact_memberships_create with membership id (edit
745 * membership).
746 * success expected.
747 */
00be9182 748 public function testMembershipCreateUpdateWithIdNoContact() {
6a488035
TO
749 $membershipID = $this->contactMembershipCreate($this->_params);
750 $params = array(
751 'id' => $membershipID,
752 'membership_type_id' => $this->_membershipTypeID,
753 'contact_id' => $this->_contactID,
754 'join_date' => '2006-01-21',
755 'start_date' => '2006-01-21',
756 'end_date' => '2006-12-21',
757 'source' => 'Payment',
758 'is_override' => 1,
759 'status_id' => $this->_membershipStatusID,
6a488035
TO
760 );
761
771f3245 762 $result = $this->callAPISuccess('membership', 'create', $params);
763 $this->callAPISuccess('Membership', 'Delete', array(
6a488035 764 'id' => $result['id'],
5896d037 765 ));
771f3245 766
6a488035
TO
767 $this->assertEquals($result['id'], $membershipID, "in line " . __LINE__);
768 }
769
770 /**
771 * Test civicrm_contact_memberships_create with membership id (edit
772 * membership).
773 * success expected.
774 */
00be9182 775 public function testMembershipCreateUpdateWithIdNoDates() {
6a488035
TO
776 $membershipID = $this->contactMembershipCreate($this->_params);
777 $params = array(
778 'id' => $membershipID,
779 'contact_id' => $this->_contactID,
780 'membership_type_id' => $this->_membershipTypeID,
781 'source' => 'Payment',
782 'is_override' => 1,
783 'status_id' => $this->_membershipStatusID,
6a488035
TO
784 );
785
771f3245 786 $result = $this->callAPISuccess('membership', 'create', $params);
787 $this->callAPISuccess('Membership', 'Delete', array(
6a488035 788 'id' => $result['id'],
5896d037 789 ));
6a488035
TO
790 $this->assertEquals($result['id'], $membershipID, "in line " . __LINE__);
791 }
792
793 /**
794 * Test civicrm_contact_memberships_create with membership id (edit
795 * membership).
796 * success expected.
797 */
00be9182 798 public function testMembershipCreateUpdateWithIdNoDatesNoType() {
6a488035
TO
799 $membershipID = $this->contactMembershipCreate($this->_params);
800 $params = array(
801 'id' => $membershipID,
802 'source' => 'not much here',
803 'contact_id' => $this->_contactID,
804 'is_override' => 1,
805 'status_id' => $this->_membershipStatusID,
6a488035
TO
806 );
807
771f3245 808 $result = $this->callAPISuccess('membership', 'create', $params);
809 $this->callAPISuccess('Membership', 'Delete', array(
6a488035 810 'id' => $result['id'],
771f3245 811 ));
6a488035
TO
812 $this->assertEquals($result['id'], $membershipID, "in line " . __LINE__);
813 }
814
815 /**
816 * Test civicrm_contact_memberships_create with membership id (edit
817 * membership).
818 * success expected.
819 */
00be9182 820 public function testMembershipCreateUpdateWithIDAndSource() {
6a488035
TO
821 $membershipID = $this->contactMembershipCreate($this->_params);
822 $params = array(
823 'id' => $membershipID,
824 'source' => 'changed',
825 'contact_id' => $this->_contactID,
6c6e6187 826 'status_id' => $this->_membershipStatusID,
5896d037 827 'membership_type_id' => $this->_membershipTypeID,
6a488035
TO
828 'skipStatusCal' => 1,
829 );
771f3245 830 $result = $this->callAPISuccess('membership', 'create', $params);
6a488035 831 $this->assertEquals($result['id'], $membershipID, "in line " . __LINE__);
771f3245 832 $this->callAPISuccess('Membership', 'Delete', array(
6a488035 833 'id' => $result['id'],
5896d037 834 ));
6a488035
TO
835 }
836
837 /**
eceb18cc 838 * Change custom field using update.
6a488035 839 */
00be9182 840 public function testUpdateWithCustom() {
6a488035
TO
841 $ids = $this->entityCustomGroupWithSingleFieldCreate(__FUNCTION__, __FILE__);
842
843 $params = $this->_params;
844 $params['custom_' . $ids['custom_field_id']] = "custom string";
a828d7b8 845 $result = $this->callAPIAndDocument($this->_entity, 'create', $params, __FUNCTION__, __FILE__, NULL, 'UpdateCustomData');
5896d037
TO
846 $result = $this->callAPISuccess($this->_entity, 'create', array(
847 'id' => $result['id'],
21dfd5f5 848 'custom_' . $ids['custom_field_id'] => "new custom",
5896d037
TO
849 ));
850 $check = $this->callAPISuccess($this->_entity, 'get', array(
851 'id' => $result['id'],
21dfd5f5 852 'contact_id' => $this->_contactID,
5896d037 853 ));
6a488035
TO
854
855 $this->assertEquals("new custom", $check['values'][$result['id']]['custom_' . $ids['custom_field_id']], ' in line ' . __LINE__);
d54576ed 856 $this->callAPISuccess('Membership', 'Delete', array(
6a488035 857 'id' => $check['id'],
5896d037 858 ));
6a488035
TO
859
860 $this->customFieldDelete($ids['custom_field_id']);
861 $this->customGroupDelete($ids['custom_group_id']);
862 }
863
93c482a4
EM
864 /**
865 * per CRM-15746 check that the id can be altered in an update hook
866 */
28a04ea9 867 public function testMembershipUpdateCreateHookCRM15746() {
93c482a4
EM
868 $this->hookClass->setHook('civicrm_pre', array($this, 'hook_civicrm_pre_update_create_membership'));
869 $result = $this->callAPISuccess('membership', 'create', $this->_params);
870 $this->callAPISuccess('membership', 'create', array('id' => $result['id'], 'end_date' => '1 year ago'));
871 $this->callAPISuccessGetCount('membership', array(), 2);
872 $this->hookClass->reset();
873 $this->callAPISuccess('membership', 'create', array('id' => $result['id'], 'end_date' => '1 year ago'));
874 $this->callAPISuccessGetCount('membership', array(), 2);
875 }
876
2ea0abec
EM
877 /**
878 * Custom hook for update membership.
879 *
880 * @param string $op
881 * @param object $objectName
882 * @param int $id
883 * @param array $params
884 *
885 * @throws \Exception
886 */
28a04ea9 887 public function hook_civicrm_pre_update_create_membership($op, $objectName, $id, &$params) {
93c482a4
EM
888 if ($objectName == 'Membership' && $op == 'edit') {
889 $existingMembership = $this->callAPISuccessGetSingle('membership', array('id' => $params['id']));
890 unset($params['id'], $params['membership_id']);
6c6e6187 891 $params['join_date'] = $params['membership_start_date'] = $params['start_date'] = date('Ymd000000', strtotime($existingMembership['start_date']));
93c482a4
EM
892 $params = array_merge($existingMembership, $params);
893 $params['id'] = NULL;
894 }
895 }
896
6a488035 897 /**
fe482240 898 * Test civicrm_contact_memberships_create Invalid membership data.
6a488035
TO
899 * Error expected.
900 */
00be9182 901 public function testMembershipCreateInvalidMemData() {
6a488035
TO
902 //membership_contact_id as string
903 $params = array(
904 'membership_contact_id' => 'Invalid',
905 'membership_type_id' => $this->_membershipTypeID,
906 'join_date' => '2011-01-21',
907 'start_date' => '2010-01-21',
908 'end_date' => '2008-12-21',
909 'source' => 'Payment',
910 'is_override' => 1,
5896d037
TO
911 'status_id' => $this->_membershipStatusID,
912 );
6a488035 913
d54576ed 914 $this->callAPIFailure('membership', 'create', $params);
6a488035
TO
915
916 //membership_contact_id which is no in contact table
917 $params['membership_contact_id'] = 999;
d54576ed 918 $this->callAPIFailure('membership', 'create', $params);
6a488035
TO
919
920 //invalid join date
921 unset($params['membership_contact_id']);
922 $params['join_date'] = "invalid";
d54576ed 923 $this->callAPIFailure('Membership', 'Create', $params);
6a488035
TO
924 }
925
926 /**
927 * Test civicrm_contact_memberships_create with membership_contact_id
928 * membership).
929 * Success expected.
930 */
00be9182 931 public function testMembershipCreateWithMemContact() {
6a488035
TO
932 $params = array(
933 'membership_contact_id' => $this->_contactID,
934 'membership_type_id' => $this->_membershipTypeID,
935 'join_date' => '2011-01-21',
936 'start_date' => '2010-01-21',
937 'end_date' => '2008-12-21',
938 'source' => 'Payment',
939 'is_override' => 1,
940 'status_id' => $this->_membershipStatusID,
6a488035
TO
941 );
942
771f3245 943 $result = $this->callAPISuccess('membership', 'create', $params);
6a488035 944
d54576ed 945 $this->callAPISuccess('Membership', 'Delete', array(
6a488035 946 'id' => $result['id'],
771f3245 947 ));
6a488035 948 }
5896d037 949
cc73900e 950 /**
951 * Test civicrm_contact_memberships_create with membership_contact_id
952 * membership).
953 * Success expected.
954 */
00be9182 955 public function testMembershipCreateValidMembershipTypeString() {
cc73900e 956 $params = array(
957 'membership_contact_id' => $this->_contactID,
958 'membership_type_id' => 'General',
959 'join_date' => '2011-01-21',
960 'start_date' => '2010-01-21',
961 'end_date' => '2008-12-21',
962 'source' => 'Payment',
963 'is_override' => 1,
964 'status_id' => $this->_membershipStatusID,
965 );
966
967 $result = $this->callAPISuccess('membership', 'create', $params);
968 $this->assertEquals($this->_membershipTypeID, $result['values'][$result['id']]['membership_type_id']);
d54576ed 969 $this->callAPISuccess('Membership', 'Delete', array(
cc73900e 970 'id' => $result['id'],
971 ));
972 }
973
974 /**
975 * Test civicrm_contact_memberships_create with membership_contact_id
976 * membership).
977 * Success expected.
978 */
00be9182 979 public function testMembershipCreateInValidMembershipTypeString() {
cc73900e 980 $params = array(
981 'membership_contact_id' => $this->_contactID,
982 'membership_type_id' => 'invalid',
983 'join_date' => '2011-01-21',
984 'start_date' => '2010-01-21',
985 'end_date' => '2008-12-21',
986 'source' => 'Payment',
987 'is_override' => 1,
988 'status_id' => $this->_membershipStatusID,
989 );
990
d54576ed 991 $this->callAPIFailure('membership', 'create', $params);
cc73900e 992 }
6a488035 993
cc73900e 994 /**
eceb18cc 995 * Test that if membership join date is not set it defaults to today.
cc73900e 996 */
00be9182 997 public function testEmptyJoinDate() {
8c33a68c 998 unset($this->_params['join_date'], $this->_params['is_override']);
999 $result = $this->callAPISuccess($this->_entity, 'create', $this->_params);
1000 $result = $this->callAPISuccess($this->_entity, 'getsingle', array('id' => $result['id']));
1001 $this->assertEquals(date('Y-m-d', strtotime('now')), $result['join_date']);
1002 $this->assertEquals('2009-01-21', $result['start_date']);
1003 $this->assertEquals('2009-12-21', $result['end_date']);
cc73900e 1004 }
5896d037 1005
cc73900e 1006 /**
fe482240 1007 * Test that if membership start date is not set it defaults to correct end date.
8c33a68c 1008 * - fixed
cc73900e 1009 */
00be9182 1010 public function testEmptyStartDateFixed() {
8c33a68c 1011 unset($this->_params['start_date'], $this->_params['is_override']);
1012 $this->_params['membership_type_id'] = $this->_membershipTypeID2;
1013 $result = $this->callAPISuccess($this->_entity, 'create', $this->_params);
1014 $result = $this->callAPISuccess($this->_entity, 'getsingle', array('id' => $result['id']));
1015 $this->assertEquals('2009-01-21', $result['join_date']);
1016 $this->assertEquals('2008-03-01', $result['start_date']);
1017 $this->assertEquals('2009-12-21', $result['end_date']);
1018 }
cc73900e 1019
8c33a68c 1020 /**
1021 * Test that if membership start date is not set it defaults to correct end date
1022 * - fixed
1023 */
2ea0abec
EM
1024 public function testEmptyStartEndDateFixedOneYear() {
1025 unset($this->_params['start_date'], $this->_params['is_override'], $this->_params['end_date']);
1026 $this->callAPISuccess('membership_type', 'create', array('id' => $this->_membershipTypeID2, 'duration_interval' => 1));
1027 $this->_params['membership_type_id'] = $this->_membershipTypeID2;
1028 $result = $this->callAPISuccess($this->_entity, 'create', $this->_params);
1029 $result = $this->callAPISuccess($this->_entity, 'getsingle', array('id' => $result['id']));
1030 $this->assertEquals('2009-01-21', $result['join_date']);
1031 $this->assertEquals('2008-03-01', $result['start_date']);
1032 $this->assertEquals('2010-02-28', $result['end_date']);
1033 }
1034
1035 /**
9398f167
EM
1036 * Test that if membership start date is not set it defaults to correct end date for fixed multi year memberships.
1037 */
1038 public function testEmptyStartEndDateFixedMultiYear() {
1039 unset($this->_params['start_date'], $this->_params['is_override'], $this->_params['end_date']);
1040 $this->callAPISuccess('membership_type', 'create', array('id' => $this->_membershipTypeID2, 'duration_interval' => 5));
1041 $this->_params['membership_type_id'] = $this->_membershipTypeID2;
1042 $result = $this->callAPISuccess($this->_entity, 'create', $this->_params);
1043 $result = $this->callAPISuccess($this->_entity, 'getsingle', array('id' => $result['id']));
1044 $this->assertEquals('2009-01-21', $result['join_date']);
1045 $this->assertEquals('2008-03-01', $result['start_date']);
1046 $this->assertEquals('2014-02-28', $result['end_date']);
1047 }
1048
b1fc74f0 1049 /**
964a9e96
EM
1050 * Test correct end and start dates are calculated for fixed multi year memberships.
1051 *
1052 * The empty start date is calculated to be the start_date (1 Jan prior to the join_date - so 1 Jan 15)
1053 *
1054 * In this set our start date is after the start day and before the rollover day so we don't get an extra year
1055 * and we end one day before the rollover day. Start day is 1 Jan so we end on 31 Dec
1056 * and we add on 4 years rather than 5 because we are not after the rollover day - so we calculate 31 Dec 2019
1057 */
1058 public function testFixedMultiYearDateSetTwoEmptyStartEndDate() {
1059 unset($this->_params['start_date'], $this->_params['is_override'], $this->_params['end_date']);
1060
1061 $this->callAPISuccess('membership_type', 'create', array(
1062 'id' => $this->_membershipTypeID2,
1063 'duration_interval' => 5,
1064 // Ie 1 Jan.
1065 'fixed_period_start_day' => '101',
1066 // Ie. 1 Nov.
1067 'fixed_period_rollover_day' => '1101',
1068 ));
1069 $this->_params['membership_type_id'] = $this->_membershipTypeID2;
1070 $dates = array(
1071 'join_date' => '28-Jan 2015',
1072 );
1073 $result = $this->callAPISuccess($this->_entity, 'create', array_merge($this->_params, $dates));
1074 $result = $this->callAPISuccess($this->_entity, 'getsingle', array('id' => $result['id']));
1075 $this->assertEquals('2015-01-28', $result['join_date']);
1076 $this->assertEquals('2015-01-01', $result['start_date']);
1077 $this->assertEquals('2019-12-31', $result['end_date']);
1078 }
1079
1080 /**
1081 * Test that correct end date is calculated for fixed multi year memberships and start date is not changed.
b1fc74f0
EM
1082 *
1083 * In this set our start date is after the start day and before the rollover day so we don't get an extra year
1084 * and we end one day before the rollover day. Start day is 1 Jan so we end on 31 Dec
1085 * and we add on 4 years rather than 5 because we are not after the rollover day - so we calculate 31 Dec 2019
1086 */
964a9e96 1087 public function testFixedMultiYearDateSetTwoEmptyEndDate() {
b1fc74f0
EM
1088 unset($this->_params['start_date'], $this->_params['is_override'], $this->_params['end_date']);
1089
1090 $this->callAPISuccess('membership_type', 'create', array(
1091 'id' => $this->_membershipTypeID2,
1092 'duration_interval' => 5,
1093 // Ie 1 Jan.
1094 'fixed_period_start_day' => '101',
1095 // Ie. 1 Nov.
1096 'fixed_period_rollover_day' => '1101',
1097 ));
1098 $this->_params['membership_type_id'] = $this->_membershipTypeID2;
1099 $dates = array(
1100 'start_date' => '28-Jan 2015',
1101 'join_date' => '28-Jan 2015',
1102 );
1103 $result = $this->callAPISuccess($this->_entity, 'create', array_merge($this->_params, $dates));
1104 $result = $this->callAPISuccess($this->_entity, 'getsingle', array('id' => $result['id']));
1105 $this->assertEquals('2015-01-28', $result['join_date']);
1106 $this->assertEquals('2015-01-28', $result['start_date']);
1107 $this->assertEquals('2019-12-31', $result['end_date']);
1108 }
1109
1110 /**
964a9e96
EM
1111 * Test correct end and start dates are calculated for fixed multi year memberships.
1112 *
1113 * The empty start date is calculated to be the start_date (1 Jan prior to the join_date - so 1 Jan 15)
1114 *
1115 * In this set our start date is after the start day and before the rollover day so we don't get an extra year
1116 * and we end one day before the rollover day. Start day is 1 Jan so we end on 31 Dec
1117 * and we add on <1 years rather than > 1 because we are not after the rollover day - so we calculate 31 Dec 2015
1118 */
1119 public function testFixedSingleYearDateSetTwoEmptyStartEndDate() {
1120 unset($this->_params['start_date'], $this->_params['is_override'], $this->_params['end_date']);
1121
1122 $this->callAPISuccess('membership_type', 'create', array(
1123 'id' => $this->_membershipTypeID2,
1124 'duration_interval' => 1,
1125 // Ie 1 Jan.
1126 'fixed_period_start_day' => '101',
1127 // Ie. 1 Nov.
1128 'fixed_period_rollover_day' => '1101',
1129 ));
1130 $this->_params['membership_type_id'] = $this->_membershipTypeID2;
1131 $dates = array(
1132 'join_date' => '28-Jan 2015',
1133 );
1134 $result = $this->callAPISuccess($this->_entity, 'create', array_merge($this->_params, $dates));
1135 $result = $this->callAPISuccess($this->_entity, 'getsingle', array('id' => $result['id']));
1136 $this->assertEquals('2015-01-28', $result['join_date']);
1137 $this->assertEquals('2015-01-01', $result['start_date']);
1138 $this->assertEquals('2015-12-31', $result['end_date']);
1139 }
1140
1141 /**
1142 * Test correct end date for fixed single year memberships is calculated and start_date is not changed.
b1fc74f0
EM
1143 *
1144 * In this set our start date is after the start day and before the rollover day so we don't get an extra year
1145 * and we end one day before the rollover day. Start day is 1 Jan so we end on 31 Dec
1146 * and we add on <1 years rather than > 1 because we are not after the rollover day - so we calculate 31 Dec 2015
1147 */
964a9e96 1148 public function testFixedSingleYearDateSetTwoEmptyEndDate() {
b1fc74f0
EM
1149 unset($this->_params['start_date'], $this->_params['is_override'], $this->_params['end_date']);
1150
1151 $this->callAPISuccess('membership_type', 'create', array(
1152 'id' => $this->_membershipTypeID2,
1153 'duration_interval' => 1,
1154 // Ie 1 Jan.
1155 'fixed_period_start_day' => '101',
1156 // Ie. 1 Nov.
1157 'fixed_period_rollover_day' => '1101',
1158 ));
1159 $this->_params['membership_type_id'] = $this->_membershipTypeID2;
1160 $dates = array(
1161 'start_date' => '28-Jan 2015',
1162 'join_date' => '28-Jan 2015',
1163 );
1164 $result = $this->callAPISuccess($this->_entity, 'create', array_merge($this->_params, $dates));
1165 $result = $this->callAPISuccess($this->_entity, 'getsingle', array('id' => $result['id']));
1166 $this->assertEquals('2015-01-28', $result['join_date']);
1167 $this->assertEquals('2015-01-28', $result['start_date']);
1168 $this->assertEquals('2015-12-31', $result['end_date']);
1169 }
1170
1171 /**
964a9e96 1172 * Test that correct end date is calculated for fixed multi year memberships and start date is not changed.
b1fc74f0
EM
1173 *
1174 * In this set our start date is after the start day and after the rollover day so we do get an extra year
1175 * and we end one day before the rollover day. Start day is 1 Nov so we end on 31 Oct
964a9e96 1176 * and we add on 1 year we are after the rollover day - so we calculate 31 Oct 2016
b1fc74f0 1177 */
964a9e96 1178 public function testFixedSingleYearDateSetThreeEmptyEndDate() {
b1fc74f0
EM
1179 unset($this->_params['start_date'], $this->_params['is_override'], $this->_params['end_date']);
1180
1181 $this->callAPISuccess('membership_type', 'create', array(
1182 'id' => $this->_membershipTypeID2,
1183 'duration_interval' => 1,
1184 // Ie. 1 Nov.
1185 'fixed_period_start_day' => '1101',
1186 // Ie 1 Jan.
1187 'fixed_period_rollover_day' => '101',
1188 ));
1189 $this->_params['membership_type_id'] = $this->_membershipTypeID2;
1190 $dates = array(
1191 'start_date' => '28-Jan 2015',
1192 'join_date' => '28-Jan 2015',
1193 );
1194 $result = $this->callAPISuccess($this->_entity, 'create', array_merge($this->_params, $dates));
1195 $result = $this->callAPISuccess($this->_entity, 'getsingle', array('id' => $result['id']));
1196 $this->assertEquals('2015-01-28', $result['join_date']);
1197 $this->assertEquals('2015-01-28', $result['start_date']);
1198 $this->assertEquals('2016-10-31', $result['end_date']);
1199 }
1200
964a9e96
EM
1201 /**
1202 * Test correct end and start dates are calculated for fixed multi year memberships.
1203 *
d177a2a6 1204 * The empty start date is calculated to be the start_date (1 Nov prior to the join_date - so 1 Nov 14)
964a9e96
EM
1205 *
1206 * In this set our start date is after the start day and after the rollover day so we do get an extra year
1207 * and we end one day before the rollover day. Start day is 1 Nov so we end on 31 Oct
1208 * and we add on 1 year we are after the rollover day - so we calculate 31 Oct 2016
1209 */
1210 public function testFixedSingleYearDateSetThreeEmptyStartEndDate() {
1211 unset($this->_params['start_date'], $this->_params['is_override'], $this->_params['end_date']);
1212
1213 $this->callAPISuccess('membership_type', 'create', array(
1214 'id' => $this->_membershipTypeID2,
1215 'duration_interval' => 1,
1216 // Ie. 1 Nov.
1217 'fixed_period_start_day' => '1101',
1218 // Ie 1 Jan.
1219 'fixed_period_rollover_day' => '101',
1220 ));
1221 $this->_params['membership_type_id'] = $this->_membershipTypeID2;
1222 $dates = array(
1223 'join_date' => '28-Jan 2015',
1224 );
1225 $result = $this->callAPISuccess($this->_entity, 'create', array_merge($this->_params, $dates));
1226 $result = $this->callAPISuccess($this->_entity, 'getsingle', array('id' => $result['id']));
1227 $this->assertEquals('2015-01-28', $result['join_date']);
1228 $this->assertEquals('2014-11-01', $result['start_date']);
1229 $this->assertEquals('2016-10-31', $result['end_date']);
1230 }
b1fc74f0
EM
1231
1232 /**
964a9e96 1233 * Test that correct end date is calculated for fixed multi year memberships and start date is not changed.
b1fc74f0
EM
1234 *
1235 * In this set our start date is after the start day and after the rollover day so we do get an extra year
1236 * and we end one day before the rollover day. Start day is 1 Nov so we end on 31 Oct
1237 * and we add on 5 years we are after the rollover day - so we calculate 31 Oct 2020
1238 */
964a9e96 1239 public function testFixedMultiYearDateSetThreeEmptyEndDate() {
b1fc74f0
EM
1240 unset($this->_params['start_date'], $this->_params['is_override'], $this->_params['end_date']);
1241
1242 $this->callAPISuccess('membership_type', 'create', array(
1243 'id' => $this->_membershipTypeID2,
1244 'duration_interval' => 5,
1245 // Ie. 1 Nov.
1246 'fixed_period_start_day' => '1101',
1247 // Ie 1 Jan.
1248 'fixed_period_rollover_day' => '101',
1249 ));
1250 $this->_params['membership_type_id'] = $this->_membershipTypeID2;
1251 $dates = array(
1252 'start_date' => '28-Jan 2015',
1253 'join_date' => '28-Jan 2015',
1254 );
1255 $result = $this->callAPISuccess($this->_entity, 'create', array_merge($this->_params, $dates));
1256 $result = $this->callAPISuccess($this->_entity, 'getsingle', array('id' => $result['id']));
1257 $this->assertEquals('2015-01-28', $result['join_date']);
1258 $this->assertEquals('2015-01-28', $result['start_date']);
1259 $this->assertEquals('2020-10-31', $result['end_date']);
1260 }
9398f167 1261
964a9e96
EM
1262 /**
1263 * Test correct end and start dates are calculated for fixed multi year memberships.
1264 *
d177a2a6 1265 * The empty start date is calculated to be the start_date (1 Nov prior to the join_date - so 1 Nov 14)
964a9e96
EM
1266 *
1267 * The empty start date is calculated to be the start_date (1 Nov prior to the join_date - so 1 Nov 14)
1268 * In this set our join date is after the start day and after the rollover day so we do get an extra year
1269 * and we end one day before the rollover day. Start day is 1 Nov so we end on 31 Oct
1270 * and we add on 5 years we are after the rollover day - so we calculate 31 Oct 2020
1271 */
1272 public function testFixedMultiYearDateSetThreeEmptyStartEndDate() {
1273 unset($this->_params['start_date'], $this->_params['is_override'], $this->_params['end_date']);
1274
1275 $this->callAPISuccess('membership_type', 'create', array(
1276 'id' => $this->_membershipTypeID2,
1277 'duration_interval' => 5,
1278 // Ie. 1 Nov.
1279 'fixed_period_start_day' => '1101',
1280 // Ie 1 Jan.
1281 'fixed_period_rollover_day' => '101',
1282 ));
1283 $this->_params['membership_type_id'] = $this->_membershipTypeID2;
1284 $dates = array(
1285 'join_date' => '28-Jan 2015',
1286 );
1287 $result = $this->callAPISuccess($this->_entity, 'create', array_merge($this->_params, $dates));
1288 $result = $this->callAPISuccess($this->_entity, 'getsingle', array('id' => $result['id']));
1289 $this->assertEquals('2015-01-28', $result['join_date']);
1290 $this->assertEquals('2014-11-01', $result['start_date']);
1291 $this->assertEquals('2020-10-31', $result['end_date']);
1292 }
1293
9398f167
EM
1294 /**
1295 * Test that if membership start date is not set it defaults to correct end date for fixed single year memberships.
2ea0abec 1296 */
00be9182 1297 public function testEmptyStartDateRolling() {
8c33a68c 1298 unset($this->_params['start_date'], $this->_params['is_override']);
1299 $result = $this->callAPISuccess($this->_entity, 'create', $this->_params);
1300 $result = $this->callAPISuccess($this->_entity, 'getsingle', array('id' => $result['id']));
1301 $this->assertEquals('2009-01-21', $result['join_date']);
1302 $this->assertEquals('2009-01-21', $result['start_date']);
1303 $this->assertEquals('2009-12-21', $result['end_date']);
cc73900e 1304 }
5896d037 1305
8c33a68c 1306 /**
eceb18cc 1307 * Test that if membership end date is not set it defaults to correct end date.
8c33a68c 1308 * - rolling
1309 */
00be9182 1310 public function testEmptyEndDateFixed() {
8c33a68c 1311 unset($this->_params['start_date'], $this->_params['is_override'], $this->_params['end_date']);
1312 $this->_params['membership_type_id'] = $this->_membershipTypeID2;
1313 $result = $this->callAPISuccess($this->_entity, 'create', $this->_params);
1314 $result = $this->callAPISuccess($this->_entity, 'getsingle', array('id' => $result['id']));
1315 $this->assertEquals('2009-01-21', $result['join_date']);
1316 $this->assertEquals('2008-03-01', $result['start_date']);
1317 $this->assertEquals('2010-02-28', $result['end_date']);
1318 }
5896d037 1319
8c33a68c 1320 /**
eceb18cc 1321 * Test that if membership end date is not set it defaults to correct end date.
8c33a68c 1322 * - rolling
1323 */
00be9182 1324 public function testEmptyEndDateRolling() {
8c33a68c 1325 unset($this->_params['is_override'], $this->_params['end_date']);
1326 $this->_params['membership_type_id'] = $this->_membershipTypeID;
1327 $result = $this->callAPISuccess($this->_entity, 'create', $this->_params);
1328 $result = $this->callAPISuccess($this->_entity, 'getsingle', array('id' => $result['id']));
1329 $this->assertEquals('2009-01-21', $result['join_date']);
1330 $this->assertEquals('2009-01-21', $result['start_date']);
1331 $this->assertEquals('2010-01-20', $result['end_date']);
1332 }
1333
1334
1335 /**
452b9e04 1336 * Test that if dates are set they not over-ridden if id is passed in
8c33a68c 1337 */
6c6e6187 1338 public function testMembershipDatesNotOverridden() {
8c33a68c 1339 $result = $this->callAPISuccess($this->_entity, 'create', $this->_params);
1340 unset($this->_params['end_date'], $this->_params['start_date']);
1341 $this->_params['id'] = $result['id'];
1342 $this->callAPISuccess($this->_entity, 'create', $this->_params);
1343 $result = $this->callAPISuccess($this->_entity, 'getsingle', array('id' => $result['id']));
1344 $this->assertEquals('2009-01-21', $result['join_date']);
1345 $this->assertEquals('2009-01-21', $result['start_date']);
1346 $this->assertEquals('2009-12-21', $result['end_date']);
1347
6c6e6187 1348 }
96025800 1349
6a488035 1350}