From b3a2ab5ac3cd7496846f6e381372e21520b02019 Mon Sep 17 00:00:00 2001 From: Amitosh Swain Mahapatra Date: Tue, 22 Oct 2019 22:45:20 +0000 Subject: [PATCH] Show versions that are active when delete_version_after is configured (#7685) --- ui/app/models/secret-v2-version.js | 8 +++-- .../unit/models/secret-v2-version-test.js | 31 +++++++++++++++++++ 2 files changed, 37 insertions(+), 2 deletions(-) create mode 100644 ui/tests/unit/models/secret-v2-version-test.js diff --git a/ui/app/models/secret-v2-version.js b/ui/app/models/secret-v2-version.js index 442f79e4f50d..4ad9c11dc1a2 100644 --- a/ui/app/models/secret-v2-version.js +++ b/ui/app/models/secret-v2-version.js @@ -1,6 +1,6 @@ import Secret from './secret'; import DS from 'ember-data'; -import { bool } from '@ember/object/computed'; +import { computed } from '@ember/object'; const { attr, belongsTo } = DS; @@ -12,7 +12,11 @@ export default Secret.extend({ path: attr('string'), deletionTime: attr('string'), createdTime: attr('string'), - deleted: bool('deletionTime'), + deleted: computed('deletionTime', function() { + const deletionTime = new Date(this.get('deletionTime')); + const now = new Date(); + return deletionTime <= now; + }), destroyed: attr('boolean'), currentVersion: attr('number'), }); diff --git a/ui/tests/unit/models/secret-v2-version-test.js b/ui/tests/unit/models/secret-v2-version-test.js new file mode 100644 index 000000000000..d9dfb0148ac1 --- /dev/null +++ b/ui/tests/unit/models/secret-v2-version-test.js @@ -0,0 +1,31 @@ +import { run } from '@ember/runloop'; +import { module, test } from 'qunit'; +import { setupTest } from 'ember-qunit'; + +module('Unit | Model | secret-v2-version', function(hooks) { + setupTest(hooks); + + test('deleted is true for a past deletionTime', function(assert) { + let model; + run(() => { + model = run(() => + this.owner.lookup('service:store').createRecord('secret-v2-version', { + deletionTime: '2000-10-14T00:00:00.000000Z', + }) + ); + assert.equal(model.get('deleted'), true); + }); + }); + + test('deleted is false for a future deletionTime', function(assert) { + let model; + run(() => { + model = run(() => + this.owner.lookup('service:store').createRecord('secret-v2-version', { + deletionTime: '2999-10-14T00:00:00.000000Z', + }) + ); + assert.equal(model.get('deleted'), false); + }); + }); +});