Вход Регистрация
Файл: vendor/laravel/framework/src/Illuminate/Foundation/Console/TestMakeCommand.php
Строк: 168
<?php

namespace IlluminateFoundationConsole;

use 
IlluminateConsoleGeneratorCommand;
use 
IlluminateSupportStr;
use 
SymfonyComponentConsoleAttributeAsCommand;
use 
SymfonyComponentConsoleInputInputInterface;
use 
SymfonyComponentConsoleInputInputOption;
use 
SymfonyComponentConsoleOutputOutputInterface;

use function 
LaravelPromptsselect;

#[AsCommand(name: 'make:test')]
class TestMakeCommand extends GeneratorCommand
{
    
/**
     * The console command name.
     *
     * @var string
     */
    
protected $name 'make:test';

    
/**
     * The console command description.
     *
     * @var string
     */
    
protected $description 'Create a new test class';

    
/**
     * The type of class being generated.
     *
     * @var string
     */
    
protected $type 'Test';

    
/**
     * Get the stub file for the generator.
     *
     * @return string
     */
    
protected function getStub()
    {
        
$suffix $this->option('unit') ? '.unit.stub' '.stub';

        return 
$this->option('pest')
            ? 
$this->resolveStubPath('/stubs/pest'.$suffix)
            : 
$this->resolveStubPath('/stubs/test'.$suffix);
    }

    
/**
     * Resolve the fully-qualified path to the stub.
     *
     * @param  string  $stub
     * @return string
     */
    
protected function resolveStubPath($stub)
    {
        return 
file_exists($customPath $this->laravel->basePath(trim($stub'/')))
                        ? 
$customPath
                        
__DIR__.$stub;
    }

    
/**
     * Get the destination class path.
     *
     * @param  string  $name
     * @return string
     */
    
protected function getPath($name)
    {
        
$name Str::replaceFirst($this->rootNamespace(), ''$name);

        return 
base_path('tests').str_replace('\', '/', $name).'.php';
    }

    /**
     * Get the default namespace for the class.
     *
     * @param  string  $rootNamespace
     * @return string
     */
    protected function getDefaultNamespace($rootNamespace)
    {
        if ($this->option('
unit')) {
            return $rootNamespace.'
Unit';
        } else {
            return $rootNamespace.'
Feature';
        }
    }

    /**
     * Get the root namespace for the class.
     *
     * @return string
     */
    protected function rootNamespace()
    {
        return '
Tests';
    }

    /**
     * Get the console command options.
     *
     * @return array
     */
    protected function getOptions()
    {
        return [
            ['
force', 'f', InputOption::VALUE_NONE, 'Create the class even if the test already exists'],
            ['
unit', 'u', InputOption::VALUE_NONE, 'Create a unit test'],
            ['
pest', 'p', InputOption::VALUE_NONE, 'Create a Pest test'],
        ];
    }

    /**
     * Interact further with the user if they were prompted for missing arguments.
     *
     * @param  SymfonyComponentConsoleInputInputInterface  $input
     * @param  SymfonyComponentConsoleOutputOutputInterface  $output
     * @return void
     */
    protected function afterPromptingForMissingArguments(InputInterface $input, OutputInterface $output)
    {
        if ($this->isReservedName($this->getNameInput()) || $this->didReceiveOptions($input)) {
            return;
        }

        $type = select('
Which type of test would you like?', [
            '
feature' => 'Feature (PHPUnit)',
            '
unit' => 'Unit (PHPUnit)',
            '
pest-feature' => 'Feature (Pest)',
            '
pest-unit' => 'Unit (Pest)',
        ]);

        match ($type) {
            '
feature' => null,
            '
unit' => $input->setOption('unit', true),
            '
pest-feature' => $input->setOption('pest', true),
            '
pest-unit' => tap($input)->setOption('pest', true)->setOption('unit', true),
        };
    }
}
Онлайн: 0
Реклама