function FilterUnitTestCase::assertFilteredString
Asserts multiple filter output expectations for multiple input strings.
$tests = array(
'Input string' => array(
'<p>Input string</p>' => TRUE,
'Input string<br' => FALSE,
),
);
Parameters
$filter: A input filter object.
$tests: An associative array, whereas each key is an arbitrary input string and each value is again an associative array whose keys are filter output strings and whose values are Booleans indicating whether the output is expected or not.
For example:
3 calls to FilterUnitTestCase::assertFilteredString()
- FilterUnitTestCase::testHtmlEscapeFilter in modules/
filter/ filter.test - Tests the HTML escaping filter.
- FilterUnitTestCase::testLineBreakFilter in modules/
filter/ filter.test - Tests the line break filter.
- FilterUnitTestCase::testUrlFilter in modules/
filter/ filter.test - Tests the URL filter.
File
-
modules/
filter/ filter.test, line 1592
Class
- FilterUnitTestCase
- Unit tests for core filters.
Code
function assertFilteredString($filter, $tests) {
foreach ($tests as $source => $tasks) {
$function = $filter->callback;
$result = $function($source, $filter);
foreach ($tasks as $value => $is_expected) {
// Not using assertIdentical, since combination with strpos() is hard to grok.
if ($is_expected) {
$success = $this->assertTrue(strpos($result, $value) !== FALSE, format_string('@source: @value found.', array(
'@source' => var_export($source, TRUE),
'@value' => var_export($value, TRUE),
)));
}
else {
$success = $this->assertTrue(strpos($result, $value) === FALSE, format_string('@source: @value not found.', array(
'@source' => var_export($source, TRUE),
'@value' => var_export($value, TRUE),
)));
}
if (!$success) {
$this->verbose('Source:<pre>' . check_plain(var_export($source, TRUE)) . '</pre>' . '<hr />' . 'Result:<pre>' . check_plain(var_export($result, TRUE)) . '</pre>' . '<hr />' . ($is_expected ? 'Expected:' : 'Not expected:') . '<pre>' . check_plain(var_export($value, TRUE)) . '</pre>');
}
}
}
}
Buggy or inaccurate documentation? Please file an issue. Need support? Need help programming? Connect with the Drupal community.