From 09c7a73f8a7bc60911931543c0edf1707baf1d40 Mon Sep 17 00:00:00 2001 From: Seamus Lee Date: Sun, 15 Dec 2019 09:03:56 +1100 Subject: [PATCH] Add in Country and StateProvince APIv4 Entities --- Civi/Api4/Country.php | 30 ++++++++++++++++++++++ Civi/Api4/StateProvince.php | 30 ++++++++++++++++++++++ tests/phpunit/api/v3/CountryTest.php | 13 +++++++--- tests/phpunit/api/v3/StateProvinceTest.php | 12 +++++++-- 4 files changed, 80 insertions(+), 5 deletions(-) create mode 100644 Civi/Api4/Country.php create mode 100644 Civi/Api4/StateProvince.php diff --git a/Civi/Api4/Country.php b/Civi/Api4/Country.php new file mode 100644 index 000000000000..619cc6c3601f --- /dev/null +++ b/Civi/Api4/Country.php @@ -0,0 +1,30 @@ +_apiversion = 3; parent::setUp(); $this->useTransaction(TRUE); $this->_params = [ @@ -30,7 +28,9 @@ public function setUp() { 'region_id' => 1, ]; } - + /** + * @dataProvider versionThreeAndFour + */ public function testCreateCountry() { $result = $this->callAPIAndDocument('country', 'create', $this->_params, __FUNCTION__, __FILE__); @@ -40,6 +40,9 @@ public function testCreateCountry() { $this->callAPISuccess('country', 'delete', ['id' => $result['id']]); } + /** + * @dataProvider versionThreeAndFour + */ public function testDeleteCountry() { //create one $create = $this->callAPISuccess('country', 'create', $this->_params); @@ -54,6 +57,7 @@ public function testDeleteCountry() { /** * Test civicrm_phone_get with empty params. + * @dataProvider versionThreeAndFour */ public function testGetEmptyParams() { $result = $this->callAPISuccess('Country', 'Get', []); @@ -61,6 +65,7 @@ public function testGetEmptyParams() { /** * Test civicrm_phone_get with wrong params. + * @dataProvider versionThreeAndFour */ public function testGetWrongParams() { $this->callAPIFailure('Country', 'Get', ['id' => 'abc']); @@ -68,6 +73,7 @@ public function testGetWrongParams() { /** * Test civicrm_phone_get - success expected. + * @dataProvider versionThreeAndFour */ public function testGet() { $country = $this->callAPISuccess('Country', 'create', $this->_params); @@ -84,6 +90,7 @@ public function testGet() { /** * If a new country is created and it is created again it should not create a second one. * We check on the iso code (there should be only one iso code + * @dataProvider versionThreeAndFour */ public function testCreateDuplicateFail() { $params = $this->_params; diff --git a/tests/phpunit/api/v3/StateProvinceTest.php b/tests/phpunit/api/v3/StateProvinceTest.php index 8afa132a3e14..7085bf5efb22 100644 --- a/tests/phpunit/api/v3/StateProvinceTest.php +++ b/tests/phpunit/api/v3/StateProvinceTest.php @@ -17,11 +17,9 @@ * @group headless */ class api_v3_StateProvinceTest extends CiviUnitTestCase { - protected $_apiversion; protected $_params; public function setUp() { - $this->_apiversion = 3; parent::setUp(); $this->useTransaction(TRUE); $this->_params = [ @@ -31,6 +29,9 @@ public function setUp() { ]; } + /** + * @dataProvider versionThreeAndFour + */ public function testCreateStateProvince() { $result = $this->callAPIAndDocument('StateProvince', 'create', $this->_params, __FUNCTION__, __FILE__); $this->assertEquals(1, $result['count']); @@ -38,6 +39,9 @@ public function testCreateStateProvince() { $this->callAPISuccess('StateProvince', 'delete', ['id' => $result['id']]); } + /** + * @dataProvider versionThreeAndFour + */ public function testDeleteStateProvince() { // Create $create = $this->callAPISuccess('StateProvince', 'create', $this->_params); @@ -53,6 +57,7 @@ public function testDeleteStateProvince() { /** * Test with empty params + * @dataProvider versionThreeAndFour */ public function testGetEmptyParams() { $result = $this->callAPISuccess('StateProvince', 'Get', []); @@ -60,6 +65,7 @@ public function testGetEmptyParams() { /** * Test with wrong params + * @dataProvider versionThreeAndFour */ public function testGetWrongParams() { $this->callAPIFailure('StateProvince', 'Get', ['id' => 'abc']); @@ -67,6 +73,7 @@ public function testGetWrongParams() { /** * Test get + * @dataProvider versionThreeAndFour */ public function testGet() { $province = $this->callAPISuccess('StateProvince', 'create', $this->_params); @@ -80,6 +87,7 @@ public function testGet() { /** * There cannot be two state/provinces with the same name in the same country. + * @dataProvider versionThreeAndFour */ public function testCreateDuplicateFail() { $params = $this->_params;