Skip to content
Snippets Groups Projects
Select Git revision
  • bf4a5800358cef833169c44101ee20919e128397
  • master default protected
  • bugfix/wordpress-review
  • bugfix/prevent-error-notice
  • remove-arrow
  • feature/update-message
  • feature/minimum-plugin-version-check-demo1
  • feature/plugin-name
  • 3.7.1
  • 3.7.0
  • 3.6.3
  • 3.6.2
  • 3.6.1
  • 3.6.0
  • 3.6.0-beta3
  • 3.6.0-beta2
  • 3.6.0-beta1
  • 3.5.2
  • 3.5.1
  • 3.5.0
  • 3.4.0
  • 3.3.0
  • 3.2.8
  • 3.2.7
  • 3.2.6
  • 3.2.5
  • 3.2.4
  • 3.2.3
28 results

Test_Basic_Requirement_Checker.php

Blame
  • Test_Basic_Requirement_Checker.php 5.47 KiB
    <?php
    
    class Test_Basic_Requirement_Checker extends PHPUnit\Framework\TestCase {
    	const RANDOM_PLUGIN_FILE = 'file';
    
    	const RANDOM_PLUGIN_NAME = 'name';
    
    	const RANDOM_PLUGIN_TEXTDOMAIN = 'text';
    
    	const ALWAYS_VALID_PHP_VERSION = '5.2';
    
    	const ALWAYS_NOT_VALID_PHP_VERSION = '100.100';
    
    	const ALWAYS_VALID_WP_VERSION = '4.0';
    
    	const HOOK_TYPE_ACTION = 'action';
    
    	public function setUp() {
    		WP_Mock::setUp();
    
    		WP_Mock::wpFunction( 'get_bloginfo' )
    		       ->andReturn( self::ALWAYS_VALID_WP_VERSION );
    	}
    
    	public function tearDown() {
    		WP_Mock::tearDown();
    	}
    
    	public function test_php_version_check() {
    		$known_PHP_versions = [ '7.3', '7.2', '7.1', '7.0', '5.6', '5.5', '5.4', '5.3', '5.2' ];
    
    		$requirements = $this->create_requirements_for_php_wp(
    			self::ALWAYS_VALID_PHP_VERSION,
    			self::ALWAYS_VALID_WP_VERSION );
    
    		foreach ( $known_PHP_versions as $version ) {
    			$requirements->set_min_php_require( $version );
    			if ( version_compare( PHP_VERSION, $version, '>=' ) ) {
    				$this->assertTrue( $requirements->are_requirements_met(),
    					'Should be ok because WP is OK and PHP is OK' );
    			} else {
    				$this->assertFalse( $requirements->are_requirements_met(),
    					'Should fail because required PHP should be at least  ' . $version );
    			}
    		}
    		$requirements->set_min_php_require( self::ALWAYS_NOT_VALID_PHP_VERSION );
    		$requirements->are_requirements_met();
    		$this->expectOutputRegex( "/PHP/" );
    		$requirements->render_notices_action();
    	}
    
    	/**
    	 * @param string $php
    	 * @param string $wp
    	 *
    	 * @return WPDesk_Basic_Requirement_Checker
    	 */
    	public function create_requirements_for_php_wp( $php, $wp ) {
    		return new WPDesk_Basic_Requirement_Checker( self::RANDOM_PLUGIN_FILE, self::RANDOM_PLUGIN_NAME,
    			self::RANDOM_PLUGIN_TEXTDOMAIN, $php, $wp );
    	}
    
    	public function test_wp_version_check() {
    		$wp_version_fail = '4.1';
    
    		$requirements = $this->create_requirements_for_php_wp(
    			self::ALWAYS_VALID_PHP_VERSION,
    			self::ALWAYS_VALID_WP_VERSION );
    
    		$this->assertTrue( $requirements->are_requirements_met(), 'Should be ok because WP is OK and PHP is OK' );
    		$requirements->set_min_wp_require( $wp_version_fail );
    		$this->assertFalse( $requirements->are_requirements_met(),
    			'Should fail because required WP should be at least ' . $wp_version_fail );
    
    		$this->expectOutputRegex( "/WordPress/" );
    		$requirements->render_notices_action();
    	}
    
    	/**
    	 * @requires extension curl
    	 */
    	public function test_module_check() {
    		$requirements = $this->create_requirements_for_php_wp(
    			self::ALWAYS_VALID_PHP_VERSION,
    			self::ALWAYS_VALID_WP_VERSION );
    
    		$requirements->add_php_module_require( 'curl' );
    		$this->assertTrue( $requirements->are_requirements_met(), 'Curl should exists' );
    
    		$this->expectOutputRegex( "/^$/" );
    		$requirements->render_notices_action();
    	}
    
    	public function test_plugin_check_with_multisite() {
    		$multisite                     = true;
    		$exising_plugin_name           = 'WooCommerce';
    		$exising_multisite_plugin_name = 'Multisite';
    		$not_existing_plugin_name      = 'Not exist';
    
    		WP_Mock::wpFunction( 'get_option' )
    		       ->withArgs( [ 'active_plugins', [] ] )
    		       ->andReturn( [ $exising_plugin_name ] );
    
    		WP_Mock::wpFunction( 'is_multisite' )
    		       ->andReturn( $multisite );
    
    		WP_Mock::wpFunction( 'get_site_option' )
    		       ->withArgs( [ 'active_sitewide_plugins', [] ] )
    		       ->andReturn( [ $exising_multisite_plugin_name ] );
    
    
    		$requirements = $this->create_requirements_for_php_wp( self::ALWAYS_VALID_PHP_VERSION,
    			self::ALWAYS_VALID_WP_VERSION );
    
    		$requirements->add_plugin_require( $exising_plugin_name );
    		$this->assertTrue( $requirements->are_requirements_met(), 'Plugin should exists' );
    
    		$requirements->add_plugin_require( $exising_multisite_plugin_name );
    		$this->assertTrue( $requirements->are_requirements_met(), 'Multisite plugin should exists' );
    
    		$requirements->add_plugin_require( $not_existing_plugin_name );
    		$this->assertFalse( $requirements->are_requirements_met(), 'Plugin should not exists' );
    
    		$this->expectOutputRegex( "/$not_existing_plugin_name/" );
    		$requirements->render_notices_action();
    	}
    
    	/**
    	 * @requires extension openssl
    	 */
    	public function test_existing_openssl_requirement() {
    		$open_ssl_always_valid     = 1;
    		$open_ssl_always_not_valid = 0x900905000; // 9.9.6
    
    		$requirements = $this->create_requirements_for_php_wp( self::ALWAYS_VALID_PHP_VERSION,
    			self::ALWAYS_VALID_WP_VERSION );
    
    		$this->assertTrue( $requirements->is_open_ssl_at_least( $open_ssl_always_valid ),
    			'OpenSSL should have at least 0.1 version if exists' );
    
    		$this->assertFalse( $requirements->is_open_ssl_at_least( $open_ssl_always_not_valid ),
    			'OpenSSL should fail for that high number' );
    
    		$requirements->set_min_openssl_require( $open_ssl_always_not_valid );
    
    		$this->assertFalse( $requirements->are_requirements_met(),
    			'Requirement OpenSSL should fail for that high number' );
    
    		$this->expectOutputRegex( '/without OpenSSL module/' );
    		$requirements->render_notices_action();
    	}
    
    	public function test_deactivate_plugin_notice() {
    		$requirements = $this->create_requirements_for_php_wp( self::ALWAYS_NOT_VALID_PHP_VERSION,
    			self::ALWAYS_VALID_WP_VERSION );
    
    		WP_Mock::expectActionAdded( WPDesk_Basic_Requirement_Checker::HOOK_ADMIN_NOTICES_ACTION,
    			[ $requirements, 'render_notices_action' ] );
    
    		$this->assertFalse( $requirements->are_requirements_met() );
    		$requirements->disable_plugin();
            $requirements->render_notices();
    
    		$this->expectOutputRegex( '/cannot run on PHP/' );
    		$requirements->render_notices_action();
    	}
    }