icingaweb2-module-director/test/php/library/Director/IcingaConfig/AssignRendererTest.php
Markus Frosch cbd34149b1
Some checks are pending
L10n Update / update (push) Waiting to run
PHP Tests / Static analysis for php 7.2 on ubuntu-latest (push) Waiting to run
PHP Tests / Static analysis for php 7.3 on ubuntu-latest (push) Waiting to run
PHP Tests / Static analysis for php 7.4 on ubuntu-latest (push) Waiting to run
PHP Tests / Static analysis for php 8.0 on ubuntu-latest (push) Waiting to run
PHP Tests / Static analysis for php 8.1 on ubuntu-latest (push) Waiting to run
PHP Tests / Static analysis for php 8.2 on ubuntu-latest (push) Waiting to run
PHP Tests / Static analysis for php 8.3 on ubuntu-latest (push) Waiting to run
PHP Tests / Unit tests with php 8.2 on ubuntu-latest (push) Waiting to run
PHP Tests / Unit tests with php 8.3 on ubuntu-latest (push) Waiting to run
AssignRenderer: Add wildcard support and render with match()
This used MatchAny explicitly, since we check against an array here.
2026-02-11 11:55:21 +01:00

135 lines
3.7 KiB
PHP

<?php
namespace Tests\Icinga\Module\Director\IcingaConfig;
use Icinga\Data\Filter\Filter;
use Icinga\Module\Director\IcingaConfig\AssignRenderer;
use Icinga\Module\Director\Test\BaseTestCase;
class AssignRendererTest extends BaseTestCase
{
public function testEqualMatchIsCorrectlyRendered()
{
$string = 'host.name="localhost"';
$expected = 'assign where host.name == "localhost"';
$this->assertEquals(
$expected,
$this->renderer($string)->renderAssign()
);
}
public function testNegationIsRenderedCorrectlyOnRootLevel()
{
$string = '!(host.name="one"&host.name="two")';
$expected = 'assign where !(host.name == "one" && host.name == "two")';
$this->assertEquals(
$expected,
$this->renderer($string)->renderAssign()
);
}
public function testNegationIsRenderedCorrectlyOnDeeperLevel()
{
$string = 'host.address="127.*"&!host.name="localhost"';
$expected = 'assign where match("127.*", host.address) && !(host.name == "localhost")';
$this->assertEquals(
$expected,
$this->renderer($string)->renderAssign()
);
}
public function testWildcardsRenderAMatchMethod()
{
$string = 'host.address="127.0.0.*"';
$expected = 'assign where match("127.0.0.*", host.address)';
$this->assertEquals(
$expected,
$this->renderer($string)->renderAssign()
);
}
public function testACombinedFilterRendersCorrectly()
{
$string = 'host.name="*internal"|(service.vars.priority<2'
. '&host.vars.is_clustered=true)';
$expected = 'assign where match("*internal", host.name) ||'
. ' (service.vars.priority < 2 && host.vars.is_clustered)';
$this->assertEquals(
$expected,
$this->renderer($string)->renderAssign()
);
}
public function testSlashesAreNotEscaped()
{
$string = 'host.name=' . json_encode('a/b');
$expected = 'assign where host.name == "a/b"';
$this->assertEquals(
$expected,
$this->renderer($string)->renderAssign()
);
}
public function testFakeContainsOperatorRendersCorrectly()
{
$string = json_encode('member') . '=host.groups';
$expected = 'assign where "member" in host.groups';
$this->assertEquals(
$expected,
$this->renderer($string)->renderAssign()
);
$string = json_encode('member') . '=host.vars.some_array';
$expected = 'assign where "member" in host.vars.some_array';
$this->assertEquals(
$expected,
$this->renderer($string)->renderAssign()
);
$string = json_encode('member*') . '=host.vars.some_array';
$expected = 'assign where match("member*", host.vars.some_array, MatchAny)';
$this->assertEquals(
$expected,
$this->renderer($string)->renderAssign()
);
}
public function testInArrayIsRenderedCorrectly()
{
$string = 'host.name=' . json_encode(array('a' ,'b'));
$expected = 'assign where host.name in [ "a", "b" ]';
$this->assertEquals(
$expected,
$this->renderer($string)->renderAssign()
);
}
public function testWhetherSlashesAreNotEscaped()
{
$string = 'host.name=' . json_encode('a/b');
$expected = 'assign where host.name == "a/b"';
$this->assertEquals(
$expected,
$this->renderer($string)->renderAssign()
);
}
protected function renderer($string)
{
return AssignRenderer::forFilter(Filter::fromQueryString($string));
}
}