Skip to content

Commit

Permalink
feat(utils): diff finder replaceNondeterministicStrings
Browse files Browse the repository at this point in the history
  • Loading branch information
patrickhulce committed Oct 15, 2019
1 parent b549344 commit dee2613
Show file tree
Hide file tree
Showing 2 changed files with 45 additions and 1 deletion.
12 changes: 11 additions & 1 deletion packages/utils/src/audit-diff-finder.js
Expand Up @@ -242,6 +242,15 @@ function findAuditDetailItemKeyDiffs(auditId, baseEntry, compareEntry) {

return diffs;
}

/** @param {string} s */
function replaceNondeterministicStrings(s) {
return s
.replace(/\b[0-9a-f]{8}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{12}\b/gi, 'UUID')
.replace(/:[0-9]{3,5}\//, ':PORT/')
.replace(/\.[0-9a-f]{8}\.(js|css|woff|html|png|jpeg|jpg|svg)/, '.HASH.$1');
}

/**
* TODO: consider doing more than URL-based comparisons.
*
Expand All @@ -255,7 +264,7 @@ function zipBaseAndCompareItems(baseItems, compareItems) {
...baseItems.map((item, i) => ({item, kind: 'base', index: i})),
...compareItems.map((item, i) => ({item, kind: 'compare', index: i})),
],
entry => (entry.item.url === undefined ? JSON.stringify(entry.item) : entry.item.url)
entry => replaceNondeterministicStrings(getItemKey(entry.item))
);

/** @type {Array<{base?: DetailItemEntry, compare?: DetailItemEntry}>} */
Expand Down Expand Up @@ -453,4 +462,5 @@ module.exports = {
getRowLabelForIndex,
getMostSevereDiffLabel,
zipBaseAndCompareItems,
replaceNondeterministicStrings,
};
34 changes: 34 additions & 0 deletions packages/utils/test/audit-diff-finder.test.js
Expand Up @@ -13,6 +13,8 @@ const {
getDiffLabel,
getRowLabel,
getRowLabelForIndex,
zipBaseAndCompareItems,
replaceNondeterministicStrings,
} = require('@lhci/utils/src/audit-diff-finder.js');

describe('#findAuditDiffs', () => {
Expand Down Expand Up @@ -516,3 +518,35 @@ describe('#getRowLabel', () => {
expect(getRowLabelForIndex(diffs, 2, 0)).toEqual('better');
});
});

describe('#replaceNondeterministicStrings', () => {
it('should work on non-replacements', () => {
expect(replaceNondeterministicStrings('nonsense')).toEqual('nonsense');
expect(replaceNondeterministicStrings('Other')).toEqual('Other');
expect(replaceNondeterministicStrings('Unknown')).toEqual('Unknown');
expect(replaceNondeterministicStrings('foo.notahash.js')).toEqual('foo.notahash.js');
expect(replaceNondeterministicStrings('foo.1234567.js')).toEqual('foo.1234567.js');
expect(replaceNondeterministicStrings('at foo.js:1234')).toEqual('at foo.js:1234');
expect(replaceNondeterministicStrings('http://localhost/foo')).toEqual('http://localhost/foo');
expect(replaceNondeterministicStrings('')).toEqual(
''
);
});

it('should replace hash parts', () => {
expect(replaceNondeterministicStrings('foo.12345678.js')).toEqual('foo.HASH.js');
expect(replaceNondeterministicStrings('foo.abcdef12.js')).toEqual('foo.HASH.js');
});

it('should replace ports', () => {
expect(replaceNondeterministicStrings('http://localhost:1337/foo?bar=1#baz')).toEqual(
'http://localhost:PORT/foo?bar=1#baz'
);
});

it('should replace uuids', () => {
expect(
replaceNondeterministicStrings('<a href="/app/12345678-1234-1234-1234-123456781234">Text</a>')
).toEqual('<a href="/app/UUID">Text</a>');
});
});

0 comments on commit dee2613

Please sign in to comment.