2019-02-15 15:42:53 +01:00
|
|
|
<?php
|
|
|
|
|
|
|
|
final class HarbormasterBuildUnitMessageQuery
|
|
|
|
extends PhabricatorCursorPagedPolicyAwareQuery {
|
|
|
|
|
|
|
|
private $ids;
|
|
|
|
private $phids;
|
|
|
|
private $targetPHIDs;
|
|
|
|
|
|
|
|
public function withIDs(array $ids) {
|
|
|
|
$this->ids = $ids;
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function withPHIDs(array $phids) {
|
|
|
|
$this->phids = $phids;
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function withBuildTargetPHIDs(array $target_phids) {
|
|
|
|
$this->targetPHIDs = $target_phids;
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function newResultObject() {
|
|
|
|
return new HarbormasterBuildUnitMessage();
|
|
|
|
}
|
|
|
|
|
|
|
|
protected function loadPage() {
|
|
|
|
return $this->loadStandardPage($this->newResultObject());
|
|
|
|
}
|
|
|
|
|
|
|
|
protected function buildWhereClauseParts(AphrontDatabaseConnection $conn) {
|
|
|
|
$where = parent::buildWhereClauseParts($conn);
|
|
|
|
|
|
|
|
if ($this->ids !== null) {
|
|
|
|
$where[] = qsprintf(
|
|
|
|
$conn,
|
|
|
|
'id IN (%Ld)',
|
|
|
|
$this->ids);
|
|
|
|
}
|
|
|
|
|
|
|
|
if ($this->phids !== null) {
|
|
|
|
$where[] = qsprintf(
|
|
|
|
$conn,
|
|
|
|
'phid in (%Ls)',
|
|
|
|
$this->phids);
|
|
|
|
}
|
|
|
|
|
|
|
|
if ($this->targetPHIDs !== null) {
|
|
|
|
$where[] = qsprintf(
|
|
|
|
$conn,
|
|
|
|
'buildTargetPHID in (%Ls)',
|
|
|
|
$this->targetPHIDs);
|
|
|
|
}
|
|
|
|
|
|
|
|
return $where;
|
|
|
|
}
|
|
|
|
|
Allow unit tests to have arbitrarily long names (>255 characters)
Summary:
Depends on D20179. Ref T13088. See PHI351. See PHI1018. In various cases, unit tests names are 19 paths mashed together.
This is probably not an ideal name, and the test harness should probably pick a better name, but if users are fine with it and don't want to do the work to summarize on their own, accept them. We may summarize with "..." in some cases depending on how this fares in the UI.
The actual implementation is a separate "strings" table which is just `<hash-of-string, full-string>`. The unit message table can end up being mostly strings, so this should reduce storage requirements a bit.
For now, I'm not forcing a migration: new writes use the new table, existing rows retain the data. I plan to provide a migration tool, recommend migration, then force migration eventually.
Prior to that, I'm likely to move at least some other columns to use this table (e.g., lint names), since we have a lot of similar data (arbitrarily long user string constants that we are unlikely to need to search or filter).
Test Plan: {F6213819}
Reviewers: amckinley
Reviewed By: amckinley
Subscribers: PHID-OPKG-gm6ozazyms6q6i22gyam
Maniphest Tasks: T13088
Differential Revision: https://secure.phabricator.com/D20180
2019-02-15 15:24:49 +01:00
|
|
|
protected function didFilterPage(array $messages) {
|
|
|
|
$indexes = array();
|
|
|
|
foreach ($messages as $message) {
|
|
|
|
$index = $message->getNameIndex();
|
|
|
|
if (strlen($index)) {
|
|
|
|
$indexes[$index] = $index;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if ($indexes) {
|
|
|
|
$map = HarbormasterString::newIndexMap($indexes);
|
|
|
|
|
|
|
|
foreach ($messages as $message) {
|
|
|
|
$index = $message->getNameIndex();
|
|
|
|
|
|
|
|
if (!strlen($index)) {
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
|
|
|
|
$name = idx($map, $index);
|
|
|
|
if ($name === null) {
|
|
|
|
$name = pht('Unknown Unit Message ("%s")', $index);
|
|
|
|
}
|
|
|
|
|
|
|
|
$message->setName($name);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return $messages;
|
|
|
|
}
|
|
|
|
|
2019-02-15 15:42:53 +01:00
|
|
|
public function getQueryApplicationClass() {
|
|
|
|
return 'PhabricatorHarbormasterApplication';
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|