Skip to content

Commit

Permalink
Allow passing an array to Collection::find (#16849)
Browse files Browse the repository at this point in the history
  • Loading branch information
JosephSilber authored and taylorotwell committed Dec 18, 2016
1 parent cd0396f commit 1cf3b94
Show file tree
Hide file tree
Showing 2 changed files with 31 additions and 1 deletion.
10 changes: 9 additions & 1 deletion src/Illuminate/Database/Eloquent/Collection.php
Original file line number Diff line number Diff line change
Expand Up @@ -14,14 +14,22 @@ class Collection extends BaseCollection implements QueueableCollection
*
* @param mixed $key
* @param mixed $default
* @return \Illuminate\Database\Eloquent\Model
* @return \Illuminate\Database\Eloquent\Model|static
*/
public function find($key, $default = null)
{
if ($key instanceof Model) {
$key = $key->getKey();
}

if (is_array($key)) {
if ($this->isEmpty()) {
return new static;
}

return $this->whereIn($this->first()->getKeyName(), $key);
}

return Arr::first($this->items, function ($model) use ($key) {
return $model->getKey() == $key;
}, $default);
Expand Down
22 changes: 22 additions & 0 deletions tests/Database/DatabaseEloquentCollectionTest.php
Original file line number Diff line number Diff line change
Expand Up @@ -109,6 +109,28 @@ public function testFindMethodFindsModelById()
$this->assertSame('taylor', $c->find(2, 'taylor'));
}

public function testFindMethodFindsManyModelsById()
{
$model1 = (new TestEloquentCollectionModel)->forceFill(['id' => 1]);
$model2 = (new TestEloquentCollectionModel)->forceFill(['id' => 2]);
$model3 = (new TestEloquentCollectionModel)->forceFill(['id' => 3]);

$c = new Collection;
$this->assertInstanceOf(Collection::class, $c->find([]));
$this->assertCount(0, $c->find([1]));

$c->push($model1);
$this->assertCount(1, $c->find([1]));
$this->assertEquals(1, $c->find([1])->first()->id);
$this->assertCount(0, $c->find([2]));

$c->push($model2)->push($model3);
$this->assertCount(1, $c->find([2]));
$this->assertEquals(2, $c->find([2])->first()->id);
$this->assertCount(2, $c->find([2, 3, 4]));
$this->assertEquals([2, 3], $c->find([2, 3, 4])->pluck('id')->all());
}

public function testLoadMethodEagerLoadsGivenRelationships()
{
$c = $this->getMockBuilder('Illuminate\Database\Eloquent\Collection')->setMethods(['first'])->setConstructorArgs([['foo']])->getMock();
Expand Down

0 comments on commit 1cf3b94

Please sign in to comment.