assertEquals('id', normalise_id('id'));
$this->assertEquals('id', normalise_id('X-ZOT:id'));
$this->assertEquals('id id2', normalise_id('X-ZOT:id X-ZOT:id2'));
$this->assertEmpty(normalise_id(''));
}
public function test_encode_rel_links() {
// invalid params return empty array
$this->assertEquals([], encode_rel_links('string'));
$this->assertEquals([], encode_rel_links([]));
$b = ['attribs' => ['' => [
'rel' => 'rel_value',
'type' => 'type_value',
'href' => 'href_value',
'length' => 'length_value',
'title' => 'title_value'
]]];
$blink1 = ['link1' => $b];
$bresult[] = $b['attribs'][''];
$this->assertEquals($bresult, encode_rel_links($blink1));
}
/* public function test_encode_rel_links_fail() {
$a = [ 'key' => 'value'];
$this->assertFalse(encode_rel_links($a));
//Illegal string offset 'attribs'
}*/
/**
* @uses ::xmlify
*/
public function test_atom_author() {
$this->assertEquals('', atom_author('', 'nick', 'name', 'uri', 72, 72, 'png', 'photourl'));
$expected = 'urinickurinickname';
$this->assertAtomAuthorMatches(
$expected,
atom_author('tag', 'nick', 'name', 'uri', 72, 72, 'png', 'http://photourl')
);
}
/**
* @uses ::xmlify
*/
public function test_atom_render_author() {
$xchan = [
'xchan_addr' => 'chan@hub',
'xchan_url' => 'http://hub',
'xchan_name' => 'Chan',
'xchan_photo_l' => 'http://hub/img',
'xchan_photo_mimetype' => 'mimetype'
];
// There is no input validation in atom_render_author
//$this->assertEquals('', atom_render_author('', $xchan));
$a = 'http://activitystrea.ms/schema/1.0/personhttp://hubchanhttp://hubchanChan';
$this->assertAtomAuthorMatches($a, atom_render_author('tag', $xchan));
}
/**
* Helper method to assert that the generated author tag matches
* what we expect.
*
* Calling `assertXmlStringEqualsXmlString` directly on the fragments
* does not work anymore in PHPUnit >= 10.x, as t will throw an XMLException
* because of undefined namespaces.
*
* To overcome that we wrap the generated tags in the proper template,
* and compare the fully generated XML from the template instead.
*
* @param string $expected The expected author XML fragment.
* @param string $actual The actually generated authr XML fragment.
*/
private function assertAtomAuthorMatches(string $expected, string $actual): void {
// Make sure the template engine is initialized before we try to render
// the template.
//
// This may be problematic, as it will compile the template into the same
// directory as the site. Assuming that nobody is crazy enough to run the
// test suite in a production server, it should probably be fine for now.
$smarty = new \Zotlabs\Render\SmartyTemplate();
\App::register_template_engine(get_class($smarty));
$feed_template = get_markup_template('atom_feed.tpl');
$expected_xml = replace_macros($feed_template, [
'$version' => 42,
'$generator' => 'Hubzilla test',
'$generator_uri' => 'https://hubzilla.test',
'$feed_id' => 'test_channel',
'$feed_title' => 'Test channel',
'$feed_updated' => 'Sometime',
'$author' => $expected,
'$owner' => $expected,
'$profile_page' => xmlify('https://hubzilla.test/channel/test'),
]);
$expected_xml .= '';
$actual_xml = replace_macros($feed_template, [
'$version' => 42,
'$generator' => 'Hubzilla test',
'$generator_uri' => 'https://hubzilla.test',
'$feed_id' => 'test_channel',
'$feed_title' => 'Test channel',
'$feed_updated' => 'Sometime',
'$author' => $actual,
'$owner' => $actual,
'$profile_page' => xmlify('https://hubzilla.test/channel/test'),
]);
$actual_xml .= '';
$this->assertXmlStringEqualsXmlString($expected_xml, $actual_xml);
}
}