Skip to content

Commit

Permalink
Query: Determine omitted & target columns correctly
Browse files Browse the repository at this point in the history
  • Loading branch information
yhabteab authored and nilmerg committed Sep 24, 2024
1 parent e9d6117 commit 832d9ff
Show file tree
Hide file tree
Showing 2 changed files with 61 additions and 1 deletion.
13 changes: 12 additions & 1 deletion src/Query.php
Original file line number Diff line number Diff line change
Expand Up @@ -454,7 +454,18 @@ public function assembleSelect()
foreach ($resolved as $target) {
$targetColumns = $resolved[$target]->getArrayCopy();
if (isset($omitted[$target])) {
$targetColumns = array_diff($targetColumns, $omitted[$target]->getArrayCopy());
$toExclude = $omitted[$target]->getArrayCopy();
$targetColumns = array_filter($targetColumns, function ($column, $alias) use ($toExclude) {
if (is_string($alias) && isset($toExclude[$alias])) {
return false;
}

if (is_string($alias)) {
return ! in_array($alias, $toExclude, true);
}

return ! in_array($column, $toExclude, true);
}, ARRAY_FILTER_USE_BOTH);
}

if (! empty($customAliases)) {
Expand Down
49 changes: 49 additions & 0 deletions tests/QueryTest.php
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@

use ipl\Orm\Exception\InvalidRelationException;
use ipl\Orm\Query;
use ipl\Orm\ResolvedExpression;
use ipl\Sql\Expression;
use ipl\Tests\Sql\TestCase;

Expand Down Expand Up @@ -401,6 +402,32 @@ public function testWithColumnsSupportsExpressions()
);
}

public function testWithColumnsSupportsAliasedExpressions()
{
$model = new class () extends User {
public function getColumns(): array
{
return ['username', 'aliased_expr' => new Expression('1')];
}
};

$query = (new Query())
->setModel($model)
->columns('username')
->withColumns('aliased_expr');

$this->assertEquals(
[
'user.username',
'aliased_expr' => new ResolvedExpression(
new Expression('1'),
$query->getResolver()->requireAndResolveColumns(['aliased_expr'])
),
],
$query->assembleSelect()->getColumns()
);
}

public function testWithColumnsHandlesCustomAliasesCorrectly()
{
$query = (new Query())
Expand Down Expand Up @@ -486,6 +513,28 @@ public function testWithoutColumnsOverridesColumnsAndWithColumns()
);
}

public function testWithoutColumnsExcludesAliasedExpressions()
{
$model = new class () extends User {
public function getColumns(): array
{
return [
'username',
'aliased_expr' => new Expression('1')
];
}
};

$query = (new Query())
->setModel($model)
->withoutColumns(['aliased_expr', 'id']);

$this->assertSame(
['user.username'],
$query->assembleSelect()->getColumns()
);
}

public function testWithoutColumnsDoesNotWorkWithExpressions()
{
$expression = new Expression('1');
Expand Down

0 comments on commit 832d9ff

Please sign in to comment.