diff --git a/.github/workflows/test.yml b/.github/workflows/test.yml index d9f3b4785..9cecbe07c 100644 --- a/.github/workflows/test.yml +++ b/.github/workflows/test.yml @@ -1,69 +1,69 @@ name: Unit/Integration tests on: - pull_request: - branches: - - trunk - - develop - - branch-* + pull_request: + branches: + - trunk + - develop + - branch-* jobs: - run: - runs-on: ${{ matrix.operating-system }} + run: + runs-on: ${{ matrix.operating-system }} - strategy: - fail-fast: false - matrix: - operating-system: [ubuntu-latest] - php-versions: ['7.4'] - wp-versions: ['latest'] + strategy: + fail-fast: false + matrix: + operating-system: [ubuntu-latest] + php-versions: ['8.0', '8.1', '8.2'] + wp-versions: ['latest'] - name: WP ${{ matrix.wp-versions }} with PHP ${{ matrix.php-versions }} on ${{ matrix.operating-system }}. + name: WP ${{ matrix.wp-versions }} with PHP ${{ matrix.php-versions }} on ${{ matrix.operating-system }}. - env: - WP_TESTS_DIR: "/tmp/tests/phpunit" - WP_CORE_DIR: "/tmp/wordpress-develop" - IMAGIFY_TESTS_API_KEY: ${{ secrets.IMAGIFY_TESTS_API_KEY }} + env: + WP_TESTS_DIR: "/tmp/tests/phpunit" + WP_CORE_DIR: "/tmp/wordpress-develop" + IMAGIFY_TESTS_API_KEY: ${{ secrets.IMAGIFY_TESTS_API_KEY }} - steps: - - name: Checkout - uses: actions/checkout@v2 + steps: + - name: Checkout + uses: actions/checkout@v2 - - name: Setup PHP - uses: shivammathur/setup-php@v2 - with: - php-version: ${{ matrix.php-versions }} - coverage: none # XDebug can be enabled here 'coverage: xdebug' - tools: composer:v2, phpunit + - name: Setup PHP + uses: shivammathur/setup-php@v2 + with: + php-version: ${{ matrix.php-versions }} + coverage: none # XDebug can be enabled here 'coverage: xdebug' + tools: composer:v2, phpunit - - name: Start mysql service - run: sudo /etc/init.d/mysql start + - name: Start mysql service + run: sudo /etc/init.d/mysql start - - name: Setup problem matchers for PHP - run: echo "::add-matcher::${{ runner.tool_cache }}/php.json" + - name: Setup problem matchers for PHP + run: echo "::add-matcher::${{ runner.tool_cache }}/php.json" - - name: Setup problem matchers for PHPUnit - run: echo "::add-matcher::${{ runner.tool_cache }}/phpunit.json" + - name: Setup problem matchers for PHPUnit + run: echo "::add-matcher::${{ runner.tool_cache }}/phpunit.json" - - name: Get composer cache directory - id: composercache - run: echo "::set-output name=dir::$(composer config cache-files-dir)" + - name: Get composer cache directory + id: composercache + run: echo "::set-output name=dir::$(composer config cache-files-dir)" - - name: Cache dependencies - uses: actions/cache@v2 - with: - path: ${{ steps.composercache.outputs.dir }} - key: ${{ runner.os }}-composer-${{ hashFiles('**/composer.json') }} - restore-keys: ${{ runner.os }}-composer- + - name: Cache dependencies + uses: actions/cache@v2 + with: + path: ${{ steps.composercache.outputs.dir }} + key: ${{ runner.os }}-composer-${{ hashFiles('**/composer.json') }} + restore-keys: ${{ runner.os }}-composer- - - name: Install dependencies - run: composer install --prefer-dist --no-interaction --no-scripts + - name: Install dependencies + run: composer install --prefer-dist --no-interaction --no-scripts --ignore-platform-reqs - - name: Install tests - run: bash bin/install-wp-tests.sh wordpress_test root root 127.0.0.1:3306 ${{ matrix.wp-versions }} + - name: Install tests + run: bash bin/install-wp-tests.sh wordpress_test root root 127.0.0.1:3306 ${{ matrix.wp-versions }} - - name: Mysql8 auth plugin workaround - run: sudo mysql -u root -proot -e "ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY 'root';" + - name: Mysql8 auth plugin workaround + run: sudo mysql -u root -proot -e "ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY 'root';" - - name: Test - run: composer run-tests + - name: Test + run: composer run-tests diff --git a/.github/workflows/test_plugin_legacy.yml b/.github/workflows/test_legacy.yml similarity index 64% rename from .github/workflows/test_plugin_legacy.yml rename to .github/workflows/test_legacy.yml index a7ac21013..f654fa4a9 100644 --- a/.github/workflows/test_plugin_legacy.yml +++ b/.github/workflows/test_legacy.yml @@ -15,7 +15,7 @@ jobs: fail-fast: false matrix: operating-system: [ubuntu-latest] - php-versions: ['7.3'] + php-versions: ['7.3', '7.4'] wp-versions: ['5.3'] name: WP ${{ matrix.wp-versions }} with PHP ${{ matrix.php-versions }} on ${{ matrix.operating-system }}. @@ -27,7 +27,7 @@ jobs: steps: - name: Checkout - uses: actions/checkout@v2 + uses: actions/checkout@v4 - name: Setup PHP uses: shivammathur/setup-php@v2 @@ -35,11 +35,28 @@ jobs: php-version: ${{ matrix.php-versions }} extensions: mysqli coverage: none # XDebug can be enabled here 'coverage: xdebug' - tools: composer:v2 + tools: composer:v2, phpunit - name: Start mysql service run: sudo /etc/init.d/mysql start + - name: Setup problem matchers for PHP + run: echo "::add-matcher::${{ runner.tool_cache }}/php.json" + + - name: Setup problem matchers for PHPUnit + run: echo "::add-matcher::${{ runner.tool_cache }}/phpunit.json" + + - name: Get composer cache directory + id: composercache + run: echo "::set-output name=dir::$(composer config cache-files-dir)" + + - name: Cache dependencies + uses: actions/cache@v4 + with: + path: ${{ steps.composercache.outputs.dir }} + key: ${{ runner.os }}-composer-${{ hashFiles('**/composer.json') }} + restore-keys: ${{ runner.os }}-composer- + - name: Mysql8 auth plugin workaround run: sudo mysql -u root -proot -e "ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY 'root';" @@ -49,8 +66,8 @@ jobs: - name: Setup problem matchers for PHPUnit run: echo "::add-matcher::${{ runner.tool_cache }}/phpunit.json" - - name: Remove unmet dependencies by legacy versions - run: composer remove --dev --no-scripts coenjacobs/mozart + - name: Require PHPUnit 7.5 for WP compatibility + run: composer require --dev --no-scripts phpunit/phpunit "^7.5" -W - name: Install dependencies run: composer install --prefer-dist --no-interaction --no-scripts diff --git a/.github/workflows/test_php8.yml b/.github/workflows/test_php8.yml deleted file mode 100644 index cf2e5c4d6..000000000 --- a/.github/workflows/test_php8.yml +++ /dev/null @@ -1,69 +0,0 @@ -name: Unit/Integration tests for PHP 8 - -on: - pull_request: - branches: - - trunk - - develop - - branch-* - -jobs: - run: - runs-on: ${{ matrix.operating-system }} - - strategy: - fail-fast: false - matrix: - operating-system: [ubuntu-latest] - php-versions: ['8.0'] - wp-versions: ['latest'] - - name: WP ${{ matrix.wp-versions }} with PHP ${{ matrix.php-versions }} on ${{ matrix.operating-system }}. - - env: - WP_TESTS_DIR: "/tmp/tests/phpunit" - WP_CORE_DIR: "/tmp/wordpress-develop" - IMAGIFY_TESTS_API_KEY: ${{ secrets.IMAGIFY_TESTS_API_KEY }} - - steps: - - name: Checkout - uses: actions/checkout@v2 - - - name: Setup PHP - uses: shivammathur/setup-php@v2 - with: - php-version: ${{ matrix.php-versions }} - coverage: none # XDebug can be enabled here 'coverage: xdebug' - tools: composer:v2, phpunit - - - name: Start mysql service - run: sudo /etc/init.d/mysql start - - - name: Setup problem matchers for PHP - run: echo "::add-matcher::${{ runner.tool_cache }}/php.json" - - - name: Setup problem matchers for PHPUnit - run: echo "::add-matcher::${{ runner.tool_cache }}/phpunit.json" - - - name: Get composer cache directory - id: composercache - run: echo "::set-output name=dir::$(composer config cache-files-dir)" - - - name: Cache dependencies - uses: actions/cache@v2 - with: - path: ${{ steps.composercache.outputs.dir }} - key: ${{ runner.os }}-composer-${{ hashFiles('**/composer.json') }} - restore-keys: ${{ runner.os }}-composer- - - - name: Install dependencies - run: composer install --prefer-dist --no-interaction --no-scripts --ignore-platform-reqs - - - name: Install tests - run: bash bin/install-wp-tests.sh wordpress_test root root 127.0.0.1:3306 ${{ matrix.wp-versions }} - - - name: Mysql8 auth plugin workaround - run: sudo mysql -u root -proot -e "ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY 'root';" - - - name: Test - run: composer run-tests diff --git a/.gitignore b/.gitignore index 66154b4bf..14c615832 100644 --- a/.gitignore +++ b/.gitignore @@ -8,3 +8,4 @@ composer.lock package-lock.json /_dev/node_modules +.phpunit.result.cache diff --git a/Tests/Integration/TestCase.php b/Tests/Integration/TestCase.php index 20203e7c9..be55aed71 100644 --- a/Tests/Integration/TestCase.php +++ b/Tests/Integration/TestCase.php @@ -2,26 +2,27 @@ namespace Imagify\Tests\Integration; -use Brain\Monkey; use Imagify; -use Imagify\Tests\TestCaseTrait; +use ReflectionObject; use WPMedia\PHPUnit\Integration\TestCase as BaseTestCase; abstract class TestCase extends BaseTestCase { - use TestCaseTrait; - protected $useApi = true; protected $api_credentials_config_file = 'imagify-api.php'; protected $invalidApiKey = '1234567890abcdefghijklmnopqrstuvwxyz'; protected $originalImagifyInstance; protected $originalApiKeyOption; + protected $config; /** * Prepares the test environment before each test. */ - public function setUp() { - parent::setUp(); - Monkey\setUp(); + public function set_up() { + parent::set_up(); + + if ( empty( $this->config ) ) { + $this->loadTestDataConfig(); + } if ( ! $this->useApi ) { return; @@ -35,9 +36,8 @@ public function setUp() { /** * Cleans up the test environment after each test. */ - public function tearDown() { - Monkey\tearDown(); - parent::tearDown(); + public function tear_down() { + parent::tear_down(); if ( ! $this->useApi ) { return; @@ -48,6 +48,23 @@ public function tearDown() { update_imagify_option( 'api_key', $this->originalApiKeyOption ); } + public function configTestData() { + if ( empty( $this->config ) ) { + $this->loadTestDataConfig(); + } + + return isset( $this->config['test_data'] ) + ? $this->config['test_data'] + : $this->config; + } + + protected function loadTestDataConfig() { + $obj = new ReflectionObject( $this ); + $filename = $obj->getFileName(); + + $this->config = $this->getTestData( dirname( $filename ), basename( $filename, '.php' ) ); + } + /** * Gets the credential's value from either an environment variable (stored locally on the machine or CI) or from a * local constant defined in `tests/env/local/imagify-api.php`. @@ -86,4 +103,59 @@ protected function getApiCredential( $name ) { return constant( $name ); } + + /** + * Set the singleton's `$instance` property to the given instance. + * + * @param string $class Name of the target class. + * @param mixed $instance Instance of the target object. + * + * @return mixed Previous value. + * @throws ReflectionException Throws an exception if property does not exist. + * + */ + protected function setSingletonInstance( $class, $instance ) { + return $this->setPropertyValue( 'instance', $class, $instance ); + } + + /** + * Set the value of a private/protected property. + * + * @param string $property Property name for which to gain access. + * @param string|object $class Class name for a static property, or instance for an instance property. + * @param mixed $value The value to set to the property. + * + * @return mixed The previous value of the property. + * @throws ReflectionException Throws an exception if property does not exist. + * + */ + protected function setPropertyValue( $property, $class, $value ) { + $ref = $this->get_reflective_property( $property, $class ); + + if ( is_object( $class ) ) { + $previous = $ref->getValue( $class ); + // Instance property. + $ref->setValue( $class, $value ); + } else { + $previous = $ref->getValue(); + // Static property. + $ref->setValue( $value ); + } + + return $previous; + } + + /** + * Reset the value of a private/protected property. + * + * @param string $property Property name for which to gain access. + * @param string|object $class Class name for a static property, or instance for an instance property. + * + * @return mixed The previous value of the property. + * @throws ReflectionException Throws an exception if property does not exist. + * + */ + protected function resetPropertyValue( $property, $class ) { + return $this->setPropertyValue( $property, $class, null ); + } } diff --git a/Tests/Integration/bootstrap.php b/Tests/Integration/bootstrap.php index 9c6d7749b..1a464f09f 100644 --- a/Tests/Integration/bootstrap.php +++ b/Tests/Integration/bootstrap.php @@ -7,58 +7,14 @@ namespace Imagify\Tests\Integration; -use function Imagify\Tests\init_test_suite; -require_once dirname( dirname( __FILE__ ) ) . '/bootstrap-functions.php'; -init_test_suite( 'Integration' ); +define( 'IMAGIFY_PLUGIN_ROOT', dirname( dirname( __DIR__ ) ) . DIRECTORY_SEPARATOR ); -/** - * Get the WordPress' tests suite directory. - * - * @return string Returns The directory path to the WordPress testing environment. - */ -function get_wp_tests_dir() { - $tests_dir = getenv( 'WP_TESTS_DIR' ); - - // Travis CI & Vagrant SSH tests directory. - if ( empty( $tests_dir ) ) { - $tests_dir = '/tmp/wordpress-tests-lib'; - } - - // If the tests' includes directory does not exist, try a relative path to Core tests directory. - if ( ! file_exists( $tests_dir . '/includes/' ) ) { - $tests_dir = '../../../../tests/phpunit'; - } - - // Check it again. If it doesn't exist, stop here and post a message as to why we stopped. - if ( ! file_exists( $tests_dir . '/includes/' ) ) { - trigger_error( 'Unable to run the integration tests, because the WordPress test suite could not be located.', E_USER_ERROR ); // phpcs:ignore WordPress.PHP.DevelopmentFunctions.error_log_trigger_error -- Valid use case for our testing suite. +// Manually load the plugin being tested. +tests_add_filter( + 'muplugins_loaded', + function() { + // Load the plugin. + require IMAGIFY_PLUGIN_ROOT . '/imagify.php'; } - - // Strip off the trailing directory separator, if it exists. - return rtrim( $tests_dir, DIRECTORY_SEPARATOR ); -} - -/** - * Bootstraps the integration testing environment with WordPress and Imagify. - * - * @param string $wp_tests_dir The directory path to the WordPress testing environment. - */ -function bootstrap_integration_suite( $wp_tests_dir ) { - // Give access to tests_add_filter() function. - require_once $wp_tests_dir . '/includes/functions.php'; - - // Manually load the plugin being tested. - tests_add_filter( - 'muplugins_loaded', - function() { - // Load the plugin. - require IMAGIFY_PLUGIN_ROOT . '/imagify.php'; - } - ); - - // Start up the WP testing environment. - require_once $wp_tests_dir . '/includes/bootstrap.php'; -} - -bootstrap_integration_suite( get_wp_tests_dir() ); +); diff --git a/Tests/Integration/inc/classes/ImagifySettings/updateSiteOptionOnNetwork.php b/Tests/Integration/inc/classes/ImagifySettings/updateSiteOptionOnNetwork.php index 645d92f89..cd825d1ee 100644 --- a/Tests/Integration/inc/classes/ImagifySettings/updateSiteOptionOnNetwork.php +++ b/Tests/Integration/inc/classes/ImagifySettings/updateSiteOptionOnNetwork.php @@ -1,4 +1,5 @@ getTestData( __DIR__, 'updateSiteOptionOnNetwork' ); + return parent::tear_down(); } /** - * @dataProvider provideData + * @dataProvider configTestData */ public function testShouldUpdateNetworkSettings( $config, $expected ) { $_POST['option_page'] = $config['option_page']; diff --git a/Tests/Integration/inc/classes/ImagifyUser/TestCase.php b/Tests/Integration/inc/classes/ImagifyUser/TestCase.php index 79c1a9a57..0e2685154 100644 --- a/Tests/Integration/inc/classes/ImagifyUser/TestCase.php +++ b/Tests/Integration/inc/classes/ImagifyUser/TestCase.php @@ -8,8 +8,8 @@ abstract class TestCase extends BaseTestCase { protected $originalUserInstance; - public function setUp() { - parent::setUp(); + public function set_up() { + parent::set_up(); $this->originalUserInstance = $this->resetPropertyValue( 'user', Imagify::class ); @@ -17,8 +17,8 @@ public function setUp() { delete_transient('imagify_user_cache'); } - public function tearDown() { - parent::tearDown(); + public function tear_down() { + parent::tear_down(); // Restore the user on the static property. $this->setPropertyValue( 'user', Imagify::class, $this->originalUserInstance ); diff --git a/Tests/Integration/inc/classes/ImagifyUser/getError.php b/Tests/Integration/inc/classes/ImagifyUser/getError.php index aade75abc..9c0078f23 100644 --- a/Tests/Integration/inc/classes/ImagifyUser/getError.php +++ b/Tests/Integration/inc/classes/ImagifyUser/getError.php @@ -46,6 +46,6 @@ public function testShouldReturnErrorWhenCouldNotFetchUserData() { $user_data = $this->getNonPublicPropertyValue( 'user', Imagify::class ); $this->assertInstanceOf( WP_Error::class, $user_data ); - $this->assertContains( 'Invalid token', $user_data->get_error_message() ); + $this->assertStringContainsString( 'Invalid token', $user_data->get_error_message() ); } } diff --git a/Tests/Integration/inc/classes/ImagifyUser/getPercentConsumedQuota.php b/Tests/Integration/inc/classes/ImagifyUser/getPercentConsumedQuota.php index c17400be8..76607c4d4 100644 --- a/Tests/Integration/inc/classes/ImagifyUser/getPercentConsumedQuota.php +++ b/Tests/Integration/inc/classes/ImagifyUser/getPercentConsumedQuota.php @@ -14,14 +14,14 @@ class Test_GetPercentConsumedQuota extends TestCase { private $originalPreviousQuotaOption; - public function setUp() { - parent::setUp(); + public function set_up() { + parent::set_up(); $this->originalPreviousQuotaOption = get_imagify_option( 'previous_quota_percent' ); } - public function tearDown() { - parent::tearDown(); + public function tear_down() { + parent::tear_down(); // Restore the original option. update_imagify_option( 'previous_quota_percent', $this->originalPreviousQuotaOption ); diff --git a/Tests/Integration/inc/classes/ImagifyUser/isOverQuota.php b/Tests/Integration/inc/classes/ImagifyUser/isOverQuota.php index d8f030843..f772aecce 100644 --- a/Tests/Integration/inc/classes/ImagifyUser/isOverQuota.php +++ b/Tests/Integration/inc/classes/ImagifyUser/isOverQuota.php @@ -13,14 +13,14 @@ class Test_IsOverQuota extends TestCase { private $originalPreviousQuotaOption; - public function setUp() { - parent::setUp(); + public function set_up() { + parent::set_up(); $this->originalPreviousQuotaOption = get_imagify_option( 'previous_quota_percent' ); } - public function tearDown() { - parent::tearDown(); + public function tear_down() { + parent::tear_down(); // Restore the original option. update_imagify_option( 'previous_quota_percent', $this->originalPreviousQuotaOption ); diff --git a/Tests/Integration/init-tests.php b/Tests/Integration/init-tests.php new file mode 100644 index 000000000..4323edbd5 --- /dev/null +++ b/Tests/Integration/init-tests.php @@ -0,0 +1,11 @@ + setPropertyValue( 'instance', $class, $instance ); - } - - /** - * Reset the value of a private/protected property. - * - * @param string $property Property name for which to gain access. - * @param string|object $class Class name for a static property, or instance for an instance property. - * - * @return mixed The previous value of the property. - * @throws ReflectionException Throws an exception if property does not exist. - * - */ - protected function resetPropertyValue( $property, $class ) { - return $this->setPropertyValue( $property, $class, null ); - } - - /** - * Set the value of a private/protected property. - * - * @param string $property Property name for which to gain access. - * @param string|object $class Class name for a static property, or instance for an instance property. - * @param mixed $value The value to set to the property. - * - * @return mixed The previous value of the property. - * @throws ReflectionException Throws an exception if property does not exist. - * - */ - protected function setPropertyValue( $property, $class, $value ) { - $ref = $this->get_reflective_property( $property, $class ); - - if ( is_object( $class ) ) { - $previous = $ref->getValue( $class ); - // Instance property. - $ref->setValue( $class, $value ); - } else { - $previous = $ref->getValue(); - // Static property. - $ref->setValue( $value ); - } - - return $previous; - } - - /** ----------------------------------------------------------------------------------------- */ - /** REFLECTIONS ============================================================================= */ - /** ----------------------------------------------------------------------------------------- */ - - /** - * Get reflective access to a private/protected method. - * - * @param string $method_name Method name for which to gain access. - * @param string $class_name Name of the target class. - * - * @return ReflectionMethod - * @throws ReflectionException Throws an exception if method does not exist. - * - */ - protected function get_reflective_method( $method_name, $class_name ) { - $class = new ReflectionClass( $class_name ); - $method = $class->getMethod( $method_name ); - $method->setAccessible( true ); - - return $method; - } - - /** - * Get reflective access to a private/protected property. - * - * @param string $property Property name for which to gain access. - * @param string|mixed $class Class name or instance. - * - * @return ReflectionProperty - * @throws ReflectionException Throws an exception if property does not exist. - * - */ - protected function get_reflective_property( $property, $class ) { - $class = new ReflectionClass( $class ); - $property = $class->getProperty( $property ); - $property->setAccessible( true ); - - return $property; - } - - /** - * Set the value of a private/protected property. - * - * @param mixed $value The value to set for the property. - * @param string $property Property name for which to gain access. - * @param mixed $instance Instance of the target object. - * - * @return ReflectionProperty - * @throws ReflectionException Throws an exception if property does not exist. - * - */ - protected function set_reflective_property( $value, $property, $instance ) { - $property = $this->get_reflective_property( $property, $instance ); - $property->setValue( $instance, $value ); - $property->setAccessible( false ); - - return $property; - } -} diff --git a/Tests/Unit/TestCase.php b/Tests/Unit/TestCase.php index e0246a052..e224d22e0 100644 --- a/Tests/Unit/TestCase.php +++ b/Tests/Unit/TestCase.php @@ -7,37 +7,18 @@ namespace Imagify\Tests\Unit; -use WPMedia\PHPUnit\Unit\TestCase as PHPUnitTestCase; -use Brain\Monkey; -use Imagify\Tests\TestCaseTrait; use ReflectionObject; -use WP_Error; +use WPMedia\PHPUnit\Unit\TestCase as PHPUnitTestCase; abstract class TestCase extends PHPUnitTestCase { - use TestCaseTrait; - protected $config; - /** - * Prepares the test environment before each test. - */ - protected function setUp() { - parent::setUp(); - Monkey\setUp(); - + protected function setUp() : void { if ( empty( $this->config ) ) { $this->loadTestDataConfig(); } - $this->mockCommonWpFunctions(); - } - - /** - * Cleans up the test environment after each test. - */ - protected function tearDown() { - Monkey\tearDown(); - parent::tearDown(); + parent::setUp(); } public function configTestData() { @@ -58,42 +39,43 @@ protected function loadTestDataConfig() { } /** - * Mock common WP functions. + * Reset the value of a private/protected property. + * + * @param string $property Property name for which to gain access. + * @param string|object $class Class name for a static property, or instance for an instance property. + * + * @return mixed The previous value of the property. + * @throws ReflectionException Throws an exception if property does not exist. + * */ - protected function mockCommonWpFunctions() { - Monkey\Functions\stubs( - [ - '__', - 'esc_attr__', - 'esc_html__', - '_x', - 'esc_attr_x', - 'esc_html_x', - '_n', - '_nx', - 'esc_attr', - 'esc_html', - 'esc_textarea', - 'esc_url', - ] - ); - - $functions = [ - '_e', - 'esc_attr_e', - 'esc_html_e', - '_ex', - ]; + protected function resetPropertyValue( $property, $class ) { + return $this->setPropertyValue( $property, $class, null ); + } - foreach ( $functions as $function ) { - Monkey\Functions\when( $function )->echoArg(); + /** + * Set the value of a private/protected property. + * + * @param string $property Property name for which to gain access. + * @param string|object $class Class name for a static property, or instance for an instance property. + * @param mixed $value The value to set to the property. + * + * @return mixed The previous value of the property. + * @throws ReflectionException Throws an exception if property does not exist. + * + */ + protected function setPropertyValue( $property, $class, $value ) { + $ref = $this->get_reflective_property( $property, $class ); + + if ( is_object( $class ) ) { + $previous = $ref->getValue( $class ); + // Instance property. + $ref->setValue( $class, $value ); + } else { + $previous = $ref->getValue(); + // Static property. + $ref->setValue( $value ); } - include_once IMAGIFY_PLUGIN_TESTS_ROOT . '../Fixtures/WP/class-wp-error.php'; - - Monkey\Functions\when( 'is_wp_error' ) - ->alias( function( $thing ) { - return $thing instanceof WP_Error; - } ); + return $previous; } } diff --git a/Tests/Unit/bootstrap.php b/Tests/Unit/bootstrap.php index e0861164b..1ef504506 100644 --- a/Tests/Unit/bootstrap.php +++ b/Tests/Unit/bootstrap.php @@ -7,7 +7,8 @@ namespace Imagify\Tests\Unit; -use function Imagify\Tests\init_test_suite; +define( 'IMAGIFY_PLUGIN_ROOT', dirname( dirname( __DIR__ ) ) . DIRECTORY_SEPARATOR ); +define( 'IMAGIFY_PLUGIN_TESTS_FIXTURES_DIR', dirname( __DIR__ ) . '/Fixtures' ); -require_once dirname( dirname( __FILE__ ) ) . '/bootstrap-functions.php'; -init_test_suite( 'Unit' ); +require_once IMAGIFY_PLUGIN_ROOT . 'inc/functions/api.php'; +include_once IMAGIFY_PLUGIN_TESTS_FIXTURES_DIR . '/WP/class-wp-error.php'; diff --git a/Tests/Unit/classes/Admin/AdminSubscriber/pluginActionLinks.php b/Tests/Unit/classes/Admin/AdminSubscriber/pluginActionLinks.php index 8adb3e753..974183805 100644 --- a/Tests/Unit/classes/Admin/AdminSubscriber/pluginActionLinks.php +++ b/Tests/Unit/classes/Admin/AdminSubscriber/pluginActionLinks.php @@ -1,4 +1,6 @@ user = Mockery::mock( User::class ); $this->admin_subscriber = new AdminSubscriber( $this->user ); + + $this->stubTranslationFunctions(); + $this->stubEscapeFunctions(); } /** diff --git a/Tests/Unit/inc/classes/ImagifySettings/updateSiteOptionOnNetwork.php b/Tests/Unit/inc/classes/ImagifySettings/updateSiteOptionOnNetwork.php index e34823487..809d735be 100644 --- a/Tests/Unit/inc/classes/ImagifySettings/updateSiteOptionOnNetwork.php +++ b/Tests/Unit/inc/classes/ImagifySettings/updateSiteOptionOnNetwork.php @@ -1,4 +1,6 @@ justReturn( true ); + + $this->stubTranslationFunctions(); } - public function tearDown() { + public function tearDown(): void { unset( $_POST['option_page'] ); - return parent::tearDown(); + parent::tearDown(); } /** diff --git a/Tests/Unit/inc/functions/imagifySanitizeContext.php b/Tests/Unit/inc/functions/imagifySanitizeContext.php index 4de4b6817..7c7f250d5 100644 --- a/Tests/Unit/inc/functions/imagifySanitizeContext.php +++ b/Tests/Unit/inc/functions/imagifySanitizeContext.php @@ -7,7 +7,7 @@ class Test_ImagifySanitizeContext extends TestCase { - protected function setUp() { + protected function setUp(): void { parent::setUp(); require_once IMAGIFY_PLUGIN_ROOT . 'inc/functions/common.php'; diff --git a/Tests/Unit/init-tests.php b/Tests/Unit/init-tests.php new file mode 100644 index 000000000..6ca7d05eb --- /dev/null +++ b/Tests/Unit/init-tests.php @@ -0,0 +1,11 @@ +