DatabaseEloquentBelongsToManyWithDefaultAttributesTest.php 2.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061
  1. <?php
  2. namespace Illuminate\Tests\Database;
  3. use Illuminate\Database\Eloquent\Builder;
  4. use Illuminate\Database\Eloquent\Model;
  5. use Illuminate\Database\Eloquent\Relations\BelongsToMany;
  6. use Mockery as m;
  7. use PHPUnit\Framework\TestCase;
  8. use stdClass;
  9. class DatabaseEloquentBelongsToManyWithDefaultAttributesTest extends TestCase
  10. {
  11. protected function tearDown(): void
  12. {
  13. m::close();
  14. }
  15. public function testWithPivotValueMethodSetsWhereConditionsForFetching()
  16. {
  17. $relation = $this->getMockBuilder(BelongsToMany::class)->onlyMethods(['touchIfTouching'])->setConstructorArgs($this->getRelationArguments())->getMock();
  18. $relation->withPivotValue(['is_admin' => 1]);
  19. }
  20. public function testWithPivotValueMethodSetsDefaultArgumentsForInsertion()
  21. {
  22. $relation = $this->getMockBuilder(BelongsToMany::class)->onlyMethods(['touchIfTouching'])->setConstructorArgs($this->getRelationArguments())->getMock();
  23. $relation->withPivotValue(['is_admin' => 1]);
  24. $query = m::mock(stdClass::class);
  25. $query->shouldReceive('from')->once()->with('club_user')->andReturn($query);
  26. $query->shouldReceive('insert')->once()->with([['club_id' => 1, 'user_id' => 1, 'is_admin' => 1]])->andReturn(true);
  27. $relation->getQuery()->shouldReceive('getQuery')->andReturn($mockQueryBuilder = m::mock(stdClass::class));
  28. $mockQueryBuilder->shouldReceive('newQuery')->once()->andReturn($query);
  29. $relation->attach(1);
  30. }
  31. public function getRelationArguments()
  32. {
  33. $parent = m::mock(Model::class);
  34. $parent->shouldReceive('getKey')->andReturn(1);
  35. $parent->shouldReceive('getCreatedAtColumn')->andReturn('created_at');
  36. $parent->shouldReceive('getUpdatedAtColumn')->andReturn('updated_at');
  37. $parent->shouldReceive('getAttribute')->with('id')->andReturn(1);
  38. $builder = m::mock(Builder::class);
  39. $related = m::mock(Model::class);
  40. $builder->shouldReceive('getModel')->andReturn($related);
  41. $related->shouldReceive('getTable')->andReturn('users');
  42. $related->shouldReceive('getKeyName')->andReturn('id');
  43. $related->shouldReceive('qualifyColumn')->with('id')->andReturn('users.id');
  44. $builder->shouldReceive('join')->once()->with('club_user', 'users.id', '=', 'club_user.user_id');
  45. $builder->shouldReceive('where')->once()->with('club_user.club_id', '=', 1);
  46. $builder->shouldReceive('where')->once()->with('club_user.is_admin', '=', 1, 'and');
  47. return [$builder, $parent, 'club_user', 'club_id', 'user_id', 'id', 'id', null, false];
  48. }
  49. }