Skip to content

Commit

Permalink
version
Browse files Browse the repository at this point in the history
  • Loading branch information
taylorotwell committed Nov 10, 2020
2 parents 996c3b5 + cd09d46 commit b60139c
Show file tree
Hide file tree
Showing 3 changed files with 47 additions and 1 deletion.
17 changes: 17 additions & 0 deletions src/Illuminate/Database/Eloquent/Collection.php
Original file line number Diff line number Diff line change
Expand Up @@ -341,6 +341,23 @@ public function map(callable $callback)
}) ? $result->toBase() : $result;
}

/**
* Run an associative map over each of the items.
*
* The callback should return an associative array with a single key / value pair.
*
* @param callable $callback
* @return \Illuminate\Support\Collection|static
*/
public function mapWithKeys(callable $callback)
{
$result = parent::mapWithKeys($callback);

return $result->contains(function ($item) {
return ! $item instanceof Model;
}) ? $result->toBase() : $result;
}

/**
* Reload a fresh model instance from the database for all the entities.
*
Expand Down
2 changes: 1 addition & 1 deletion src/Illuminate/Foundation/Application.php
Original file line number Diff line number Diff line change
Expand Up @@ -33,7 +33,7 @@ class Application extends Container implements ApplicationContract, CachesConfig
*
* @var string
*/
const VERSION = '8.13.0';
const VERSION = '8.14.0';

/**
* The base path for the Laravel installation.
Expand Down
29 changes: 29 additions & 0 deletions tests/Database/DatabaseEloquentCollectionTest.php
Original file line number Diff line number Diff line change
Expand Up @@ -230,6 +230,35 @@ public function testMappingToNonModelsReturnsABaseCollection()
$this->assertEquals(BaseCollection::class, get_class($c));
}

public function testMapWithKeys()
{
$one = m::mock(Model::class);
$two = m::mock(Model::class);

$c = new Collection([$one, $two]);

$key = 0;
$cAfterMap = $c->mapWithKeys(function ($item) use (&$key) {
return [$key++ => $item];
});

$this->assertEquals($c->all(), $cAfterMap->all());
$this->assertInstanceOf(Collection::class, $cAfterMap);
}

public function testMapWithKeysToNonModelsReturnsABaseCollection()
{
$one = m::mock(Model::class);
$two = m::mock(Model::class);

$key = 0;
$c = (new Collection([$one, $two]))->mapWithKeys(function ($item) use (&$key) {
return [$key++ => 'not-a-model'];
});

$this->assertEquals(BaseCollection::class, get_class($c));
}

public function testCollectionDiffsWithGivenCollection()
{
$one = m::mock(Model::class);
Expand Down

0 comments on commit b60139c

Please sign in to comment.