OXIESEC PANEL
- Current Dir:
/
/
var
/
www
/
cream
/
aws-ses
/
vendor
/
phpmailer
/
phpmailer
/
test
/
PHPMailer
Server IP: 139.59.38.164
Upload:
Create Dir:
Name
Size
Modified
Perms
📁
..
-
05/19/2025 10:07:19 AM
rwxr-xr-x
📄
AddEmbeddedImageTest.php
6.45 KB
05/19/2025 10:07:19 AM
rw-r--r--
📄
AddStringAttachmentTest.php
5.19 KB
05/19/2025 10:07:19 AM
rw-r--r--
📄
AddStringEmbeddedImageTest.php
5.53 KB
05/19/2025 10:07:19 AM
rw-r--r--
📄
AddrFormatTest.php
2.08 KB
05/19/2025 10:07:19 AM
rw-r--r--
📄
AuthCRAMMD5Test.php
1.54 KB
05/19/2025 10:07:19 AM
rw-r--r--
📄
CustomHeaderTest.php
9.2 KB
05/19/2025 10:07:19 AM
rw-r--r--
📄
DKIMTest.php
9.51 KB
05/19/2025 10:07:19 AM
rw-r--r--
📄
DSNConfiguratorTest.php
6.49 KB
05/19/2025 10:07:19 AM
rw-r--r--
📄
EncodeQTest.php
3.96 KB
05/19/2025 10:07:19 AM
rw-r--r--
📄
EncodeStringTest.php
4.58 KB
05/19/2025 10:07:19 AM
rw-r--r--
📄
FileIsAccessibleTest.php
3.32 KB
05/19/2025 10:07:19 AM
rw-r--r--
📄
FilenameToTypeTest.php
2.22 KB
05/19/2025 10:07:19 AM
rw-r--r--
📄
GenerateIdTest.php
2.63 KB
05/19/2025 10:07:19 AM
rw-r--r--
📄
GetLastMessageIDTest.php
3.32 KB
05/19/2025 10:07:19 AM
rw-r--r--
📄
HasLineLongerThanMaxTest.php
4.69 KB
05/19/2025 10:07:19 AM
rw-r--r--
📄
Html2TextTest.php
9.79 KB
05/19/2025 10:07:19 AM
rw-r--r--
📄
ICalTest.php
4.32 KB
05/19/2025 10:07:19 AM
rw-r--r--
📄
IsPermittedPathTest.php
3.74 KB
05/19/2025 10:07:19 AM
rw-r--r--
📄
IsValidHostTest.php
4.18 KB
05/19/2025 10:07:19 AM
rw-r--r--
📄
LocalizationTest.php
18.51 KB
05/19/2025 10:07:19 AM
rw-r--r--
📄
MailTransportTest.php
3.67 KB
05/19/2025 10:07:19 AM
rw-r--r--
📄
MbPathinfoTest.php
5.74 KB
05/19/2025 10:07:19 AM
rw-r--r--
📄
MimeTypesTest.php
1.93 KB
05/19/2025 10:07:19 AM
rw-r--r--
📄
NormalizeBreaksTest.php
3.62 KB
05/19/2025 10:07:19 AM
rw-r--r--
📄
PHPMailerTest.php
47.39 KB
05/19/2025 10:07:19 AM
rw-r--r--
📄
ParseAddressesTest.php
14.27 KB
05/19/2025 10:07:19 AM
rw-r--r--
📄
PunyencodeAddressTest.php
4.77 KB
05/19/2025 10:07:19 AM
rw-r--r--
📄
QuotedStringTest.php
2.08 KB
05/19/2025 10:07:19 AM
rw-r--r--
📄
ReplyToGetSetClearTest.php
17.23 KB
05/19/2025 10:07:19 AM
rw-r--r--
📄
SetErrorTest.php
5.19 KB
05/19/2025 10:07:19 AM
rw-r--r--
📄
SetFromTest.php
7.08 KB
05/19/2025 10:07:19 AM
rw-r--r--
📄
SetTest.php
2.32 KB
05/19/2025 10:07:19 AM
rw-r--r--
📄
SetWordWrapTest.php
4.01 KB
05/19/2025 10:07:19 AM
rw-r--r--
📄
Utf8CharBoundaryTest.php
1.95 KB
05/19/2025 10:07:19 AM
rw-r--r--
📄
ValidateAddressCustomValidatorTest.php
3.65 KB
05/19/2025 10:07:19 AM
rw-r--r--
📄
ValidateAddressTest.php
17.2 KB
05/19/2025 10:07:19 AM
rw-r--r--
📄
WrapTextTest.php
6.05 KB
05/19/2025 10:07:19 AM
rw-r--r--
📄
XMailerTest.php
2 KB
05/19/2025 10:07:19 AM
rw-r--r--
Editing: PHPMailerTest.php
Close
<?php /** * PHPMailer - PHP email transport unit tests. * PHP version 5.5. * * @author Marcus Bointon <phpmailer@synchromedia.co.uk> * @author Andy Prevost * @copyright 2012 - 2020 Marcus Bointon * @copyright 2004 - 2009 Andy Prevost * @license http://www.gnu.org/copyleft/lesser.html GNU Lesser General Public License */ namespace PHPMailer\Test\PHPMailer; use PHPMailer\PHPMailer\Exception; use PHPMailer\PHPMailer\PHPMailer; use PHPMailer\PHPMailer\SMTP; use PHPMailer\Test\SendTestCase; /** * PHPMailer - PHP email transport unit test class. */ final class PHPMailerTest extends SendTestCase { private $Smtp; /** * Test low priority. */ public function testLowPriority() { $this->Mail->Priority = 5; $this->Mail->Body = 'Here is the main body. There should be ' . 'a reply to address in this message.'; $this->Mail->Subject .= ': Low Priority'; $this->buildBody(); self::assertTrue($this->Mail->send(), $this->Mail->ErrorInfo); } /** * Simple plain file attachment test. */ public function testMultiplePlainFileAttachment() { $this->Mail->Body = 'Here is the text body'; $this->Mail->Subject .= ': Plain + Multiple FileAttachments'; if (!$this->Mail->addAttachment(realpath(\PHPMAILER_INCLUDE_DIR . '/examples/images/phpmailer.png'))) { self::assertTrue(false, $this->Mail->ErrorInfo); return; } if (!$this->Mail->addAttachment(__FILE__, 'test.txt')) { self::assertTrue(false, $this->Mail->ErrorInfo); return; } $this->buildBody(); self::assertTrue($this->Mail->send(), $this->Mail->ErrorInfo); } /** * Rejection of non-local file attachments test. */ public function testRejectNonLocalFileAttachment() { self::assertFalse( $this->Mail->addAttachment('https://github.com/PHPMailer/PHPMailer/raw/master/README.md'), 'addAttachment should reject remote URLs' ); self::assertFalse( $this->Mail->addAttachment('phar://phar.php'), 'addAttachment should reject phar resources' ); } /** * Plain quoted-printable message. */ public function testQuotedPrintable() { $this->Mail->Body = 'Here is the main body'; $this->Mail->Subject .= ': Plain + Quoted-printable'; $this->Mail->Encoding = 'quoted-printable'; $this->buildBody(); self::assertTrue($this->Mail->send(), $this->Mail->ErrorInfo); //Check that a quoted printable encode and decode results in the same as went in $t = file_get_contents(__FILE__); //Use this file as test content //Force line breaks to UNIX-style $t = str_replace(["\r\n", "\r"], "\n", $t); self::assertSame( $t, quoted_printable_decode($this->Mail->encodeQP($t)), 'Quoted-Printable encoding round-trip failed' ); //Force line breaks to Windows-style $t = str_replace("\n", "\r\n", $t); self::assertSame( $t, quoted_printable_decode($this->Mail->encodeQP($t)), 'Quoted-Printable encoding round-trip failed (Windows line breaks)' ); } /** * Test header encoding & folding. */ public function testHeaderEncoding() { $this->Mail->CharSet = PHPMailer::CHARSET_UTF8; $letter = html_entity_decode('é', ENT_COMPAT, PHPMailer::CHARSET_UTF8); //This should select B-encoding automatically and should fold $bencode = str_repeat($letter, PHPMailer::STD_LINE_LENGTH + 1); //This should select Q-encoding automatically and should fold $qencode = str_repeat('e', PHPMailer::STD_LINE_LENGTH) . $letter; //This should select B-encoding automatically and should not fold $bencodenofold = str_repeat($letter, 10); //This should select Q-encoding automatically and should not fold $qencodenofold = str_repeat('e', 9) . $letter; //This should Q-encode as ASCII and fold (previously, this did not encode) $longheader = str_repeat('e', PHPMailer::STD_LINE_LENGTH + 10); //This should Q-encode as UTF-8 and fold $longutf8 = str_repeat($letter, PHPMailer::STD_LINE_LENGTH + 10); //This should not change $noencode = 'eeeeeeeeee'; $this->Mail->isMail(); //Expected results $bencoderes = '=?utf-8?B?w6nDqcOpw6nDqcOpw6nDqcOpw6nDqcOpw6nDqcOpw6nDqcOpw6nDqcOpw6k=?=' . PHPMailer::getLE() . ' =?utf-8?B?w6nDqcOpw6nDqcOpw6nDqcOpw6nDqcOpw6nDqcOpw6nDqcOpw6nDqcOpw6k=?=' . PHPMailer::getLE() . ' =?utf-8?B?w6nDqcOpw6nDqcOpw6nDqcOpw6nDqcOpw6nDqcOpw6nDqcOpw6nDqcOpw6k=?=' . PHPMailer::getLE() . ' =?utf-8?B?w6nDqcOpw6nDqcOpw6nDqcOpw6nDqQ==?='; $qencoderes = '=?utf-8?Q?eeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeee?=' . PHPMailer::getLE() . ' =?utf-8?Q?eeeeeeeeeeeeeeeeeeeeeeeeee=C3=A9?='; $bencodenofoldres = '=?utf-8?B?w6nDqcOpw6nDqcOpw6nDqcOpw6k=?='; $qencodenofoldres = '=?utf-8?Q?eeeeeeeee=C3=A9?='; $longheaderres = '=?us-ascii?Q?eeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeee?=' . PHPMailer::getLE() . ' =?us-ascii?Q?eeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeee?='; $longutf8res = '=?utf-8?B?w6nDqcOpw6nDqcOpw6nDqcOpw6nDqcOpw6nDqcOpw6nDqcOpw6nDqcOpw6k=?=' . PHPMailer::getLE() . ' =?utf-8?B?w6nDqcOpw6nDqcOpw6nDqcOpw6nDqcOpw6nDqcOpw6nDqcOpw6nDqcOpw6k=?=' . PHPMailer::getLE() . ' =?utf-8?B?w6nDqcOpw6nDqcOpw6nDqcOpw6nDqcOpw6nDqcOpw6nDqcOpw6nDqcOpw6k=?=' . PHPMailer::getLE() . ' =?utf-8?B?w6nDqcOpw6nDqcOpw6nDqcOpw6nDqcOpw6nDqcOpw6nDqcOpw6nDqQ==?='; $noencoderes = 'eeeeeeeeee'; self::assertSame( $bencoderes, $this->Mail->encodeHeader($bencode), 'Folded B-encoded header value incorrect' ); self::assertSame( $qencoderes, $this->Mail->encodeHeader($qencode), 'Folded Q-encoded header value incorrect' ); self::assertSame( $bencodenofoldres, $this->Mail->encodeHeader($bencodenofold), 'B-encoded header value incorrect' ); self::assertSame( $qencodenofoldres, $this->Mail->encodeHeader($qencodenofold), 'Q-encoded header value incorrect' ); self::assertSame( $longheaderres, $this->Mail->encodeHeader($longheader), 'Long header value incorrect' ); self::assertSame( $longutf8res, $this->Mail->encodeHeader($longutf8), 'Long UTF-8 header value incorrect' ); self::assertSame( $noencoderes, $this->Mail->encodeHeader($noencode), 'Unencoded header value incorrect' ); } /** * Send an HTML message. */ public function testHtml() { $this->Mail->isHTML(true); $this->Mail->Subject .= ': HTML only'; $this->Mail->Body = <<<'EOT' <!DOCTYPE html> <html lang="en"> <head> <title>HTML email test</title> </head> <body> <h1>PHPMailer does HTML!</h1> <p>This is a <strong>test message</strong> written in HTML.<br> Go to <a href="https://github.com/PHPMailer/PHPMailer/">https://github.com/PHPMailer/PHPMailer/</a> for new versions of PHPMailer.</p> <p>Thank you!</p> </body> </html> EOT; $this->buildBody(); self::assertTrue($this->Mail->send(), $this->Mail->ErrorInfo); $msg = $this->Mail->getSentMIMEMessage(); self::assertStringNotContainsString("\r\n\r\nMIME-Version:", $msg, 'Incorrect MIME headers'); } /** * Send an HTML message specifying the DSN notifications we expect. */ public function testDsn() { $this->Mail->isHTML(true); $this->Mail->Subject .= ': HTML only'; $this->Mail->Body = <<<'EOT' <!DOCTYPE html> <html lang="en"> <head> <title>HTML email test</title> </head> <body> <p>PHPMailer</p> </body> </html> EOT; $this->buildBody(); $this->Mail->dsn = 'SUCCESS,FAILURE'; self::assertTrue($this->Mail->send(), $this->Mail->ErrorInfo); //Sends the same mail, but sets the DSN notification to NEVER $this->Mail->dsn = 'NEVER'; self::assertTrue($this->Mail->send(), $this->Mail->ErrorInfo); } /** * createBody test of switch case */ public function testCreateBody() { $PHPMailer = new PHPMailer(); $reflection = new \ReflectionClass($PHPMailer); $property = $reflection->getProperty('message_type'); $property->setAccessible(true); $property->setValue($PHPMailer, 'inline'); self::assertIsString($PHPMailer->createBody()); $property->setValue($PHPMailer, 'attach'); self::assertIsString($PHPMailer->createBody()); $property->setValue($PHPMailer, 'inline_attach'); self::assertIsString($PHPMailer->createBody()); $property->setValue($PHPMailer, 'alt'); self::assertIsString($PHPMailer->createBody()); $property->setValue($PHPMailer, 'alt_inline'); self::assertIsString($PHPMailer->createBody()); $property->setValue($PHPMailer, 'alt_attach'); self::assertIsString($PHPMailer->createBody()); $property->setValue($PHPMailer, 'alt_inline_attach'); self::assertIsString($PHPMailer->createBody()); } /** * Send a message containing ISO-8859-1 text. */ public function testHtmlIso8859() { $this->Mail->isHTML(true); $this->Mail->Subject .= ': ISO-8859-1 HTML'; $this->Mail->CharSet = PHPMailer::CHARSET_ISO88591; //This file is in ISO-8859-1 charset //Needs to be external because this file is in UTF-8 $content = file_get_contents(realpath(\PHPMAILER_INCLUDE_DIR . '/examples/contents.html')); //This is the string 'éèîüçÅñæß' in ISO-8859-1, base-64 encoded $check = base64_decode('6eju/OfF8ebf'); //Make sure it really is in ISO-8859-1! $this->Mail->msgHTML( mb_convert_encoding( $content, 'ISO-8859-1', mb_detect_encoding($content, 'UTF-8, ISO-8859-1, ISO-8859-15', true) ), realpath(\PHPMAILER_INCLUDE_DIR . '/examples') ); $this->buildBody(); self::assertStringContainsString($check, $this->Mail->Body, 'ISO message body does not contain expected text'); self::assertTrue($this->Mail->send(), $this->Mail->ErrorInfo); } /** * Send a message containing multilingual UTF-8 text. */ public function testHtmlUtf8() { $this->Mail->isHTML(true); $this->Mail->Subject .= ': UTF-8 HTML Пустое тело сообщения'; $this->Mail->CharSet = 'UTF-8'; $this->Mail->Body = <<<'EOT' <!DOCTYPE html> <html lang="en"> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8"> <title>HTML email test</title> </head> <body> <p>Chinese text: 郵件內容為空</p> <p>Russian text: Пустое тело сообщения</p> <p>Armenian text: Հաղորդագրությունը դատարկ է</p> <p>Czech text: Prázdné tělo zprávy</p> </body> </html> EOT; $this->buildBody(); self::assertTrue($this->Mail->send(), $this->Mail->ErrorInfo); $msg = $this->Mail->getSentMIMEMessage(); self::assertStringNotContainsString("\r\n\r\nMIME-Version:", $msg, 'Incorrect MIME headers'); } /** * Send a message containing multilingual UTF-8 text with an embedded image. */ public function testUtf8WithEmbeddedImage() { $this->Mail->isHTML(true); $this->Mail->Subject .= ': UTF-8 with embedded image'; $this->Mail->CharSet = 'UTF-8'; $this->Mail->Body = <<<'EOT' <!DOCTYPE html> <html lang="en"> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8"> <title>HTML email test</title> </head> <body> <p>Chinese text: 郵件內容為空</p> <p>Russian text: Пустое тело сообщения</p> <p>Armenian text: Հաղորդագրությունը դատարկ է</p> <p>Czech text: Prázdné tělo zprávy</p> Embedded Image: <img alt="phpmailer" src="cid:bäck"> </body> </html> EOT; $this->Mail->addEmbeddedImage( realpath(\PHPMAILER_INCLUDE_DIR . '/examples/images/phpmailer.png'), 'bäck', 'phpmailer.png', 'base64', 'image/png' ); $this->buildBody(); self::assertTrue($this->Mail->send(), $this->Mail->ErrorInfo); } /** * Send a message containing multilingual UTF-8 text. */ public function testPlainUtf8() { $this->Mail->isHTML(false); $this->Mail->Subject .= ': UTF-8 plain text'; $this->Mail->CharSet = 'UTF-8'; $this->Mail->Body = <<<'EOT' Chinese text: 郵件內容為空 Russian text: Пустое тело сообщения Armenian text: Հաղորդագրությունը դատարկ է Czech text: Prázdné tělo zprávy EOT; $this->buildBody(); self::assertTrue($this->Mail->send(), $this->Mail->ErrorInfo); $msg = $this->Mail->getSentMIMEMessage(); self::assertStringNotContainsString("\r\n\r\nMIME-Version:", $msg, 'Incorrect MIME headers'); } /** * Test simple message builder and html2text converters. */ public function testMsgHTML() { $message = file_get_contents(realpath(\PHPMAILER_INCLUDE_DIR . '/examples/contentsutf8.html')); $this->Mail->CharSet = PHPMailer::CHARSET_UTF8; $this->Mail->Body = ''; $this->Mail->AltBody = ''; //Uses internal HTML to text conversion $this->Mail->msgHTML($message, realpath(\PHPMAILER_INCLUDE_DIR . '/examples')); $sub = $this->Mail->Subject . ': msgHTML'; $this->Mail->Subject .= $sub; self::assertNotEmpty($this->Mail->Body, 'Body not set by msgHTML'); self::assertNotEmpty($this->Mail->AltBody, 'AltBody not set by msgHTML'); self::assertTrue($this->Mail->send(), $this->Mail->ErrorInfo); //Again, using a custom HTML to text converter $this->Mail->AltBody = ''; $this->Mail->msgHTML( $message, realpath(\PHPMAILER_INCLUDE_DIR . '/examples'), static function ($html) { return strtoupper(strip_tags($html)); } ); $this->Mail->Subject = $sub . ' + custom html2text'; self::assertTrue($this->Mail->send(), $this->Mail->ErrorInfo); //Test that local paths without a basedir are ignored $this->Mail->msgHTML('<img src="/etc/hostname">test'); self::assertStringContainsString('src="/etc/hostname"', $this->Mail->Body); //Test that local paths with a basedir are not ignored $this->Mail->msgHTML('<img src="composer.json">test', realpath(\PHPMAILER_INCLUDE_DIR)); self::assertStringNotContainsString('src="composer.json"', $this->Mail->Body); //Test that local paths with parent traversal are ignored $this->Mail->msgHTML('<img src="../composer.json">test', realpath(\PHPMAILER_INCLUDE_DIR)); self::assertStringNotContainsString('src="composer.json"', $this->Mail->Body); //Test that existing embedded URLs are ignored $this->Mail->msgHTML('<img src="cid:5d41402abc4b2a76b9719d911017c592">test'); self::assertStringContainsString('src="cid:5d41402abc4b2a76b9719d911017c592"', $this->Mail->Body); //Test that absolute URLs are ignored $this->Mail->msgHTML('<img src="https://github.com/PHPMailer/PHPMailer/blob/master/composer.json">test'); self::assertStringContainsString( 'src="https://github.com/PHPMailer/PHPMailer/blob/master/composer.json"', $this->Mail->Body ); //Test that absolute URLs with anonymous/relative protocol are ignored //Note that such URLs will not work in email anyway because they have no protocol to be relative to $this->Mail->msgHTML('<img src="//github.com/PHPMailer/PHPMailer/blob/master/composer.json">test'); self::assertStringContainsString( 'src="//github.com/PHPMailer/PHPMailer/blob/master/composer.json"', $this->Mail->Body ); } /** * Simple HTML and attachment test. */ public function testHTMLAttachment() { $this->Mail->Body = 'This is the <strong>HTML</strong> part of the email.'; $this->Mail->Subject .= ': HTML + Attachment'; $this->Mail->isHTML(true); $this->Mail->CharSet = 'UTF-8'; if ( !$this->Mail->addAttachment( realpath(\PHPMAILER_INCLUDE_DIR . '/examples/images/phpmailer_mini.png'), 'phpmailer_mini.png' ) ) { self::assertTrue(false, $this->Mail->ErrorInfo); return; } //Make sure phar paths are rejected self::assertFalse($this->Mail->addAttachment('phar://pharfile.php', 'pharfile.php')); //Make sure any path that looks URLish is rejected self::assertFalse($this->Mail->addAttachment('http://example.com/test.php', 'test.php')); self::assertFalse( $this->Mail->addAttachment( 'ssh2.sftp://user:pass@attacker-controlled.example.com:22/tmp/payload.phar', 'test.php' ) ); self::assertFalse($this->Mail->addAttachment('x-1.cd+-://example.com/test.php', 'test.php')); //Make sure that trying to attach a nonexistent file fails $filename = __FILE__ . md5(microtime()) . 'nonexistent_file.txt'; self::assertFalse($this->Mail->addAttachment($filename)); //Make sure that trying to attach an existing but unreadable file fails touch($filename); chmod($filename, 0200); self::assertFalse($this->Mail->addAttachment($filename)); chmod($filename, 0644); unlink($filename); $this->buildBody(); self::assertTrue($this->Mail->send(), $this->Mail->ErrorInfo); } /** * Attachment naming test. */ public function testAttachmentNaming() { $this->Mail->Body = 'Attachments.'; $this->Mail->Subject .= ': Attachments'; $this->Mail->isHTML(true); $this->Mail->CharSet = 'UTF-8'; $this->Mail->addAttachment( realpath(\PHPMAILER_INCLUDE_DIR . '/examples/images/phpmailer_mini.png'), 'phpmailer_mini.png";.jpg' ); $this->Mail->addAttachment( realpath(\PHPMAILER_INCLUDE_DIR . '/examples/images/phpmailer.png'), 'phpmailer.png' ); $this->Mail->addAttachment( realpath(\PHPMAILER_INCLUDE_DIR . '/examples/images/PHPMailer card logo.png'), 'PHPMailer card logo.png' ); $this->Mail->addAttachment( realpath(\PHPMAILER_INCLUDE_DIR . '/examples/images/phpmailer_mini.png'), 'phpmailer_mini.png\\\";.jpg' ); $this->buildBody(); $this->Mail->preSend(); $message = $this->Mail->getSentMIMEMessage(); self::assertStringContainsString( 'Content-Type: image/png; name="phpmailer_mini.png\";.jpg"', $message, 'Name containing double quote should be escaped in Content-Type' ); self::assertStringContainsString( 'Content-Disposition: attachment; filename="phpmailer_mini.png\";.jpg"', $message, 'Filename containing double quote should be escaped in Content-Disposition' ); self::assertStringContainsString( 'Content-Type: image/png; name=phpmailer.png', $message, 'Name without special chars should not be quoted in Content-Type' ); self::assertStringContainsString( 'Content-Disposition: attachment; filename=phpmailer.png', $message, 'Filename without special chars should not be quoted in Content-Disposition' ); self::assertStringContainsString( 'Content-Type: image/png; name="PHPMailer card logo.png"', $message, 'Name with spaces should be quoted in Content-Type' ); self::assertStringContainsString( 'Content-Disposition: attachment; filename="PHPMailer card logo.png"', $message, 'Filename with spaces should be quoted in Content-Disposition' ); } /** * Simple HTML and multiple attachment test. */ public function testHTMLMultiAttachment() { $this->Mail->Body = 'This is the <strong>HTML</strong> part of the email.'; $this->Mail->Subject .= ': HTML + multiple Attachment'; $this->Mail->isHTML(true); if ( !$this->Mail->addAttachment( realpath(\PHPMAILER_INCLUDE_DIR . '/examples/images/phpmailer_mini.png'), 'phpmailer_mini.png' ) ) { self::assertTrue(false, $this->Mail->ErrorInfo); return; } if ( !$this->Mail->addAttachment( realpath(\PHPMAILER_INCLUDE_DIR . '/examples/images/phpmailer.png'), 'phpmailer.png' ) ) { self::assertTrue(false, $this->Mail->ErrorInfo); return; } $this->buildBody(); self::assertTrue($this->Mail->send(), $this->Mail->ErrorInfo); } /** * An embedded attachment test. */ public function testEmbeddedImage() { $this->Mail->msgHTML('<!DOCTYPE html> <html lang="en"> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> <title>E-Mail Inline Image Test</title> </head> <body> <p><img src=""></p> </body> </html>'); $this->Mail->preSend(); self::assertStringContainsString( 'Content-ID: <bb229a48bee31f5d54ca12dc9bd960c6@phpmailer.0>', $this->Mail->getSentMIMEMessage(), 'Embedded image header encoding incorrect.' ); } /** * An embedded attachment test. */ public function testMultiEmbeddedImage() { $this->Mail->Body = 'Embedded Image: <img alt="phpmailer" src="' . 'cid:my-attach">' . 'Here is an image!</a>'; $this->Mail->Subject .= ': Embedded Image + Attachment'; $this->Mail->isHTML(true); if ( !$this->Mail->addEmbeddedImage( realpath(\PHPMAILER_INCLUDE_DIR . '/examples/images/phpmailer.png'), 'my-attach', 'phpmailer.png', 'base64', 'image/png' ) ) { self::assertTrue(false, $this->Mail->ErrorInfo); return; } if (!$this->Mail->addAttachment(__FILE__, 'test.txt')) { self::assertTrue(false, $this->Mail->ErrorInfo); return; } $this->buildBody(); self::assertTrue($this->Mail->send(), $this->Mail->ErrorInfo); } /** * Simple multipart/alternative test. */ public function testAltBody() { $this->Mail->Body = 'This is the <strong>HTML</strong> part of the email.'; $this->Mail->AltBody = 'Here is the plain text body of this message. ' . 'It should be quite a few lines. It should be wrapped at ' . '40 characters. Make sure that it is.'; $this->Mail->WordWrap = 40; $this->addNote('This is a multipart/alternative email'); $this->Mail->Subject .= ': AltBody + Word Wrap'; $this->buildBody(); self::assertTrue($this->Mail->send(), $this->Mail->ErrorInfo); } /** * Simple HTML and attachment test. */ public function testAltBodyAttachment() { $this->Mail->Body = 'This is the <strong>HTML</strong> part of the email.'; $this->Mail->AltBody = 'This is the text part of the email.'; $this->Mail->Subject .= ': AltBody + Attachment'; $this->Mail->isHTML(true); if (!$this->Mail->addAttachment(__FILE__, 'test_attach.txt')) { self::assertTrue(false, $this->Mail->ErrorInfo); return; } //Test using non-existent UNC path self::assertFalse($this->Mail->addAttachment('\\\\nowhere\\nothing')); $this->buildBody(); self::assertTrue($this->Mail->send(), $this->Mail->ErrorInfo); } /** * Test sending multiple messages with separate connections. */ public function testMultipleSend() { $this->Mail->Body = 'Sending two messages without keepalive'; $this->buildBody(); $subject = $this->Mail->Subject; $this->Mail->Subject = $subject . ': SMTP 1'; self::assertTrue($this->Mail->send(), $this->Mail->ErrorInfo); $this->Mail->Subject = $subject . ': SMTP 2'; $this->Mail->Sender = 'blah@example.com'; self::assertTrue($this->Mail->send(), $this->Mail->ErrorInfo); } /** * Test sending an empty body. */ public function testEmptyBody() { $this->buildBody(); $this->Mail->Body = ''; $this->Mail->Subject = $this->Mail->Subject . ': Empty Body'; $this->Mail->isMail(); $this->Mail->AllowEmpty = true; self::assertTrue($this->Mail->send(), $this->Mail->ErrorInfo); $this->Mail->AllowEmpty = false; self::assertFalse($this->Mail->send(), $this->Mail->ErrorInfo); } /** * Test keepalive (sending multiple messages in a single connection). */ public function testSmtpKeepAlive() { $this->Mail->Body = 'SMTP keep-alive test.'; $this->buildBody(); $subject = $this->Mail->Subject; $this->Mail->SMTPKeepAlive = true; $this->Mail->Subject = $subject . ': SMTP keep-alive 1'; self::assertTrue($this->Mail->send(), $this->Mail->ErrorInfo); $this->Mail->Subject = $subject . ': SMTP keep-alive 2'; self::assertTrue($this->Mail->send(), $this->Mail->ErrorInfo); $this->Mail->smtpClose(); } /** * Test addressing. */ public function testAddressing() { self::assertFalse($this->Mail->addAddress(''), 'Empty address accepted'); self::assertFalse($this->Mail->addAddress('', 'Nobody'), 'Empty address with name accepted'); self::assertFalse($this->Mail->addAddress('a@example..com'), 'Invalid address accepted'); self::assertTrue($this->Mail->addAddress('a@example.com'), 'Addressing failed'); self::assertTrue($this->Mail->addAddress('nullname@example.com', null), 'Null name not ignored'); self::assertTrue( $this->Mail->addAddress('objectname@example.com', new \stdClass()), 'Object as name not ignored' ); self::assertTrue($this->Mail->addAddress('arrayname@example.com', [1,2,3]), 'Array as name not ignored'); self::assertFalse($this->Mail->addAddress('a@example.com'), 'Duplicate addressing failed'); self::assertTrue($this->Mail->addCC('b@example.com'), 'CC addressing failed'); self::assertFalse($this->Mail->addCC('b@example.com'), 'CC duplicate addressing failed'); self::assertFalse($this->Mail->addCC('a@example.com'), 'CC duplicate addressing failed (2)'); self::assertTrue($this->Mail->addBCC('c@example.com'), 'BCC addressing failed'); self::assertFalse($this->Mail->addBCC('c@example.com'), 'BCC duplicate addressing failed'); self::assertFalse($this->Mail->addBCC('a@example.com'), 'BCC duplicate addressing failed (2)'); $this->Mail->clearCCs(); $this->Mail->clearBCCs(); } /** * Test address escaping. */ public function testAddressEscaping() { $this->Mail->Subject .= ': Address escaping'; $this->Mail->clearAddresses(); $this->Mail->addAddress('foo@example.com', 'Tim "The Book" O\'Reilly'); $this->Mail->Body = 'Test correct escaping of quotes in addresses.'; $this->buildBody(); $this->Mail->preSend(); $b = $this->Mail->getSentMIMEMessage(); self::assertStringContainsString('To: "Tim \"The Book\" O\'Reilly" <foo@example.com>', $b); $this->Mail->Subject .= ': Address escaping invalid'; $this->Mail->clearAddresses(); $this->Mail->addAddress('foo@example.com', 'Tim "The Book" O\'Reilly'); $this->Mail->addAddress('invalidaddressexample.com', 'invalidaddress'); $this->Mail->Body = 'invalid address'; $this->buildBody(); $this->Mail->preSend(); self::assertSame('Invalid address: (to): invalidaddressexample.com', $this->Mail->ErrorInfo); $this->Mail->addAttachment( realpath(\PHPMAILER_INCLUDE_DIR . '/examples/images/phpmailer_mini.png'), 'phpmailer_mini.png' ); self::assertTrue($this->Mail->attachmentExists()); } /** * Test MIME structure assembly. */ public function testMIMEStructure() { $this->Mail->Subject .= ': MIME structure'; $this->Mail->Body = '<h3>MIME structure test.</h3>'; $this->Mail->AltBody = 'MIME structure test.'; $this->buildBody(); $this->Mail->preSend(); self::assertMatchesRegularExpression( "/Content-Transfer-Encoding: 8bit\r\n\r\n/", $this->Mail->getSentMIMEMessage(), 'MIME structure broken' ); } /** * Test BCC-only addressing. */ public function testBCCAddressing() { $this->Mail->isSMTP(); $this->Mail->Subject .= ': BCC-only addressing'; $this->buildBody(); $this->Mail->clearAllRecipients(); self::assertTrue($this->Mail->addBCC('a@example.com'), 'BCC addressing failed'); $this->Mail->preSend(); $b = $this->Mail->getSentMIMEMessage(); self::assertStringNotContainsString('a@example.com', $b); self::assertTrue($this->Mail->send(), 'send failed'); } /** * Expect exceptions on bad encoding */ public function testAddAttachmentEncodingException() { $this->expectException(Exception::class); $mail = new PHPMailer(true); $mail->addAttachment(__FILE__, 'test.txt', 'invalidencoding'); } /** * Expect errors on trying to attach a folder as an attachment */ public function testAddFolderAsAttachment() { $mail = new PHPMailer(); self::assertFalse($mail->addAttachment(__DIR__, 'test.txt')); $this->expectException(Exception::class); $mail = new PHPMailer(true); $mail->addAttachment(__DIR__, 'test.txt'); } /** * Expect exceptions on sending after deleting a previously successfully attached file */ public function testDeletedAttachmentException() { $this->expectException(Exception::class); $filename = __FILE__ . md5(microtime()) . 'test.txt'; touch($filename); $this->Mail = new PHPMailer(true); $this->Mail->addAttachment($filename); unlink($filename); $this->Mail->send(); } /** * Expect error on sending after deleting a previously successfully attached file */ public function testDeletedAttachmentError() { $filename = __FILE__ . md5(microtime()) . 'test.txt'; touch($filename); $this->Mail = new PHPMailer(); $this->Mail->addAttachment($filename); unlink($filename); self::assertFalse($this->Mail->send()); } /** * Test base-64 encoding. */ public function testBase64() { $this->Mail->Subject .= ': Base-64 encoding'; $this->Mail->Encoding = 'base64'; $this->buildBody(); self::assertTrue($this->Mail->send(), 'Base64 encoding failed'); } /** * S/MIME Signing tests (self-signed). * * @requires extension openssl */ public function testSigning() { $this->Mail->Subject .= ': S/MIME signing'; $this->Mail->Body = 'This message is S/MIME signed.'; $this->buildBody(); $dn = [ 'countryName' => 'UK', 'stateOrProvinceName' => 'Here', 'localityName' => 'There', 'organizationName' => 'PHP', 'organizationalUnitName' => 'PHPMailer', 'commonName' => 'PHPMailer Test', 'emailAddress' => 'phpmailer@example.com', ]; $keyconfig = [ 'digest_alg' => 'sha256', 'private_key_bits' => 2048, 'private_key_type' => OPENSSL_KEYTYPE_RSA, ]; $password = 'password'; $certfile = 'certfile.pem'; $keyfile = 'keyfile.pem'; //Make a new key pair $pk = openssl_pkey_new($keyconfig); //Create a certificate signing request $csr = openssl_csr_new($dn, $pk); //Create a self-signed cert $cert = openssl_csr_sign($csr, null, $pk, 1); //Save the cert openssl_x509_export($cert, $certout); file_put_contents($certfile, $certout); //Save the key openssl_pkey_export($pk, $pkeyout, $password); file_put_contents($keyfile, $pkeyout); $this->Mail->sign( $certfile, $keyfile, $password ); self::assertTrue($this->Mail->send(), 'S/MIME signing failed'); $msg = $this->Mail->getSentMIMEMessage(); self::assertStringNotContainsString("\r\n\r\nMIME-Version:", $msg, 'Incorrect MIME headers'); unlink($certfile); unlink($keyfile); } /** * S/MIME Signing tests using a CA chain cert. * To test that a generated message is signed correctly, save the message in a file called `signed.eml` * and use openssl along with the certs generated by this script: * `openssl smime -verify -in signed.eml -signer certfile.pem -CAfile cacertfile.pem`. * * @requires extension openssl */ public function testSigningWithCA() { $this->Mail->Subject .= ': S/MIME signing with CA'; $this->Mail->Body = 'This message is S/MIME signed with an extra CA cert.'; $this->buildBody(); $certprops = [ 'countryName' => 'UK', 'stateOrProvinceName' => 'Here', 'localityName' => 'There', 'organizationName' => 'PHP', 'organizationalUnitName' => 'PHPMailer', 'commonName' => 'PHPMailer Test', 'emailAddress' => 'phpmailer@example.com', ]; $cacertprops = [ 'countryName' => 'UK', 'stateOrProvinceName' => 'Here', 'localityName' => 'There', 'organizationName' => 'PHP', 'organizationalUnitName' => 'PHPMailer CA', 'commonName' => 'PHPMailer Test CA', 'emailAddress' => 'phpmailer@example.com', ]; $keyconfig = [ 'digest_alg' => 'sha256', 'private_key_bits' => 2048, 'private_key_type' => OPENSSL_KEYTYPE_RSA, ]; $password = 'password'; $cacertfile = 'cacertfile.pem'; $cakeyfile = 'cakeyfile.pem'; $certfile = 'certfile.pem'; $keyfile = 'keyfile.pem'; //Create a CA cert //Make a new key pair $capk = openssl_pkey_new($keyconfig); //Create a certificate signing request $csr = openssl_csr_new($cacertprops, $capk); //Create a self-signed cert $cert = openssl_csr_sign($csr, null, $capk, 1); //Save the CA cert openssl_x509_export($cert, $certout); file_put_contents($cacertfile, $certout); //Save the CA key openssl_pkey_export($capk, $pkeyout, $password); file_put_contents($cakeyfile, $pkeyout); //Create a cert signed by our CA //Make a new key pair $pk = openssl_pkey_new($keyconfig); //Create a certificate signing request $csr = openssl_csr_new($certprops, $pk); //Create a self-signed cert $cacert = file_get_contents($cacertfile); $cert = openssl_csr_sign($csr, $cacert, $capk, 1); //Save the cert openssl_x509_export($cert, $certout); file_put_contents($certfile, $certout); //Save the key openssl_pkey_export($pk, $pkeyout, $password); file_put_contents($keyfile, $pkeyout); $this->Mail->sign( $certfile, $keyfile, $password, $cacertfile ); self::assertTrue($this->Mail->send(), 'S/MIME signing with CA failed'); unlink($cacertfile); unlink($cakeyfile); unlink($certfile); unlink($keyfile); } /** * Test line break reformatting. */ public function testLineBreaks() { //May have been altered by earlier tests, can interfere with line break format $this->Mail->isSMTP(); $this->Mail->preSend(); //To see accurate results when using postfix, set `sendmail_fix_line_endings = never` in main.cf $this->Mail->Subject = 'PHPMailer DOS line breaks'; $this->Mail->Body = "This message\r\ncontains\r\nDOS-format\r\nCRLF line breaks."; self::assertTrue($this->Mail->send()); $this->Mail->Subject = 'PHPMailer UNIX line breaks'; $this->Mail->Body = "This message\ncontains\nUNIX-format\nLF line breaks."; self::assertTrue($this->Mail->send()); $this->Mail->Encoding = 'quoted-printable'; $this->Mail->Subject = 'PHPMailer DOS line breaks, QP'; $this->Mail->Body = "This message\r\ncontains\r\nDOS-format\r\nCRLF line breaks."; self::assertTrue($this->Mail->send()); $this->Mail->Subject = 'PHPMailer UNIX line breaks, QP'; $this->Mail->Body = "This message\ncontains\nUNIX-format\nLF line breaks."; self::assertTrue($this->Mail->send()); } /** * Miscellaneous calls to improve test coverage and some small tests. */ public function testMiscellaneous() { $this->Mail->clearAttachments(); $this->Mail->isHTML(false); $this->Mail->isSMTP(); $this->Mail->isMail(); $this->Mail->isSendmail(); $this->Mail->isQmail(); $this->Mail->Sender = ''; self::assertEmpty($this->Mail->Sender); $this->Mail->createHeader(); } public function testBadSMTP() { $this->Mail->smtpConnect(); $smtp = $this->Mail->getSMTPInstance(); self::assertFalse($smtp->mail("somewhere\nbad"), 'Bad SMTP command containing breaks accepted'); } /** * Tests setting and retrieving ConfirmReadingTo address, also known as "read receipt" address. */ public function testConfirmReadingTo() { $this->Mail->CharSet = PHPMailer::CHARSET_UTF8; $this->buildBody(); $this->Mail->ConfirmReadingTo = 'test@example..com'; //Invalid address self::assertFalse($this->Mail->send(), $this->Mail->ErrorInfo); $this->Mail->ConfirmReadingTo = ' test@example.com'; //Extra space to trim self::assertTrue($this->Mail->send(), $this->Mail->ErrorInfo); self::assertSame( 'test@example.com', $this->Mail->ConfirmReadingTo, 'Unexpected read receipt address' ); $letter = html_entity_decode('ç', ENT_COMPAT, PHPMailer::CHARSET_UTF8); $this->Mail->ConfirmReadingTo = 'test@fran' . $letter . 'ois.ch'; //Address with IDN if (PHPMailer::idnSupported()) { self::assertTrue($this->Mail->send(), $this->Mail->ErrorInfo); self::assertSame( 'test@xn--franois-xxa.ch', $this->Mail->ConfirmReadingTo, 'IDN address not converted to punycode' ); } else { self::assertFalse($this->Mail->send(), $this->Mail->ErrorInfo); } } /** * Tests CharSet and Unicode -> ASCII conversions for addresses with IDN. */ public function testConvertEncoding() { if (!PHPMailer::idnSupported()) { self::markTestSkipped('intl and/or mbstring extensions are not available'); } $this->Mail->clearAllRecipients(); //This file is UTF-8 encoded. Create a domain encoded in "iso-8859-1". $letter = html_entity_decode('ç', ENT_COMPAT, PHPMailer::CHARSET_ISO88591); $domain = '@' . 'fran' . $letter . 'ois.ch'; $this->Mail->addAddress('test' . $domain); $this->Mail->addCC('test+cc' . $domain); $this->Mail->addBCC('test+bcc' . $domain); //Queued addresses are not returned by get*Addresses() before send() call. self::assertEmpty($this->Mail->getToAddresses(), 'Bad "to" recipients'); self::assertEmpty($this->Mail->getCcAddresses(), 'Bad "cc" recipients'); self::assertEmpty($this->Mail->getBccAddresses(), 'Bad "bcc" recipients'); //Clear queued BCC recipient. $this->Mail->clearBCCs(); $this->buildBody(); self::assertTrue($this->Mail->send(), $this->Mail->ErrorInfo); //Addresses with IDN are returned by get*Addresses() after send() call. $domain = $this->Mail->punyencodeAddress($domain); self::assertSame( [['test' . $domain, '']], $this->Mail->getToAddresses(), 'Bad "to" recipients' ); self::assertSame( [['test+cc' . $domain, '']], $this->Mail->getCcAddresses(), 'Bad "cc" recipients' ); self::assertEmpty($this->Mail->getBccAddresses(), 'Bad "bcc" recipients'); } /** * Tests removal of duplicate recipients and reply-tos. */ public function testDuplicateIDNRemoved() { if (!PHPMailer::idnSupported()) { self::markTestSkipped('intl and/or mbstring extensions are not available'); } $this->Mail->clearAllRecipients(); $this->Mail->CharSet = PHPMailer::CHARSET_UTF8; self::assertTrue($this->Mail->addAddress('test@françois.ch')); self::assertFalse($this->Mail->addAddress('test@françois.ch')); self::assertTrue($this->Mail->addAddress('test@FRANÇOIS.CH')); self::assertFalse($this->Mail->addAddress('test@FRANÇOIS.CH')); self::assertTrue($this->Mail->addAddress('test@xn--franois-xxa.ch')); self::assertFalse($this->Mail->addAddress('test@xn--franois-xxa.ch')); self::assertFalse($this->Mail->addAddress('test@XN--FRANOIS-XXA.CH')); $this->buildBody(); self::assertTrue($this->Mail->send(), $this->Mail->ErrorInfo); //There should be only one "To" address and one "Reply-To" address. self::assertCount( 1, $this->Mail->getToAddresses(), 'Bad count of "to" recipients' ); } /** * Test SMTP Xclient options */ public function testSmtpXclient() { $this->Mail->isSMTP(); $this->Mail->SMTPAuth = false; $this->Mail->setSMTPXclientAttribute('ADDR', '127.0.0.1'); $this->Mail->setSMTPXclientAttribute('LOGIN', 'user@example.com'); $this->Mail->setSMTPXclientAttribute('HELO', 'test.example.com'); $this->assertFalse($this->Mail->setSMTPXclientAttribute('INVALID', 'value')); $attributes = $this->Mail->getSMTPXclientAttributes(); $this->assertEquals('test.example.com', $attributes['HELO']); // remove attribute $this->Mail->setSMTPXclientAttribute('HELO', null); $attributes = $this->Mail->getSMTPXclientAttributes(); $this->assertEquals(['ADDR' => '127.0.0.1', 'LOGIN' => 'user@example.com'], $attributes); $this->Mail->Subject .= ': Testing XCLIENT'; $this->buildBody(); $this->Mail->clearAllRecipients(); self::assertTrue($this->Mail->addAddress('a@example.com'), 'Addressing failed'); $this->Mail->preSend(); self::assertTrue($this->Mail->send(), 'send failed'); } /** * Test SMTP host connections. * This test can take a long time, so run it last. * * @group slow */ public function testSmtpConnect() { $this->Mail->SMTPDebug = SMTP::DEBUG_LOWLEVEL; //Show connection-level errors self::assertTrue($this->Mail->smtpConnect(), 'SMTP single connect failed'); $this->Mail->smtpClose(); //$this->Mail->Host = 'localhost:12345;10.10.10.10:54321;' . $_REQUEST['mail_host']; //self::assertTrue($this->Mail->smtpConnect(), 'SMTP multi-connect failed'); //$this->Mail->smtpClose(); //$this->Mail->Host = '[::1]:' . $this->Mail->Port . ';' . $_REQUEST['mail_host']; //self::assertTrue($this->Mail->smtpConnect(), 'SMTP IPv6 literal multi-connect failed'); //$this->Mail->smtpClose(); //All these hosts are expected to fail //$this->Mail->Host = 'xyz://bogus:25;tls://[bogus]:25;ssl://localhost:12345; //tls://localhost:587;10.10.10.10:54321;localhost:12345;10.10.10.10'. $_REQUEST['mail_host'].' '; //self::assertFalse($this->Mail->smtpConnect()); //$this->Mail->smtpClose(); $this->Mail->Host = ' localhost:12345 ; ' . $_REQUEST['mail_host'] . ' '; self::assertTrue($this->Mail->smtpConnect(), 'SMTP hosts with stray spaces failed'); $this->Mail->smtpClose(); //Need to pick a harmless option so as not cause problems of its own! socket:bind doesn't work with Travis-CI $this->Mail->Host = $_REQUEST['mail_host']; self::assertTrue($this->Mail->smtpConnect(['ssl' => ['verify_depth' => 10]])); $this->Smtp = $this->Mail->getSMTPInstance(); self::assertInstanceOf(\get_class($this->Smtp), $this->Mail->setSMTPInstance($this->Smtp)); $this->Mail->smtpClose(); } public function testGivenIdnAddress_addAddress_returns_true() { if (file_exists(\PHPMAILER_INCLUDE_DIR . '/test/fakefunctions.php') === false) { $this->markTestSkipped('/test/fakefunctions.php file not found'); } include \PHPMAILER_INCLUDE_DIR . '/test/fakefunctions.php'; $this->assertTrue($this->Mail->addAddress('test@françois.ch')); } public function testErroneousAddress_addAddress_returns_false() { $this->assertFalse($this->Mail->addAddress('mehome.com')); } }