commit
4bc5350eba
|
@ -17,11 +17,12 @@ jobs:
|
||||||
strategy:
|
strategy:
|
||||||
fail-fast: false
|
fail-fast: false
|
||||||
matrix:
|
matrix:
|
||||||
php: ['5.6', '7.0', '7.1', '7.2', '7.3', '7.4']
|
php: ['5.6', '7.0', '7.1', '7.2', '7.3', '7.4', '8.0']
|
||||||
os: ['ubuntu-latest']
|
os: ['ubuntu-latest']
|
||||||
include:
|
include:
|
||||||
- php: '5.6'
|
- php: '5.6'
|
||||||
allow_failure: true
|
allow_failure: true
|
||||||
|
phplint_options: "--exclude='{(?>.*/)?test/php/.*}' --exclude=library/Icinga/Test/BaseTestCase.php"
|
||||||
- php: '7.0'
|
- php: '7.0'
|
||||||
allow_failure: true
|
allow_failure: true
|
||||||
|
|
||||||
|
@ -40,7 +41,7 @@ jobs:
|
||||||
|
|
||||||
- name: PHP Lint
|
- name: PHP Lint
|
||||||
if: success() || matrix.allow_failure
|
if: success() || matrix.allow_failure
|
||||||
run: ./vendor/bin/phplint -n --exclude={^vendor/.*} --exclude=library/Icinga/Util/String.php -- .
|
run: ./vendor/bin/phplint -n --exclude={^vendor/.*} --exclude=library/Icinga/Util/String.php ${{ matrix.phplint_options }} -- .
|
||||||
|
|
||||||
- name: PHP CodeSniffer
|
- name: PHP CodeSniffer
|
||||||
if: success() || matrix.allow_failure
|
if: success() || matrix.allow_failure
|
||||||
|
@ -51,14 +52,16 @@ jobs:
|
||||||
runs-on: ${{ matrix.os }}
|
runs-on: ${{ matrix.os }}
|
||||||
|
|
||||||
env:
|
env:
|
||||||
phpunit-version: 5.7.27
|
phpunit-version: 9.5.4
|
||||||
mockery-version: 0.9.9 # *Any* other version is not compatible with PHP 5.6 and anything above phpunit 6
|
|
||||||
|
|
||||||
strategy:
|
strategy:
|
||||||
fail-fast: false
|
fail-fast: false
|
||||||
matrix:
|
matrix:
|
||||||
php: ['5.6', '7.0', '7.1', '7.2', '7.3', '7.4']
|
php: ['7.2', '7.3', '7.4', '8.0']
|
||||||
os: ['ubuntu-latest']
|
os: ['ubuntu-latest']
|
||||||
|
include:
|
||||||
|
- php: '7.2'
|
||||||
|
phpunit-version: 8.5.15
|
||||||
|
|
||||||
services:
|
services:
|
||||||
mysql:
|
mysql:
|
||||||
|
@ -98,13 +101,13 @@ jobs:
|
||||||
uses: shivammathur/setup-php@v2
|
uses: shivammathur/setup-php@v2
|
||||||
with:
|
with:
|
||||||
php-version: ${{ matrix.php }}
|
php-version: ${{ matrix.php }}
|
||||||
tools: phpunit:${{ env.phpunit-version }}
|
tools: phpunit:${{ matrix.phpunit-version || env.phpunit-version }}
|
||||||
extensions: mysql, pgsql, ldap
|
extensions: mysql, pgsql, ldap
|
||||||
|
|
||||||
- name: Setup dependencies
|
- name: Setup dependencies
|
||||||
run: |
|
run: |
|
||||||
sudo locale-gen en_US.UTF-8 de_DE.UTF-8 fr_FR.UTF-8
|
sudo locale-gen en_US.UTF-8 de_DE.UTF-8 fr_FR.UTF-8
|
||||||
composer require -n --no-progress mockery/mockery:${{ env.mockery-version }}
|
composer require -n --no-progress mockery/mockery
|
||||||
|
|
||||||
- name: PHPUnit
|
- name: PHPUnit
|
||||||
env:
|
env:
|
||||||
|
|
|
@ -605,7 +605,7 @@ abstract class ApplicationBootstrap
|
||||||
ini_set('display_startup_errors', 1);
|
ini_set('display_startup_errors', 1);
|
||||||
ini_set('display_errors', 1);
|
ini_set('display_errors', 1);
|
||||||
set_error_handler(function ($errno, $errstr, $errfile, $errline) {
|
set_error_handler(function ($errno, $errstr, $errfile, $errline) {
|
||||||
if (error_reporting() === 0) {
|
if (! (error_reporting() & $errno)) {
|
||||||
// Error was suppressed with the @-operator
|
// Error was suppressed with the @-operator
|
||||||
return false; // Continue with the normal error handler
|
return false; // Continue with the normal error handler
|
||||||
}
|
}
|
||||||
|
|
|
@ -23,7 +23,6 @@ namespace Icinga\Test {
|
||||||
use Exception;
|
use Exception;
|
||||||
use RuntimeException;
|
use RuntimeException;
|
||||||
use Mockery;
|
use Mockery;
|
||||||
use PHPUnit_Framework_TestCase;
|
|
||||||
use Icinga\Application\Icinga;
|
use Icinga\Application\Icinga;
|
||||||
use Icinga\Data\ConfigObject;
|
use Icinga\Data\ConfigObject;
|
||||||
use Icinga\Data\ResourceFactory;
|
use Icinga\Data\ResourceFactory;
|
||||||
|
@ -32,7 +31,7 @@ namespace Icinga\Test {
|
||||||
/**
|
/**
|
||||||
* Class BaseTestCase
|
* Class BaseTestCase
|
||||||
*/
|
*/
|
||||||
abstract class BaseTestCase extends PHPUnit_Framework_TestCase implements DbTest
|
abstract class BaseTestCase extends Mockery\Adapter\Phpunit\MockeryTestCase implements DbTest
|
||||||
{
|
{
|
||||||
/**
|
/**
|
||||||
* Path to application/
|
* Path to application/
|
||||||
|
@ -138,7 +137,7 @@ namespace Icinga\Test {
|
||||||
/**
|
/**
|
||||||
* Setup MVC bootstrapping and ensure that the Icinga-Mock gets reinitialized
|
* Setup MVC bootstrapping and ensure that the Icinga-Mock gets reinitialized
|
||||||
*/
|
*/
|
||||||
public function setUp()
|
public function setUp(): void
|
||||||
{
|
{
|
||||||
parent::setUp();
|
parent::setUp();
|
||||||
$this->setupIcingaMock();
|
$this->setupIcingaMock();
|
||||||
|
@ -334,6 +333,23 @@ namespace Icinga\Test {
|
||||||
$adapter->exec('DROP TABLE ' . $table . ';');
|
$adapter->exec('DROP TABLE ' . $table . ';');
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Add assertMatchesRegularExpression() method for phpunit >= 8.0 < 9.0 for compatibility with PHP 7.2.
|
||||||
|
*
|
||||||
|
* @TODO Remove once PHP 7.2 support is not needed for testing anymore.
|
||||||
|
*/
|
||||||
|
public static function assertMatchesRegularExpression(
|
||||||
|
string $pattern,
|
||||||
|
string $string,
|
||||||
|
string $message = ''
|
||||||
|
): void {
|
||||||
|
if (method_exists(parent::class, 'assertMatchesRegularExpression')) {
|
||||||
|
parent::assertMatchesRegularExpression($pattern, $string, $message);
|
||||||
|
} else {
|
||||||
|
static::assertRegExp($pattern, $string, $message);
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
BaseTestCase::setupTimezone();
|
BaseTestCase::setupTimezone();
|
||||||
|
|
|
@ -96,7 +96,7 @@ class HostdowntimestarthistoryQuery extends IdoQuery
|
||||||
array()
|
array()
|
||||||
);
|
);
|
||||||
|
|
||||||
if (@func_get_arg(0) === false) {
|
if (func_num_args() === 0 || func_get_arg(0) === false) {
|
||||||
$this->select->where(
|
$this->select->where(
|
||||||
"hdh.actual_start_time > '1970-01-02 00:00:00'"
|
"hdh.actual_start_time > '1970-01-02 00:00:00'"
|
||||||
);
|
);
|
||||||
|
|
|
@ -97,7 +97,7 @@ class ServicedowntimestarthistoryQuery extends IdoQuery
|
||||||
array()
|
array()
|
||||||
);
|
);
|
||||||
|
|
||||||
if (@func_get_arg(0) === false) {
|
if (func_num_args() === 0 || func_get_arg(0) === false) {
|
||||||
$this->select->where(
|
$this->select->where(
|
||||||
"sdh.actual_start_time > '1970-01-02 00:00:00'"
|
"sdh.actual_start_time > '1970-01-02 00:00:00'"
|
||||||
);
|
);
|
||||||
|
|
|
@ -20,7 +20,7 @@ class PluginOutputTest extends BaseTestCase
|
||||||
|
|
||||||
protected static $statusTags = array('OK', 'WARNING', 'CRITICAL', 'UNKNOWN', 'UP', 'DOWN');
|
protected static $statusTags = array('OK', 'WARNING', 'CRITICAL', 'UNKNOWN', 'UP', 'DOWN');
|
||||||
|
|
||||||
public function setUp()
|
public function setUp(): void
|
||||||
{
|
{
|
||||||
parent::setUp();
|
parent::setUp();
|
||||||
|
|
||||||
|
@ -45,7 +45,7 @@ class PluginOutputTest extends BaseTestCase
|
||||||
$html,
|
$html,
|
||||||
preg_quote(self::SUFFIX, '~')
|
preg_quote(self::SUFFIX, '~')
|
||||||
);
|
);
|
||||||
$this->assertRegExp($expect, $actual, 'Output must match example regexp');
|
$this->assertMatchesRegularExpression($expect, $actual, 'Output must match example regexp');
|
||||||
} else {
|
} else {
|
||||||
$expect = $prefix . $html . self::SUFFIX;
|
$expect = $prefix . $html . self::SUFFIX;
|
||||||
$this->assertEquals($expect, $actual, 'Output must match example');
|
$this->assertEquals($expect, $actual, 'Output must match example');
|
||||||
|
|
|
@ -8,19 +8,17 @@ use Icinga\Module\Monitoring\Plugin\Perfdata;
|
||||||
|
|
||||||
class PerfdataTest extends BaseTestCase
|
class PerfdataTest extends BaseTestCase
|
||||||
{
|
{
|
||||||
/**
|
|
||||||
* @expectedException \InvalidArgumentException
|
|
||||||
*/
|
|
||||||
public function testWhetherFromStringThrowsExceptionWhenGivenAnEmptyString()
|
public function testWhetherFromStringThrowsExceptionWhenGivenAnEmptyString()
|
||||||
{
|
{
|
||||||
|
$this->expectException(\InvalidArgumentException::class);
|
||||||
|
|
||||||
Perfdata::fromString('');
|
Perfdata::fromString('');
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* @expectedException \InvalidArgumentException
|
|
||||||
*/
|
|
||||||
public function testWhetherFromStringThrowsExceptionWhenGivenAnInvalidString()
|
public function testWhetherFromStringThrowsExceptionWhenGivenAnInvalidString()
|
||||||
{
|
{
|
||||||
|
$this->expectException(\InvalidArgumentException::class);
|
||||||
|
|
||||||
Perfdata::fromString('test');
|
Perfdata::fromString('test');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -16,11 +16,10 @@ class MockedRestRequest extends RestRequest
|
||||||
|
|
||||||
class RestRequestTest extends BaseTestCase
|
class RestRequestTest extends BaseTestCase
|
||||||
{
|
{
|
||||||
/**
|
|
||||||
* @expectedException \Icinga\Exception\Json\JsonDecodeException
|
|
||||||
*/
|
|
||||||
public function testInvalidServerResponseHandling()
|
public function testInvalidServerResponseHandling()
|
||||||
{
|
{
|
||||||
|
$this->expectException(\Icinga\Exception\Json\JsonDecodeException::class);
|
||||||
|
|
||||||
MockedRestRequest::get('http://localhost')->send();
|
MockedRestRequest::get('http://localhost')->send();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -24,7 +24,7 @@ class ConfigWithSetModuleConfig extends Config
|
||||||
|
|
||||||
class Bug7043Test extends BaseTestCase
|
class Bug7043Test extends BaseTestCase
|
||||||
{
|
{
|
||||||
public function tearDown()
|
public function tearDown(): void
|
||||||
{
|
{
|
||||||
parent::tearDown();
|
parent::tearDown();
|
||||||
Mockery::close(); // Necessary because some tests run in a separate process
|
Mockery::close(); // Necessary because some tests run in a separate process
|
||||||
|
|
|
@ -9,10 +9,10 @@ $currentPos = array_search($wizard->getCurrentPage(), $pages, true);
|
||||||
list($configPagesLeft, $configPagesRight) = array_chunk($configPages, count($configPages) / 2, true);
|
list($configPagesLeft, $configPagesRight) = array_chunk($configPages, count($configPages) / 2, true);
|
||||||
|
|
||||||
$visitedPages = array_keys($wizard->getPageData());
|
$visitedPages = array_keys($wizard->getPageData());
|
||||||
$maxProgress = @max(array_keys(array_filter(
|
$maxProgress = max(array_merge([0], array_keys(array_filter(
|
||||||
$pages,
|
$pages,
|
||||||
function ($page) use ($visitedPages) { return in_array($page->getName(), $visitedPages); }
|
function ($page) use ($visitedPages) { return in_array($page->getName(), $visitedPages); }
|
||||||
)));
|
))));
|
||||||
|
|
||||||
?>
|
?>
|
||||||
<div id="setup-content-wrapper" data-base-target="layout">
|
<div id="setup-content-wrapper" data-base-target="layout">
|
||||||
|
|
|
@ -12,7 +12,7 @@ require_once BaseTestCase::$appDir . '/views/helpers/DateFormat.php';
|
||||||
|
|
||||||
class DateFormatTest extends BaseTestCase
|
class DateFormatTest extends BaseTestCase
|
||||||
{
|
{
|
||||||
public function tearDown()
|
public function tearDown(): void
|
||||||
{
|
{
|
||||||
DateTimeFactory::setConfig(array('timezone' => date_default_timezone_get()));
|
DateTimeFactory::setConfig(array('timezone' => date_default_timezone_get()));
|
||||||
}
|
}
|
||||||
|
|
|
@ -36,10 +36,6 @@ if (file_exists($vendorAutoload)) {
|
||||||
|
|
||||||
require_once($icingaLibPath . '/Test/ClassLoader.php');
|
require_once($icingaLibPath . '/Test/ClassLoader.php');
|
||||||
|
|
||||||
if (! class_exists('PHPUnit_Framework_TestCase')) {
|
|
||||||
require_once __DIR__ . '/phpunit-compat.php';
|
|
||||||
}
|
|
||||||
|
|
||||||
$loader = new Icinga\Test\ClassLoader();
|
$loader = new Icinga\Test\ClassLoader();
|
||||||
$loader->registerNamespace('Tests', $testLibraryPath);
|
$loader->registerNamespace('Tests', $testLibraryPath);
|
||||||
$loader->registerNamespace('Icinga', $icingaLibPath);
|
$loader->registerNamespace('Icinga', $icingaLibPath);
|
||||||
|
|
|
@ -26,7 +26,7 @@ class TestStruct
|
||||||
|
|
||||||
EOD;
|
EOD;
|
||||||
|
|
||||||
public function setUp()
|
public function setUp(): void
|
||||||
{
|
{
|
||||||
parent::setUp();
|
parent::setUp();
|
||||||
$tempDir = sys_get_temp_dir();
|
$tempDir = sys_get_temp_dir();
|
||||||
|
@ -35,7 +35,7 @@ EOD;
|
||||||
file_put_contents($this->baseDir. self::$classFile, self::$classContent);
|
file_put_contents($this->baseDir. self::$classFile, self::$classContent);
|
||||||
}
|
}
|
||||||
|
|
||||||
public function tearDown()
|
public function tearDown(): void
|
||||||
{
|
{
|
||||||
parent::tearDown();
|
parent::tearDown();
|
||||||
system('rm -rf '. $this->baseDir);
|
system('rm -rf '. $this->baseDir);
|
||||||
|
|
|
@ -11,7 +11,7 @@ class ConfigTest extends BaseTestCase
|
||||||
/**
|
/**
|
||||||
* Set up config dir
|
* Set up config dir
|
||||||
*/
|
*/
|
||||||
public function setUp()
|
public function setUp(): void
|
||||||
{
|
{
|
||||||
parent::setUp();
|
parent::setUp();
|
||||||
$this->oldConfigDir = Config::$configDir;
|
$this->oldConfigDir = Config::$configDir;
|
||||||
|
@ -21,7 +21,7 @@ class ConfigTest extends BaseTestCase
|
||||||
/**
|
/**
|
||||||
* Reset config dir
|
* Reset config dir
|
||||||
*/
|
*/
|
||||||
public function tearDown()
|
public function tearDown(): void
|
||||||
{
|
{
|
||||||
parent::tearDown();
|
parent::tearDown();
|
||||||
Config::$configDir = $this->oldConfigDir;
|
Config::$configDir = $this->oldConfigDir;
|
||||||
|
@ -185,11 +185,10 @@ class ConfigTest extends BaseTestCase
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* @expectedException UnexpectedValueException
|
|
||||||
*/
|
|
||||||
public function testWhetherAnExceptionIsThrownWhenTryingToAccessASectionPropertyOnANonSection()
|
public function testWhetherAnExceptionIsThrownWhenTryingToAccessASectionPropertyOnANonSection()
|
||||||
{
|
{
|
||||||
|
$this->expectException(\UnexpectedValueException::class);
|
||||||
|
|
||||||
$config = Config::fromArray(array('a' => 'b'));
|
$config = Config::fromArray(array('a' => 'b'));
|
||||||
$config->get('a', 'b');
|
$config->get('a', 'b');
|
||||||
}
|
}
|
||||||
|
@ -234,11 +233,10 @@ class ConfigTest extends BaseTestCase
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* @expectedException Icinga\Exception\NotReadableError
|
|
||||||
*/
|
|
||||||
public function testWhetherFromIniThrowsAnExceptionOnInsufficientPermission()
|
public function testWhetherFromIniThrowsAnExceptionOnInsufficientPermission()
|
||||||
{
|
{
|
||||||
|
$this->expectException(\Icinga\Exception\NotReadableError::class);
|
||||||
|
|
||||||
Config::fromIni('/etc/shadow');
|
Config::fromIni('/etc/shadow');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -32,27 +32,24 @@ class AuditHookTest extends BaseTestCase
|
||||||
$this->assertEquals('foo', (new TestAuditHook())->formatMessage('{{te{.}st}}', ['te{' => ['}st' => 'foo']]));
|
$this->assertEquals('foo', (new TestAuditHook())->formatMessage('{{te{.}st}}', ['te{' => ['}st' => 'foo']]));
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* @expectedException \InvalidArgumentException
|
|
||||||
*/
|
|
||||||
public function testFormatMessageComplainsAboutUnresolvedParameters()
|
public function testFormatMessageComplainsAboutUnresolvedParameters()
|
||||||
{
|
{
|
||||||
|
$this->expectException(\InvalidArgumentException::class);
|
||||||
|
|
||||||
(new TestAuditHook())->formatMessage('{{missing}}', []);
|
(new TestAuditHook())->formatMessage('{{missing}}', []);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* @expectedException \InvalidArgumentException
|
|
||||||
*/
|
|
||||||
public function testFormatMessageComplainsAboutNonScalarParameters()
|
public function testFormatMessageComplainsAboutNonScalarParameters()
|
||||||
{
|
{
|
||||||
|
$this->expectException(\InvalidArgumentException::class);
|
||||||
|
|
||||||
(new TestAuditHook())->formatMessage('{{test}}', ['test' => ['foo' => 'bar']]);
|
(new TestAuditHook())->formatMessage('{{test}}', ['test' => ['foo' => 'bar']]);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* @expectedException \InvalidArgumentException
|
|
||||||
*/
|
|
||||||
public function testFormatMessageComplainsAboutNonArrayParameters()
|
public function testFormatMessageComplainsAboutNonArrayParameters()
|
||||||
{
|
{
|
||||||
|
$this->expectException(\InvalidArgumentException::class);
|
||||||
|
|
||||||
(new TestAuditHook())->formatMessage('{{test.foo}}', ['test' => 'foo']);
|
(new TestAuditHook())->formatMessage('{{test.foo}}', ['test' => 'foo']);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -115,11 +115,10 @@ class ConfigObjectTest extends BaseTestCase
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* @expectedException \Icinga\Exception\ProgrammingError
|
|
||||||
*/
|
|
||||||
public function testWhetherItIsNotPossibleToAppendProperties()
|
public function testWhetherItIsNotPossibleToAppendProperties()
|
||||||
{
|
{
|
||||||
|
$this->expectException(\Icinga\Exception\ProgrammingError::class);
|
||||||
|
|
||||||
$config = new ConfigObject();
|
$config = new ConfigObject();
|
||||||
$config[] = 'test';
|
$config[] = 'test';
|
||||||
}
|
}
|
||||||
|
|
|
@ -10,7 +10,7 @@ class ArrayDatasourceTest extends BaseTestCase
|
||||||
{
|
{
|
||||||
private $sampleData;
|
private $sampleData;
|
||||||
|
|
||||||
public function setUp()
|
public function setUp(): void
|
||||||
{
|
{
|
||||||
parent::setUp();
|
parent::setUp();
|
||||||
$this->sampleData = array(
|
$this->sampleData = array(
|
||||||
|
|
|
@ -61,7 +61,7 @@ class FilterTest extends BaseTestCase
|
||||||
|
|
||||||
private $sampleData;
|
private $sampleData;
|
||||||
|
|
||||||
public function setUp()
|
public function setUp(): void
|
||||||
{
|
{
|
||||||
parent::setUp();
|
parent::setUp();
|
||||||
$this->sampleData = array(
|
$this->sampleData = array(
|
||||||
|
|
|
@ -12,13 +12,13 @@ class IniParserTest extends BaseTestCase
|
||||||
{
|
{
|
||||||
protected $tempFile;
|
protected $tempFile;
|
||||||
|
|
||||||
public function setUp()
|
public function setUp(): void
|
||||||
{
|
{
|
||||||
parent::setUp();
|
parent::setUp();
|
||||||
$this->tempFile = tempnam(sys_get_temp_dir(), 'icinga-ini-parser-test');
|
$this->tempFile = tempnam(sys_get_temp_dir(), 'icinga-ini-parser-test');
|
||||||
}
|
}
|
||||||
|
|
||||||
public function tearDown()
|
public function tearDown(): void
|
||||||
{
|
{
|
||||||
parent::tearDown();
|
parent::tearDown();
|
||||||
unlink($this->tempFile);
|
unlink($this->tempFile);
|
||||||
|
|
|
@ -12,7 +12,7 @@ class IniWriterTest extends BaseTestCase
|
||||||
protected $tempFile;
|
protected $tempFile;
|
||||||
protected $tempFile2;
|
protected $tempFile2;
|
||||||
|
|
||||||
public function setUp()
|
public function setUp(): void
|
||||||
{
|
{
|
||||||
parent::setUp();
|
parent::setUp();
|
||||||
|
|
||||||
|
@ -20,7 +20,7 @@ class IniWriterTest extends BaseTestCase
|
||||||
$this->tempFile2 = tempnam(sys_get_temp_dir(), 'icinga-ini-writer-test-2');
|
$this->tempFile2 = tempnam(sys_get_temp_dir(), 'icinga-ini-writer-test-2');
|
||||||
}
|
}
|
||||||
|
|
||||||
public function tearDown()
|
public function tearDown(): void
|
||||||
{
|
{
|
||||||
parent::tearDown();
|
parent::tearDown();
|
||||||
|
|
||||||
|
@ -275,7 +275,7 @@ inkey' => 'blarg'
|
||||||
);
|
);
|
||||||
|
|
||||||
$rendered = $writer->render();
|
$rendered = $writer->render();
|
||||||
$this->assertRegExp(
|
$this->assertMatchesRegularExpression(
|
||||||
'~linebreak\\\\nin line~',
|
'~linebreak\\\\nin line~',
|
||||||
$rendered,
|
$rendered,
|
||||||
'newlines in values are not escaped'
|
'newlines in values are not escaped'
|
||||||
|
@ -322,11 +322,10 @@ EOD;
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* @expectedException \Icinga\Exception\ConfigurationError
|
|
||||||
*/
|
|
||||||
public function testWhetherBracketsAreIllegalInSectionNames()
|
public function testWhetherBracketsAreIllegalInSectionNames()
|
||||||
{
|
{
|
||||||
|
$this->expectException(\Icinga\Exception\ConfigurationError::class);
|
||||||
|
|
||||||
$config = Config::fromArray(['section [brackets]' => []]);
|
$config = Config::fromArray(['section [brackets]' => []]);
|
||||||
(new IniWriter($config, $this->tempFile))->write();
|
(new IniWriter($config, $this->tempFile))->write();
|
||||||
}
|
}
|
||||||
|
@ -419,7 +418,7 @@ EOD;
|
||||||
$config->setSection('garbage', $section);
|
$config->setSection('garbage', $section);
|
||||||
|
|
||||||
$iniWriter = new IniWriter($config, '/dev/null');
|
$iniWriter = new IniWriter($config, '/dev/null');
|
||||||
$this->assertNotContains(
|
$this->assertStringNotContainsString(
|
||||||
'foobar',
|
'foobar',
|
||||||
$iniWriter->render(),
|
$iniWriter->render(),
|
||||||
'IniWriter persists section keys with null values'
|
'IniWriter persists section keys with null values'
|
||||||
|
@ -434,7 +433,7 @@ EOD;
|
||||||
$config->setSection('garbage', $section);
|
$config->setSection('garbage', $section);
|
||||||
|
|
||||||
$iniWriter = new IniWriter($config, '/dev/null');
|
$iniWriter = new IniWriter($config, '/dev/null');
|
||||||
$this->assertContains(
|
$this->assertStringContainsString(
|
||||||
'foobar',
|
'foobar',
|
||||||
$iniWriter->render(),
|
$iniWriter->render(),
|
||||||
'IniWriter doesn\'t persist section keys with empty values'
|
'IniWriter doesn\'t persist section keys with empty values'
|
||||||
|
@ -451,7 +450,7 @@ EOD;
|
||||||
$section = $config->getSection('garbage');
|
$section = $config->getSection('garbage');
|
||||||
$section->foobar = null;
|
$section->foobar = null;
|
||||||
$iniWriter = new IniWriter($config, $filename);
|
$iniWriter = new IniWriter($config, $filename);
|
||||||
$this->assertNotContains(
|
$this->assertStringNotContainsString(
|
||||||
'foobar',
|
'foobar',
|
||||||
$iniWriter->render(),
|
$iniWriter->render(),
|
||||||
'IniWriter doesn\'t remove section keys with null values'
|
'IniWriter doesn\'t remove section keys with null values'
|
||||||
|
|
|
@ -54,11 +54,10 @@ class LocalFileStorageTest extends BaseTestCase
|
||||||
static::assertSame(array('foobar'), array_values(iterator_to_array($lfs->getIterator())));
|
static::assertSame(array('foobar'), array_values(iterator_to_array($lfs->getIterator())));
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* @expectedException \Icinga\Exception\NotReadableError
|
|
||||||
*/
|
|
||||||
public function testGetIteratorThrowsNotReadableError()
|
public function testGetIteratorThrowsNotReadableError()
|
||||||
{
|
{
|
||||||
|
$this->expectException(\Icinga\Exception\NotReadableError::class);
|
||||||
|
|
||||||
$lfs = new LocalFileStorage('/notreadabledirectory');
|
$lfs = new LocalFileStorage('/notreadabledirectory');
|
||||||
$lfs->getIterator();
|
$lfs->getIterator();
|
||||||
}
|
}
|
||||||
|
@ -79,21 +78,19 @@ class LocalFileStorageTest extends BaseTestCase
|
||||||
static::assertSame('Hello world!', $lfs->read('foo/bar'));
|
static::assertSame('Hello world!', $lfs->read('foo/bar'));
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* @expectedException \Icinga\Exception\AlreadyExistsException
|
|
||||||
*/
|
|
||||||
public function testCreateThrowsAlreadyExistsException()
|
public function testCreateThrowsAlreadyExistsException()
|
||||||
{
|
{
|
||||||
|
$this->expectException(\Icinga\Exception\AlreadyExistsException::class);
|
||||||
|
|
||||||
$lfs = new TemporaryLocalFileStorage();
|
$lfs = new TemporaryLocalFileStorage();
|
||||||
$lfs->create('foobar', 'Hello world!');
|
$lfs->create('foobar', 'Hello world!');
|
||||||
$lfs->create('foobar', 'Hello world!');
|
$lfs->create('foobar', 'Hello world!');
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* @expectedException \Icinga\Exception\NotWritableError
|
|
||||||
*/
|
|
||||||
public function testCreateThrowsNotWritableError()
|
public function testCreateThrowsNotWritableError()
|
||||||
{
|
{
|
||||||
|
$this->expectException(\Icinga\Exception\NotWritableError::class);
|
||||||
|
|
||||||
$lfs = new LocalFileStorage('/notwritabledirectory');
|
$lfs = new LocalFileStorage('/notwritabledirectory');
|
||||||
$lfs->create('foobar', 'Hello world!');
|
$lfs->create('foobar', 'Hello world!');
|
||||||
}
|
}
|
||||||
|
@ -105,20 +102,18 @@ class LocalFileStorageTest extends BaseTestCase
|
||||||
static::assertSame('Hello world!', $lfs->read('foobar'));
|
static::assertSame('Hello world!', $lfs->read('foobar'));
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* @expectedException \Icinga\Exception\NotFoundError
|
|
||||||
*/
|
|
||||||
public function testReadThrowsNotFoundError()
|
public function testReadThrowsNotFoundError()
|
||||||
{
|
{
|
||||||
|
$this->expectException(\Icinga\Exception\NotFoundError::class);
|
||||||
|
|
||||||
$lfs = new TemporaryLocalFileStorage();
|
$lfs = new TemporaryLocalFileStorage();
|
||||||
$lfs->read('foobar');
|
$lfs->read('foobar');
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* @expectedException \Icinga\Exception\NotReadableError
|
|
||||||
*/
|
|
||||||
public function testReadThrowsNotReadableError()
|
public function testReadThrowsNotReadableError()
|
||||||
{
|
{
|
||||||
|
$this->expectException(\Icinga\Exception\NotReadableError::class);
|
||||||
|
|
||||||
$lfs = new TemporaryLocalFileStorage();
|
$lfs = new TemporaryLocalFileStorage();
|
||||||
$lfs->create('foobar', 'Hello world!');
|
$lfs->create('foobar', 'Hello world!');
|
||||||
chmod($lfs->resolvePath('foobar'), 0);
|
chmod($lfs->resolvePath('foobar'), 0);
|
||||||
|
@ -133,20 +128,18 @@ class LocalFileStorageTest extends BaseTestCase
|
||||||
static::assertSame('Hello universe!', $lfs->read('foobar'));
|
static::assertSame('Hello universe!', $lfs->read('foobar'));
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* @expectedException \Icinga\Exception\NotFoundError
|
|
||||||
*/
|
|
||||||
public function testUpdateThrowsNotFoundError()
|
public function testUpdateThrowsNotFoundError()
|
||||||
{
|
{
|
||||||
|
$this->expectException(\Icinga\Exception\NotFoundError::class);
|
||||||
|
|
||||||
$lfs = new TemporaryLocalFileStorage();
|
$lfs = new TemporaryLocalFileStorage();
|
||||||
$lfs->update('foobar', 'Hello universe!');
|
$lfs->update('foobar', 'Hello universe!');
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* @expectedException \Icinga\Exception\NotWritableError
|
|
||||||
*/
|
|
||||||
public function testUpdateThrowsNotWritableError()
|
public function testUpdateThrowsNotWritableError()
|
||||||
{
|
{
|
||||||
|
$this->expectException(\Icinga\Exception\NotWritableError::class);
|
||||||
|
|
||||||
$lfs = new TemporaryLocalFileStorage();
|
$lfs = new TemporaryLocalFileStorage();
|
||||||
$lfs->create('foobar', 'Hello world!');
|
$lfs->create('foobar', 'Hello world!');
|
||||||
chmod($lfs->resolvePath('foobar'), 0);
|
chmod($lfs->resolvePath('foobar'), 0);
|
||||||
|
@ -161,20 +154,18 @@ class LocalFileStorageTest extends BaseTestCase
|
||||||
static::assertFalse($lfs->has('foobar'));
|
static::assertFalse($lfs->has('foobar'));
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* @expectedException \Icinga\Exception\NotFoundError
|
|
||||||
*/
|
|
||||||
public function testDeleteThrowsNotFoundError()
|
public function testDeleteThrowsNotFoundError()
|
||||||
{
|
{
|
||||||
|
$this->expectException(\Icinga\Exception\NotFoundError::class);
|
||||||
|
|
||||||
$lfs = new TemporaryLocalFileStorage();
|
$lfs = new TemporaryLocalFileStorage();
|
||||||
$lfs->delete('foobar');
|
$lfs->delete('foobar');
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* @expectedException \Icinga\Exception\NotWritableError
|
|
||||||
*/
|
|
||||||
public function testDeleteThrowsNotWritableError()
|
public function testDeleteThrowsNotWritableError()
|
||||||
{
|
{
|
||||||
|
$this->expectException(\Icinga\Exception\NotWritableError::class);
|
||||||
|
|
||||||
$lfs = new TemporaryLocalFileStorage();
|
$lfs = new TemporaryLocalFileStorage();
|
||||||
$lfs->create('foobar', 'Hello world!');
|
$lfs->create('foobar', 'Hello world!');
|
||||||
|
|
||||||
|
@ -204,20 +195,18 @@ class LocalFileStorageTest extends BaseTestCase
|
||||||
$lfs->resolvePath('./notRelevant/../foobar', true);
|
$lfs->resolvePath('./notRelevant/../foobar', true);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* @expectedException \Icinga\Exception\NotFoundError
|
|
||||||
*/
|
|
||||||
public function testResolvePathThrowsNotFoundError()
|
public function testResolvePathThrowsNotFoundError()
|
||||||
{
|
{
|
||||||
|
$this->expectException(\Icinga\Exception\NotFoundError::class);
|
||||||
|
|
||||||
$lfs = new TemporaryLocalFileStorage();
|
$lfs = new TemporaryLocalFileStorage();
|
||||||
$lfs->resolvePath('foobar', true);
|
$lfs->resolvePath('foobar', true);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* @expectedException \InvalidArgumentException
|
|
||||||
*/
|
|
||||||
public function testResolvePathThrowsInvalidArgumentException()
|
public function testResolvePathThrowsInvalidArgumentException()
|
||||||
{
|
{
|
||||||
|
$this->expectException(\InvalidArgumentException::class);
|
||||||
|
|
||||||
$lfs = new LocalFileStorage('/notreadabledirectory');
|
$lfs = new LocalFileStorage('/notreadabledirectory');
|
||||||
$lfs->resolvePath('../foobar');
|
$lfs->resolvePath('../foobar');
|
||||||
}
|
}
|
||||||
|
|
|
@ -10,14 +10,14 @@ use Icinga\Test\BaseTestCase;
|
||||||
|
|
||||||
class StreamWriterTest extends BaseTestCase
|
class StreamWriterTest extends BaseTestCase
|
||||||
{
|
{
|
||||||
public function setUp()
|
public function setUp(): void
|
||||||
{
|
{
|
||||||
parent::setUp();
|
parent::setUp();
|
||||||
|
|
||||||
$this->target = tempnam(sys_get_temp_dir(), 'log');
|
$this->target = tempnam(sys_get_temp_dir(), 'log');
|
||||||
}
|
}
|
||||||
|
|
||||||
public function tearDown()
|
public function tearDown(): void
|
||||||
{
|
{
|
||||||
parent::tearDown();
|
parent::tearDown();
|
||||||
|
|
||||||
|
@ -38,6 +38,6 @@ class StreamWriterTest extends BaseTestCase
|
||||||
$writer = new FileWriter(new ConfigObject(array('file' => $this->target)));
|
$writer = new FileWriter(new ConfigObject(array('file' => $this->target)));
|
||||||
$writer->log(Logger::ERROR, 'This is a test error');
|
$writer->log(Logger::ERROR, 'This is a test error');
|
||||||
$log = file_get_contents($this->target);
|
$log = file_get_contents($this->target);
|
||||||
$this->assertContains('This is a test error', $log, 'StreamWriter does not write log messages');
|
$this->assertStringContainsString('This is a test error', $log, 'StreamWriter does not write log messages');
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -10,7 +10,7 @@ class BaseTestCaseTest extends BaseTestCase
|
||||||
{
|
{
|
||||||
protected $emptySqlDumpFile;
|
protected $emptySqlDumpFile;
|
||||||
|
|
||||||
public function tearDown()
|
public function tearDown(): void
|
||||||
{
|
{
|
||||||
parent::tearDown();
|
parent::tearDown();
|
||||||
|
|
||||||
|
@ -148,19 +148,17 @@ class BaseTestCaseTest extends BaseTestCase
|
||||||
$this->assertCount(0, $tables);
|
$this->assertCount(0, $tables);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* @expectedException RuntimeException
|
|
||||||
*/
|
|
||||||
public function testWhetherLoadSqlThrowsErrorWhenFileMissing()
|
public function testWhetherLoadSqlThrowsErrorWhenFileMissing()
|
||||||
{
|
{
|
||||||
|
$this->expectException(\RuntimeException::class);
|
||||||
|
|
||||||
$this->loadSql(Mockery::mock('Icinga\Data\Db\DbConnection'), 'not_existing');
|
$this->loadSql(Mockery::mock('Icinga\Data\Db\DbConnection'), 'not_existing');
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* @expectedException RuntimeException
|
|
||||||
*/
|
|
||||||
public function testWhetherLoadSqlThrowsErrorWhenFileEmpty()
|
public function testWhetherLoadSqlThrowsErrorWhenFileEmpty()
|
||||||
{
|
{
|
||||||
|
$this->expectException(\RuntimeException::class);
|
||||||
|
|
||||||
$this->emptySqlDumpFile = tempnam(sys_get_temp_dir(), 'icinga2-web-db-test-empty');
|
$this->emptySqlDumpFile = tempnam(sys_get_temp_dir(), 'icinga2-web-db-test-empty');
|
||||||
$this->loadSql(Mockery::mock('Icinga\Data\Db\DbConnection'), $this->emptySqlDumpFile);
|
$this->loadSql(Mockery::mock('Icinga\Data\Db\DbConnection'), $this->emptySqlDumpFile);
|
||||||
}
|
}
|
||||||
|
|
|
@ -83,11 +83,10 @@ class DbStoreTest extends BaseTestCase
|
||||||
$this->assertEmpty($dbMock->deletions, 'DbStore::save deletes *new* preferences');
|
$this->assertEmpty($dbMock->deletions, 'DbStore::save deletes *new* preferences');
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* @expectedException \Icinga\Exception\NotWritableError
|
|
||||||
*/
|
|
||||||
public function testWhetherPreferenceInsertionThrowsNotWritableError()
|
public function testWhetherPreferenceInsertionThrowsNotWritableError()
|
||||||
{
|
{
|
||||||
|
$this->expectException(\Icinga\Exception\NotWritableError::class);
|
||||||
|
|
||||||
$store = $this->getStore(new FaultyDatabaseMock());
|
$store = $this->getStore(new FaultyDatabaseMock());
|
||||||
$store->save(
|
$store->save(
|
||||||
Mockery::mock(
|
Mockery::mock(
|
||||||
|
@ -114,11 +113,10 @@ class DbStoreTest extends BaseTestCase
|
||||||
$this->assertEmpty($dbMock->deletions, 'DbStore::save inserts *existing* preferneces');
|
$this->assertEmpty($dbMock->deletions, 'DbStore::save inserts *existing* preferneces');
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* @expectedException \Icinga\Exception\NotWritableError
|
|
||||||
*/
|
|
||||||
public function testWhetherPreferenceUpdatesThrowNotWritableError()
|
public function testWhetherPreferenceUpdatesThrowNotWritableError()
|
||||||
{
|
{
|
||||||
|
$this->expectException(\Icinga\Exception\NotWritableError::class);
|
||||||
|
|
||||||
$store = $this->getStore(new FaultyDatabaseMock());
|
$store = $this->getStore(new FaultyDatabaseMock());
|
||||||
$store->setPreferences(array('testsection' => array('key' => 'value')));
|
$store->setPreferences(array('testsection' => array('key' => 'value')));
|
||||||
$store->save(
|
$store->save(
|
||||||
|
@ -146,11 +144,10 @@ class DbStoreTest extends BaseTestCase
|
||||||
$this->assertEmpty($dbMock->updates, 'DbStore::save updates *removed* preferences');
|
$this->assertEmpty($dbMock->updates, 'DbStore::save updates *removed* preferences');
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* @expectedException \Icinga\Exception\NotWritableError
|
|
||||||
*/
|
|
||||||
public function testWhetherPreferenceDeletionThrowsNotWritableError()
|
public function testWhetherPreferenceDeletionThrowsNotWritableError()
|
||||||
{
|
{
|
||||||
|
$this->expectException(\Icinga\Exception\NotWritableError::class);
|
||||||
|
|
||||||
$store = $this->getStore(new FaultyDatabaseMock());
|
$store = $this->getStore(new FaultyDatabaseMock());
|
||||||
$store->setPreferences(array('testsection' => array('key' => 'value')));
|
$store->setPreferences(array('testsection' => array('key' => 'value')));
|
||||||
$store->save(
|
$store->save(
|
||||||
|
|
|
@ -52,11 +52,10 @@ class UserTest extends BaseTestCase
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* @expectedException \InvalidArgumentException
|
|
||||||
*/
|
|
||||||
public function testWhetherInvalidEmailsCannotBeSet()
|
public function testWhetherInvalidEmailsCannotBeSet()
|
||||||
{
|
{
|
||||||
|
$this->expectException(\InvalidArgumentException::class);
|
||||||
|
|
||||||
$user = new User('unittest');
|
$user = new User('unittest');
|
||||||
$user->setEmail('mySampleEmail at someDomain dot org');
|
$user->setEmail('mySampleEmail at someDomain dot org');
|
||||||
}
|
}
|
||||||
|
|
|
@ -8,20 +8,18 @@ use Icinga\Test\BaseTestCase;
|
||||||
|
|
||||||
class FileTest extends BaseTestCase
|
class FileTest extends BaseTestCase
|
||||||
{
|
{
|
||||||
/**
|
|
||||||
* @expectedException \Icinga\Exception\NotWritableError
|
|
||||||
*/
|
|
||||||
public function testWhetherWritingToNonWritableFilesThrowsAnException()
|
public function testWhetherWritingToNonWritableFilesThrowsAnException()
|
||||||
{
|
{
|
||||||
|
$this->expectException(\Icinga\Exception\NotWritableError::class);
|
||||||
|
|
||||||
$file = new File('/dev/null');
|
$file = new File('/dev/null');
|
||||||
$file->fwrite('test');
|
$file->fwrite('test');
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* @expectedException \Icinga\Exception\NotWritableError
|
|
||||||
*/
|
|
||||||
public function testWhetherTruncatingNonWritableFilesThrowsAnException()
|
public function testWhetherTruncatingNonWritableFilesThrowsAnException()
|
||||||
{
|
{
|
||||||
|
$this->expectException(\Icinga\Exception\NotWritableError::class);
|
||||||
|
|
||||||
$file = new File('/dev/null');
|
$file = new File('/dev/null');
|
||||||
$file->ftruncate(0);
|
$file->ftruncate(0);
|
||||||
}
|
}
|
||||||
|
|
|
@ -17,7 +17,7 @@ class TranslatorWithHardcodedLocaleCodes extends Translator
|
||||||
|
|
||||||
class TranslatorTest extends BaseTestCase
|
class TranslatorTest extends BaseTestCase
|
||||||
{
|
{
|
||||||
public function setUp()
|
public function setUp(): void
|
||||||
{
|
{
|
||||||
parent::setUp();
|
parent::setUp();
|
||||||
Translator::registerDomain('icingatest', BaseTestCase::$testDir . '/res/locale');
|
Translator::registerDomain('icingatest', BaseTestCase::$testDir . '/res/locale');
|
||||||
|
@ -48,11 +48,10 @@ class TranslatorTest extends BaseTestCase
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* @expectedException Icinga\Exception\IcingaException
|
|
||||||
*/
|
|
||||||
public function testWhetherSetupLocaleThrowsAnExceptionWhenGivenAnInvalidLocale()
|
public function testWhetherSetupLocaleThrowsAnExceptionWhenGivenAnInvalidLocale()
|
||||||
{
|
{
|
||||||
|
$this->expectException(\Icinga\Exception\IcingaException::class);
|
||||||
|
|
||||||
Translator::setupLocale('foobar');
|
Translator::setupLocale('foobar');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -26,7 +26,7 @@ class SuccessfulForm extends Form
|
||||||
|
|
||||||
class FormTest extends BaseTestCase
|
class FormTest extends BaseTestCase
|
||||||
{
|
{
|
||||||
public function tearDown()
|
public function tearDown(): void
|
||||||
{
|
{
|
||||||
Mockery::close(); // Necessary as some tests are running isolated
|
Mockery::close(); // Necessary as some tests are running isolated
|
||||||
}
|
}
|
||||||
|
@ -251,11 +251,10 @@ class FormTest extends BaseTestCase
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* @expectedException \Icinga\Exception\ProgrammingError
|
|
||||||
*/
|
|
||||||
public function testWhetherTheOnSuccessOptionMustBeCallable()
|
public function testWhetherTheOnSuccessOptionMustBeCallable()
|
||||||
{
|
{
|
||||||
|
$this->expectException(\Icinga\Exception\ProgrammingError::class);
|
||||||
|
|
||||||
new Form(array('onSuccess' => '_invalid_'));
|
new Form(array('onSuccess' => '_invalid_'));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -41,14 +41,14 @@ class HookTest extends BaseTestCase
|
||||||
protected $failingHook = '\\Tests\\Icinga\\Web\\FailingHook';
|
protected $failingHook = '\\Tests\\Icinga\\Web\\FailingHook';
|
||||||
protected $testBaseClass = '\\Icinga\\Web\\Hook\\TestHook';
|
protected $testBaseClass = '\\Icinga\\Web\\Hook\\TestHook';
|
||||||
|
|
||||||
public function setUp()
|
public function setUp(): void
|
||||||
{
|
{
|
||||||
$this->markTestSkipped();
|
$this->markTestSkipped();
|
||||||
parent::setUp();
|
parent::setUp();
|
||||||
Hook::clean();
|
Hook::clean();
|
||||||
}
|
}
|
||||||
|
|
||||||
public function tearDown()
|
public function tearDown(): void
|
||||||
{
|
{
|
||||||
parent::tearDown();
|
parent::tearDown();
|
||||||
Hook::clean();
|
Hook::clean();
|
||||||
|
|
|
@ -17,7 +17,7 @@ class SlidingwithborderTest extends BaseTestCase
|
||||||
$paginator = new Zend_Paginator($this->getPaginatorAdapter());
|
$paginator = new Zend_Paginator($this->getPaginatorAdapter());
|
||||||
|
|
||||||
$pages = $scrollingStyle->getPages($paginator);
|
$pages = $scrollingStyle->getPages($paginator);
|
||||||
$this->assertInternalType('array', $pages);
|
$this->assertIsArray($pages);
|
||||||
$this->assertCount(10, $pages);
|
$this->assertCount(10, $pages);
|
||||||
$this->assertEquals('...', $pages[8]);
|
$this->assertEquals('...', $pages[8]);
|
||||||
}
|
}
|
||||||
|
@ -29,7 +29,7 @@ class SlidingwithborderTest extends BaseTestCase
|
||||||
$paginator->setCurrentPageNumber(9);
|
$paginator->setCurrentPageNumber(9);
|
||||||
|
|
||||||
$pages = $scrollingStyle->getPages($paginator);
|
$pages = $scrollingStyle->getPages($paginator);
|
||||||
$this->assertInternalType('array', $pages);
|
$this->assertIsArray($pages);
|
||||||
$this->assertCount(10, $pages);
|
$this->assertCount(10, $pages);
|
||||||
$this->assertEquals('...', $pages[3]);
|
$this->assertEquals('...', $pages[3]);
|
||||||
$this->assertEquals('...', $pages[12]);
|
$this->assertEquals('...', $pages[12]);
|
||||||
|
|
|
@ -62,11 +62,10 @@ class SessionNamespaceTest extends BaseTestCase
|
||||||
$this->assertNull($ns->get('key2'));
|
$this->assertNull($ns->get('key2'));
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* @expectedException Icinga\Exception\IcingaException
|
|
||||||
*/
|
|
||||||
public function testFailingPropertyAccess()
|
public function testFailingPropertyAccess()
|
||||||
{
|
{
|
||||||
|
$this->expectException(\Icinga\Exception\IcingaException::class);
|
||||||
|
|
||||||
$ns = new SessionNamespace();
|
$ns = new SessionNamespace();
|
||||||
$ns->missing;
|
$ns->missing;
|
||||||
}
|
}
|
||||||
|
|
|
@ -130,11 +130,10 @@ class UrlTest extends BaseTestCase
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* @expectedException Icinga\Exception\ProgrammingError
|
|
||||||
*/
|
|
||||||
public function testWhetherFromPathProperlyHandlesInvalidUrls()
|
public function testWhetherFromPathProperlyHandlesInvalidUrls()
|
||||||
{
|
{
|
||||||
|
$this->expectException(\Icinga\Exception\ProgrammingError::class);
|
||||||
|
|
||||||
Url::fromPath(null);
|
Url::fromPath(null);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -39,7 +39,7 @@ class DashboardWithPredefinableActiveName extends Dashboard
|
||||||
|
|
||||||
class DashboardTest extends BaseTestCase
|
class DashboardTest extends BaseTestCase
|
||||||
{
|
{
|
||||||
public function tearDown()
|
public function tearDown(): void
|
||||||
{
|
{
|
||||||
parent::tearDown();
|
parent::tearDown();
|
||||||
Mockery::close(); // Necessary because some tests run in a separate process
|
Mockery::close(); // Necessary because some tests run in a separate process
|
||||||
|
@ -109,11 +109,12 @@ class DashboardTest extends BaseTestCase
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @expectedException \Icinga\Exception\ProgrammingError
|
|
||||||
* @depends testWhetherCreatePaneCreatesAPane
|
* @depends testWhetherCreatePaneCreatesAPane
|
||||||
*/
|
*/
|
||||||
public function testWhetherGetPaneThrowsAnExceptionOnNotExistentPaneName()
|
public function testWhetherGetPaneThrowsAnExceptionOnNotExistentPaneName()
|
||||||
{
|
{
|
||||||
|
$this->expectException(\Icinga\Exception\ProgrammingError::class);
|
||||||
|
|
||||||
$dashboard = new Dashboard();
|
$dashboard = new Dashboard();
|
||||||
$dashboard->createPane('test1');
|
$dashboard->createPane('test1');
|
||||||
|
|
||||||
|
@ -267,11 +268,10 @@ class DashboardTest extends BaseTestCase
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* @expectedException \Icinga\Exception\ConfigurationError
|
|
||||||
*/
|
|
||||||
public function testWhetherDetermineActivePaneThrowsAnExceptionIfCouldNotDetermine()
|
public function testWhetherDetermineActivePaneThrowsAnExceptionIfCouldNotDetermine()
|
||||||
{
|
{
|
||||||
|
$this->expectException(\Icinga\Exception\ConfigurationError::class);
|
||||||
|
|
||||||
$dashboard = new Dashboard();
|
$dashboard = new Dashboard();
|
||||||
$dashboard->determineActivePane();
|
$dashboard->determineActivePane();
|
||||||
}
|
}
|
||||||
|
@ -279,11 +279,12 @@ class DashboardTest extends BaseTestCase
|
||||||
/**
|
/**
|
||||||
* @runInSeparateProcess
|
* @runInSeparateProcess
|
||||||
* @preserveGlobalState disabled
|
* @preserveGlobalState disabled
|
||||||
* @expectedException \Icinga\Exception\ProgrammingError
|
|
||||||
* @depends testWhetherCreatePaneCreatesAPane
|
* @depends testWhetherCreatePaneCreatesAPane
|
||||||
*/
|
*/
|
||||||
public function testWhetherDetermineActivePaneThrowsAnExceptionIfCouldNotDetermineInvalidPane()
|
public function testWhetherDetermineActivePaneThrowsAnExceptionIfCouldNotDetermineInvalidPane()
|
||||||
{
|
{
|
||||||
|
$this->expectException(\Icinga\Exception\ProgrammingError::class);
|
||||||
|
|
||||||
$dashboard = new DashboardWithPredefinableActiveName();
|
$dashboard = new DashboardWithPredefinableActiveName();
|
||||||
$dashboard->createPane('test1');
|
$dashboard->createPane('test1');
|
||||||
|
|
||||||
|
|
|
@ -11,7 +11,7 @@ use Icinga\Web\Widget\SearchDashboard;
|
||||||
|
|
||||||
class SearchDashboardTest extends BaseTestCase
|
class SearchDashboardTest extends BaseTestCase
|
||||||
{
|
{
|
||||||
public function setUp()
|
public function setUp(): void
|
||||||
{
|
{
|
||||||
$moduleMock = Mockery::mock('Icinga\Application\Modules\Module');
|
$moduleMock = Mockery::mock('Icinga\Application\Modules\Module');
|
||||||
$searchUrl = (object) array(
|
$searchUrl = (object) array(
|
||||||
|
@ -32,11 +32,10 @@ class SearchDashboardTest extends BaseTestCase
|
||||||
$bootstrapMock->shouldReceive('getModuleManager')->andReturn($moduleManagerMock);
|
$bootstrapMock->shouldReceive('getModuleManager')->andReturn($moduleManagerMock);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* @expectedException Zend_Controller_Action_Exception
|
|
||||||
*/
|
|
||||||
public function testWhetherRenderThrowsAnExceptionWhenHasNoDashlets()
|
public function testWhetherRenderThrowsAnExceptionWhenHasNoDashlets()
|
||||||
{
|
{
|
||||||
|
$this->expectException(\Zend_Controller_Action_Exception::class);
|
||||||
|
|
||||||
$user = new User('test');
|
$user = new User('test');
|
||||||
$user->setPermissions(array('*' => '*'));
|
$user->setPermissions(array('*' => '*'));
|
||||||
$dashboard = new SearchDashboard();
|
$dashboard = new SearchDashboard();
|
||||||
|
|
|
@ -1,15 +0,0 @@
|
||||||
<?php
|
|
||||||
/**
|
|
||||||
* @codingStandardsIgnoreStart
|
|
||||||
*/
|
|
||||||
class PHPUnit_Framework_TestCase extends \PHPUnit\Framework\TestCase
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
interface PHPUnit_Framework_Test extends \PHPUnit\Framework\Test
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
interface PHPUnit_Framework_TestListener extends \PHPUnit\Framework\TestListener
|
|
||||||
{
|
|
||||||
}
|
|
|
@ -1,42 +0,0 @@
|
||||||
<?php
|
|
||||||
/* Icinga Web 2 | (c) 2013 Icinga Development Team | GPLv2+ */
|
|
||||||
|
|
||||||
namespace Tests\Icinga\Regression;
|
|
||||||
|
|
||||||
use Icinga\Test\BaseTestCase;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Class Bug4102
|
|
||||||
*
|
|
||||||
* Bogus regression test
|
|
||||||
*
|
|
||||||
* @see https://dev.icinga.com/issues/4102
|
|
||||||
*/
|
|
||||||
class Bug4102Test extends BaseTestCase
|
|
||||||
{
|
|
||||||
/**
|
|
||||||
* Test class name to match definition
|
|
||||||
*/
|
|
||||||
public function testClassName()
|
|
||||||
{
|
|
||||||
$class = get_class($this);
|
|
||||||
$this->assertContains('Bug4102Test', $class);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Test namespace to match definition
|
|
||||||
*/
|
|
||||||
public function testNamespace()
|
|
||||||
{
|
|
||||||
$namespace = __NAMESPACE__;
|
|
||||||
$this->assertEquals('Tests\Icinga\Regression', $namespace);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Test phpunit inheritance
|
|
||||||
*/
|
|
||||||
public function testInheritance()
|
|
||||||
{
|
|
||||||
$this->assertInstanceOf('\PHPUnit_Framework_TestCase', $this);
|
|
||||||
}
|
|
||||||
}
|
|
Loading…
Reference in New Issue