Skip to content

Commit

Permalink
Fix obscure bug on updating custom fields (not necessarily hittable v…
Browse files Browse the repository at this point in the history
…ia UI)

This fixes a bug which I think only applies to programatically created custom fields -basically if the field has an empty option_group_id
and then you update it to have one it does a check to see if the existing option_group_id is in use and does not handle the
fact the field is empty - leading to a mysql error.
  • Loading branch information
eileenmcnaughton committed Jul 8, 2019
1 parent dba70c0 commit aa4143b
Show file tree
Hide file tree
Showing 2 changed files with 33 additions and 12 deletions.
2 changes: 1 addition & 1 deletion CRM/Core/BAO/CustomField.php
Original file line number Diff line number Diff line change
Expand Up @@ -2156,7 +2156,7 @@ public static function fixOptionGroups($customFieldId, $optionGroupId) {
);
// get the updated option group
// if both are same return
if ($currentOptionGroupId == $optionGroupId) {
if (!$currentOptionGroupId || $currentOptionGroupId == $optionGroupId) {
return;
}

Expand Down
43 changes: 32 additions & 11 deletions tests/phpunit/api/v3/CustomFieldTest.php
Original file line number Diff line number Diff line change
Expand Up @@ -33,21 +33,18 @@
*/
class api_v3_CustomFieldTest extends CiviUnitTestCase {

protected $_apiversion;

public function setUp() {
$this->_apiversion = 3;
parent::setUp();
}

/**
* Clean up after test.
*
* @throws \CRM_Core_Exception
*/
public function tearDown() {
$tablesToTruncate = [
$this->quickCleanup([
'civicrm_contact',
'civicrm_file',
'civicrm_entity_file',
];
// true tells quickCleanup to drop custom_value tables that might have been created in the test
$this->quickCleanup($tablesToTruncate, TRUE);
], TRUE);
parent::tearDown();
}

/**
Expand Down Expand Up @@ -300,6 +297,30 @@ public function testCustomFieldExistingOptionGroup() {
$this->assertEquals($optionGroupID, 3);
}

/**
* Test adding an optionGroup to an existing field doesn't cause a fatal error.
*
* (this was happening due to a check running despite no existing option_group_id)
*
* @throws \CiviCRM_API3_Exception
*/
public function testUpdateCustomFieldAddOptionGroup() {
$customGroup = $this->customGroupCreate(['extends' => 'Organization', 'title' => 'test_group']);
$params = [
'custom_group_id' => $customGroup['id'],
'label' => 'Organization Gender',
'html_type' => 'Text',
'data_type' => 'Int',
];

$customField = $this->callAPISuccess('custom_field', 'create', $params);
$this->callAPISuccess('CustomField', 'create', [
'option_group_id' => civicrm_api3('OptionGroup', 'getvalue', ['options' => ['limit' => 1], 'return' => 'id']),
'id' => $customField['id'],
'html_type' => 'Select',
]);
}

/**
* Test custom field get works & return param works
*/
Expand Down

0 comments on commit aa4143b

Please sign in to comment.