2014-04-23 10:51:50 +08:00
|
|
|
<?php
|
|
|
|
/**
|
|
|
|
* PhpConfigReaderTest
|
|
|
|
*
|
2018-03-18 09:24:15 +08:00
|
|
|
* CakePHP(tm) Tests <https://book.cakephp.org/2.0/en/development/testing.html>
|
|
|
|
* Copyright (c) Cake Software Foundation, Inc. (https://cakefoundation.org)
|
2014-04-23 10:51:50 +08:00
|
|
|
*
|
|
|
|
* Licensed under The MIT License
|
|
|
|
* For full copyright and license information, please see the LICENSE.txt
|
|
|
|
* Redistributions of files must retain the above copyright notice
|
|
|
|
*
|
2018-03-18 09:24:15 +08:00
|
|
|
* @copyright Copyright (c) Cake Software Foundation, Inc. (https://cakefoundation.org)
|
|
|
|
* @link https://book.cakephp.org/2.0/en/development/testing.html CakePHP(tm) Tests
|
2014-04-23 10:51:50 +08:00
|
|
|
* @package Cake.Test.Case.Configure
|
|
|
|
* @since CakePHP(tm) v 2.0
|
2018-03-18 09:24:15 +08:00
|
|
|
* @license https://opensource.org/licenses/mit-license.php MIT License
|
2014-04-23 10:51:50 +08:00
|
|
|
*/
|
|
|
|
|
|
|
|
App::uses('PhpReader', 'Configure');
|
|
|
|
|
|
|
|
/**
|
2018-03-18 09:24:15 +08:00
|
|
|
* PhpReaderTest
|
2014-04-23 10:51:50 +08:00
|
|
|
*
|
|
|
|
* @package Cake.Test.Case.Configure
|
|
|
|
*/
|
|
|
|
class PhpReaderTest extends CakeTestCase {
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Test data to serialize and unserialize.
|
|
|
|
*
|
|
|
|
* @var array
|
|
|
|
*/
|
|
|
|
public $testData = array(
|
|
|
|
'One' => array(
|
|
|
|
'two' => 'value',
|
|
|
|
'three' => array(
|
|
|
|
'four' => 'value four'
|
|
|
|
),
|
|
|
|
'is_null' => null,
|
|
|
|
'bool_false' => false,
|
|
|
|
'bool_true' => true,
|
|
|
|
),
|
|
|
|
'Asset' => array(
|
|
|
|
'timestamp' => 'force'
|
|
|
|
),
|
|
|
|
);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Setup.
|
|
|
|
*
|
|
|
|
* @return void
|
|
|
|
*/
|
|
|
|
public function setUp() {
|
|
|
|
parent::setUp();
|
|
|
|
$this->path = CAKE . 'Test' . DS . 'test_app' . DS . 'Config' . DS;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Test reading files.
|
|
|
|
*
|
|
|
|
* @return void
|
|
|
|
*/
|
|
|
|
public function testRead() {
|
|
|
|
$reader = new PhpReader($this->path);
|
|
|
|
$values = $reader->read('var_test');
|
|
|
|
$this->assertEquals('value', $values['Read']);
|
|
|
|
$this->assertEquals('buried', $values['Deep']['Deeper']['Deepest']);
|
|
|
|
|
|
|
|
$values = $reader->read('var_test.php');
|
|
|
|
$this->assertEquals('value', $values['Read']);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Test an exception is thrown by reading files that exist without .php extension.
|
|
|
|
*
|
|
|
|
* @expectedException ConfigureException
|
|
|
|
* @return void
|
|
|
|
*/
|
|
|
|
public function testReadWithExistentFileWithoutExtension() {
|
|
|
|
$reader = new PhpReader($this->path);
|
|
|
|
$reader->read('no_php_extension');
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Test an exception is thrown by reading files that don't exist.
|
|
|
|
*
|
|
|
|
* @expectedException ConfigureException
|
|
|
|
* @return void
|
|
|
|
*/
|
|
|
|
public function testReadWithNonExistentFile() {
|
|
|
|
$reader = new PhpReader($this->path);
|
|
|
|
$reader->read('fake_values');
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Test reading an empty file.
|
|
|
|
*
|
|
|
|
* @expectedException ConfigureException
|
|
|
|
* @return void
|
|
|
|
*/
|
|
|
|
public function testReadEmptyFile() {
|
|
|
|
$reader = new PhpReader($this->path);
|
|
|
|
$reader->read('empty');
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Test reading keys with ../ doesn't work.
|
|
|
|
*
|
|
|
|
* @expectedException ConfigureException
|
|
|
|
* @return void
|
|
|
|
*/
|
|
|
|
public function testReadWithDots() {
|
|
|
|
$reader = new PhpReader($this->path);
|
|
|
|
$reader->read('../empty');
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Test reading from plugins.
|
|
|
|
*
|
|
|
|
* @return void
|
|
|
|
*/
|
|
|
|
public function testReadPluginValue() {
|
|
|
|
App::build(array(
|
|
|
|
'Plugin' => array(CAKE . 'Test' . DS . 'test_app' . DS . 'Plugin' . DS)
|
|
|
|
), App::RESET);
|
|
|
|
CakePlugin::load('TestPlugin');
|
|
|
|
$reader = new PhpReader($this->path);
|
|
|
|
$result = $reader->read('TestPlugin.load');
|
|
|
|
$this->assertTrue(isset($result['plugin_load']));
|
|
|
|
|
|
|
|
$result = $reader->read('TestPlugin.load.php');
|
|
|
|
$this->assertTrue(isset($result['plugin_load']));
|
|
|
|
CakePlugin::unload();
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Test dumping data to PHP format.
|
|
|
|
*
|
|
|
|
* @return void
|
|
|
|
*/
|
|
|
|
public function testDump() {
|
|
|
|
$reader = new PhpReader(TMP);
|
|
|
|
$result = $reader->dump('test.php', $this->testData);
|
|
|
|
$this->assertTrue($result > 0);
|
|
|
|
$expected = <<<PHP
|
|
|
|
<?php
|
|
|
|
\$config = array (
|
|
|
|
'One' =>
|
|
|
|
array (
|
|
|
|
'two' => 'value',
|
|
|
|
'three' =>
|
|
|
|
array (
|
|
|
|
'four' => 'value four',
|
|
|
|
),
|
|
|
|
'is_null' => NULL,
|
|
|
|
'bool_false' => false,
|
|
|
|
'bool_true' => true,
|
|
|
|
),
|
|
|
|
'Asset' =>
|
|
|
|
array (
|
|
|
|
'timestamp' => 'force',
|
|
|
|
),
|
|
|
|
);
|
|
|
|
PHP;
|
|
|
|
$file = TMP . 'test.php';
|
|
|
|
$contents = file_get_contents($file);
|
|
|
|
|
|
|
|
unlink($file);
|
|
|
|
$this->assertTextEquals($expected, $contents);
|
|
|
|
|
|
|
|
$result = $reader->dump('test', $this->testData);
|
|
|
|
$this->assertTrue($result > 0);
|
|
|
|
|
|
|
|
$contents = file_get_contents($file);
|
|
|
|
$this->assertTextEquals($expected, $contents);
|
|
|
|
unlink($file);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Test that dump() makes files read() can read.
|
|
|
|
*
|
|
|
|
* @return void
|
|
|
|
*/
|
|
|
|
public function testDumpRead() {
|
|
|
|
$reader = new PhpReader(TMP);
|
|
|
|
$reader->dump('test.php', $this->testData);
|
|
|
|
$result = $reader->read('test.php');
|
|
|
|
unlink(TMP . 'test.php');
|
|
|
|
|
|
|
|
$this->assertEquals($this->testData, $result);
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|