test failure fix2
[civicrm-core.git] / tests / phpunit / api / v3 / SystemTest.php
1 <?php
2 /*
3 +--------------------------------------------------------------------+
4 | CiviCRM version 4.6 |
5 +--------------------------------------------------------------------+
6 | Copyright CiviCRM LLC (c) 2004-2014 |
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
28 require_once 'CiviTest/CiviUnitTestCase.php';
29
30 /**
31 * Test class for System API - civicrm_system_*
32 *
33 * @package CiviCRM
34 */
35 class api_v3_SystemTest extends CiviUnitTestCase {
36
37 const TEST_CACHE_GROUP = 'SystemTest';
38 const TEST_CACHE_PATH = 'api/v3/system';
39
40 /**
41 * Sets up the fixture, for example, opens a network connection.
42 * This method is called before a test is executed.
43 */
44 protected function setUp() {
45 parent::setUp();
46 $this->useTransaction(TRUE);
47 }
48
49 ///////////////// civicrm_domain_get methods
50
51 /**
52 * Test system flush
53 */
54 public function testFlush() {
55 // Note: this operation actually flushes several different caches; we don't
56 // check all of them -- just enough to make sure that the API is doing
57 // something
58
59 $this->assertTrue(NULL === CRM_Core_BAO_Cache::getItem(self::TEST_CACHE_GROUP, self::TEST_CACHE_PATH));
60
61 $data = 'abc';
62 CRM_Core_BAO_Cache::setItem($data, self::TEST_CACHE_GROUP, self::TEST_CACHE_PATH);
63
64 $this->assertEquals('abc', CRM_Core_BAO_Cache::getItem(self::TEST_CACHE_GROUP, self::TEST_CACHE_PATH));
65
66 $params = array();
67 $result = $this->callAPIAndDocument('system', 'flush', $params, __FUNCTION__, __FILE__, "Flush all system caches", 'Flush', 'flush');
68
69 $this->assertTrue(NULL === CRM_Core_BAO_Cache::getItem(self::TEST_CACHE_GROUP, self::TEST_CACHE_PATH));
70 }
71
72 /**
73 * Test system log function
74 */
75 public function testSystemLog() {
76 $this->callAPISuccess('system', 'log', array('level' => 'info', 'message' => 'We wish you a merry Christmas'));
77 $result = $this->callAPISuccess('SystemLog', 'getsingle', array(
78 'sequential' => 1,
79 'message' => array('LIKE' => '%Chris%'),
80 ));
81 $this->assertEquals($result['message'], 'We wish you a merry Christmas');
82 $this->assertEquals($result['level'], 'info');
83 }
84
85 /**
86 * Test system log function
87 */
88 public function testSystemLogNoLevel() {
89 $this->callAPISuccess('system', 'log', array('message' => 'We wish you a merry Christmas', 'level' => 'alert'));
90 $result = $this->callAPISuccess('SystemLog', 'getsingle', array(
91 'sequential' => 1,
92 'message' => array('LIKE' => '%Chris%'),
93 ));
94 $this->assertEquals($result['message'], 'We wish you a merry Christmas');
95 $this->assertEquals($result['level'], 'alert');
96 }
97
98 public function testSystemGet() {
99 $result = $this->callAPISuccess('system', 'get', array());
100 $this->assertRegExp('/^[0-9]+\.[0-9]+\.[0-9a-z\-]+$/', $result['values'][0]['version']);
101 $this->assertEquals('UnitTests', $result['values'][0]['uf']);
102 }
103 }