1
1
Fork 0
mirror of https://code.mensbeam.com/MensBeam/Arsse.git synced 2025-01-21 18:40:33 +00:00
Arsse/tests/cases/Conf/TestConf.php

187 lines
6.6 KiB
PHP
Raw Normal View History

2017-02-05 19:00:57 -05:00
<?php
/** @license MIT
* Copyright 2017 J. King, Dustin Wilson et al.
* See LICENSE and AUTHORS files for details */
2017-02-05 19:00:57 -05:00
declare(strict_types=1);
2017-12-21 22:47:19 -05:00
namespace JKingWeb\Arsse\TestCase\Conf;
2017-08-29 10:50:31 -04:00
2017-12-21 22:47:19 -05:00
use JKingWeb\Arsse\Conf;
use org\bovigo\vfs\vfsStream;
2017-02-05 19:00:57 -05:00
2017-07-20 18:36:03 -04:00
/** @covers \JKingWeb\Arsse\Conf */
2017-12-21 22:47:19 -05:00
class TestConf extends \JKingWeb\Arsse\Test\AbstractTest {
2017-08-29 10:50:31 -04:00
public static $vfs;
public static $path;
2017-02-05 19:00:57 -05:00
2019-10-16 14:42:43 -04:00
public function setUp(): void {
2021-02-27 15:24:02 -05:00
parent::setUp();
2017-02-16 14:29:42 -06:00
self::$vfs = vfsStream::setup("root", null, [
'confGood' => '<?php return Array("lang" => "xx");',
'confNotArray' => '<?php return 0;',
'confCorrupt' => '<?php return 0',
'confNotPHP' => 'DEAD BEEF',
'confEmpty' => '',
'confUnreadable' => '',
'confForbidden' => [],
2017-02-16 14:29:42 -06:00
]);
self::$path = self::$vfs->url()."/";
// set up a file without read or write access
2017-02-16 14:29:42 -06:00
chmod(self::$path."confUnreadable", 0000);
// set up a directory without read or write access
chmod(self::$path."confForbidden", 0000);
2017-02-16 14:29:42 -06:00
}
2017-02-08 10:00:38 -05:00
2019-10-16 14:42:43 -04:00
public function tearDown(): void {
2017-02-16 14:29:42 -06:00
self::$path = null;
self::$vfs = null;
2021-02-27 15:24:02 -05:00
parent::tearDown();
2017-02-16 14:29:42 -06:00
}
2020-01-20 13:52:48 -05:00
public function testLoadDefaultValues(): void {
$this->assertInstanceOf(Conf::class, new Conf);
2017-02-16 14:29:42 -06:00
}
2017-07-20 18:36:03 -04:00
/** @depends testLoadDefaultValues */
2020-01-20 13:52:48 -05:00
public function testImportFromArray(): void {
$arr = [
2020-03-01 15:16:50 -05:00
'lang' => "xx",
'purgeFeeds' => "P2D",
];
$conf = new Conf;
2017-02-16 14:29:42 -06:00
$conf->import($arr);
$this->assertEquals("xx", $conf->lang);
}
2017-02-05 19:00:57 -05:00
2017-07-20 18:36:03 -04:00
/** @depends testImportFromArray */
2020-01-20 13:52:48 -05:00
public function testImportFromFile(): void {
$conf = new Conf;
2017-02-16 14:29:42 -06:00
$conf->importFile(self::$path."confGood");
$this->assertEquals("xx", $conf->lang);
$conf = new Conf(self::$path."confGood");
$this->assertEquals("xx", $conf->lang);
}
2017-02-05 19:00:57 -05:00
2017-07-20 18:36:03 -04:00
/** @depends testImportFromFile */
2020-01-20 13:52:48 -05:00
public function testImportFromMissingFile(): void {
2017-02-16 14:29:42 -06:00
$this->assertException("fileMissing", "Conf");
$conf = new Conf(self::$path."confMissing");
}
2017-02-05 19:00:57 -05:00
2017-07-20 18:36:03 -04:00
/** @depends testImportFromFile */
2020-01-20 13:52:48 -05:00
public function testImportFromEmptyFile(): void {
2017-02-16 14:29:42 -06:00
$this->assertException("fileCorrupt", "Conf");
$conf = new Conf(self::$path."confEmpty");
}
2017-02-08 16:59:16 -05:00
2017-07-20 18:36:03 -04:00
/** @depends testImportFromFile */
2020-01-20 13:52:48 -05:00
public function testImportFromFileWithoutReadPermission(): void {
2017-02-16 14:29:42 -06:00
$this->assertException("fileUnreadable", "Conf");
$conf = new Conf(self::$path."confUnreadable");
}
2017-02-05 19:00:57 -05:00
2017-07-20 18:36:03 -04:00
/** @depends testImportFromFile */
2020-01-20 13:52:48 -05:00
public function testImportFromFileWhichIsNotAnArray(): void {
2017-02-16 14:29:42 -06:00
$this->assertException("fileCorrupt", "Conf");
$conf = new Conf(self::$path."confNotArray");
}
2017-02-05 19:00:57 -05:00
2017-07-20 18:36:03 -04:00
/** @depends testImportFromFile */
2020-01-20 13:52:48 -05:00
public function testImportFromFileWhichIsNotPhp(): void {
2017-02-16 14:29:42 -06:00
$this->assertException("fileCorrupt", "Conf");
// this should not print the output of the non-PHP file
$conf = new Conf(self::$path."confNotPHP");
}
2017-02-05 19:00:57 -05:00
2017-07-20 18:36:03 -04:00
/** @depends testImportFromFile */
2020-01-20 13:52:48 -05:00
public function testImportFromCorruptFile(): void {
2017-02-16 14:29:42 -06:00
$this->assertException("fileCorrupt", "Conf");
$conf = new Conf(self::$path."confCorrupt");
}
2020-01-20 13:52:48 -05:00
public function testImportBogusValue(): void {
$arr = [
'dbAutoUpdate' => "yes, please",
];
$conf = new Conf;
$this->assertException("typeMismatch", "Conf");
$conf->import($arr);
}
2021-05-18 18:42:42 -04:00
public function testImportCustomProperty(): void {
$arr = [
'customProperty' => "I'm special!",
];
$conf = new Conf;
$this->assertSame($conf, $conf->import($arr));
}
2020-01-20 13:52:48 -05:00
public function testImportBogusDriver(): void {
$arr = [
'dbDriver' => "this driver does not exist",
];
$conf = new Conf;
$this->assertException("semanticMismatch", "Conf");
$conf->import($arr);
}
2020-01-20 13:52:48 -05:00
public function testExportToArray(): void {
$conf = new Conf;
$conf->lang = ["en", "fr"]; // should not be exported: not scalar
$conf->dbSQLite3File = "test.db"; // should be exported: value changed
2017-08-29 23:17:57 -04:00
$conf->userDriver = null; // should be exported: changed value, even when null
2019-01-21 09:55:25 -05:00
$conf->serviceFrequency = new \DateInterval("PT1H"); // should be exported (as string): value changed
$conf->someCustomProperty = "Look at me!"; // should be exported: unknown property
$exp = [
2020-03-01 15:16:50 -05:00
'dbSQLite3File' => "test.db",
'userDriver' => null,
'serviceFrequency' => "PT1H",
'someCustomProperty' => "Look at me!",
];
$this->assertSame($exp, $conf->export());
$res = $conf->export(true); // export all properties
$this->assertNotSame($exp, $res);
$this->assertArraySubset($exp, $res);
}
2017-08-29 10:50:31 -04:00
/** @depends testExportToArray
* @depends testImportFromFile */
2020-01-20 13:52:48 -05:00
public function testExportToFile(): void {
$conf = new Conf;
$conf->lang = ["en", "fr"]; // should not be exported: not scalar
$conf->dbSQLite3File = "test.db"; // should be exported: value changed
2017-08-29 23:17:57 -04:00
$conf->userDriver = null; // should be exported: changed value, even when null
$conf->someCustomProperty = "Look at me!"; // should be exported: unknown property
$conf->exportFile(self::$path."confNotArray");
$arr = (include self::$path."confNotArray");
$exp = [
2020-03-01 15:16:50 -05:00
'dbSQLite3File' => "test.db",
'userDriver' => null,
'someCustomProperty' => "Look at me!",
];
$this->assertSame($exp, $arr);
$conf->exportFile(self::$path."confNotArray", true); // export all properties
$arr = (include self::$path."confNotArray");
$this->assertNotSame($exp, $arr);
$this->assertArraySubset($exp, $arr);
}
2018-11-06 12:32:28 -05:00
/** @depends testExportToFile */
2020-01-20 13:52:48 -05:00
public function testExportToStdout(): void {
2018-11-06 12:32:28 -05:00
$conf = new Conf(self::$path."confGood");
$conf->exportFile(self::$path."confGood");
$this->expectOutputString(file_get_contents(self::$path."confGood"));
$conf->exportFile("php://output");
}
2020-01-20 13:52:48 -05:00
public function testExportToFileWithoutWritePermission(): void {
$this->assertException("fileUnwritable", "Conf");
(new Conf)->exportFile(self::$path."confUnreadable");
}
2020-01-20 13:52:48 -05:00
public function testExportToFileWithoutCreatePermission(): void {
$this->assertException("fileUncreatable", "Conf");
(new Conf)->exportFile(self::$path."confForbidden/conf");
}
2017-02-05 19:00:57 -05:00
}