Skip to content
This repository has been archived by the owner on Jan 30, 2020. It is now read-only.

Commit

Permalink
Merge branch 'master' into rfc/escaper
Browse files Browse the repository at this point in the history
  • Loading branch information
Show file tree
Hide file tree
Showing 9 changed files with 25 additions and 97 deletions.
13 changes: 4 additions & 9 deletions src/Decode.php
Original file line number Diff line number Diff line change
Expand Up @@ -18,14 +18,9 @@
* @license http://framework.zend.com/license/new-bsd New BSD License
*/

/**
* @namespace
*/
namespace Zend\Mime;

/**
* @uses \Zend\Mime\Exception\RuntimeException
* @uses \Zend\Mime\Mime
* @category Zend
* @package Zend_Mime
* @copyright Copyright (c) 2005-2012 Zend Technologies USA Inc. (http://www.zend.com)
Expand Down Expand Up @@ -184,13 +179,13 @@ public static function splitContentType($type, $wantedPart = null)
/**
* split a header field like content type in its different parts
*
* @param string $type header field
* @param string $field header field
* @param string $wantedPart the wanted part, else an array with all parts is returned
* @param string $firstName key name for the first part
* @return string|array wanted part or all parts as array($firstName => firstPart, partname => value)
* @throws Exception\RuntimeException
*/
public static function splitHeaderField($field, $wantedPart = null, $firstName = 0)
public static function splitHeaderField($field, $wantedPart = null, $firstName = '0')
{
$wantedPart = strtolower($wantedPart);
$firstName = strtolower($firstName);
Expand Down Expand Up @@ -237,11 +232,11 @@ public static function splitHeaderField($field, $wantedPart = null, $firstName =
*
* The charset of the returned string depends on your iconv settings.
*
* @param string encoded string
* @param string $string encoded string
* @return string decoded string
*/
public static function decodeQuotedPrintable($string)
{
return quoted_printable_decode($string);
return iconv_mime_decode($string, ICONV_MIME_DECODE_CONTINUE_ON_ERROR);
}
}
7 changes: 2 additions & 5 deletions src/Exception.php → src/Exception/ExceptionInterface.php
Original file line number Diff line number Diff line change
Expand Up @@ -18,17 +18,14 @@
* @license http://framework.zend.com/license/new-bsd New BSD License
*/

/**
* @namespace
*/
namespace Zend\Mime;
namespace Zend\Mime\Exception;

/**
* @category Zend
* @package Zend_Mime
* @copyright Copyright (c) 2005-2012 Zend Technologies USA Inc. (http://www.zend.com)
* @license http://framework.zend.com/license/new-bsd New BSD License
*/
interface Exception
interface ExceptionInterface
{}

9 changes: 2 additions & 7 deletions src/Exception/RuntimeException.php
Original file line number Diff line number Diff line change
Expand Up @@ -19,23 +19,18 @@
* @license http://framework.zend.com/license/new-bsd New BSD License
*/

/**
* @namespace
*/
namespace Zend\Mime\Exception;
use Zend\Mime\Exception;

/**
* Exception for Zend_Mime component.
*
* @uses Zend\Exception
* @category Zend
* @package Zend_Mime
* @copyright Copyright (c) 2005-2012 Zend Technologies USA Inc. (http://www.zend.com)
* @license http://framework.zend.com/license/new-bsd New BSD License
*/
class RuntimeException
extends \RuntimeException
implements Exception
implements ExceptionInterface
{
}
}
7 changes: 0 additions & 7 deletions src/Message.php
Original file line number Diff line number Diff line change
Expand Up @@ -18,16 +18,9 @@
* @license http://framework.zend.com/license/new-bsd New BSD License
*/

/**
* @namespace
*/
namespace Zend\Mime;

/**
* @uses \Zend\Mime\Exception\RuntimeException
* @uses \Zend\Mime\Mime
* @uses \Zend\Mime\Decode
* @uses \Zend\Mime\Part
* @category Zend
* @package Zend_Mime
* @copyright Copyright (c) 2005-2012 Zend Technologies USA Inc. (http://www.zend.com)
Expand Down
3 changes: 0 additions & 3 deletions src/Mime.php
Original file line number Diff line number Diff line change
Expand Up @@ -18,9 +18,6 @@
* @license http://framework.zend.com/license/new-bsd New BSD License
*/

/**
* @namespace
*/
namespace Zend\Mime;

/**
Expand Down
7 changes: 1 addition & 6 deletions src/Part.php
Original file line number Diff line number Diff line change
Expand Up @@ -18,16 +18,11 @@
* @license http://framework.zend.com/license/new-bsd New BSD License
*/

/**
* @namespace
*/
namespace Zend\Mime;

