'Default Domain Name', 'domain_version' => '4.7', ); $result = $this->callAPISuccess('domain', 'get', $params); if (empty($result['id'])) { $result = $this->callAPISuccess('domain', 'create', $params); } $params['name'] = 'Second Domain'; $result = $this->callAPISuccess('domain', 'get', $params); if (empty($result['id'])) { $result = $this->callAPISuccess('domain', 'create', $params); } $this->_domainID2 = $result['id']; $params['name'] = 'A-team domain'; $result = $this->callAPISuccess('domain', 'get', $params); if (empty($result['id'])) { $result = $this->callAPISuccess('domain', 'create', $params); } $this->_domainID3 = $result['id']; $this->_currentDomain = CRM_Core_Config::domainID(); $this->hookClass = CRM_Utils_Hook::singleton(); } public function tearDown() { CRM_Utils_Hook::singleton()->reset(); parent::tearDown(); $this->callAPISuccess('system', 'flush', array()); $this->quickCleanup(array('civicrm_domain')); } /** * Set additional settings into metadata (implements hook) * @param array $metaDataFolders */ public function setExtensionMetadata(&$metaDataFolders) { global $civicrm_root; $metaDataFolders[] = $civicrm_root . '/tests/phpunit/api/v3/settings'; } /** * /** * Check getfields works. */ public function testGetFields() { $description = 'Demonstrate return from getfields - see subfolder for variants'; $result = $this->callAPIAndDocument('setting', 'getfields', array(), __FUNCTION__, __FILE__, $description); $this->assertArrayHasKey('customCSSURL', $result['values']); $description = 'Demonstrate return from getfields'; $result = $this->callAPISuccess('setting', 'getfields', array()); $this->assertArrayHasKey('customCSSURL', $result['values']); $this->callAPISuccess('system', 'flush', array()); } /** * Let's check it's loading from cache by meddling with the cache */ public function testGetFieldsCaching() { $settingsMetadata = array(); Civi::cache('settings')->set('settingsMetadata_' . \CRM_Core_Config::domainID() . '_', $settingsMetadata); Civi::cache('settings')->set(\Civi\Core\SettingsMetadata::ALL, $settingsMetadata); $result = $this->callAPISuccess('setting', 'getfields', array()); $this->assertArrayNotHasKey('customCSSURL', $result['values']); $this->quickCleanup(array('civicrm_cache')); Civi::cache('settings')->flush(); } public function testGetFieldsFilters() { $params = array('name' => 'advanced_search_options'); $result = $this->callAPISuccess('setting', 'getfields', $params); $this->assertArrayNotHasKey('customCSSURL', $result['values']); $this->assertArrayHasKey('advanced_search_options', $result['values']); } /** * Test that getfields will filter on group. */ public function testGetFieldsGroupFilters() { $params = array('filters' => array('group' => 'multisite')); $result = $this->callAPISuccess('setting', 'getfields', $params); $this->assertArrayNotHasKey('customCSSURL', $result['values']); $this->assertArrayHasKey('domain_group_id', $result['values']); } /** * Ensure that on_change callbacks fire. * * Note: api_v3_SettingTest::testOnChange and CRM_Core_BAO_SettingTest::testOnChange * are very similar, but they exercise different codepaths. The first uses the API * and setItems [plural]; the second uses setItem [singular]. */ public function testOnChange() { global $_testOnChange_hookCalls; $this->setMockSettingsMetaData(array( 'onChangeExample' => array( 'group_name' => 'CiviCRM Preferences', 'group' => 'core', 'name' => 'onChangeExample', 'type' => 'Array', 'quick_form_type' => 'Element', 'html_type' => 'advmultiselect', 'default' => array('CiviEvent', 'CiviContribute'), 'add' => '4.4', 'title' => 'List of Components', 'is_domain' => '1', 'is_contact' => 0, 'description' => NULL, 'help_text' => NULL, 'on_change' => array(// list of callbacks array(__CLASS__, '_testOnChange_onChangeExample'), ), ), )); // set initial value $_testOnChange_hookCalls = array('count' => 0); $this->callAPISuccess('setting', 'create', array( 'onChangeExample' => array('First', 'Value'), )); $this->assertEquals(1, $_testOnChange_hookCalls['count']); $this->assertEquals(array('First', 'Value'), $_testOnChange_hookCalls['newValue']); $this->assertEquals('List of Components', $_testOnChange_hookCalls['metadata']['title']); // change value $_testOnChange_hookCalls = array('count' => 0); $this->callAPISuccess('setting', 'create', array( 'onChangeExample' => array('Second', 'Value'), )); $this->assertEquals(1, $_testOnChange_hookCalls['count']); $this->assertEquals(array('First', 'Value'), $_testOnChange_hookCalls['oldValue']); $this->assertEquals(array('Second', 'Value'), $_testOnChange_hookCalls['newValue']); $this->assertEquals('List of Components', $_testOnChange_hookCalls['metadata']['title']); } /** * Mock callback for a setting's on_change handler * * @param $oldValue * @param $newValue * @param $metadata */ public static function _testOnChange_onChangeExample($oldValue, $newValue, $metadata) { global $_testOnChange_hookCalls; $_testOnChange_hookCalls['count']++; $_testOnChange_hookCalls['oldValue'] = $oldValue; $_testOnChange_hookCalls['newValue'] = $newValue; $_testOnChange_hookCalls['metadata'] = $metadata; } /** * Check getfields works. */ public function testCreateSetting() { $description = "Shows setting a variable for a given domain - if no domain is set current is assumed."; $params = array( 'domain_id' => $this->_domainID2, 'uniq_email_per_site' => 1, ); $result = $this->callAPIAndDocument('setting', 'create', $params, __FUNCTION__, __FILE__); $params = array('uniq_email_per_site' => 1); $description = "Shows setting a variable for a current domain."; $result = $this->callAPIAndDocument('setting', 'create', $params, __FUNCTION__, __FILE__, $description, 'CreateSettingCurrentDomain'); $this->assertArrayHasKey(CRM_Core_Config::domainID(), $result['values']); } /** * Check getfields works. */ public function testCreateInvalidSettings() { $params = array( 'domain_id' => $this->_domainID2, 'invalid_key' => 1, ); $result = $this->callAPIFailure('setting', 'create', $params); } /** * Check invalid settings rejected - */ public function testCreateInvalidURLSettings() { $params = array( 'domain_id' => $this->_domainID2, 'userFrameworkResourceURL' => 'dfhkd hfd', ); $result = $this->callAPIFailure('setting', 'create', $params); $params = array( 'domain_id' => $this->_domainID2, 'userFrameworkResourceURL' => 'http://blah.com', ); $result = $this->callAPISuccess('setting', 'create', $params); } /** * Check getfields works. */ public function testCreateInvalidBooleanSettings() { $params = array( 'domain_id' => $this->_domainID2, 'track_civimail_replies' => 'dfhkdhfd', ); $result = $this->callAPIFailure('setting', 'create', $params); $params = array('track_civimail_replies' => '0'); $result = $this->callAPISuccess('setting', 'create', $params); $getResult = $this->callAPISuccess('setting', 'get', $params); $this->assertEquals(0, $getResult['values'][$this->_currentDomain]['track_civimail_replies']); $getResult = $this->callAPISuccess('setting', 'get', $params); $this->assertEquals(0, $getResult['values'][$this->_currentDomain]['track_civimail_replies']); $params = array( 'domain_id' => $this->_domainID2, 'track_civimail_replies' => '1', ); $result = $this->callAPISuccess('setting', 'create', $params); $getResult = $this->callAPISuccess('setting', 'get', $params); $this->assertEquals(1, $getResult['values'][$this->_domainID2]['track_civimail_replies']); $params = array( 'domain_id' => $this->_domainID2, 'track_civimail_replies' => 'TRUE', ); $result = $this->callAPISuccess('setting', 'create', $params); $getResult = $this->callAPISuccess('setting', 'get', $params); $this->assertEquals(1, $getResult['values'][$this->_domainID2]['track_civimail_replies'], "check TRUE is converted to 1"); } /** * Check getfields works. */ public function testCreateSettingMultipleDomains() { $description = "Shows setting a variable for all domains."; $params = array( 'domain_id' => 'all', 'uniq_email_per_site' => 1, ); $result = $this->callAPIAndDocument('setting', 'create', $params, __FUNCTION__, __FILE__, $description, 'CreateAllDomains'); $this->assertEquals(1, $result['values'][2]['uniq_email_per_site']); $this->assertEquals(1, $result['values'][1]['uniq_email_per_site']); $this->assertArrayHasKey(3, $result['values'], 'Domain create probably failed Debug this IF domain test is passing'); $this->assertEquals(1, $result['values'][3]['uniq_email_per_site'], 'failed to set setting for domain 3.'); $params = array( 'domain_id' => 'all', 'return' => 'uniq_email_per_site', ); // we'll check it with a 'get' $description = "Shows getting a variable for all domains."; $result = $this->callAPIAndDocument('setting', 'get', $params, __FUNCTION__, __FILE__, $description, 'GetAllDomains'); $this->assertEquals(1, $result['values'][2]['uniq_email_per_site']); $this->assertEquals(1, $result['values'][1]['uniq_email_per_site']); $this->assertEquals(1, $result['values'][3]['uniq_email_per_site']); $params = array( 'domain_id' => array(1, 3), 'uniq_email_per_site' => 0, ); $description = "Shows setting a variable for specified domains."; $result = $this->callAPIAndDocument('setting', 'create', $params, __FUNCTION__, __FILE__, $description, 'CreateSpecifiedDomains'); $this->assertEquals(0, $result['values'][3]['uniq_email_per_site']); $this->assertEquals(0, $result['values'][1]['uniq_email_per_site']); $params = array( 'domain_id' => array(1, 2), 'return' => array('uniq_email_per_site'), ); $description = "Shows getting a variable for specified domains."; $result = $this->callAPIAndDocument('setting', 'get', $params, __FUNCTION__, __FILE__, $description, 'GetSpecifiedDomains'); $this->assertEquals(1, $result['values'][2]['uniq_email_per_site']); $this->assertEquals(0, $result['values'][1]['uniq_email_per_site']); } public function testGetSetting() { $params = array( 'domain_id' => $this->_domainID2, 'return' => 'uniq_email_per_site', ); $description = "Shows get setting a variable for a given domain - if no domain is set current is assumed."; $result = $this->callAPIAndDocument('setting', 'get', $params, __FUNCTION__, __FILE__); $params = array( 'return' => 'uniq_email_per_site', ); $description = "Shows getting a variable for a current domain."; $result = $this->callAPIAndDocument('setting', 'get', $params, __FUNCTION__, __FILE__, $description, 'GetSettingCurrentDomain'); $this->assertArrayHasKey(CRM_Core_Config::domainID(), $result['values']); } /** * Check that setting defined in extension can be retrieved. */ public function testGetExtensionSetting() { $this->hookClass->setHook('civicrm_alterSettingsFolders', array($this, 'setExtensionMetadata')); $data = NULL; Civi::cache('settings')->flush(); $fields = $this->callAPISuccess('setting', 'getfields', array('filters' => array('group_name' => 'Test Settings'))); $this->assertArrayHasKey('test_key', $fields['values']); $this->callAPISuccess('setting', 'create', array('test_key' => 'keyset')); $this->assertEquals('keyset', Civi::settings()->get('test_key')); $result = $this->callAPISuccess('setting', 'getvalue', array('name' => 'test_key', 'group' => 'Test Settings')); $this->assertEquals('keyset', $result); } /** * Setting api should set & fetch settings stored in config as well as those in settings table */ public function testGetConfigSetting() { $settings = $this->callAPISuccess('setting', 'get', array( 'name' => 'defaultCurrency', 'sequential' => 1, ) ); $this->assertEquals('USD', $settings['values'][0]['defaultCurrency']); } /** * Setting api should set & fetch settings stored in config as well as those in settings table */ public function testGetSetConfigSettingMultipleDomains() { $settings = $this->callAPISuccess('setting', 'create', array( 'defaultCurrency' => 'USD', 'domain_id' => $this->_currentDomain, ) ); $settings = $this->callAPISuccess('setting', 'create', array( 'defaultCurrency' => 'CAD', 'domain_id' => $this->_domainID2, ) ); $settings = $this->callAPISuccess('setting', 'get', array( 'return' => 'defaultCurrency', 'domain_id' => 'all', ) ); $this->assertEquals('USD', $settings['values'][$this->_currentDomain]['defaultCurrency']); $this->assertEquals('CAD', $settings['values'][$this->_domainID2]['defaultCurrency'], "second domain (id {$this->_domainID2} ) should be set to CAD. First dom was {$this->_currentDomain} & was USD"); } /** * Use getValue against a config setting. */ public function testGetValueConfigSetting() { $params = array( 'name' => 'monetaryThousandSeparator', 'group' => 'Localization Setting', ); $result = $this->callAPISuccess('setting', 'getvalue', $params); $this->assertEquals(',', $result); } public function testGetValue() { $params = array( 'name' => 'petition_contacts', 'group' => 'Campaign Preferences', ); $description = "Demonstrates getvalue action - intended for runtime use as better caching than get."; $result = $this->callAPIAndDocument('setting', 'getvalue', $params, __FUNCTION__, __FILE__, $description); $this->assertEquals('Petition Contacts', $result); } public function testGetDefaults() { $description = "Gets defaults setting a variable for a given domain - if no domain is set current is assumed."; $params = array( 'name' => 'address_format', ); $result = $this->callAPIAndDocument('setting', 'getdefaults', $params, __FUNCTION__, __FILE__, $description, 'GetDefaults'); $this->assertEquals("{contact.address_name}\n{contact.street_address}\n{contact.supplemental_address_1}\n{contact.supplemental_address_2}\n{contact.supplemental_address_3}\n{contact.city}{, }{contact.state_province}{ }{contact.postal_code}\n{contact.country}", $result['values'][CRM_Core_Config::domainID()]['address_format']); $params = array('name' => 'mailing_format'); $result = $this->callAPISuccess('setting', 'getdefaults', $params); $this->assertEquals("{contact.addressee}\n{contact.street_address}\n{contact.supplemental_address_1}\n{contact.supplemental_address_2}\n{contact.supplemental_address_3}\n{contact.city}{, }{contact.state_province}{ }{contact.postal_code}\n{contact.country}", $result['values'][CRM_Core_Config::domainID()]['mailing_format']); $this->assertArrayHasKey(CRM_Core_Config::domainID(), $result['values']); } /** * Function tests reverting a specific parameter. */ public function testRevert() { $params = array( 'address_format' => 'xyz', 'mailing_format' => 'bcs', ); $result = $this->callAPISuccess('setting', 'create', $params); $this->assertAPISuccess($result, "in line " . __LINE__); $revertParams = array( 'name' => 'address_format', ); $result = $this->callAPISuccess('setting', 'get', $params); //make sure it's set $this->assertEquals('xyz', $result['values'][CRM_Core_Config::domainID()]['address_format']); $description = "Demonstrates reverting a parameter to default value."; $result = $this->callAPIAndDocument('setting', 'revert', $revertParams, __FUNCTION__, __FILE__, $description, ''); //make sure it's reverted $result = $this->callAPISuccess('setting', 'get', $params); $this->assertEquals("{contact.address_name}\n{contact.street_address}\n{contact.supplemental_address_1}\n{contact.supplemental_address_2}\n{contact.supplemental_address_3}\n{contact.city}{, }{contact.state_province}{ }{contact.postal_code}\n{contact.country}", $result['values'][CRM_Core_Config::domainID()]['address_format']); $params = array( 'return' => array('mailing_format'), ); $result = $this->callAPISuccess('setting', 'get', $params); //make sure it's unchanged $this->assertEquals('bcs', $result['values'][CRM_Core_Config::domainID()]['mailing_format']); } /** * Tests reverting ALL parameters (specific domain) */ public function testRevertAll() { $params = array( 'address_format' => 'xyz', 'mailing_format' => 'bcs', ); $result = $this->callAPISuccess('setting', 'create', $params); $revertParams = array(); $result = $this->callAPISuccess('setting', 'get', $params); //make sure it's set $this->assertEquals('xyz', $result['values'][CRM_Core_Config::domainID()]['address_format']); $this->callAPISuccess('setting', 'revert', $revertParams); //make sure it's reverted $result = $this->callAPISuccess('setting', 'get', array('group' => 'core')); $this->assertEquals("{contact.address_name}\n{contact.street_address}\n{contact.supplemental_address_1}\n{contact.supplemental_address_2}\n{contact.supplemental_address_3}\n{contact.city}{, }{contact.state_province}{ }{contact.postal_code}\n{contact.country}", $result['values'][CRM_Core_Config::domainID()]['address_format']); $this->assertEquals("{contact.addressee}\n{contact.street_address}\n{contact.supplemental_address_1}\n{contact.supplemental_address_2}\n{contact.supplemental_address_3}\n{contact.city}{, }{contact.state_province}{ }{contact.postal_code}\n{contact.country}", $result['values'][CRM_Core_Config::domainID()]['mailing_format']); } /** * Settings should respect their defaults */ public function testDefaults() { $domparams = array( 'name' => 'B Team Domain', 'domain_version' => '4.7', ); $dom = $this->callAPISuccess('domain', 'create', $domparams); $params = array( 'domain_id' => 'all', ); $result = $this->callAPISuccess('setting', 'get', $params); $params = array( 'address_format' => 'xyz', 'mailing_format' => 'bcs', 'domain_id' => $this->_domainID2, ); $result = $this->callAPISuccess('setting', 'create', $params); $params = array( 'domain_id' => $dom['id'], ); $result = $this->callAPISuccess('setting', 'get', $params); $this->assertAPISuccess($result, "in line " . __LINE__); $this->assertEquals('Unconfirmed', $result['values'][$dom['id']]['tag_unconfirmed']); // The 'fill' operation is no longer necessary, but third parties might still use it, so let's // make sure it doesn't do anything weird (crashing or breaking values). $result = $this->callAPISuccess('setting', 'fill', $params); $this->assertAPISuccess($result, "in line " . __LINE__); $result = $this->callAPISuccess('setting', 'get', $params); $this->assertAPISuccess($result, "in line " . __LINE__); $this->assertArrayHasKey('tag_unconfirmed', $result['values'][$dom['id']]); // Setting has NULL default. Not returned. //$this->assertArrayHasKey('extensionsDir', $result['values'][$dom['id']]); $this->assertEquals('Unconfirmed', $result['values'][$dom['id']]['tag_unconfirmed']); } /** * Test to set isProductionEnvironment * */ public function testSetCivicrmEnvironment() { $params = array( 'environment' => 'Staging', ); $result = $this->callAPISuccess('Setting', 'create', $params); $params = array( 'name' => 'environment', 'group' => 'Developer Preferences', ); $result = $this->callAPISuccess('Setting', 'getvalue', $params); $this->assertEquals('Staging', $result); global $civicrm_setting; $civicrm_setting[CRM_Core_BAO_Setting::DEVELOPER_PREFERENCES_NAME]['environment'] = 'Production'; Civi::service('settings_manager')->useMandatory(); $result = $this->callAPISuccess('Setting', 'getvalue', $params); $this->assertEquals('Production', $result); } }