mirror of
https://github.com/flarum/core.git
synced 2025-08-04 15:37:51 +02:00
fix: multiple createdAt columns in query causes conflicts (#3506)
* test: list posts with mentions filter and `createdAt` sort * fix: multiple `createdAt` columns in query causes conflicts * chore: link to pull request for context Signed-off-by: Sami Mazouz <ilyasmazouz@gmail.com>
This commit is contained in:
@@ -14,7 +14,7 @@ use Flarum\Testing\integration\RetrievesAuthorizedUsers;
|
|||||||
use Flarum\Testing\integration\TestCase;
|
use Flarum\Testing\integration\TestCase;
|
||||||
use Illuminate\Support\Arr;
|
use Illuminate\Support\Arr;
|
||||||
|
|
||||||
class ListTest extends TestCase
|
class ListPostsTest extends TestCase
|
||||||
{
|
{
|
||||||
use RetrievesAuthorizedUsers;
|
use RetrievesAuthorizedUsers;
|
||||||
|
|
||||||
@@ -85,4 +85,26 @@ class ListTest extends TestCase
|
|||||||
$ids = Arr::pluck($data, 'id');
|
$ids = Arr::pluck($data, 'id');
|
||||||
$this->assertEqualsCanonicalizing(['4'], $ids, 'IDs do not match');
|
$this->assertEqualsCanonicalizing(['4'], $ids, 'IDs do not match');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @test
|
||||||
|
*/
|
||||||
|
public function mentioned_filter_works_with_sort()
|
||||||
|
{
|
||||||
|
$response = $this->send(
|
||||||
|
$this->request('GET', '/api/posts')
|
||||||
|
->withQueryParams([
|
||||||
|
'filter' => ['mentioned' => 1],
|
||||||
|
'sort' => '-createdAt'
|
||||||
|
])
|
||||||
|
);
|
||||||
|
|
||||||
|
$data = json_decode($response->getBody()->getContents(), true)['data'];
|
||||||
|
|
||||||
|
$this->assertEquals(200, $response->getStatusCode());
|
||||||
|
|
||||||
|
// Order-independent comparison
|
||||||
|
$ids = Arr::pluck($data, 'id');
|
||||||
|
$this->assertEqualsCanonicalizing(['3', '2'], $ids, 'IDs do not match');
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@@ -113,6 +113,20 @@ class ListPostsController extends AbstractListController
|
|||||||
return $results;
|
return $results;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @link https://github.com/flarum/framework/pull/3506
|
||||||
|
*/
|
||||||
|
protected function extractSort(ServerRequestInterface $request)
|
||||||
|
{
|
||||||
|
$sort = [];
|
||||||
|
|
||||||
|
foreach ((parent::extractSort($request) ?: []) as $field => $direction) {
|
||||||
|
$sort["posts.$field"] = $direction;
|
||||||
|
}
|
||||||
|
|
||||||
|
return $sort;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* {@inheritdoc}
|
* {@inheritdoc}
|
||||||
*/
|
*/
|
||||||
|
Reference in New Issue
Block a user