Skip to content

Commit

Permalink
Remove 'track' property from ImpressionDTO, to not modify the Impress…
Browse files Browse the repository at this point in the history
…ionListener types
  • Loading branch information
EmilianoSanchez committed Dec 11, 2024
1 parent e6d46fd commit f9dc947
Show file tree
Hide file tree
Showing 5 changed files with 20 additions and 21 deletions.
19 changes: 9 additions & 10 deletions src/sdkClient/client.ts
Original file line number Diff line number Diff line change
Expand Up @@ -34,11 +34,11 @@ export function clientFactory(params: ISdkFactoryContext): SplitIO.IClient | Spl
const stopTelemetryTracker = telemetryTracker.trackEval(withConfig ? TREATMENT_WITH_CONFIG : TREATMENT);

const wrapUp = (evaluationResult: IEvaluationResult) => {
const queue: SplitIO.ImpressionDTO[] = [];
const queue: [impression: SplitIO.ImpressionDTO, track?: boolean][] = [];
const treatment = processEvaluation(evaluationResult, featureFlagName, key, attributes, withConfig, methodName, queue);
impressionsTracker.track(queue, attributes);

stopTelemetryTracker(queue[0] && queue[0].label);
stopTelemetryTracker(queue[0] && queue[0][0].label);
return treatment;
};

Expand All @@ -59,14 +59,14 @@ export function clientFactory(params: ISdkFactoryContext): SplitIO.IClient | Spl
const stopTelemetryTracker = telemetryTracker.trackEval(withConfig ? TREATMENTS_WITH_CONFIG : TREATMENTS);

const wrapUp = (evaluationResults: Record<string, IEvaluationResult>) => {
const queue: SplitIO.ImpressionDTO[] = [];
const queue: [impression: SplitIO.ImpressionDTO, track?: boolean][] = [];
const treatments: Record<string, SplitIO.Treatment | SplitIO.TreatmentWithConfig> = {};
Object.keys(evaluationResults).forEach(featureFlagName => {
treatments[featureFlagName] = processEvaluation(evaluationResults[featureFlagName], featureFlagName, key, attributes, withConfig, methodName, queue);
});
impressionsTracker.track(queue, attributes);

stopTelemetryTracker(queue[0] && queue[0].label);
stopTelemetryTracker(queue[0] && queue[0][0].label);
return treatments;
};

Expand All @@ -87,15 +87,15 @@ export function clientFactory(params: ISdkFactoryContext): SplitIO.IClient | Spl
const stopTelemetryTracker = telemetryTracker.trackEval(method);

const wrapUp = (evaluationResults: Record<string, IEvaluationResult>) => {
const queue: SplitIO.ImpressionDTO[] = [];
const queue: [impression: SplitIO.ImpressionDTO, track?: boolean][] = [];
const treatments: Record<string, SplitIO.Treatment | SplitIO.TreatmentWithConfig> = {};
const evaluations = evaluationResults;
Object.keys(evaluations).forEach(featureFlagName => {
treatments[featureFlagName] = processEvaluation(evaluations[featureFlagName], featureFlagName, key, attributes, withConfig, methodName, queue);
});
impressionsTracker.track(queue, attributes);

stopTelemetryTracker(queue[0] && queue[0].label);
stopTelemetryTracker(queue[0] && queue[0][0].label);
return treatments;
};

