-
Notifications
You must be signed in to change notification settings - Fork 101
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
CANTINA-953: Add
vip_block_wp_mail
filter (#4975)
* Add vip_block_wp_mail filter * Adds tests Add tests * PHP 8.2 fix for dynamic property PHP 8.2 fix for dynamic property
- Loading branch information
1 parent
09fffbe
commit d6f7a34
Showing
3 changed files
with
137 additions
and
5 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,19 +1,28 @@ | ||
<?php | ||
namespace Automattic\VIP\Mail; | ||
|
||
use PHPMailer\PHPMailer\PHPMailer; | ||
use Automattic\Test\Constant_Mocker; | ||
|
||
// phpcs:disable WordPress.NamingConventions.ValidVariableName.UsedPropertyNotSnakeCase -- PHPMailer does not follow the conventions | ||
// phpcs:disable WordPressVIPMinimum.Functions.RestrictedFunctions.wp_mail_wp_mail -- we are testing it | ||
|
||
class VIP_Mail_Test extends WP_UnitTestCase { | ||
class VIP_Mail_Test extends \WP_UnitTestCase { | ||
public function setUp(): void { | ||
parent::setUp(); | ||
reset_phpmailer_instance(); | ||
if ( ! defined( 'USE_VIP_PHPMAILER' ) ) { | ||
define( 'USE_VIP_PHPMAILER', true ); | ||
if ( ! Constant_Mocker::defined( 'USE_VIP_PHPMAILER' ) ) { | ||
Constant_Mocker::define( 'USE_VIP_PHPMAILER', true ); | ||
} | ||
} | ||
|
||
public function tearDown(): void { | ||
parent::tearDown(); | ||
|
||
Constant_Mocker::clear(); | ||
remove_all_filters( 'vip_block_wp_mail' ); | ||
} | ||
|
||
public function test__all_smtp_servers__not_array() { | ||
$GLOBALS['all_smtp_servers'] = false; | ||
|
||
|
@@ -67,7 +76,7 @@ public function test__has_tracking_header_with_key() { | |
} | ||
|
||
public function test_load_VIP_PHPMailer() { | ||
$this->assertTrue( class_exists( 'VIP_PHPMailer', false ) ); | ||
$this->assertTrue( class_exists( '\Automattic\VIP\Mail\VIP_PHPMailer', false ) ); | ||
} | ||
|
||
/** | ||
|
@@ -132,4 +141,94 @@ public function test_filter_removal(): void { | |
|
||
self::assertEquals( $expected, $actual ); | ||
} | ||
|
||
public function test_noop_mailer__filter_only() { | ||
set_error_handler( // phpcs:ignore WordPress.PHP.DevelopmentFunctions.error_log_set_error_handler | ||
static function ( $errno, $errstr ) { | ||
restore_error_handler(); | ||
throw new \Exception( $errstr, $errno ); // phpcs:ignore WordPress.Security.EscapeOutput.ExceptionNotEscaped | ||
}, | ||
E_ALL | ||
); | ||
|
||
add_filter( 'vip_block_wp_mail', '__return_true' ); | ||
|
||
$this->expectException( \Exception::class ); | ||
$this->expectExceptionMessage( 'VIP_Noop_Mailer::send: skipped sending email with subject `Test` to [email protected]' ); | ||
|
||
wp_mail( '[email protected]', 'Test', 'Should not be sent' ); | ||
|
||
restore_error_handler(); | ||
} | ||
|
||
public function test_noop_mailer__constant_true_filter_false() { | ||
set_error_handler( // phpcs:ignore WordPress.PHP.DevelopmentFunctions.error_log_set_error_handler | ||
static function ( $errno, $errstr ) { | ||
restore_error_handler(); | ||
throw new \Exception( $errstr, $errno ); // phpcs:ignore WordPress.Security.EscapeOutput.ExceptionNotEscaped | ||
}, | ||
E_ALL | ||
); | ||
|
||
Constant_Mocker::define( 'VIP_BLOCK_WP_MAIL', true ); | ||
add_filter( 'vip_block_wp_mail', '__return_false' ); | ||
|
||
$this->expectException( \Exception::class ); | ||
$this->expectExceptionMessage( 'VIP_Noop_Mailer::send: skipped sending email with subject `Test` to [email protected]' ); | ||
|
||
wp_mail( '[email protected]', 'Test', 'Should not be sent' ); | ||
|
||
restore_error_handler(); | ||
} | ||
|
||
public function test_noop_mailer__constant_only() { | ||
set_error_handler( // phpcs:ignore WordPress.PHP.DevelopmentFunctions.error_log_set_error_handler | ||
static function ( $errno, $errstr ) { | ||
restore_error_handler(); | ||
throw new \Exception( $errstr, $errno ); // phpcs:ignore WordPress.Security.EscapeOutput.ExceptionNotEscaped | ||
}, | ||
E_ALL | ||
); | ||
|
||
Constant_Mocker::define( 'VIP_BLOCK_WP_MAIL', true ); | ||
|
||
$this->expectException( \Exception::class ); | ||
$this->expectExceptionMessage( 'VIP_Noop_Mailer::send: skipped sending email with subject `Test` to [email protected]' ); | ||
|
||
wp_mail( '[email protected]', 'Test', 'Should not be sent' ); | ||
|
||
restore_error_handler(); | ||
} | ||
|
||
public function test_noop_mailer__constant_and_filter_false() { | ||
Constant_Mocker::define( 'VIP_BLOCK_WP_MAIL', false ); | ||
add_filter( 'vip_block_wp_mail', '__return_false' ); | ||
|
||
$body = 'Testing should send'; | ||
wp_mail( '[email protected]', 'Test', $body ); | ||
|
||
$mailer = tests_retrieve_phpmailer_instance(); | ||
|
||
$this->assertEquals( $body, $mailer->Body ); | ||
} | ||
|
||
public function test_noop_mailer__constant_false_filter_true() { | ||
set_error_handler( // phpcs:ignore WordPress.PHP.DevelopmentFunctions.error_log_set_error_handler | ||
static function ( $errno, $errstr ) { | ||
restore_error_handler(); | ||
throw new \Exception( $errstr, $errno ); // phpcs:ignore WordPress.Security.EscapeOutput.ExceptionNotEscaped | ||
}, | ||
E_ALL | ||
); | ||
|
||
Constant_Mocker::define( 'VIP_BLOCK_WP_MAIL', false ); | ||
add_filter( 'vip_block_wp_mail', '__return_true' ); | ||
|
||
$this->expectException( \Exception::class ); | ||
$this->expectExceptionMessage( 'VIP_Noop_Mailer::send: skipped sending email with subject `Test` to [email protected]' ); | ||
|
||
wp_mail( '[email protected]', 'Test', 'Should not be sent' ); | ||
|
||
restore_error_handler(); | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters