<?php

/*
 * This file is part of Psy Shell.
 *
 * (c) 2012-2018 Justin Hileman
 *
 * For the full copyright and license information, please view the LICENSE
 * file that was distributed with this source code.
 */

namespace Psy\Test\CodeCleaner;

use Psy\CodeCleaner\ExitPass;

class ExitPassTest extends CodeCleanerTestCase
{
    /**
     * @var string
     */
    private $expectedExceptionString = '\\Psy\\Exception\\BreakException::exitShell()';

    public function setUp()
    {
        $this->setPass(new ExitPass());
    }

    /**
     * @dataProvider dataProviderExitStatement
     */
    public function testExitStatement($from, $to)
    {
        $this->assertProcessesAs($from, $to);
    }

    /**
     * Data provider for testExitStatement.
     *
     * @return array
     */
    public function dataProviderExitStatement()
    {
        return [
            ['exit;', "{$this->expectedExceptionString};"],
            ['exit();', "{$this->expectedExceptionString};"],
            ['die;', "{$this->expectedExceptionString};"],
            ['exit(die(die));', "{$this->expectedExceptionString};"],
            ['if (true) { exit; }', "if (true) {\n    {$this->expectedExceptionString};\n}"],
            ['if (false) { exit; }', "if (false) {\n    {$this->expectedExceptionString};\n}"],
            ['1 and exit();', "1 and {$this->expectedExceptionString};"],
            ['foo() or die', "foo() or {$this->expectedExceptionString};"],
            ['exit and 1;', "{$this->expectedExceptionString} and 1;"],
            ['if (exit) { echo $wat; }', "if ({$this->expectedExceptionString}) {\n    echo \$wat;\n}"],
            ['exit or die;', "{$this->expectedExceptionString} or {$this->expectedExceptionString};"],
            ['switch (die) { }', "switch ({$this->expectedExceptionString}) {\n}"],
            ['for ($i = 1; $i < 10; die) {}', "for (\$i = 1; \$i < 10; {$this->expectedExceptionString}) {\n}"],
        ];
    }
}