Expand Down Expand Up @@ -128,7 +128,7 @@ export function clientFactory(params: ISdkFactoryContext): SplitIO.IClient | Spl
attributes: SplitIO.Attributes | undefined,
withConfig: boolean,
invokingMethodName: string,
queue: SplitIO.ImpressionDTO[]
queue: [impression: SplitIO.ImpressionDTO, track?: boolean][]
): SplitIO.Treatment | SplitIO.TreatmentWithConfig {
const matchingKey = getMatching(key);
const bucketingKey = getBucketing(key);
Expand All @@ -138,16 +138,15 @@ export function clientFactory(params: ISdkFactoryContext): SplitIO.IClient | Spl

if (validateSplitExistence(log, readinessManager, featureFlagName, label, invokingMethodName)) {
log.info(IMPRESSION_QUEUEING);
queue.push({
queue.push([{
feature: featureFlagName,
keyName: matchingKey,
treatment,
time: Date.now(),
bucketingKey,
label,
changeNumber: changeNumber as number,
track
});
}, track]);
}

if (withConfig) {
Expand Down
16 changes: 8 additions & 8 deletions src/trackers/__tests__/impressionsTracker.spec.ts
Original file line number Diff line number Diff line change
Expand Up @@ -70,7 +70,7 @@ describe('Impressions Tracker', () => {

expect(fakeImpressionsCache.track).not.toBeCalled(); // cache method should not be called by just creating a tracker

tracker.track([imp1, imp2, imp3]);
tracker.track([[imp1], [imp2], [imp3]]);

expect(fakeImpressionsCache.track.mock.calls[0][0]).toEqual([imp1, imp2, imp3]); // Should call the storage track method once we invoke .track() method, passing queued params in a sequence.
});
Expand All @@ -93,7 +93,7 @@ describe('Impressions Tracker', () => {
expect(fakeIntegrationsManager.handleImpression).not.toBeCalled(); // The integrations manager handleImpression method should not be invoked if we haven't tracked impressions.

// We signal that we actually want to track the queued impressions.
tracker.track([fakeImpression, fakeImpression2], fakeAttributes);
tracker.track([[fakeImpression], [fakeImpression2]], fakeAttributes);

expect(fakeImpressionsCache.track.mock.calls[0][0]).toEqual([fakeImpression, fakeImpression2]); // Even with a listener, impression should be sent to the cache
expect(fakeListener.logImpression).not.toBeCalled(); // The listener should not be executed synchronously.
Expand Down Expand Up @@ -157,7 +157,7 @@ describe('Impressions Tracker', () => {
expect(fakeImpressionsCache.track).not.toBeCalled(); // storage method should not be called until impressions are tracked.

trackers.forEach(tracker => {
tracker.track([impression, impression2, impression3]);
tracker.track([[impression], [impression2], [impression3]]);

const lastArgs = fakeImpressionsCache.track.mock.calls[fakeImpressionsCache.track.mock.calls.length - 1];

Expand All @@ -182,7 +182,7 @@ describe('Impressions Tracker', () => {

expect(fakeImpressionsCache.track).not.toBeCalled(); // cache method should not be called by just creating a tracker

tracker.track([impression, impression2, impression3]);
tracker.track([[impression], [impression2], [impression3]]);

const lastArgs = fakeImpressionsCache.track.mock.calls[fakeImpressionsCache.track.mock.calls.length - 1];

Expand All @@ -203,19 +203,19 @@ describe('Impressions Tracker', () => {

const tracker = impressionsTrackerFactory(settings, fakeImpressionsCache, strategy, fakeWhenInit);

tracker.track([impression]);
tracker.track([[impression]]);
expect(fakeImpressionsCache.track).toBeCalledTimes(1); // impression should be tracked if userConsent is undefined

settings.userConsent = 'UNKNOWN';
tracker.track([impression]);
tracker.track([[impression]]);
expect(fakeImpressionsCache.track).toBeCalledTimes(2); // impression should be tracked if userConsent is unknown

settings.userConsent = 'GRANTED';
tracker.track([impression]);
tracker.track([[impression]]);
expect(fakeImpressionsCache.track).toBeCalledTimes(3); // impression should be tracked if userConsent is granted

settings.userConsent = 'DECLINED';
tracker.track([impression]);
tracker.track([[impression]]);
expect(fakeImpressionsCache.track).toBeCalledTimes(3); // impression should not be tracked if userConsent is declined
});

Expand Down
3 changes: 2 additions & 1 deletion src/trackers/impressionsTracker.ts
Original file line number Diff line number Diff line change
Expand Up @@ -28,9 +28,10 @@ export function impressionsTrackerFactory(
const { log, impressionListener, runtime: { ip, hostname }, version } = settings;

return {
track(impressions: SplitIO.ImpressionDTO[], attributes?: SplitIO.Attributes) {
track(imps: [impression: SplitIO.ImpressionDTO, track?: boolean][], attributes?: SplitIO.Attributes) {
if (settings.userConsent === CONSENT_DECLINED) return;

const impressions = imps.map((item) => item[0]);
const impressionsCount = impressions.length;
const { impressionsToStore, impressionsToListener, deduped } = strategy.process(impressions);

Expand Down
2 changes: 1 addition & 1 deletion src/trackers/types.ts
Original file line number Diff line number Diff line change
Expand Up @@ -18,7 +18,7 @@ export interface IImpressionsHandler {
}

export interface IImpressionsTracker {
track(impressions: SplitIO.ImpressionDTO[], attributes?: SplitIO.Attributes): void
track(impressions: [impression: SplitIO.ImpressionDTO, track?: boolean][], attributes?: SplitIO.Attributes): void
}

/** Telemetry tracker */
Expand Down
1 change: 0 additions & 1 deletion types/splitio.d.ts
Original file line number Diff line number Diff line change
Expand Up @@ -811,7 +811,6 @@ declare namespace SplitIO {
label: string;
changeNumber: number;
pt?: number;
track?: boolean;
}
/**
* Object with information about an impression. It contains the generated impression DTO as well as
Expand Down

0 comments on commit f9dc947

Please sign in to comment.