Skip to content

Commit

Permalink
adapt lifecycle tests to support transition topic
Browse files Browse the repository at this point in the history
Issue: BB-467
  • Loading branch information
Kerkesni committed Nov 9, 2023
1 parent 285756d commit a2826dd
Show file tree
Hide file tree
Showing 9 changed files with 97 additions and 6 deletions.
21 changes: 20 additions & 1 deletion tests/config.json
Original file line number Diff line number Diff line change
Expand Up @@ -156,6 +156,7 @@
"zookeeperPath": "/lifecycletest",
"bucketTasksTopic": "backbeat-test-dummy-bucket-task",
"objectTasksTopic": "backbeat-test-dummy-object-task",
"transitionTasksTopic": "backbeat-test-dummy-transition-task",
"conductor": {
"cronRule": "0 */5 * * * *",
"probeServer": {
Expand Down Expand Up @@ -196,11 +197,29 @@
"port": 8554
}
},
"transitionProcessor": {
"groupId": "backbeat-lifecycle-transition-processor-group",
"retry": {
"maxRetries": 5,
"timeoutS": 300,
"backoff": {
"min": 1000,
"max": 300000,
"jitter": 0.1,
"factor": 1.5
}
},
"concurrency": 10,
"probeServer": {
"port": 8554
}
},
"auth": {
"type": "account",
"account": "bart"
},
"coldStorageArchiveTopicPrefix": "cold-archive-req-"
"coldStorageArchiveTopicPrefix": "cold-archive-req-",
"coldStorageTopics": []
},
"gc": {
"topic": "backbeat-test-gc",
Expand Down
1 change: 1 addition & 0 deletions tests/functional/lifecycle/LifecycleConductor.spec.js
Original file line number Diff line number Diff line change
Expand Up @@ -95,6 +95,7 @@ const baseLCConfig = {
zookeeperPath: '/test/lifecycle',
bucketTasksTopic,
objectTasksTopic: 'backbeat-lifecycle-object-tasks-spec',
transitionTasksTopic: 'backbeat-lifecycle-transition-tasks-spec',
conductor: {
cronRule: '*/5 * * * * *',
backlogControl: {
Expand Down
16 changes: 12 additions & 4 deletions tests/functional/lifecycle/LifecycleTask.js
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,12 @@ const LifecycleRule = require('arsenal').models.LifecycleRule;
const LifecycleTask = require('../../../extensions/lifecycle/tasks/LifecycleTask');
const testConfig = require('../../config.json');
const { objectMD } = require('../utils/MetadataMock');
const {
bucketTasksTopic,
objectTasksTopic,
transitionTasksTopic,
} = require('./configObjects');

const timeOptions = {
expireOneDayEarlier: true,
transitionOneDayEarlier: true,
Expand Down Expand Up @@ -328,10 +334,10 @@ class ProducerMock {

sendToTopic(topicName, entries, cb) {
const entry = JSON.parse(entries[0].message);
if (topicName === 'bucket-tasks') {
if (topicName === bucketTasksTopic) {
this.sendCount.bucket++;
this.entries.bucket.push(entry);
} else if (topicName === 'object-tasks') {
} else if (topicName === objectTasksTopic) {
this.sendCount.object++;
this.entries.object.push(entry.target.key);
} else if (topicName === 'backbeat-data-mover') {
Expand Down Expand Up @@ -421,8 +427,9 @@ class LifecycleBucketProcessorMock {
bootstrapList: [{ site: 'us-east-2', type: 'aws_s3' }],
s3Endpoint: s3config.endpoint,
s3Auth: lifecycle.auth,
bucketTasksTopic: 'bucket-tasks',
objectTasksTopic: 'object-tasks',
bucketTasksTopic,
objectTasksTopic,
transitionTasksTopic,
kafkaBacklogMetrics: this._kafkaBacklogMetrics,
pausedLocations: new Set(),
log: this._log,
Expand Down Expand Up @@ -510,6 +517,7 @@ describe('lifecycle task functional tests', function dF() {
entries.transitions.forEach(transition => {
assert.strictEqual(transition.target.bucket, 'test-bucket');
assert.strictEqual(transition.toLocation, 'us-east-2');
assert.strictEqual(transition.resultsTopic, transitionTasksTopic);
});
}

Expand Down
3 changes: 3 additions & 0 deletions tests/functional/lifecycle/LifecycleTaskV2-versioned.js
Original file line number Diff line number Diff line change
Expand Up @@ -39,9 +39,11 @@ const destinationLocation = 'us-east-2';

const bucketTopic = 'bucket-topic';
const objectTopic = 'object-topic';
const transitionTopic = 'transition-topic';
const dataMoverTopic = 'backbeat-data-mover';
const testKafkaEntry = new TestKafkaEntry({
objectTopic,
transitionTopic,
bucketTopic,
dataMoverTopic,
ownerId,
Expand Down Expand Up @@ -72,6 +74,7 @@ describe('LifecycleTaskV2 with bucket versioned', () => {
producer,
bucketTasksTopic: bucketTopic,
objectTasksTopic: objectTopic,
transitionTasksTopic: transitionTopic,
kafkaBacklogMetrics: { snapshotTopicOffsets: () => {} },
pausedLocations: new Set(),
log,
Expand Down
3 changes: 3 additions & 0 deletions tests/functional/lifecycle/LifecycleTaskV2.js
Original file line number Diff line number Diff line change
Expand Up @@ -40,9 +40,11 @@ const destinationLocation = 'us-east-2';

const bucketTopic = 'bucket-topic';
const objectTopic = 'object-topic';
const transitionTopic = 'transition-topic';
const dataMoverTopic = 'backbeat-data-mover';
const testKafkaEntry = new TestKafkaEntry({
objectTopic,
transitionTopic,
bucketTopic,
dataMoverTopic,
ownerId,
Expand Down Expand Up @@ -73,6 +75,7 @@ describe('LifecycleTaskV2 with bucket non-versioned', () => {
producer,
bucketTasksTopic: bucketTopic,
objectTasksTopic: objectTopic,
transitionTasksTopic: transitionTopic,
kafkaBacklogMetrics: { snapshotTopicOffsets: () => {} },
pausedLocations: new Set(),
log,
Expand Down
3 changes: 3 additions & 0 deletions tests/functional/lifecycle/configObjects.js
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
const bucketTasksTopic = 'bucket-tasks';
const objectTasksTopic = 'object-tasks';
const transitionTasksTopic = 'transition-tasks';

const zkConfig = {
connectionString: 'localhost:2181',
Expand Down Expand Up @@ -35,6 +36,7 @@ const lcConfig = {
},
bucketTasksTopic,
objectTasksTopic,
transitionTasksTopic,
rules: {
expiration: {
enabled: true,
Expand Down Expand Up @@ -69,6 +71,7 @@ const timeOptions = {
module.exports = {
bucketTasksTopic,
objectTasksTopic,
transitionTasksTopic,
zkConfig,
kafkaConfig,
lcConfig,
Expand Down
4 changes: 3 additions & 1 deletion tests/functional/lifecycle/utils.js
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,7 @@ class TestKafkaEntry {
constructor(state) {
const {
objectTopic,
transitionTopic,
bucketTopic,
dataMoverTopic,
ownerId,
Expand All @@ -14,6 +15,7 @@ class TestKafkaEntry {
} = state;

this.objectTopic = objectTopic;
this.transitionTopic = transitionTopic;
this.bucketTopic = bucketTopic;
this.dataMoverTopic = dataMoverTopic;
this.ownerId = ownerId;
Expand Down Expand Up @@ -96,7 +98,7 @@ class TestKafkaEntry {
assert.strictEqual(metrics.contentLength, contentLength);

assert.strictEqual(message.toLocation, destinationLocation);
assert.strictEqual(message.resultsTopic, this.objectTopic);
assert.strictEqual(message.resultsTopic, this.transitionTopic);
}

expectBucketEntry(e, {
Expand Down
26 changes: 26 additions & 0 deletions tests/unit/lifecycle/LifecycleObjectExpirationProcessor.spec.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,26 @@
const assert = require('assert');
const config = require('../../config.json');
const LifecycleObjectExpirationProcessor =
require('../../../extensions/lifecycle/objectProcessor/LifecycleObjectExpirationProcessor');

describe('LifecycleObjectExpirationProcessor', () => {
let objectProcessor;

beforeEach(() => {
objectProcessor = new LifecycleObjectExpirationProcessor(
config.zookeeper,
config.kafka,
config.extensions.lifecycle,
config.s3,
);
});

it('consumer params should contain object tasks topic', () => {
const consumerParams = objectProcessor.getConsumerParams();
assert.deepStrictEqual(Object.keys(consumerParams), [config.extensions.lifecycle.objectTasksTopic]);
assert.strictEqual(
consumerParams[config.extensions.lifecycle.objectTasksTopic].topic,
config.extensions.lifecycle.objectTasksTopic,
);
});
});
26 changes: 26 additions & 0 deletions tests/unit/lifecycle/LifecycleObjectTransitionProcessor.spec.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,26 @@
const assert = require('assert');
const config = require('../../config.json');
const LifecycleObjectTransitionProcessor =
require('../../../extensions/lifecycle/objectProcessor/LifecycleObjectTransitionProcessor');

describe('LifecycleObjectExpirationProcessor', () => {
let objectProcessor;

beforeEach(() => {
objectProcessor = new LifecycleObjectTransitionProcessor(
config.zookeeper,
config.kafka,
config.extensions.lifecycle,
config.s3,
);
});

it('consumer params should contain transition tasks topic', () => {
const consumerParams = objectProcessor.getConsumerParams();
assert.deepStrictEqual(Object.keys(consumerParams), [config.extensions.lifecycle.transitionTasksTopic]);
assert.strictEqual(
consumerParams[config.extensions.lifecycle.transitionTasksTopic].topic,
config.extensions.lifecycle.transitionTasksTopic
);
});
});

0 comments on commit a2826dd

Please sign in to comment.