Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

fix(instrumentation-user-interaction): support clicks in React apps #537

Merged
merged 4 commits into from
Jun 21, 2021

Conversation

kkruk-sumo
Copy link
Contributor

@kkruk-sumo kkruk-sumo commented Jun 14, 2021

Which problem is this PR solving?

This fixes #168.

React <17 listens on document. It didn't work previously, because we were only listening on HTMLElement instances.
React >=17 listens on a page root (usually a div or document.body), so all spans had the same xpath.

Short description of the changes

This PR changes current behaviour.

The good news is that the current behaviour is undocumented - I didn't have to change existing unit tests.

Previously the element on which the listener has been added was taken into a span (in div.addEventListener - the div was always in span's xpath, not the clicked child).
After this change, the event.target will be taken (the actually clicked element).

@kkruk-sumo kkruk-sumo requested a review from a team June 14, 2021 20:25
@codecov
Copy link

codecov bot commented Jun 14, 2021

Codecov Report

Merging #537 (f59aec7) into main (621f014) will increase coverage by 0.04%.
The diff coverage is n/a.

❗ Current head f59aec7 differs from pull request most recent head b14db18. Consider uploading reports for the commit b14db18 to get more accurate results

@@            Coverage Diff             @@
##             main     #537      +/-   ##
==========================================
+ Coverage   94.82%   94.87%   +0.04%     
==========================================
  Files         157      157              
  Lines        9862     9867       +5     
  Branches      957      963       +6     
==========================================
+ Hits         9352     9361       +9     
+ Misses        510      506       -4     
Impacted Files Coverage Δ
...umentation-user-interaction/src/instrumentation.ts 95.48% <0.00%> (+1.61%) ⬆️

if (event) {
parentSpan = plugin._eventsSpanMap.get(event);
}
if (once) {
plugin.removePatchedListener(this, type, listener);
}
const span = plugin._createSpan(target, type, parentSpan);
const span =
target instanceof HTMLElement
Copy link
Member

Choose a reason for hiding this comment

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

_createSpan already has a number of "does this have enough information to produce a good span? -> if not, undefined" checks, and I think this one belongs inside _createSpan rather than outside it, to keep said logic centralized.

let span: api.Span | undefined;
const activeZone = this;
if (target) {
if (target instanceof HTMLElement) {
Copy link
Member

Choose a reason for hiding this comment

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

See previous comment - if _createSpan does this check, it doesn't need to be repeated elsewhere.


try {
btn1.click();
btn2.click();
Copy link
Member

Choose a reason for hiding this comment

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

I appreciate this test (having two targets and ensuring that the span names properly line up)!

@@ -40,6 +40,12 @@ const FILE_URL =
'https://raw.githubusercontent.com/open-telemetry/opentelemetry-js/main/package.json';

describe('UserInteractionInstrumentation', () => {
afterEach(() => {
while (document.body.lastChild) {
document.body.removeChild(document.body.lastChild);
Copy link
Member

Choose a reason for hiding this comment

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

I'm not sure why this is necessary? Perhaps a comment?

Copy link
Contributor Author

Choose a reason for hiding this comment

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

Comment added.

@kkruk-sumo kkruk-sumo requested a review from johnbley June 16, 2021 14:47
Copy link
Member

@johnbley johnbley left a comment

Choose a reason for hiding this comment

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

Looks good now, thanks for the edits!

@obecny obecny merged commit 73e522e into open-telemetry:main Jun 21, 2021
@obecny obecny added the bug Something isn't working label Jun 21, 2021
@kkruk-sumo kkruk-sumo deleted the support_react_clicks branch June 22, 2021 07:36
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
bug Something isn't working
Projects
None yet
Development

Successfully merging this pull request may close these issues.

onclick - react, zone.js
4 participants