Skip to content

Commit

Permalink
chore: extracted replacer into SegmentUtils
Browse files Browse the repository at this point in the history
  • Loading branch information
Andrea Amorosi committed Oct 18, 2023
1 parent e707960 commit 00e98a8
Show file tree
Hide file tree
Showing 5 changed files with 28 additions and 14 deletions.
11 changes: 4 additions & 7 deletions packages/core/lib/segments/attributes/subsegment.js
Original file line number Diff line number Diff line change
Expand Up @@ -432,13 +432,10 @@ Subsegment.prototype.toJSON = function toJSON() {
* Returns the serialized subsegment JSON string, replacing any BigInts with strings.
*/
Subsegment.prototype.serialize = function serialize(object) {
return JSON.stringify(object ?? this, (_, value) => {
if (typeof value === 'bigint') {
return value.toString();
}

return value;
});
return JSON.stringify(
object ?? this,
SegmentUtils.getJsonStringifyReplacer()
);
};

module.exports = Subsegment;
11 changes: 4 additions & 7 deletions packages/core/lib/segments/segment.js
Original file line number Diff line number Diff line change
Expand Up @@ -439,13 +439,10 @@ Segment.prototype.toString = function toString() {
};

Segment.prototype.serialize = function serialize(object) {
return JSON.stringify(object ?? this, (_, value) => {
if (typeof value === 'bigint') {
return value.toString();
}

return value;
});
return JSON.stringify(
object ?? this,
SegmentUtils.getJsonStringifyReplacer()
);
};

module.exports = Segment;
2 changes: 2 additions & 0 deletions packages/core/lib/segments/segment_utils.d.ts
Original file line number Diff line number Diff line change
Expand Up @@ -17,3 +17,5 @@ export function setStreamingThreshold(threshold: number): void;
export function getStreamingThreshold(): number;

export function getHttpResponseData(res: http.ServerResponse): object;

export function getJsonStringifyReplacer(): (key: string, value: any) => any;
8 changes: 8 additions & 0 deletions packages/core/lib/segments/segment_utils.js
Original file line number Diff line number Diff line change
Expand Up @@ -67,6 +67,14 @@ var utils = {
ret.content_length = safeParseInt(res.headers['content-length']);
}
return ret;
},

getJsonStringifyReplacer: () => (_, value) => {
if (typeof value === 'bigint') {
return value.toString();
}

return value;
}
};

Expand Down
10 changes: 10 additions & 0 deletions packages/core/test/unit/segments/segment_utils.test.js
Original file line number Diff line number Diff line change
Expand Up @@ -43,4 +43,14 @@ describe('SegmentUtils', function() {
assert.deepEqual(emptyRes, {});
});
});

describe('#getJsonStringifyReplacer', () => {
it('should stringify BigInts', () => {
const obj = {foo: 1n, bar: BigInt(2)};
const replacer = SegmentUtils.getJsonStringifyReplacer();
const result = JSON.stringify(obj, replacer);

assert.equal(result, '{"foo":"1","bar":"2"}');
});
});
});

0 comments on commit 00e98a8

Please sign in to comment.