2009-05-20 03:09:50 +00:00
|
|
|
<?php
|
2013-05-26 11:01:46 +12:00
|
|
|
|
2009-05-20 03:09:50 +00:00
|
|
|
/**
|
|
|
|
* Test various functions on the {@link Convert} class.
|
2013-05-26 11:01:46 +12:00
|
|
|
*
|
2012-04-12 18:02:46 +12:00
|
|
|
* @package framework
|
2009-05-20 03:09:50 +00:00
|
|
|
* @subpackage tests
|
|
|
|
*/
|
|
|
|
class ConvertTest extends SapphireTest {
|
|
|
|
|
2013-05-26 11:01:46 +12:00
|
|
|
protected $usesDatabase = false;
|
|
|
|
|
2009-05-20 03:09:50 +00:00
|
|
|
/**
|
|
|
|
* Tests {@link Convert::raw2att()}
|
|
|
|
*/
|
2012-09-19 12:07:39 +02:00
|
|
|
public function testRaw2Att() {
|
2009-05-20 03:09:50 +00:00
|
|
|
$val1 = '<input type="text">';
|
2012-09-27 09:34:00 +12:00
|
|
|
$this->assertEquals('<input type="text">', Convert::raw2att($val1),
|
|
|
|
'Special characters are escaped');
|
2014-08-15 18:53:05 +12:00
|
|
|
|
2009-05-20 03:09:50 +00:00
|
|
|
$val2 = 'This is some normal text.';
|
2012-09-27 09:34:00 +12:00
|
|
|
$this->assertEquals('This is some normal text.', Convert::raw2att($val2),
|
|
|
|
'Normal text is not escaped');
|
2009-05-20 03:09:50 +00:00
|
|
|
}
|
2014-08-15 18:53:05 +12:00
|
|
|
|
2009-05-20 03:09:50 +00:00
|
|
|
/**
|
|
|
|
* Tests {@link Convert::raw2htmlatt()}
|
|
|
|
*/
|
2012-09-19 12:07:39 +02:00
|
|
|
public function testRaw2HtmlAtt() {
|
2009-05-20 03:09:50 +00:00
|
|
|
$val1 = '<input type="text">';
|
2012-09-27 09:34:00 +12:00
|
|
|
$this->assertEquals('<input type="text">', Convert::raw2htmlatt($val1),
|
|
|
|
'Special characters are escaped');
|
2014-08-15 18:53:05 +12:00
|
|
|
|
2009-05-20 03:09:50 +00:00
|
|
|
$val2 = 'This is some normal text.';
|
2012-09-27 09:34:00 +12:00
|
|
|
$this->assertEquals('This is some normal text.', Convert::raw2htmlatt($val2),
|
|
|
|
'Normal text is not escaped');
|
2009-05-20 03:09:50 +00:00
|
|
|
}
|
2014-08-15 18:53:05 +12:00
|
|
|
|
2015-07-28 03:54:49 +02:00
|
|
|
/**
|
|
|
|
* Tests {@link Convert::html2raw()}
|
|
|
|
*/
|
2012-09-19 12:07:39 +02:00
|
|
|
public function testHtml2raw() {
|
2014-08-15 18:53:05 +12:00
|
|
|
$val1 = 'This has a <strong>strong tag</strong>.';
|
2014-09-25 16:04:48 +12:00
|
|
|
$this->assertEquals('This has a *strong tag*.', Convert::html2raw($val1),
|
2012-09-27 09:34:00 +12:00
|
|
|
'Strong tags are replaced with asterisks');
|
2014-08-15 18:53:05 +12:00
|
|
|
|
|
|
|
$val1 = 'This has a <b class="test" style="font-weight: bold">b tag with attributes</b>.';
|
2014-09-25 16:04:48 +12:00
|
|
|
$this->assertEquals('This has a *b tag with attributes*.', Convert::html2raw($val1),
|
2012-09-27 09:34:00 +12:00
|
|
|
'B tags with attributes are replaced with asterisks');
|
2014-08-15 18:53:05 +12:00
|
|
|
|
|
|
|
$val2 = 'This has a <strong class="test" style="font-weight: bold">strong tag with attributes</STRONG>.';
|
2014-09-25 16:04:48 +12:00
|
|
|
$this->assertEquals('This has a *strong tag with attributes*.', Convert::html2raw($val2),
|
2012-09-27 09:34:00 +12:00
|
|
|
'Strong tags with attributes are replaced with asterisks');
|
2014-08-15 18:53:05 +12:00
|
|
|
|
2016-01-24 18:12:45 +13:00
|
|
|
$val3 = '<script type="application/javascript">Some really nasty javascript here</script>';
|
2014-09-25 16:04:48 +12:00
|
|
|
$this->assertEquals('', Convert::html2raw($val3),
|
2012-09-27 09:34:00 +12:00
|
|
|
'Script tags are completely removed');
|
2014-08-15 18:53:05 +12:00
|
|
|
|
2012-02-15 07:55:52 +13:00
|
|
|
$val4 = '<style type="text/css">Some really nasty CSS here</style>';
|
2014-09-25 16:04:48 +12:00
|
|
|
$this->assertEquals('', Convert::html2raw($val4),
|
2012-09-27 09:34:00 +12:00
|
|
|
'Style tags are completely removed');
|
2014-08-15 18:53:05 +12:00
|
|
|
|
2016-01-24 18:12:45 +13:00
|
|
|
$val5 = '<script type="application/javascript">Some really nasty
|
2012-02-15 07:55:52 +13:00
|
|
|
multiline javascript here</script>';
|
2014-09-25 16:04:48 +12:00
|
|
|
$this->assertEquals('', Convert::html2raw($val5),
|
2012-09-27 09:34:00 +12:00
|
|
|
'Multiline script tags are completely removed');
|
2014-08-15 18:53:05 +12:00
|
|
|
|
2012-02-15 07:55:52 +13:00
|
|
|
$val6 = '<style type="text/css">Some really nasty
|
|
|
|
multiline CSS here</style>';
|
2014-09-25 16:04:48 +12:00
|
|
|
$this->assertEquals('', Convert::html2raw($val6),
|
2012-09-27 09:34:00 +12:00
|
|
|
'Multiline style tags are completely removed');
|
2014-09-25 16:04:48 +12:00
|
|
|
|
|
|
|
$val7 = '<p>That's absolutely correct</p>';
|
|
|
|
$this->assertEquals(
|
|
|
|
"That's absolutely correct",
|
|
|
|
Convert::html2raw($val7),
|
|
|
|
"Single quotes are decoded correctly"
|
|
|
|
);
|
|
|
|
|
|
|
|
$val8 = 'Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor '.
|
|
|
|
'incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud '.
|
|
|
|
'exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat. Duis aute '.
|
|
|
|
'irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla '.
|
|
|
|
'pariatur. Excepteur sint occaecat cupidatat non proident, sunt in culpa qui officia '.
|
|
|
|
'deserunt mollit anim id est laborum.';
|
|
|
|
$this->assertEquals($val8, Convert::html2raw($val8), 'Test long text is unwrapped');
|
|
|
|
$this->assertEquals(<<<PHP
|
|
|
|
Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed
|
|
|
|
do eiusmod tempor incididunt ut labore et dolore magna
|
|
|
|
aliqua. Ut enim ad minim veniam, quis nostrud exercitation
|
|
|
|
ullamco laboris nisi ut aliquip ex ea commodo consequat.
|
|
|
|
Duis aute irure dolor in reprehenderit in voluptate velit
|
|
|
|
esse cillum dolore eu fugiat nulla pariatur. Excepteur sint
|
|
|
|
occaecat cupidatat non proident, sunt in culpa qui officia
|
|
|
|
deserunt mollit anim id est laborum.
|
|
|
|
PHP
|
|
|
|
,
|
|
|
|
Convert::html2raw($val8, false, 60),
|
|
|
|
'Test long text is wrapped'
|
|
|
|
);
|
2010-10-15 03:51:55 +00:00
|
|
|
}
|
2014-08-15 18:53:05 +12:00
|
|
|
|
2009-05-20 03:09:50 +00:00
|
|
|
/**
|
|
|
|
* Tests {@link Convert::raw2xml()}
|
|
|
|
*/
|
2012-09-19 12:07:39 +02:00
|
|
|
public function testRaw2Xml() {
|
2009-05-20 03:09:50 +00:00
|
|
|
$val1 = '<input type="text">';
|
2012-09-27 09:34:00 +12:00
|
|
|
$this->assertEquals('<input type="text">', Convert::raw2xml($val1),
|
|
|
|
'Special characters are escaped');
|
2014-08-15 18:53:05 +12:00
|
|
|
|
2009-05-20 03:09:50 +00:00
|
|
|
$val2 = 'This is some normal text.';
|
2012-09-27 09:34:00 +12:00
|
|
|
$this->assertEquals('This is some normal text.', Convert::raw2xml($val2),
|
|
|
|
'Normal text is not escaped');
|
2010-12-16 22:55:17 +00:00
|
|
|
|
|
|
|
$val3 = "This is test\nNow on a new line.";
|
2012-09-27 09:34:00 +12:00
|
|
|
$this->assertEquals("This is test\nNow on a new line.", Convert::raw2xml($val3),
|
|
|
|
'Newlines are retained. They should not be replaced with <br /> as it is not XML valid');
|
2010-12-16 22:55:17 +00:00
|
|
|
}
|
2014-08-15 18:53:05 +12:00
|
|
|
|
2013-05-26 11:01:46 +12:00
|
|
|
/**
|
|
|
|
* Tests {@link Convert::raw2htmlid()}
|
|
|
|
*/
|
|
|
|
public function testRaw2HtmlID() {
|
2010-12-16 22:55:17 +00:00
|
|
|
$val1 = 'test test 123';
|
2013-05-26 11:01:46 +12:00
|
|
|
$this->assertEquals('test_test_123', Convert::raw2htmlid($val1));
|
|
|
|
|
|
|
|
$val1 = 'test[test][123]';
|
|
|
|
$this->assertEquals('test_test_123', Convert::raw2htmlid($val1));
|
|
|
|
|
|
|
|
$val1 = '[test[[test]][123]]';
|
|
|
|
$this->assertEquals('test_test_123', Convert::raw2htmlid($val1));
|
2009-05-20 03:09:50 +00:00
|
|
|
}
|
2014-08-15 18:53:05 +12:00
|
|
|
|
2009-05-20 03:09:50 +00:00
|
|
|
/**
|
|
|
|
* Tests {@link Convert::xml2raw()}
|
|
|
|
*/
|
2012-09-19 12:07:39 +02:00
|
|
|
public function testXml2Raw() {
|
2009-05-20 03:09:50 +00:00
|
|
|
$val1 = '<input type="text">';
|
|
|
|
$this->assertEquals('<input type="text">', Convert::xml2raw($val1), 'Special characters are escaped');
|
2014-08-15 18:53:05 +12:00
|
|
|
|
2009-05-20 03:09:50 +00:00
|
|
|
$val2 = 'This is some normal text.';
|
|
|
|
$this->assertEquals('This is some normal text.', Convert::xml2raw($val2), 'Normal text is not escaped');
|
|
|
|
}
|
2010-05-25 03:52:38 +00:00
|
|
|
|
2015-07-28 03:54:49 +02:00
|
|
|
/**
|
|
|
|
* Tests {@link Convert::xml2raw()}
|
|
|
|
*/
|
2012-09-19 12:07:39 +02:00
|
|
|
public function testArray2JSON() {
|
2010-05-25 03:52:38 +00:00
|
|
|
$val = array(
|
|
|
|
'Joe' => 'Bloggs',
|
|
|
|
'Tom' => 'Jones',
|
|
|
|
'My' => array(
|
|
|
|
'Complicated' => 'Structure'
|
|
|
|
)
|
|
|
|
);
|
|
|
|
$encoded = Convert::array2json($val);
|
2012-09-27 09:34:00 +12:00
|
|
|
$this->assertEquals('{"Joe":"Bloggs","Tom":"Jones","My":{"Complicated":"Structure"}}', $encoded,
|
|
|
|
'Array is encoded in JSON');
|
2010-05-25 03:52:38 +00:00
|
|
|
}
|
|
|
|
|
2015-07-28 03:54:49 +02:00
|
|
|
/**
|
|
|
|
* Tests {@link Convert::json2array()}
|
|
|
|
*/
|
2012-09-19 12:07:39 +02:00
|
|
|
public function testJSON2Array() {
|
2010-05-25 03:52:38 +00:00
|
|
|
$val = '{"Joe":"Bloggs","Tom":"Jones","My":{"Complicated":"Structure"}}';
|
|
|
|
$decoded = Convert::json2array($val);
|
|
|
|
$this->assertEquals(3, count($decoded), '3 items in the decoded array');
|
|
|
|
$this->assertContains('Bloggs', $decoded, 'Contains "Bloggs" value in decoded array');
|
|
|
|
$this->assertContains('Jones', $decoded, 'Contains "Jones" value in decoded array');
|
2012-03-30 16:18:14 +13:00
|
|
|
$this->assertContains('Structure', $decoded['My']['Complicated']);
|
2010-05-25 03:52:38 +00:00
|
|
|
}
|
|
|
|
|
2015-07-28 03:54:49 +02:00
|
|
|
/**
|
|
|
|
* Tests {@link Convert::testJSON2Obj()}
|
|
|
|
*/
|
2012-09-19 12:07:39 +02:00
|
|
|
public function testJSON2Obj() {
|
2010-05-25 03:52:38 +00:00
|
|
|
$val = '{"Joe":"Bloggs","Tom":"Jones","My":{"Complicated":"Structure"}}';
|
|
|
|
$obj = Convert::json2obj($val);
|
|
|
|
$this->assertEquals('Bloggs', $obj->Joe);
|
|
|
|
$this->assertEquals('Jones', $obj->Tom);
|
|
|
|
$this->assertEquals('Structure', $obj->My->Complicated);
|
|
|
|
}
|
2014-08-15 18:53:05 +12:00
|
|
|
|
2010-12-20 03:18:51 +00:00
|
|
|
/**
|
2015-07-28 03:54:49 +02:00
|
|
|
* Tests {@link Convert::testRaw2URL()}
|
2010-12-20 03:18:51 +00:00
|
|
|
* @todo test toASCII()
|
|
|
|
*/
|
2012-09-19 12:07:39 +02:00
|
|
|
public function testRaw2URL() {
|
2013-03-21 19:48:54 +01:00
|
|
|
$orig = Config::inst()->get('URLSegmentFilter', 'default_allow_multibyte');
|
|
|
|
Config::inst()->update('URLSegmentFilter', 'default_allow_multibyte', false);
|
2010-12-20 03:18:51 +00:00
|
|
|
$this->assertEquals('foo', Convert::raw2url('foo'));
|
|
|
|
$this->assertEquals('foo-and-bar', Convert::raw2url('foo & bar'));
|
|
|
|
$this->assertEquals('foo-and-bar', Convert::raw2url('foo & bar!'));
|
2011-11-14 12:26:51 +01:00
|
|
|
$this->assertEquals('foos-bar-2', Convert::raw2url('foo\'s [bar] (2)'));
|
2013-03-21 19:48:54 +01:00
|
|
|
Config::inst()->update('URLSegmentFilter', 'default_allow_multibyte', $orig);
|
2010-12-20 03:18:51 +00:00
|
|
|
}
|
2014-08-15 18:53:05 +12:00
|
|
|
|
2012-10-16 17:10:54 +13:00
|
|
|
/**
|
|
|
|
* Helper function for comparing characters with significant whitespaces
|
2013-06-21 10:32:08 +12:00
|
|
|
* @param string $expected
|
2014-08-15 18:53:05 +12:00
|
|
|
* @param string $actual
|
2012-10-16 17:10:54 +13:00
|
|
|
*/
|
|
|
|
protected function assertEqualsQuoted($expected, $actual) {
|
|
|
|
$message = sprintf(
|
2014-08-15 18:53:05 +12:00
|
|
|
"Expected \"%s\" but given \"%s\"",
|
|
|
|
addcslashes($expected, "\r\n"),
|
2012-10-16 17:10:54 +13:00
|
|
|
addcslashes($actual, "\r\n")
|
|
|
|
);
|
|
|
|
$this->assertEquals($expected, $actual, $message);
|
|
|
|
}
|
2014-08-15 18:53:05 +12:00
|
|
|
|
2015-07-28 03:54:49 +02:00
|
|
|
/**
|
|
|
|
* Tests {@link Convert::nl2os()}
|
|
|
|
*/
|
2012-10-16 17:10:54 +13:00
|
|
|
public function testNL2OS() {
|
2014-08-15 18:53:05 +12:00
|
|
|
|
2012-10-16 17:10:54 +13:00
|
|
|
foreach(array("\r\n", "\r", "\n") as $nl) {
|
2014-08-15 18:53:05 +12:00
|
|
|
|
2012-10-16 17:10:54 +13:00
|
|
|
// Base case: no action
|
|
|
|
$this->assertEqualsQuoted(
|
|
|
|
"Base case",
|
|
|
|
Convert::nl2os("Base case", $nl)
|
|
|
|
);
|
2014-08-15 18:53:05 +12:00
|
|
|
|
2012-10-16 17:10:54 +13:00
|
|
|
// Mixed formats
|
|
|
|
$this->assertEqualsQuoted(
|
|
|
|
"Test{$nl}Text{$nl}Is{$nl}{$nl}Here{$nl}.",
|
|
|
|
Convert::nl2os("Test\rText\r\nIs\n\rHere\r\n.", $nl)
|
|
|
|
);
|
2014-08-15 18:53:05 +12:00
|
|
|
|
2012-10-16 17:10:54 +13:00
|
|
|
// Test that multiple runs are non-destructive
|
|
|
|
$expected = "Test{$nl}Text{$nl}Is{$nl}{$nl}Here{$nl}.";
|
|
|
|
$this->assertEqualsQuoted(
|
|
|
|
$expected,
|
|
|
|
Convert::nl2os($expected, $nl)
|
|
|
|
);
|
2014-08-15 18:53:05 +12:00
|
|
|
|
2012-10-16 17:10:54 +13:00
|
|
|
// Check repeated sequence behaves correctly
|
|
|
|
$expected = "{$nl}{$nl}{$nl}{$nl}{$nl}{$nl}{$nl}{$nl}";
|
|
|
|
$input = "\r\r\n\r\r\n\n\n\n\r";
|
|
|
|
$this->assertEqualsQuoted(
|
|
|
|
$expected,
|
|
|
|
Convert::nl2os($input, $nl)
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|
2014-08-15 18:53:05 +12:00
|
|
|
|
2015-07-28 03:54:49 +02:00
|
|
|
/**
|
|
|
|
* Tests {@link Convert::raw2js()}
|
|
|
|
*/
|
2014-04-02 17:19:14 +13:00
|
|
|
public function testRaw2JS() {
|
|
|
|
// Test attempt to break out of string
|
|
|
|
$this->assertEquals(
|
|
|
|
'\\"; window.location=\\"http://www.google.com',
|
|
|
|
Convert::raw2js('"; window.location="http://www.google.com')
|
|
|
|
);
|
|
|
|
$this->assertEquals(
|
|
|
|
'\\\'; window.location=\\\'http://www.google.com',
|
|
|
|
Convert::raw2js('\'; window.location=\'http://www.google.com')
|
|
|
|
);
|
|
|
|
// Test attempt to close script tag
|
|
|
|
$this->assertEquals(
|
|
|
|
'\\"; \\x3c/script\\x3e\\x3ch1\\x3eHa \\x26amp; Ha\\x3c/h1\\x3e\\x3cscript\\x3e',
|
|
|
|
Convert::raw2js('"; </script><h1>Ha & Ha</h1><script>')
|
|
|
|
);
|
|
|
|
// Test newlines are properly escaped
|
|
|
|
$this->assertEquals(
|
|
|
|
'New\\nLine\\rReturn', Convert::raw2js("New\nLine\rReturn")
|
|
|
|
);
|
|
|
|
// Check escape of slashes
|
|
|
|
$this->assertEquals(
|
|
|
|
'\\\\\\"\\x3eClick here',
|
|
|
|
Convert::raw2js('\\">Click here')
|
|
|
|
);
|
|
|
|
}
|
2014-08-15 18:53:05 +12:00
|
|
|
|
2015-07-28 03:54:49 +02:00
|
|
|
/**
|
|
|
|
* Tests {@link Convert::raw2json()}
|
|
|
|
*/
|
2014-04-02 17:19:14 +13:00
|
|
|
public function testRaw2JSON() {
|
2014-08-15 18:53:05 +12:00
|
|
|
|
2014-04-02 17:19:14 +13:00
|
|
|
// Test object
|
|
|
|
$input = new stdClass();
|
|
|
|
$input->Title = 'My Object';
|
|
|
|
$input->Content = '<p>Data</p>';
|
|
|
|
$this->assertEquals(
|
|
|
|
'{"Title":"My Object","Content":"<p>Data<\/p>"}',
|
|
|
|
Convert::raw2json($input)
|
|
|
|
);
|
2014-08-15 18:53:05 +12:00
|
|
|
|
2014-04-02 17:19:14 +13:00
|
|
|
// Array
|
|
|
|
$array = array('One' => 'Apple', 'Two' => 'Banana');
|
|
|
|
$this->assertEquals(
|
|
|
|
'{"One":"Apple","Two":"Banana"}',
|
|
|
|
Convert::raw2json($array)
|
|
|
|
);
|
2014-08-15 18:53:05 +12:00
|
|
|
|
2014-04-02 17:19:14 +13:00
|
|
|
// String value with already encoded data. Result should be quoted.
|
|
|
|
$value = '{"Left": "Value"}';
|
|
|
|
$this->assertEquals(
|
|
|
|
'"{\\"Left\\": \\"Value\\"}"',
|
|
|
|
Convert::raw2json($value)
|
|
|
|
);
|
|
|
|
}
|
2015-03-20 17:21:59 +13:00
|
|
|
|
2015-07-28 03:54:49 +02:00
|
|
|
/**
|
|
|
|
* Tests {@link Convert::xml2array()}
|
|
|
|
*/
|
2015-03-20 17:21:59 +13:00
|
|
|
public function testXML2Array() {
|
|
|
|
// Ensure an XML file at risk of entity expansion can be avoided safely
|
|
|
|
$inputXML = <<<XML
|
|
|
|
<?xml version="1.0"?>
|
|
|
|
<!DOCTYPE results [<!ENTITY long "SOME_SUPER_LONG_STRING">]>
|
|
|
|
<results>
|
|
|
|
<result>Now include &long; lots of times to expand the in-memory size of this XML structure</result>
|
|
|
|
<result>&long;&long;&long;</result>
|
|
|
|
</results>
|
|
|
|
XML
|
|
|
|
;
|
|
|
|
try {
|
|
|
|
Convert::xml2array($inputXML, true);
|
|
|
|
} catch(Exception $ex) {}
|
|
|
|
$this->assertTrue(
|
|
|
|
isset($ex)
|
|
|
|
&& $ex instanceof InvalidArgumentException
|
|
|
|
&& $ex->getMessage() === 'XML Doctype parsing disabled'
|
|
|
|
);
|
|
|
|
|
|
|
|
// Test without doctype validation
|
|
|
|
$expected = array(
|
|
|
|
'result' => array(
|
|
|
|
"Now include SOME_SUPER_LONG_STRING lots of times to expand the in-memory size of this XML structure",
|
|
|
|
array(
|
|
|
|
'long' => array(
|
|
|
|
array(
|
|
|
|
'long' => 'SOME_SUPER_LONG_STRING'
|
|
|
|
),
|
|
|
|
array(
|
|
|
|
'long' => 'SOME_SUPER_LONG_STRING'
|
|
|
|
),
|
|
|
|
array(
|
|
|
|
'long' => 'SOME_SUPER_LONG_STRING'
|
|
|
|
)
|
|
|
|
)
|
|
|
|
)
|
|
|
|
)
|
|
|
|
);
|
|
|
|
$result = Convert::xml2array($inputXML, false, true);
|
|
|
|
$this->assertEquals(
|
|
|
|
$expected,
|
|
|
|
$result
|
|
|
|
);
|
|
|
|
$result = Convert::xml2array($inputXML, false, false);
|
|
|
|
$this->assertEquals(
|
|
|
|
$expected,
|
|
|
|
$result
|
|
|
|
);
|
|
|
|
}
|
2015-07-28 03:54:49 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Tests {@link Convert::base64url_encode()} and {@link Convert::base64url_decode()}
|
|
|
|
*/
|
|
|
|
public function testBase64url() {
|
|
|
|
$data = 'Wëīrð characters ☺ such as ¤Ø¶÷╬';
|
|
|
|
// This requires this test file to have UTF-8 character encoding
|
|
|
|
$this->assertEquals(
|
2016-01-06 12:34:58 +13:00
|
|
|
$data,
|
2015-07-28 03:54:49 +02:00
|
|
|
Convert::base64url_decode(Convert::base64url_encode($data))
|
|
|
|
);
|
2016-01-06 12:34:58 +13:00
|
|
|
|
2015-07-28 03:54:49 +02:00
|
|
|
$data = 654.423;
|
|
|
|
$this->assertEquals(
|
|
|
|
$data,
|
|
|
|
Convert::base64url_decode(Convert::base64url_encode($data))
|
|
|
|
);
|
2016-01-06 12:34:58 +13:00
|
|
|
|
2015-07-28 03:54:49 +02:00
|
|
|
$data = true;
|
|
|
|
$this->assertEquals(
|
|
|
|
$data,
|
|
|
|
Convert::base64url_decode(Convert::base64url_encode($data))
|
|
|
|
);
|
2016-01-06 12:34:58 +13:00
|
|
|
|
2015-07-28 03:54:49 +02:00
|
|
|
$data = array('simple','array','¤Ø¶÷╬');
|
|
|
|
$this->assertEquals(
|
|
|
|
$data,
|
|
|
|
Convert::base64url_decode(Convert::base64url_encode($data))
|
|
|
|
);
|
2016-01-06 12:34:58 +13:00
|
|
|
|
2015-07-28 03:54:49 +02:00
|
|
|
$data = array(
|
|
|
|
'a' => 'associative',
|
|
|
|
4 => 'array',
|
|
|
|
'☺' => '¤Ø¶÷╬'
|
|
|
|
);
|
|
|
|
$this->assertEquals(
|
|
|
|
$data,
|
|
|
|
Convert::base64url_decode(Convert::base64url_encode($data))
|
|
|
|
);
|
|
|
|
}
|
2012-03-30 16:18:14 +13:00
|
|
|
}
|