Seditio Source
Root |
./othercms/croogo-4.0.7/vendor/squizlabs/php_codesniffer/tests/Core/Ruleset/RuleInclusionAbsoluteWindowsTest.php
<?php
/**
 * Tests for the \PHP_CodeSniffer\Ruleset class using a Windows-style absolute path to include a sniff.
 *
 * @author    Juliette Reinders Folmer <phpcs_nospam@adviesenzo.nl>
 * @copyright 2019 Juliette Reinders Folmer. All rights reserved.
 * @license   https://github.com/squizlabs/PHP_CodeSniffer/blob/master/licence.txt BSD Licence
 */

namespace PHP_CodeSniffer\Tests\Core\Ruleset;

use
PHP_CodeSniffer\Config;
use
PHP_CodeSniffer\Ruleset;
use
PHPUnit\Framework\TestCase;

class
RuleInclusionAbsoluteWindowsTest extends TestCase
{

   
/**
     * The Ruleset object.
     *
     * @var \PHP_CodeSniffer\Ruleset
     */
   
protected $ruleset;

   
/**
     * Path to the ruleset file.
     *
     * @var string
     */
   
private $standard = '';

   
/**
     * The original content of the ruleset.
     *
     * @var string
     */
   
private $contents = '';


   
/**
     * Initialize the config and ruleset objects.
     *
     * @return void
     */
   
public function setUp()
    {
        if (
DIRECTORY_SEPARATOR === '/') {
           
$this->markTestSkipped('Windows specific test');
        }

        if (
$GLOBALS['PHP_CODESNIFFER_PEAR'] === true) {
           
// PEAR installs test and sniff files into different locations
            // so these tests will not pass as they directly reference files
            // by relative location.
           
$this->markTestSkipped('Test cannot run from a PEAR install');
        }

       
$this->standard = __DIR__.'/'.basename(__FILE__, '.php').'.xml';
       
$repoRootDir    = dirname(dirname(dirname(__DIR__)));

       
// On-the-fly adjust the ruleset test file to be able to test sniffs included with absolute paths.
       
$contents       = file_get_contents($this->standard);
       
$this->contents = $contents;

       
$adjusted = str_replace('%path_slash_back%', $repoRootDir, $contents);

        if (
file_put_contents($this->standard, $adjusted) === false) {
           
$this->markTestSkipped('On the fly ruleset adjustment failed');
        }

       
// Initialize the config and ruleset objects for the test.
       
$config        = new Config(["--standard={$this->standard}"]);
       
$this->ruleset = new Ruleset($config);

    }
//end setUp()


    /**
     * Reset ruleset file.
     *
     * @return void
     */
   
public function tearDown()
    {
        if (
DIRECTORY_SEPARATOR !== '/') {
           
file_put_contents($this->standard, $this->contents);
        }

    }
//end tearDown()


    /**
     * Test that sniffs registed with a Windows absolute path are correctly recognized and that
     * properties are correctly set for them.
     *
     * @return void
     */
   
public function testWindowsStylePathRuleInclusion()
    {
       
// Test that the sniff is correctly registered.
       
$this->assertObjectHasAttribute('sniffCodes', $this->ruleset);
       
$this->assertCount(1, $this->ruleset->sniffCodes);
       
$this->assertArrayHasKey('Generic.Formatting.SpaceAfterCast', $this->ruleset->sniffCodes);
       
$this->assertSame(
           
'PHP_CodeSniffer\Standards\Generic\Sniffs\Formatting\SpaceAfterCastSniff',
           
$this->ruleset->sniffCodes['Generic.Formatting.SpaceAfterCast']
        );

       
// Test that the sniff property is correctly set.
       
$this->assertSame(
           
'10',
           
$this->ruleset->sniffs['PHP_CodeSniffer\Standards\Generic\Sniffs\Formatting\SpaceAfterCastSniff']->spacing
       
);

    }
//end testWindowsStylePathRuleInclusion()


}//end class