Skip to content

Commit

Permalink
ENH: Respect sort and limit arguments (#158)
Browse files Browse the repository at this point in the history
These parameters are defined in the PHPDocs for `Report` and are technically part of the method signature. They should be respected and in the case of the new default limit in silverstripe/silverstripe-reports#139 this could have performance ramifications for large datasets.
  • Loading branch information
GuySartorelli authored Mar 10, 2022
1 parent 46a637a commit 141e8d0
Show file tree
Hide file tree
Showing 3 changed files with 30 additions and 16 deletions.
12 changes: 11 additions & 1 deletion src/Reports/PagesDueForReviewReport.php
Original file line number Diff line number Diff line change
Expand Up @@ -148,16 +148,26 @@ public function columns()

/**
* @param array $params
* @param array|string|null $sort
* @param int|null $limit
*
* @return SS_List
*/
public function sourceRecords($params = [])
public function sourceRecords($params = [], $sort = null, $limit = null)
{
Versioned::set_stage(Versioned::DRAFT);

$records = SiteTree::get();
$compatibility = ContentReviewCompatability::start();

// Apply sort and limit if appropriate.
if ($sort !== null) {
$records = $records->sort($sort);
}
if ($limit !== null) {
$records = $records->limit($limit);
}

if (empty($params['ReviewDateBefore']) && empty($params['ReviewDateAfter'])) {
// If there's no review dates set, default to all pages due for review now
$records = $records->where(
Expand Down
22 changes: 13 additions & 9 deletions src/Reports/PagesWithoutReviewScheduleReport.php
Original file line number Diff line number Diff line change
Expand Up @@ -104,10 +104,12 @@ public function columns()

/**
* @param array $params
* @param array|string|null $sort
* @param int|null $limit
*
* @return SS_List
*/
public function sourceRecords($params = [])
public function sourceRecords($params = [], $sort = null, $limit = null)
{
Versioned::set_stage(Versioned::DRAFT);

Expand All @@ -125,16 +127,18 @@ public function sourceRecords($params = [])
));
}

$records->sort("ParentID");
$records = $records->toArray();
// Apply sort and limit if appropriate.
if ($sort !== null) {
$records = $records->sort($sort);
}
if ($limit !== null) {
$records = $records->limit($limit);
}

// Trim out calculated values
$list = ArrayList::create();
foreach ($records as $record) {
if (!$this->hasReviewSchedule($record)) {
$list->push($record);
}
}
$list = $records->filterByCallback(function ($record) {
return !$this->hasReviewSchedule($record);
});

ContentReviewCompatability::done($compatibility);

Expand Down
12 changes: 6 additions & 6 deletions tests/php/ContentReviewReportTest.php
Original file line number Diff line number Diff line change
Expand Up @@ -87,11 +87,11 @@ public function testPagesWithoutReviewScheduleReport()

$results = $report->sourceRecords();

$this->assertEquals([
"Home",
"About Us",
"Page without review date",
"Page owned by group",
], $results->column("Title"));
$this->assertListEquals([
['Title' => 'Home'],
['Title' => 'About Us'],
['Title' => 'Page without review date'],
['Title' => 'Page owned by group'],
], $results);
}
}

0 comments on commit 141e8d0

Please sign in to comment.