/**
* Class representing a MIME part.
*
* @uses \Zend\Mime\Mime
* @uses \Zend\Mime\Exception
* @category Zend
* @package Zend_Mime
* @copyright Copyright (c) 2005-2012 Zend Technologies USA Inc. (http://www.zend.com)
Expand Down Expand Up @@ -88,7 +83,7 @@ public function isStream()
* reading the content. very useful for large file attachments.
*
* @return stream
* @throws \Zend\Mime\Exception if not a stream or unable to append filter
* @throws Exception\RuntimeException if not a stream or unable to append filter
*/
public function getEncodedStream()
{
Expand Down
3 changes: 0 additions & 3 deletions test/MessageTest.php
Original file line number Diff line number Diff line change
Expand Up @@ -19,9 +19,6 @@
* @license http://framework.zend.com/license/new-bsd New BSD License
*/

/**
* @namespace
*/
namespace ZendTest\Mime;
use Zend\Mime;

Expand Down
70 changes: 16 additions & 54 deletions test/MimeTest.php
Original file line number Diff line number Diff line change
Expand Up @@ -19,13 +19,9 @@
* @license http://framework.zend.com/license/new-bsd New BSD License
*/

/**
* @namespace
*/
namespace Zend;
use Zend\Mime;
use Zend\Mail;
namespace ZendTest\Mime;

use Zend\Mime;

/**
* @category Zend
Expand All @@ -39,6 +35,7 @@ class MimeTest extends \PHPUnit_Framework_TestCase
{
/**
* Stores the original set timezone
*
* @var string
*/
private $_originaltimezone;
Expand All @@ -52,7 +49,7 @@ public function setUp()
}

/**
* Teardown environment
* Tear down environment
*/
public function tearDown()
{
Expand All @@ -68,7 +65,7 @@ public function testBoundary()

// check instantiating with arbitrary boundary string
$myBoundary = 'mySpecificBoundary';
$m3 = new Mime\Mime($myBoundary);
$m3 = new Mime\Mime($myBoundary);
$this->assertEquals($m3->boundary(), $myBoundary);

}
Expand Down Expand Up @@ -105,25 +102,13 @@ public function testBase64()

public function testZf1058WhitespaceAtEndOfBodyCausesInfiniteLoop()
{
// Set timezone to avoid "date(): It is not safe to rely on the system's timezone settings."
// message.
date_default_timezone_set('GMT');

$mail = new \Zend\Mail\Mail();
$mail->setSubject('my subject');
$mail->setBodyText("my body\r\n\r\n...after two newlines\r\n ");
$mail->setFrom('test@email.com');
$mail->addTo('test@email.com');

// test with generic transport
$mock = new SendmailTransportMock();
$mail->send($mock);
$body = quoted_printable_decode($mock->body);
$this->assertContains("my body\r\n\r\n...after two newlines", $body, $body);
$text = "my body\r\n\r\n...after two newlines\r\n ";
$result = quoted_printable_decode(Mime\Mime::encodeQuotedPrintable($text));
$this->assertContains("my body\r\n\r\n...after two newlines", $result, $result);
}

/**
* @group ZF-1688
* @group ZF-1688
* @dataProvider dataTestEncodeMailHeaderQuotedPrintable
*/
public function testEncodeMailHeaderQuotedPrintable($str, $charset, $result)
Expand All @@ -145,7 +130,7 @@ public static function dataTestEncodeMailHeaderQuotedPrintable()
}

/**
* @group ZF-1688
* @group ZF-1688
* @dataProvider dataTestEncodeMailHeaderBase64
*/
public function testEncodeMailHeaderBase64($str, $charset, $result)
Expand All @@ -170,39 +155,16 @@ public function testLineLengthInQuotedPrintableHeaderEncoding()
{
$subject = "Alle meine Entchen schwimmen in dem See, schwimmen in dem See, Köpfchen in das Wasser, Schwänzchen in die Höh!";
$encoded = Mime\Mime::encodeQuotedPrintableHeader($subject, "UTF-8", 100);
foreach(explode(Mime\Mime::LINEEND, $encoded) AS $line ) {
if(strlen($line) > 100) {
$this->fail("Line '".$line."' is ".strlen($line)." chars long, only 100 allowed.");
foreach (explode(Mime\Mime::LINEEND, $encoded) AS $line) {
if (strlen($line) > 100) {
$this->fail("Line '" . $line . "' is " . strlen($line) . " chars long, only 100 allowed.");
}
}
$encoded = Mime\Mime::encodeQuotedPrintableHeader($subject, "UTF-8", 40);
foreach(explode(Mime\Mime::LINEEND, $encoded) AS $line ) {
if(strlen($line) > 40) {
$this->fail("Line '".$line."' is ".strlen($line)." chars long, only 40 allowed.");
foreach (explode(Mime\Mime::LINEEND, $encoded) AS $line) {
if (strlen($line) > 40) {
$this->fail("Line '" . $line . "' is " . strlen($line) . " chars long, only 40 allowed.");
}
}
}
}


/**
* Mock mail transport class for testing Sendmail transport
*/
class SendmailTransportMock extends Mail\Transport\Sendmail
{
/**
* @var Zend_Mail
*/
public $mail = null;
public $from = null;
public $subject = null;
public $called = false;

public function _sendMail()
{
$this->mail = $this->_mail;
$this->from = $this->_mail->getFrom();
$this->subject = $this->_mail->getSubject();
$this->called = true;
}
}
3 changes: 0 additions & 3 deletions test/PartTest.php
Original file line number Diff line number Diff line change
Expand Up @@ -19,9 +19,6 @@
* @license http://framework.zend.com/license/new-bsd New BSD License
*/

/**
* @namespace
*/
namespace ZendTest\Mime;
use Zend\Mime;

Expand Down

0 comments on commit 23843e6

Please sign in to comment.