mirror of
https://github.com/TryGhost/Ghost.git
synced 2024-11-24 14:43:08 +03:00
Added tests for DomainEventsAnalytics
no issue - Added unit tests for newly added `DomainEventsAnalytics` class to verify intended functionality
This commit is contained in:
parent
2c4d9e2776
commit
9b27804276
@ -0,0 +1,199 @@
|
||||
const assert = require('assert');
|
||||
const sinon = require('sinon');
|
||||
const ObjectId = require('bson-objectid').default;
|
||||
|
||||
// To test
|
||||
const DomainEventsAnalytics = require('../../../../../core/server/services/segment/DomainEventsAnalytics');
|
||||
|
||||
// Stubbed dependencies
|
||||
const DomainEvents = require('@tryghost/domain-events');
|
||||
const {MilestoneCreatedEvent} = require('@tryghost/milestones');
|
||||
const logging = require('@tryghost/logging');
|
||||
|
||||
describe('DomainEventsAnalytics', function () {
|
||||
describe('Constructor', function () {
|
||||
it('doesn\'t throw', function () {
|
||||
new DomainEventsAnalytics({});
|
||||
});
|
||||
});
|
||||
|
||||
describe('Domain events analytics service', function () {
|
||||
let domainAnalytics;
|
||||
let analyticsStub;
|
||||
let sentryStub;
|
||||
let loggingStub;
|
||||
|
||||
beforeEach(function () {
|
||||
analyticsStub = sinon.stub();
|
||||
sentryStub = sinon.stub();
|
||||
loggingStub = sinon.stub(logging, 'error');
|
||||
});
|
||||
|
||||
afterEach(function () {
|
||||
sinon.restore();
|
||||
});
|
||||
|
||||
it('subscribes to events', async function () {
|
||||
const domainEventsStub = sinon.stub(DomainEvents, 'subscribe').resolves();
|
||||
|
||||
domainAnalytics = new DomainEventsAnalytics({
|
||||
analytics: analyticsStub,
|
||||
trackDefaults: {
|
||||
userId: '1234',
|
||||
properties: {email: 'john@test.com'}
|
||||
},
|
||||
prefix: 'Pro: ',
|
||||
sentry: {
|
||||
captureException: sentryStub
|
||||
}
|
||||
});
|
||||
|
||||
domainAnalytics.subscribeToDomainEvents();
|
||||
assert(domainEventsStub.callCount === 1);
|
||||
assert(loggingStub.callCount === 0);
|
||||
});
|
||||
|
||||
it('handles milestone created event for 100 members', async function () {
|
||||
domainAnalytics = new DomainEventsAnalytics({
|
||||
analytics: {
|
||||
track: analyticsStub
|
||||
},
|
||||
trackDefaults: {
|
||||
userId: '1234',
|
||||
properties: {email: 'john@test.com'}
|
||||
},
|
||||
prefix: 'Pro: ',
|
||||
sentry: {
|
||||
captureException: sentryStub
|
||||
}
|
||||
});
|
||||
|
||||
domainAnalytics.subscribeToDomainEvents();
|
||||
|
||||
DomainEvents.dispatch(MilestoneCreatedEvent.create({
|
||||
milestone: {
|
||||
id: new ObjectId().toHexString(),
|
||||
type: 'members',
|
||||
value: 100,
|
||||
createdAt: new Date(),
|
||||
emailSentAt: new Date()
|
||||
}
|
||||
}));
|
||||
|
||||
await DomainEvents.allSettled();
|
||||
|
||||
assert(analyticsStub.callCount === 1);
|
||||
assert(analyticsStub.calledWith({
|
||||
userId: '1234',
|
||||
properties: {email: 'john@test.com'},
|
||||
event: 'Pro: 100 members reached'
|
||||
}));
|
||||
|
||||
DomainEvents.dispatch(MilestoneCreatedEvent.create({
|
||||
milestone: {
|
||||
id: new ObjectId().toHexString(),
|
||||
type: 'members',
|
||||
value: 1000,
|
||||
createdAt: new Date(),
|
||||
emailSentAt: new Date()
|
||||
}
|
||||
}));
|
||||
|
||||
await DomainEvents.allSettled();
|
||||
// Analytics should not be called again
|
||||
assert(analyticsStub.callCount === 1);
|
||||
assert(loggingStub.callCount === 0);
|
||||
});
|
||||
|
||||
it('handles milestone created event for $100 ARR', async function () {
|
||||
domainAnalytics = new DomainEventsAnalytics({
|
||||
analytics: {
|
||||
track: analyticsStub
|
||||
},
|
||||
trackDefaults: {
|
||||
userId: '9876',
|
||||
properties: {email: 'john+arr@test.com'}
|
||||
},
|
||||
prefix: 'Pro: ',
|
||||
sentry: {
|
||||
captureException: sentryStub
|
||||
}
|
||||
});
|
||||
|
||||
domainAnalytics.subscribeToDomainEvents();
|
||||
|
||||
DomainEvents.dispatch(MilestoneCreatedEvent.create({
|
||||
milestone: {
|
||||
id: new ObjectId().toHexString(),
|
||||
type: 'arr',
|
||||
currency: 'usd',
|
||||
value: 100,
|
||||
createdAt: new Date(),
|
||||
emailSentAt: new Date()
|
||||
}
|
||||
}));
|
||||
|
||||
await DomainEvents.allSettled();
|
||||
|
||||
assert(analyticsStub.callCount === 1);
|
||||
assert(analyticsStub.calledWith({
|
||||
userId: '9876',
|
||||
properties: {email: 'john+arr@test.com'},
|
||||
event: 'Pro: $100 MRR reached'
|
||||
}));
|
||||
assert(loggingStub.callCount === 0);
|
||||
|
||||
DomainEvents.dispatch(MilestoneCreatedEvent.create({
|
||||
milestone: {
|
||||
id: new ObjectId().toHexString(),
|
||||
type: 'arr',
|
||||
currency: 'usd',
|
||||
value: 1000,
|
||||
createdAt: new Date(),
|
||||
emailSentAt: new Date()
|
||||
}
|
||||
}));
|
||||
|
||||
await DomainEvents.allSettled();
|
||||
// Analytics should not be called again
|
||||
assert(analyticsStub.callCount === 1);
|
||||
assert(loggingStub.callCount === 0);
|
||||
});
|
||||
|
||||
it('can handle tracking errors', async function () {
|
||||
let error = new Error('Test error');
|
||||
domainAnalytics = new DomainEventsAnalytics({
|
||||
analytics: {
|
||||
track: analyticsStub.throws(error)
|
||||
},
|
||||
trackDefaults: {},
|
||||
prefix: '',
|
||||
sentry: {
|
||||
captureException: sentryStub
|
||||
}
|
||||
});
|
||||
|
||||
domainAnalytics.subscribeToDomainEvents();
|
||||
|
||||
try {
|
||||
DomainEvents.dispatch(MilestoneCreatedEvent.create({
|
||||
milestone: {
|
||||
id: new ObjectId().toHexString(),
|
||||
type: 'arr',
|
||||
currency: 'usd',
|
||||
value: 100,
|
||||
createdAt: new Date(),
|
||||
emailSentAt: new Date()
|
||||
}
|
||||
}));
|
||||
|
||||
await DomainEvents.allSettled();
|
||||
} catch (err) {
|
||||
assert(analyticsStub.callCount === 1);
|
||||
assert(sentryStub.callCount === 1);
|
||||
assert(sentryStub.calledWith(error));
|
||||
assert(loggingStub.callCount === 1);
|
||||
}
|
||||
});
|
||||
});
|
||||
});
|
@ -6,6 +6,6 @@ describe('Segment Analytics Service', function () {
|
||||
it('Provides expected public API', async function () {
|
||||
segmentService = require('../../../../../core/server/services/segment');
|
||||
|
||||
assert.ok(segmentService.initAndRun);
|
||||
assert.ok(segmentService.init);
|
||||
});
|
||||
});
|
||||
|
Loading…
Reference in New Issue
Block a user