<?php
/*
+--------------------------------------------------------------------+
- | CiviCRM version 4.6 |
+ | CiviCRM version 4.7 |
+--------------------------------------------------------------------+
| Copyright CiviCRM LLC (c) 2004-2015 |
+--------------------------------------------------------------------+
* @subpackage API_Member
*/
-
-require_once 'CiviTest/CiviUnitTestCase.php';
-
/**
* Class api_v3_MembershipTest
+ * @group headless
*/
class api_v3_MembershipTest extends CiviUnitTestCase {
protected $_apiversion;
protected $_entity;
protected $_params;
-
+ /**
+ * Set up for tests.
+ */
public function setUp() {
- // Connect to the database.
parent::setUp();
$this->_apiversion = 3;
$this->_contactID = $this->individualCreate();
);
}
+ /**
+ * Clean up after tests.
+ *
+ * @throws \Exception
+ */
public function tearDown() {
$this->quickCleanup(array(
'civicrm_membership',
/**
* Test civicrm_membership_get with params not array.
+ *
* Gets treated as contact_id, memberships expected.
*/
public function testGetWithParamsMemberShipTypeId() {
'id' => $membership['id'],
));
$result = $membership['values'][$membership['id']];
- $this->assertEquals($result['contact_id'], $this->_contactID, "In line " . __LINE__);
- $this->assertEquals($result['membership_type_id'], $this->_membershipTypeID, "In line " . __LINE__);
- $this->assertEquals($result['status_id'], $this->_membershipStatusID, "In line " . __LINE__);
- $this->assertEquals($result['join_date'], '2009-01-21', "In line " . __LINE__);
- $this->assertEquals($result['start_date'], '2009-01-21', "In line " . __LINE__);
- $this->assertEquals($result['end_date'], '2009-12-21', "In line " . __LINE__);
- $this->assertEquals($result['source'], 'Payment', "In line " . __LINE__);
- $this->assertEquals($result['is_override'], 1, "In line " . __LINE__);
+ $this->assertEquals($result['contact_id'], $this->_contactID);
+ $this->assertEquals($result['membership_type_id'], $this->_membershipTypeID);
+ $this->assertEquals($result['status_id'], $this->_membershipStatusID);
+ $this->assertEquals($result['join_date'], '2009-01-21');
+ $this->assertEquals($result['start_date'], '2009-01-21');
+ $this->assertEquals($result['end_date'], '2009-12-21');
+ $this->assertEquals($result['source'], 'Payment');
+ $this->assertEquals($result['is_override'], 1);
$this->assertEquals($result['id'], $membership['id']);
}
}
/**
- * Check with complete array + custom field
+ * Check with complete array + custom field.
+ *
* Note that the test is written on purpose without any
* variables specific to participant so it can be replicated into other entities
* and / or moved to the automated test suite
$this->callAPISuccess('Membership', 'Delete', array(
'id' => $membership['id'],
));
- $this->assertEquals($result['join_date'], '2009-01-21', "In line " . __LINE__);
- $this->assertEquals($result['contact_id'], $this->_contactID, "In line " . __LINE__);
- $this->assertEquals($result['membership_type_id'], $this->_membershipTypeID, "In line " . __LINE__);
- $this->assertEquals($result['status_id'], $this->_membershipStatusID, "In line " . __LINE__);
+ $this->assertEquals($result['join_date'], '2009-01-21');
+ $this->assertEquals($result['contact_id'], $this->_contactID);
+ $this->assertEquals($result['membership_type_id'], $this->_membershipTypeID);
+ $this->assertEquals($result['status_id'], $this->_membershipStatusID);
- $this->assertEquals($result['start_date'], '2009-01-21', "In line " . __LINE__);
- $this->assertEquals($result['end_date'], '2009-12-21', "In line " . __LINE__);
- $this->assertEquals($result['source'], 'Payment', "In line " . __LINE__);
- $this->assertEquals($result['is_override'], 1, "In line " . __LINE__);
+ $this->assertEquals($result['start_date'], '2009-01-21');
+ $this->assertEquals($result['end_date'], '2009-12-21');
+ $this->assertEquals($result['source'], 'Payment');
+ $this->assertEquals($result['is_override'], 1);
}
);
$membership = $this->callAPISuccess('membership', 'get', $params);
- $this->assertEquals($membership['count'], 0, "In line " . __LINE__);
+ $this->assertEquals($membership['count'], 0);
}
/**
$this->contactMembershipCreate($this->_params);
$result = $this->callAPISuccess('membership', 'get', array('return' => 'end_date'));
foreach ($result['values'] as $membership) {
- $this->assertEquals(array('end_date', 'membership_end_date', 'id'), array_keys($membership));
+ $this->assertEquals(array('end_date', 'id'), array_keys($membership));
}
}
///////////////// civicrm_membership_create methods
}
+ /**
+ * Test that all membership types are returned when getoptions is called.
+ *
+ * This test locks in current behaviour where types for all domains are returned. It should possibly be domain
+ * specific but that should only be done in conjunction with adding a hook to allow that to be altered as the
+ * multisite use case expects the master domain to be able to see all sites.
+ *
+ * See CRM-17075.
+ */
+ public function testGetOptionsMembershipTypeID() {
+ $options = $this->callAPISuccess('Membership', 'getoptions', array('field' => 'membership_type_id'));
+ $this->assertEquals('General', array_pop($options['values']));
+ $this->assertEquals('General', array_pop($options['values']));
+ $this->assertEquals(NULL, array_pop($options['values']));
+ }
+
}