use of com.google.cloud.storage.BucketInfo.LifecycleRule.SetStorageClassLifecycleAction in project terra-workspace-manager by DataBiosphere.
the class ControlledGcsBucketLifecycle method verifyUpdatedLifecycleRules.
private void verifyUpdatedLifecycleRules(List<? extends LifecycleRule> lifecycleRules) {
final LifecycleRule rule = lifecycleRules.get(0);
assertEquals(SetStorageClassLifecycleAction.TYPE, rule.getAction().getActionType());
final SetStorageClassLifecycleAction setStorageClassLifecycleAction = (SetStorageClassLifecycleAction) rule.getAction();
assertEquals(StorageClass.ARCHIVE, setStorageClassLifecycleAction.getStorageClass());
final LifecycleCondition condition = rule.getCondition();
assertEquals(30, condition.getAge());
// The datetime gets simplified to midnight UTC somewhere along the line
assertEquals(DateTime.parseRfc3339("1981-04-21"), condition.getCreatedBefore());
assertTrue(condition.getIsLive());
assertEquals(3, condition.getNumberOfNewerVersions());
final List<StorageClass> matchesStorageClass = condition.getMatchesStorageClass();
assertThat(matchesStorageClass, hasSize(1));
assertEquals(StorageClass.ARCHIVE, matchesStorageClass.get(0));
}
use of com.google.cloud.storage.BucketInfo.LifecycleRule.SetStorageClassLifecycleAction in project terra-workspace-manager by DataBiosphere.
the class ControlledGcsBucketLifecycle method verifyClonedLifecycleRules.
private void verifyClonedLifecycleRules(Bucket destinationBucket) {
// We can't rely on the order of the lifecycle rules being maintained
final LifecycleRule clonedDeleteRule = destinationBucket.getLifecycleRules().stream().filter(r -> DeleteLifecycleAction.TYPE.equals(r.getAction().getActionType())).findFirst().orElseThrow(() -> new RuntimeException("Can't find Delete lifecycle rule."));
assertEquals(BUCKET_LIFECYCLE_RULE_1_CONDITION_AGE, clonedDeleteRule.getCondition().getAge());
assertEquals(BUCKET_LIFECYCLE_RULE_1_CONDITION_LIVE, clonedDeleteRule.getCondition().getIsLive());
assertEquals(StorageClass.ARCHIVE, clonedDeleteRule.getCondition().getMatchesStorageClass().get(0));
assertEquals(BUCKET_LIFECYCLE_RULE_1_CONDITION_NUM_NEWER_VERSIONS, clonedDeleteRule.getCondition().getNumberOfNewerVersions());
final LifecycleRule setStorageClassRule = destinationBucket.getLifecycleRules().stream().filter(r -> SetStorageClassLifecycleAction.TYPE.equals(r.getAction().getActionType())).findFirst().orElseThrow(() -> new RuntimeException("Can't find SetStorageClass lifecycle rule."));
final SetStorageClassLifecycleAction setStorageClassLifecycleAction = (SetStorageClassLifecycleAction) setStorageClassRule.getAction();
assertEquals(StorageClass.NEARLINE, setStorageClassLifecycleAction.getStorageClass());
assertEquals(DateTime.parseRfc3339("2007-01-03"), setStorageClassRule.getCondition().getCreatedBefore());
assertThat(setStorageClassRule.getCondition().getMatchesStorageClass(), contains(StorageClass.STANDARD));
}
use of com.google.cloud.storage.BucketInfo.LifecycleRule.SetStorageClassLifecycleAction in project terra-workspace-manager by DataBiosphere.
the class UpdateGcsBucketStepTest method testUndoStep.
@Test
public void testUndoStep() throws InterruptedException, RetryException {
final StepResult result = updateGcsBucketStep.undoStep(mockFlightContext);
verify(mockBuiltBucketCow, times(2)).update();
assertEquals(StepResult.getStepResultSuccess(), result);
final StorageClass storageClass = storageClassCaptor.getValue();
assertEquals(StorageClass.NEARLINE, storageClass);
final List<LifecycleRule> rules = lifecycleRulesCaptor.getValue();
assertThat(rules, hasSize(1));
final LifecycleAction action = rules.get(0).getAction();
assertEquals(SetStorageClassLifecycleAction.TYPE, action.getActionType());
assertEquals(StorageClass.COLDLINE, ((SetStorageClassLifecycleAction) action).getStorageClass());
final LifecycleCondition condition = rules.get(0).getCondition();
assertEquals(45, condition.getAge());
assertEquals(toGoogleDateTime(OFFSET_DATE_TIME_2).getValue(), condition.getCreatedBefore().getValue());
assertEquals(1, condition.getNumberOfNewerVersions());
assertTrue(condition.getIsLive());
assertThat(condition.getMatchesStorageClass(), hasSize(1));
assertEquals(StorageClass.STANDARD, condition.getMatchesStorageClass().get(0));
}
use of com.google.cloud.storage.BucketInfo.LifecycleRule.SetStorageClassLifecycleAction in project terra-workspace-manager by DataBiosphere.
the class UpdateGcsBucketStepTest method testDoStep.
@Test
public void testDoStep() throws InterruptedException, RetryException {
final StepResult result = updateGcsBucketStep.doStep(mockFlightContext);
verify(mockBuiltBucketCow, times(2)).update();
assertEquals(StepResult.getStepResultSuccess(), result);
final StorageClass storageClass = storageClassCaptor.getValue();
assertEquals(StorageClass.STANDARD, storageClass);
final List<LifecycleRule> rules = lifecycleRulesCaptor.getValue();
assertThat(rules, hasSize(2));
assertEquals(DeleteLifecycleAction.TYPE, rules.get(0).getAction().getActionType());
final LifecycleCondition rule1condition = rules.get(0).getCondition();
assertEquals(31, rule1condition.getAge());
// TODO: [PF-933] This (and all other date checks in this test) work around the fact that
// Stairway FlightMap loses time zone data at serialization time by normalizing to UTC via call
// to getValue(). Once PF-933 is addressed, these assertions should all revert to apply time
// zone comparison by removing the getValue() call from both sides of the equality assertion.
assertEquals(toGoogleDateTime(OFFSET_DATE_TIME_2).getValue(), rule1condition.getCreatedBefore().getValue());
assertEquals(3, rule1condition.getNumberOfNewerVersions());
assertTrue(rule1condition.getIsLive());
assertThat(rule1condition.getMatchesStorageClass(), hasSize(2));
assertEquals(StorageClass.ARCHIVE, rule1condition.getMatchesStorageClass().get(0));
assertEquals(StorageClass.STANDARD, rule1condition.getMatchesStorageClass().get(1));
final LifecycleAction rule2action = rules.get(1).getAction();
assertEquals(SetStorageClassLifecycleAction.TYPE, rule2action.getActionType());
assertEquals(StorageClass.NEARLINE, ((SetStorageClassLifecycleAction) rule2action).getStorageClass());
final LifecycleCondition rule2condition = rules.get(1).getCondition();
assertEquals(15, rule2condition.getAge());
assertEquals(toGoogleDateTime(OFFSET_DATE_TIME_1).getValue(), rule2condition.getCreatedBefore().getValue());
assertEquals(5, rule2condition.getNumberOfNewerVersions());
assertTrue(rule2condition.getIsLive());
assertThat(rule2condition.getMatchesStorageClass(), hasSize(1));
assertEquals(StorageClass.ARCHIVE, rule2condition.getMatchesStorageClass().get(0));
}
Aggregations