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

namespace IlluminateFoundationTesting;

use 
IlluminateContractsConsoleKernel;
use 
IlluminateDatabaseConnectionInterface;
use 
IlluminateFoundationTestingTraitsCanConfigureMigrationCommands;

trait 
DatabaseTruncation
{
    use 
CanConfigureMigrationCommands;

    
/**
     * The cached names of the database tables for each connection.
     *
     * @var array
     */
    
protected static array $allTables;

    
/**
     * Truncate the database tables for all configured connections.
     *
     * @return void
     */
    
protected function truncateDatabaseTables(): void
    
{
        
$this->beforeTruncatingDatabase();

        
// Migrate and seed the database on first run...
        
if (! RefreshDatabaseState::$migrated) {
            
$this->artisan('migrate:fresh'$this->migrateFreshUsing());

            
$this->app[Kernel::class]->setArtisan(null);

            
RefreshDatabaseState::$migrated true;

            return;
        }

        
// Always clear any test data on subsequent runs...
        
$this->truncateTablesForAllConnections();

        if (
$seeder $this->seeder()) {
            
// Use a specific seeder class...
            
$this->artisan('db:seed', ['--class' => $seeder]);
        } elseif (
$this->shouldSeed()) {
            
// Use the default seeder class...
            
$this->artisan('db:seed');
        }

        
$this->afterTruncatingDatabase();
    }

    
/**
     * Truncate the database tables for all configured connections.
     *
     * @return void
     */
    
protected function truncateTablesForAllConnections(): void
    
{
        
$database $this->app->make('db');

        
collect($this->connectionsToTruncate())
            ->
each(function ($name) use ($database) {
                
$connection $database->connection($name);

                
$connection->getSchemaBuilder()->withoutForeignKeyConstraints(
                    
fn () => $this->truncateTablesForConnection($connection$name)
                );
            });
    }

    
/**
     * Truncate the database tables for the given database connection.
     *
     * @param  IlluminateDatabaseConnectionInterface  $connection
     * @param  string|null  $name
     * @return void
     */
    
protected function truncateTablesForConnection(ConnectionInterface $connection, ?string $name): void
    
{
        
$dispatcher $connection->getEventDispatcher();

        
$connection->unsetEventDispatcher();

        
collect(static::$allTables[$name] ??= $connection->getDoctrineSchemaManager()->listTableNames())
            ->
when(
                
property_exists($this'tablesToTruncate'),
                
fn ($tables) => $tables->intersect($this->tablesToTruncate),
                
fn ($tables) => $tables->diff($this->exceptTables($name))
            )
            ->
filter(fn ($table) => $connection->table($this->withoutTablePrefix($connection$table))->exists())
            ->
each(fn ($table) => $connection->table($this->withoutTablePrefix($connection$table))->truncate());

        
$connection->setEventDispatcher($dispatcher);
    }

    
/**
     * Remove the table prefix from a table name, if it exists.
     *
     * @param  IlluminateDatabaseConnectionInterface  $connection
     * @param  string  $table
     * @return string
     */
    
protected function withoutTablePrefix(ConnectionInterface $connectionstring $table)
    {
        
$prefix $connection->getTablePrefix();

        return 
strpos($table$prefix) === 0
            
substr($tablestrlen($prefix))
            : 
$table;
    }

    
/**
     * The database connections that should have their tables truncated.
     *
     * @return array
     */
    
protected function connectionsToTruncate(): array
    {
        return 
property_exists($this'connectionsToTruncate')
                    ? 
$this->connectionsToTruncate : [null];
    }

    
/**
     * Get the tables that should not be truncated.
     *
     * @param  string|null  $connectionName
     * @return array
     */
    
protected function exceptTables(?string $connectionName): array
    {
        if (
property_exists($this'exceptTables')) {
            
$migrationsTable $this->app['config']->get('database.migrations');

            if (
array_is_list($this->exceptTables ?? [])) {
                return 
array_merge(
                    
$this->exceptTables ?? [],
                    [
$migrationsTable],
                );
            }

            return 
array_merge(
                
$this->exceptTables[$connectionName] ?? [],
                [
$migrationsTable],
            );
        }

        return [
$this->app['config']->get('database.migrations')];
    }

    
/**
     * Perform any work that should take place before the database has started truncating.
     *
     * @return void
     */
    
protected function beforeTruncatingDatabase(): void
    
{
        
//
    
}

    
/**
     * Perform any work that should take place once the database has finished truncating.
     *
     * @return void
     */
    
protected function afterTruncatingDatabase(): void
    
{
        
//
    
}
}
Онлайн: 1
Реклама