123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134 |
- <?php
-
- require_once 'Swift/Tests/SwiftUnitTestCase.php';
-
- class Swift_Bug51Test extends Swift_Tests_SwiftUnitTestCase
- {
-
- private $_attachmentFile;
- private $_outputFile;
-
- public function skip()
- {
- $this->skipUnless(
- is_writable(SWIFT_TMP_DIR),
- '%s: This test requires tests/acceptance.conf.php to specify a ' .
- 'writable SWIFT_TMP_DIR'
- );
- }
-
- public function setUp()
- {
- $this->_attachmentFile = SWIFT_TMP_DIR . '/attach.rand.bin';
- file_put_contents($this->_attachmentFile, '');
-
- $this->_outputFile = SWIFT_TMP_DIR . '/attach.out.bin';
- file_put_contents($this->_outputFile, '');
- }
-
- public function tearDown()
- {
- unlink($this->_attachmentFile);
- unlink($this->_outputFile);
- }
-
- public function testAttachmentsDoNotGetTruncatedUsingToByteStream()
- {
- //Run 100 times with 10KB attachments
- for ($i = 0; $i < 10; ++$i)
- {
- $message = $this->_createMessageWithRandomAttachment(
- 10000, $this->_attachmentFile
- );
-
- file_put_contents($this->_outputFile, '');
- $message->toByteStream(
- new Swift_ByteStream_FileByteStream($this->_outputFile, true)
- );
-
- $emailSource = file_get_contents($this->_outputFile);
-
- $this->assertAttachmentFromSourceMatches(
- file_get_contents($this->_attachmentFile),
- $emailSource
- );
- }
- }
-
- public function testAttachmentsDoNotGetTruncatedUsingToString()
- {
- //Run 100 times with 10KB attachments
- for ($i = 0; $i < 10; ++$i)
- {
- $message = $this->_createMessageWithRandomAttachment(
- 10000, $this->_attachmentFile
- );
-
- $emailSource = $message->toString();
-
- $this->assertAttachmentFromSourceMatches(
- file_get_contents($this->_attachmentFile),
- $emailSource
- );
- }
- }
-
- // -- Custom Assertions
-
- public function assertAttachmentFromSourceMatches($attachmentData, $source)
- {
- $encHeader = 'Content-Transfer-Encoding: base64';
- $base64declaration = strpos($source, $encHeader);
-
- $attachmentDataStart = strpos($source, "\r\n\r\n", $base64declaration);
- $attachmentDataEnd = strpos($source, "\r\n--", $attachmentDataStart);
-
- if (false === $attachmentDataEnd)
- {
- $attachmentBase64 = trim(substr($source, $attachmentDataStart));
- }
- else
- {
- $attachmentBase64 = trim(substr(
- $source, $attachmentDataStart,
- $attachmentDataEnd - $attachmentDataStart
- ));
- }
-
- $this->assertIdenticalBinary($attachmentData, base64_decode($attachmentBase64));
- }
-
- // -- Creation Methods
-
- private function _fillFileWithRandomBytes($byteCount, $file)
- {
- // I was going to use dd with if=/dev/random but this way seems more
- // cross platform even if a hella expensive!!
-
- file_put_contents($file, '');
- $fp = fopen($file, 'wb');
- for ($i = 0; $i < $byteCount; ++$i)
- {
- $byteVal = rand(0, 255);
- fwrite($fp, pack('i', $byteVal));
- }
- fclose($fp);
- }
-
- private function _createMessageWithRandomAttachment($size, $attachmentPath)
- {
- $this->_fillFileWithRandomBytes($size, $attachmentPath);
-
- $message = Swift_Message::newInstance()
- ->setSubject('test')
- ->setBody('test')
- ->setFrom('a@b.c')
- ->setTo('d@e.f')
- ->attach(Swift_Attachment::fromPath($attachmentPath))
- ;
-
- return $message;
- }
-
- }
|