1
0
Fork 0
mirror of https://we.phorge.it/source/phorge.git synced 2025-01-10 23:01:04 +01:00

Formalize some more Drydock conditions and bookkeeping

Summary:
Ref T13677. Track which resources a given lease has begun allocating or reclaiming in a more formal way, and add logging for waiting actions.

The "allocating" mechanism is new. This will replace an existing similar "reclaiming" mechanism in a future change.

Test Plan: See followup changes.

Subscribers: yelirekim, PHID-OPKG-gm6ozazyms6q6i22gyam

Maniphest Tasks: T13677

Differential Revision: https://secure.phabricator.com/D21806
This commit is contained in:
epriestley 2022-05-05 14:43:09 -07:00
parent 1b6727ac3d
commit 13a37282bc
5 changed files with 106 additions and 5 deletions

View file

@ -1229,6 +1229,8 @@ phutil_register_library_map(array(
'DrydockLeaseStatus' => 'applications/drydock/constants/DrydockLeaseStatus.php',
'DrydockLeaseUpdateWorker' => 'applications/drydock/worker/DrydockLeaseUpdateWorker.php',
'DrydockLeaseViewController' => 'applications/drydock/controller/DrydockLeaseViewController.php',
'DrydockLeaseWaitingForActivationLogType' => 'applications/drydock/logtype/DrydockLeaseWaitingForActivationLogType.php',
'DrydockLeaseWaitingForReclamationLogType' => 'applications/drydock/logtype/DrydockLeaseWaitingForReclamationLogType.php',
'DrydockLeaseWaitingForResourcesLogType' => 'applications/drydock/logtype/DrydockLeaseWaitingForResourcesLogType.php',
'DrydockLog' => 'applications/drydock/storage/DrydockLog.php',
'DrydockLogController' => 'applications/drydock/controller/DrydockLogController.php',
@ -7294,6 +7296,8 @@ phutil_register_library_map(array(
'DrydockLeaseStatus' => 'PhabricatorObjectStatus',
'DrydockLeaseUpdateWorker' => 'DrydockWorker',
'DrydockLeaseViewController' => 'DrydockLeaseController',
'DrydockLeaseWaitingForActivationLogType' => 'DrydockLogType',
'DrydockLeaseWaitingForReclamationLogType' => 'DrydockLogType',
'DrydockLeaseWaitingForResourcesLogType' => 'DrydockLogType',
'DrydockLog' => array(
'DrydockDAO',

View file

@ -43,11 +43,6 @@ final class DrydockWorkingCopyBlueprintImplementation
return false;
}
// TODO: If we have a pending resource which is compatible with the
// configuration for this lease, prevent a new allocation? Otherwise the
// queue can fill up with copies of requests from the same lease. But
// maybe we can deal with this with "pre-leasing"?
return true;
}

View file

@ -0,0 +1,23 @@
<?php
final class DrydockLeaseWaitingForActivationLogType extends DrydockLogType {
const LOGCONST = 'core.lease.waiting-for-activation';
public function getLogTypeName() {
return pht('Waiting For Activation');
}
public function getLogTypeIcon(array $data) {
return 'fa-clock-o yellow';
}
public function renderLog(array $data) {
$resource_phids = idx($data, 'resourcePHIDs', array());
return pht(
'Waiting for activation of resources: %s.',
$this->renderHandleList($resource_phids));
}
}

View file

@ -0,0 +1,23 @@
<?php
final class DrydockLeaseWaitingForReclamationLogType extends DrydockLogType {
const LOGCONST = 'core.lease.waiting-for-reclamation';
public function getLogTypeName() {
return pht('Waiting For Reclamation');
}
public function getLogTypeIcon(array $data) {
return 'fa-clock-o yellow';
}
public function renderLog(array $data) {
$resource_phids = idx($data, 'resourcePHIDs', array());
return pht(
'Waiting for reclamation of resources: %s.',
$this->renderHandleList($resource_phids));
}
}

View file

@ -392,6 +392,62 @@ final class DrydockLease extends DrydockDAO
));
}
public function getAllocatedResourcePHIDs() {
return $this->getAttribute('internal.resourcePHIDs.allocated', array());
}
public function setAllocatedResourcePHIDs(array $phids) {
return $this->setAttribute('internal.resourcePHIDs.allocated', $phids);
}
public function addAllocatedResourcePHIDs(array $phids) {
$allocated_phids = $this->getAllocatedResourcePHIDs();
foreach ($phids as $phid) {
$allocated_phids[$phid] = $phid;
}
return $this->setAllocatedResourcePHIDs($allocated_phids);
}
public function removeAllocatedResourcePHIDs(array $phids) {
$allocated_phids = $this->getAllocatedResourcePHIDs();
foreach ($phids as $phid) {
unset($allocated_phids[$phid]);
}
return $this->setAllocatedResourcePHIDs($allocated_phids);
}
public function getReclaimedResourcePHIDs() {
return $this->getAttribute('internal.resourcePHIDs.reclaimed', array());
}
public function setReclaimedResourcePHIDs(array $phids) {
return $this->setAttribute('internal.resourcePHIDs.reclaimed', $phids);
}
public function addReclaimedResourcePHIDs(array $phids) {
$reclaimed_phids = $this->getReclaimedResourcePHIDs();
foreach ($phids as $phid) {
$reclaimed_phids[$phid] = $phid;
}
return $this->setReclaimedResourcePHIDs($reclaimed_phids);
}
public function removeReclaimedResourcePHIDs(array $phids) {
$reclaimed_phids = $this->getReclaimedResourcePHIDs();
foreach ($phids as $phid) {
unset($reclaimed_phids[$phid]);
}
return $this->setReclaimedResourcePHIDs($reclaimed_phids);
}
public function setAwakenTaskIDs(array $ids) {
$this->setAttribute('internal.awakenTaskIDs', $ids);
return $this;