Merge pull request #14639 from colemanw/i18nCleanup
[civicrm-core.git] / tests / phpunit / CRM / Core / BAO / OptionValueTest.php
CommitLineData
6f408d71 1<?php
2/*
3 +--------------------------------------------------------------------+
2fe49090 4 | CiviCRM version 5 |
6f408d71 5 +--------------------------------------------------------------------+
6b83d5bd 6 | Copyright CiviCRM LLC (c) 2004-2019 |
6f408d71 7 +--------------------------------------------------------------------+
8 | This file is a part of CiviCRM. |
9 | |
10 | CiviCRM is free software; you can copy, modify, and distribute it |
11 | under the terms of the GNU Affero General Public License |
12 | Version 3, 19 November 2007 and the CiviCRM Licensing Exception. |
13 | |
14 | CiviCRM is distributed in the hope that it will be useful, but |
15 | WITHOUT ANY WARRANTY; without even the implied warranty of |
16 | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. |
17 | See the GNU Affero General Public License for more details. |
18 | |
19 | You should have received a copy of the GNU Affero General Public |
20 | License and the CiviCRM Licensing Exception along |
21 | with this program; if not, contact CiviCRM LLC |
22 | at info[AT]civicrm[DOT]org. If you have questions about the |
23 | GNU Affero General Public License or the licensing of CiviCRM, |
24 | see the CiviCRM license FAQ at http://civicrm.org/licensing |
25 +--------------------------------------------------------------------+
26 */
27
6f408d71 28/**
29 * Class CRM_Core_BAO_SchemaHandlerTest.
30 *
31 * These tests create and drop indexes on the civicrm_uf_join table. The indexes
32 * being added and dropped we assume will never exist.
acb109b7 33 * @group headless
6f408d71 34 */
35class CRM_Core_BAO_OptionValueTest extends CiviUnitTestCase {
36
37 /**
38 * Test setup for every test.
39 */
40 public function setUp() {
41 parent::setUp();
42 $this->useTransaction(TRUE);
43 }
44
45 /**
46 * Ensure only one option value exists after calling ensureOptionValueExists.
47 */
48 public function testEnsureOptionValueExistsExistingValue() {
49 CRM_Core_BAO_OptionValue::ensureOptionValueExists(array('name' => 'Completed', 'option_group_id' => 'contribution_status'));
50 $this->callAPISuccessGetSingle('OptionValue', array('name' => 'Completed', 'option_group_id' => 'contribution_status'));
51 }
52
53 /**
54 * Ensure only one option value exists adds a new value.
55 */
56 public function testEnsureOptionValueExistsNewValue() {
57 CRM_Core_BAO_OptionValue::ensureOptionValueExists(array('name' => 'Bombed', 'option_group_id' => 'contribution_status'));
58 $optionValues = $this->callAPISuccess('OptionValue', 'get', array('option_group_id' => 'contribution_status'));
59 foreach ($optionValues['values'] as $value) {
60 if ($value['name'] == 'Bombed') {
61 return;
62 }
63 }
64 $this->fail('Should not have gotten this far');
65 }
66
6f408d71 67 /**
68 * Ensure only one option value copes with disabled.
69 *
70 * (Our expectation is no change - ie. currently we are respecting 'someone's
71 * decision to disable it & leaving it in that state.
72 */
73 public function testEnsureOptionValueExistsDisabled() {
ad8d1ce3 74 $optionValue = CRM_Core_BAO_OptionValue::ensureOptionValueExists(array('name' => 'Crashed', 'option_group_id' => 'contribution_status', 'is_active' => 0));
6f408d71 75 $value = $this->callAPISuccessGetSingle('OptionValue', array('name' => 'Crashed', 'option_group_id' => 'contribution_status'));
76 $this->assertEquals(0, $value['is_active']);
ad8d1ce3
RO
77 $this->assertEquals($value['id'], $optionValue['id']);
78
79 $optionValue = CRM_Core_BAO_OptionValue::ensureOptionValueExists(array('name' => 'Crashed', 'option_group_id' => 'contribution_status'));
6f408d71 80 $value = $this->callAPISuccessGetSingle('OptionValue', array('name' => 'Crashed', 'option_group_id' => 'contribution_status'));
81 $this->assertEquals(0, $value['is_active']);
ad8d1ce3 82 $this->assertEquals($value['id'], $optionValue['id']);
6f408d71 83 }
84
85}