This repository has been archived by the owner on Jul 24, 2021. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 11
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
We will delete all device reports (and associated validation_state records, and then orphaned validation_results) that are older than 6 months, except we retain the most recent report of each state (error, fail, pass). Due to the amount of time to run (6+ hours), it is implemented mainly as a command that can be run in parallel with normal operations, rather than as a database migration that is run in between system restarts.
- Loading branch information
1 parent
163dd8c
commit 569c623
Showing
2 changed files
with
66 additions
and
79 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,29 @@ | ||
SELECT run_migration(171, $$ | ||
|
||
-- create a placeholder validation_state record for every device_report without a | ||
-- validation_state record pointing to it | ||
-- (reports created before 2019-01-08 were not associated with validation_states, so we had to | ||
-- match them up as best we could based on similar timestamps, and not everyone found his | ||
-- match.) | ||
insert into validation_state (validation_plan_id, created, status, device_report_id, device_id, hardware_product_id) | ||
( | ||
select | ||
hardware_product.validation_plan_id, | ||
device_report.created, | ||
'error', | ||
device_report.id, | ||
device_report.device_id, | ||
device.hardware_product_id | ||
from device_report | ||
left join validation_state on validation_state.device_report_id = device_report.id | ||
left join device on device_report.device_id = device.id | ||
left join hardware_product on hardware_product.id = device.hardware_product_id | ||
where validation_state.id is null | ||
); | ||
|
||
-- now we can run bin/conch thin_device_reports, which will delete all device_report rows | ||
-- (cascading to validation_state, validation_state_member) which are older than six months, | ||
-- except for the most recent report of each validation status (error, fail, pass).. | ||
-- and then delete newly-orphaned validation_result rows. | ||
|
||
$$); |