radarrplexorganizrnginxsonarrdashboardsabnzbdheimdallembycouchpotatonzbgetbookmarkapplication-dashboardmuximuxlandingpagestartpagelandinghtpcserverhomepage
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
139 lines
5.4 KiB
139 lines
5.4 KiB
<?php
|
|
|
|
/*
|
|
* This file is part of the Symfony package.
|
|
*
|
|
* (c) Fabien Potencier <fabien@symfony.com>
|
|
*
|
|
* For the full copyright and license information, please view the LICENSE
|
|
* file that was distributed with this source code.
|
|
*/
|
|
|
|
namespace Symfony\Component\Mime\Tests\Encoder;
|
|
|
|
use PHPUnit\Framework\TestCase;
|
|
use Symfony\Component\Mime\Encoder\QpMimeHeaderEncoder;
|
|
|
|
class QpMimeHeaderEncoderTest extends TestCase
|
|
{
|
|
public function testNameIsQ()
|
|
{
|
|
$encoder = new QpMimeHeaderEncoder();
|
|
$this->assertEquals('Q', $encoder->getName());
|
|
}
|
|
|
|
public function testSpaceAndTabNeverAppear()
|
|
{
|
|
/* -- RFC 2047, 4.
|
|
Only a subset of the printable ASCII characters may be used in
|
|
'encoded-text'. Space and tab characters are not allowed, so that
|
|
the beginning and end of an 'encoded-word' are obvious.
|
|
*/
|
|
|
|
$encoder = new QpMimeHeaderEncoder();
|
|
$this->assertNotRegExp('~[ \t]~', $encoder->encodeString("a \t b"), 'encoded-words in headers cannot contain LWSP as per RFC 2047.');
|
|
}
|
|
|
|
public function testSpaceIsRepresentedByUnderscore()
|
|
{
|
|
/* -- RFC 2047, 4.2.
|
|
(2) The 8-bit hexadecimal value 20 (e.g., ISO-8859-1 SPACE) may be
|
|
represented as "_" (underscore, ASCII 95.). (This character may
|
|
not pass through some internetwork mail gateways, but its use
|
|
will greatly enhance readability of "Q" encoded data with mail
|
|
readers that do not support this encoding.) Note that the "_"
|
|
always represents hexadecimal 20, even if the SPACE character
|
|
occupies a different code position in the character set in use.
|
|
*/
|
|
$encoder = new QpMimeHeaderEncoder();
|
|
$this->assertEquals('a_b', $encoder->encodeString('a b'), 'Spaces can be represented by more readable underscores as per RFC 2047.');
|
|
}
|
|
|
|
public function testEqualsAndQuestionAndUnderscoreAreEncoded()
|
|
{
|
|
/* -- RFC 2047, 4.2.
|
|
(3) 8-bit values which correspond to printable ASCII characters other
|
|
than "=", "?", and "_" (underscore), MAY be represented as those
|
|
characters. (But see section 5 for restrictions.) In
|
|
particular, SPACE and TAB MUST NOT be represented as themselves
|
|
within encoded words.
|
|
*/
|
|
$encoder = new QpMimeHeaderEncoder();
|
|
$this->assertEquals('=3D=3F=5F', $encoder->encodeString('=?_'), 'Chars =, ? and _ (underscore) may not appear as per RFC 2047.');
|
|
}
|
|
|
|
public function testParensAndQuotesAreEncoded()
|
|
{
|
|
/* -- RFC 2047, 5 (2).
|
|
A "Q"-encoded 'encoded-word' which appears in a 'comment' MUST NOT
|
|
contain the characters "(", ")" or "
|
|
*/
|
|
|
|
$encoder = new QpMimeHeaderEncoder();
|
|
$this->assertEquals('=28=22=29', $encoder->encodeString('(")'), 'Chars (, " (DQUOTE) and ) may not appear as per RFC 2047.');
|
|
}
|
|
|
|
public function testOnlyCharactersAllowedInPhrasesAreUsed()
|
|
{
|
|
/* -- RFC 2047, 5.
|
|
(3) As a replacement for a 'word' entity within a 'phrase', for example,
|
|
one that precedes an address in a From, To, or Cc header. The ABNF
|
|
definition for 'phrase' from RFC 822 thus becomes:
|
|
|
|
phrase = 1*( encoded-word / word )
|
|
|
|
In this case the set of characters that may be used in a "Q"-encoded
|
|
'encoded-word' is restricted to: <upper and lower case ASCII
|
|
letters, decimal digits, "!", "*", "+", "-", "/", "=", and "_"
|
|
(underscore, ASCII 95.)>. An 'encoded-word' that appears within a
|
|
'phrase' MUST be separated from any adjacent 'word', 'text' or
|
|
'special' by 'linear-white-space'.
|
|
*/
|
|
|
|
$allowedBytes = array_merge(
|
|
range(\ord('a'), \ord('z')), range(\ord('A'), \ord('Z')),
|
|
range(\ord('0'), \ord('9')),
|
|
[\ord('!'), \ord('*'), \ord('+'), \ord('-'), \ord('/')]
|
|
);
|
|
$encoder = new QpMimeHeaderEncoder();
|
|
foreach (range(0x00, 0xFF) as $byte) {
|
|
$char = pack('C', $byte);
|
|
$encodedChar = $encoder->encodeString($char, 'iso-8859-1');
|
|
if (\in_array($byte, $allowedBytes)) {
|
|
$this->assertEquals($char, $encodedChar, 'Character '.$char.' should not be encoded.');
|
|
} elseif (0x20 == $byte) {
|
|
// special case
|
|
$this->assertEquals('_', $encodedChar, 'Space character should be replaced.');
|
|
} else {
|
|
$this->assertEquals(sprintf('=%02X', $byte), $encodedChar, 'Byte '.$byte.' should be encoded.');
|
|
}
|
|
}
|
|
}
|
|
|
|
public function testEqualsNeverAppearsAtEndOfLine()
|
|
{
|
|
/* -- RFC 2047, 5 (3).
|
|
The 'encoded-text' in an 'encoded-word' must be self-contained;
|
|
'encoded-text' MUST NOT be continued from one 'encoded-word' to
|
|
another. This implies that the 'encoded-text' portion of a "B"
|
|
'encoded-word' will be a multiple of 4 characters long; for a "Q"
|
|
'encoded-word', any "=" character that appears in the 'encoded-text'
|
|
portion will be followed by two hexadecimal characters.
|
|
*/
|
|
|
|
$input = str_repeat('a', 140);
|
|
|
|
$output = '';
|
|
$seq = 0;
|
|
for (; $seq < 140; ++$seq) {
|
|
// compute the end of line (multiple of 4 chars)
|
|
if (18 * 4 === $seq) {
|
|
$output .= "\r\n"; // =\r\n
|
|
}
|
|
$output .= 'a';
|
|
}
|
|
|
|
$encoder = new QpMimeHeaderEncoder();
|
|
$this->assertEquals($output, $encoder->encodeString($input));
|
|
}
|
|
}
|
|
|