added api test
authorPradeep Nayak <pradpnayak@gmail.com>
Thu, 19 Jul 2018 17:30:04 +0000 (23:00 +0530)
committerPradeep Nayak <pradpnayak@gmail.com>
Mon, 23 Jul 2018 13:26:24 +0000 (14:26 +0100)
tests/phpunit/api/v3/FinancialTypeTest.php [new file with mode: 0644]

diff --git a/tests/phpunit/api/v3/FinancialTypeTest.php b/tests/phpunit/api/v3/FinancialTypeTest.php
new file mode 100644 (file)
index 0000000..4e87bfd
--- /dev/null
@@ -0,0 +1,100 @@
+<?php
+/*
+ +--------------------------------------------------------------------+
+ | CiviCRM version 5                                                  |
+ +--------------------------------------------------------------------+
+ | Copyright CiviCRM LLC (c) 2004-2018                                |
+ +--------------------------------------------------------------------+
+ | This file is a part of CiviCRM.                                    |
+ |                                                                    |
+ | CiviCRM is free software; you can copy, modify, and distribute it  |
+ | under the terms of the GNU Affero General Public License           |
+ | Version 3, 19 November 2007 and the CiviCRM Licensing Exception.   |
+ |                                                                    |
+ | CiviCRM is distributed in the hope that it will be useful, but     |
+ | WITHOUT ANY WARRANTY; without even the implied warranty of         |
+ | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.               |
+ | See the GNU Affero General Public License for more details.        |
+ |                                                                    |
+ | You should have received a copy of the GNU Affero General Public   |
+ | License and the CiviCRM Licensing Exception along                  |
+ | with this program; if not, contact CiviCRM LLC                     |
+ | at info[AT]civicrm[DOT]org. If you have questions about the        |
+ | GNU Affero General Public License or the licensing of CiviCRM,     |
+ | see the CiviCRM license FAQ at http://civicrm.org/licensing        |
+ +--------------------------------------------------------------------+
+ */
+
+/**
+ *
+ * @package CiviCRM_APIv3
+ */
+class api_v3_FinancialTypeTest extends CiviUnitTestCase {
+
+  /**
+   * Test Create, Read, Update Financial type with custom field.
+   */
+  public function testCreateUpdateFinancialTypeCustomField() {
+    // create custom group and custom field
+    $customFieldIds = $this->CustomGroupMultipleCreateWithFields([
+      'name' => 'Test_Group_Financial_type',
+      'title' => 'Test_Group_Financial_type',
+      'extends' => 'FinancialType',
+      'is_multiple' => FALSE,
+    ]);
+    $financialTypeData = [
+      'Financial Type' . substr(sha1(rand()), 0, 4) => [
+        ['Test-1', 'Test-2', NULL],
+        [NULL, '', 'Test_3'],
+      ],
+      'Financial Type' . substr(sha1(rand()), 0, 4) => [
+        [NULL, NULL, NULL],
+        ['Test_1', NULL, 'Test_3'],
+      ],
+    ];
+    foreach ($financialTypeData as $financialTypeName => $data) {
+      $params = [
+        'name' => $financialTypeName,
+        'is_deductible' => '1',
+        'is_reserved' => '0',
+        'is_active' => '1',
+      ];
+      $customFields = [];
+      foreach ($data[0] as $key => $value) {
+        $customFields['custom_' . $customFieldIds['custom_field_id'][$key]] = $value;
+      }
+
+      // create financial type with custom field
+      $financialType = $this->callAPISuccess('FinancialType', 'create', array_merge($params, $customFields));
+
+      // get financial type to check custom field value
+      $expectedResult = array_filter(array_merge($params, $customFields), function($var) {
+        return (!is_null($var) && $var != '');
+      });
+      $result = $this->callAPISuccessGetSingle('FinancialType', [
+        'id' => $financialType['id'],
+      ], $expectedResult);
+
+      // updated financial type with custom field
+      $updateCustomFields = [];
+      foreach ($data[1] as $key => $value) {
+        $updateCustomFields['custom_' . $customFieldIds['custom_field_id'][$key]] = $value;
+        if (!is_null($value)) {
+          $customFields['custom_' . $customFieldIds['custom_field_id'][$key]] = $value;
+        }
+      }
+      $this->callAPISuccess('FinancialType', 'create', array_merge([
+        'id' => $financialType['id'],
+      ], $updateCustomFields));
+
+      // get financial type to check custom field value
+      $expectedResult = array_filter(array_merge($params, $customFields), function($var) {
+        return (!is_null($var) && $var != '');
+      });
+      $result = $this->callAPISuccessGetSingle('FinancialType', [
+        'id' => $financialType['id'],
+      ], $expectedResult);
+    }
+  }
+
+}