Skip to content

Commit

Permalink
[FSSDK-8184] override attribute bug fix of track method (#287)
Browse files Browse the repository at this point in the history
  • Loading branch information
junaed-optimizely authored Nov 6, 2024
1 parent f3185b7 commit 33b4344
Show file tree
Hide file tree
Showing 2 changed files with 37 additions and 20 deletions.
56 changes: 37 additions & 19 deletions src/client.spec.ts
Original file line number Diff line number Diff line change
Expand Up @@ -1390,36 +1390,54 @@ describe('ReactSDKClient', () => {
expect(mockFn).toHaveBeenCalledTimes(0);
});

it('track works as expected', () => {
const mockFn = mockInnerClient.track as jest.Mock;
describe('track with different parameters', () => {
it('track with only event key, calls inner client with valid arguments', () => {
const mockFn = mockInnerClient.track as jest.Mock;
instance.track('evt1');

instance.track('evt1');
expect(mockFn).toHaveBeenCalledTimes(1);
expect(mockFn).toHaveBeenCalledWith('evt1', 'user1', { foo: 'bar' }, undefined);
});

expect(mockFn).toHaveBeenCalledTimes(1);
expect(mockFn).toHaveBeenCalledWith('evt1', 'user1', { foo: 'bar' }, undefined);
it('track with event key and overrided user id and attributes, calls inner client with valid arguments', () => {
const mockFn = mockInnerClient.track as jest.Mock;
instance.track('evt1', 'user2', { bar: 'baz' });

mockFn.mockReset();
expect(mockFn).toHaveBeenCalledTimes(1);
expect(mockFn).toHaveBeenCalledWith('evt1', 'user2', { bar: 'baz' }, undefined);
});

instance.track('evt1', 'user2', { bar: 'baz' });
it('track with event key and event tags, calls inner client with valid arguments', () => {
const mockFn = mockInnerClient.track as jest.Mock;
instance.track('evt1', { tagKey: 'tagVal' });

expect(mockFn).toHaveBeenCalledTimes(1);
expect(mockFn).toHaveBeenCalledWith('evt1', 'user2', { bar: 'baz' }, undefined);
expect(mockFn).toHaveBeenCalledTimes(1);
expect(mockFn).toHaveBeenCalledWith('evt1', 'user1', { foo: 'bar' }, { tagKey: 'tagVal' });
});

mockFn.mockReset();
it('track with event key, overrided user id and attributes and event tags, calls inner client with valid arguments', () => {
const mockFn = mockInnerClient.track as jest.Mock;
instance.track('evt1', 'user3', { bla: 'bla' }, { tagKey: 'tagVal' });

// Use pre-set user with event tags
instance.track('evt1', { tagKey: 'tagVal' });
expect(mockFn).toHaveBeenCalledTimes(1);
expect(mockFn).toHaveBeenCalledWith('evt1', 'user3', { bla: 'bla' }, { tagKey: 'tagVal' });
});

expect(mockFn).toHaveBeenCalledTimes(1);
expect(mockFn).toHaveBeenCalledWith('evt1', 'user1', { foo: 'bar' }, { tagKey: 'tagVal' });
it('track with event key, tags, and overrided attributes, calls inner client with valid arguments', () => {
const mockFn = mockInnerClient.track as jest.Mock;
instance.track('evt1', { tagKey: 'tagVal' }, { bla: 'bla' });

mockFn.mockReset();
expect(mockFn).toHaveBeenCalledTimes(1);
expect(mockFn).toHaveBeenCalledWith('evt1', 'user1', { bla: 'bla' }, { tagKey: 'tagVal' });
});

// Use overrides with event tags
instance.track('evt1', 'user3', { bla: 'bla' }, { tagKey: 'tagVal' });
it('track with event key, userId undefined, attributes undefined, and event tags, calls inner client with valid arguments', () => {
const mockFn = mockInnerClient.track as jest.Mock;
instance.track('evt1', undefined, undefined, { tagKey: 'tagVal' });

expect(mockFn).toHaveBeenCalledTimes(1);
expect(mockFn).toHaveBeenCalledWith('evt1', 'user3', { bla: 'bla' }, { tagKey: 'tagVal' });
expect(mockFn).toHaveBeenCalledTimes(1);
expect(mockFn).toHaveBeenCalledWith('evt1', 'user1', { foo: 'bar' }, { tagKey: 'tagVal' });
});
});
});

Expand Down
1 change: 0 additions & 1 deletion src/client.ts
Original file line number Diff line number Diff line change
Expand Up @@ -635,7 +635,6 @@ class OptimizelyReactSDKClient implements ReactSDKClient {
if (typeof overrideUserId !== 'undefined' && typeof overrideUserId !== 'string') {
eventTags = overrideUserId;
overrideUserId = undefined;
overrideAttributes = undefined;
}

const user = this.getUserWithOverrides(overrideUserId, overrideAttributes);
Expand Down

1 comment on commit 33b4344

@github-actions
Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Jest Coverage Report

St.
Category Percentage Covered / Total
🟢 Statements 98.95% 846/855
🟢 Branches 91.6% 338/369
🟢 Functions 97.52% 157/161
🟢 Lines 99.09% 764/771

Test suite run success

263 tests passing in 10 suites.

Report generated by 🧪jest coverage report action from 33b4344

Please sign in to comment.