1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90
|
<?php
namespace Illuminate\Tests\Database;
use Illuminate\Database\Connection;
use Illuminate\Database\Query\Processors\PostgresProcessor;
use Illuminate\Database\Schema\Builder;
use LogicException;
use Mockery as m;
use PHPUnit\Framework\TestCase;
use stdClass;
class DatabaseSchemaBuilderTest extends TestCase
{
protected function tearDown(): void
{
m::close();
}
public function testCreateDatabase()
{
$connection = m::mock(Connection::class);
$grammar = m::mock(stdClass::class);
$connection->shouldReceive('getSchemaGrammar')->andReturn($grammar);
$builder = new Builder($connection);
$this->expectException(LogicException::class);
$this->expectExceptionMessage('This database driver does not support creating databases.');
$builder->createDatabase('foo');
}
public function testDropDatabaseIfExists()
{
$connection = m::mock(Connection::class);
$grammar = m::mock(stdClass::class);
$connection->shouldReceive('getSchemaGrammar')->andReturn($grammar);
$builder = new Builder($connection);
$this->expectException(LogicException::class);
$this->expectExceptionMessage('This database driver does not support dropping databases.');
$builder->dropDatabaseIfExists('foo');
}
public function testHasTableCorrectlyCallsGrammar()
{
$connection = m::mock(Connection::class);
$grammar = m::mock(stdClass::class);
$processor = m::mock(PostgresProcessor::class);
$connection->shouldReceive('getSchemaGrammar')->andReturn($grammar);
$connection->shouldReceive('getPostProcessor')->andReturn($processor);
$builder = new Builder($connection);
$grammar->shouldReceive('compileTables')->once()->andReturn('sql');
$processor->shouldReceive('processTables')->once()->andReturn([['name' => 'prefix_table']]);
$connection->shouldReceive('getTablePrefix')->once()->andReturn('prefix_');
$connection->shouldReceive('selectFromWriteConnection')->once()->with('sql')->andReturn([['name' => 'prefix_table']]);
$this->assertTrue($builder->hasTable('table'));
}
public function testTableHasColumns()
{
$connection = m::mock(Connection::class);
$grammar = m::mock(stdClass::class);
$connection->shouldReceive('getSchemaGrammar')->andReturn($grammar);
$builder = m::mock(Builder::class.'[getColumnListing]', [$connection]);
$builder->shouldReceive('getColumnListing')->with('users')->twice()->andReturn(['id', 'firstname']);
$this->assertTrue($builder->hasColumns('users', ['id', 'firstname']));
$this->assertFalse($builder->hasColumns('users', ['id', 'address']));
}
public function testGetColumnTypeAddsPrefix()
{
$connection = m::mock(Connection::class);
$column = m::mock(stdClass::class);
$type = m::mock(stdClass::class);
$grammar = m::mock(stdClass::class);
$connection->shouldReceive('getSchemaGrammar')->once()->andReturn($grammar);
$builder = new Builder($connection);
$connection->shouldReceive('getTablePrefix')->once()->andReturn('prefix_');
$connection->shouldReceive('getDoctrineColumn')->once()->with('prefix_users', 'id')->andReturn($column);
$connection->shouldReceive('usingNativeSchemaOperations')->once()->andReturn(false);
$column->shouldReceive('getType')->once()->andReturn($type);
$type->shouldReceive('getName')->once()->andReturn('integer');
$this->assertSame('integer', $builder->getColumnType('users', 'id'));
}
}
|