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

Add GA event tracking for the "Top content" metric area of an Audience Tile #9495

Closed
5 tasks
techanvil opened this issue Oct 11, 2024 · 6 comments
Closed
5 tasks
Labels
Module: Analytics Google Analytics module related issues P0 High priority Team M Issues for Squad 2 Type: Enhancement Improvement of an existing feature

Comments

@techanvil
Copy link
Collaborator

techanvil commented Oct 11, 2024

Feature Description

GA events should be added to keep track of interaction with the "Top content" metric area of an Audience Tile.


Do not alter or remove anything below. The following sections will be managed by moderators only.

Acceptance criteria

The following GA events should be tracked for the given actions. See the GA events sheet.

Event Name Category Trigger Condition
view_cta {viewContext}_audiences-top-content-cta Element visibility User views the "Update" CTA for creating the custom dimension for "Top content" on a tile
create_custom_dimension {viewContext}_audiences-top-content-cta Click User clicks the "Update" CTA
auth_error {viewContext}_audiences-top-content-cta Element visibility User views the OAuth error modal on the dashboard when an error occurs in response to clicking the CTA
auth_error_retry {viewContext}_audiences-top-content-cta Click User clicks "Retry" on the modal
auth_error_cancel {viewContext}_audiences-top-content-cta Click User clicks "Cancel" on the modal
insufficient_permissions_error {viewContext}_audiences-top-content-cta Element visibility User views the insufficient permissions error modal on the dashboard when an error occurs in response to clicking the CTA
insufficient_permissions_error_request_access {viewContext}_audiences-top-content-cta Click User clicks "Request access" on the modal
insufficient_permissions_error_cancel {viewContext}_audiences-top-content-cta Click User clicks "Cancel" on the modal
setup_error {viewContext}_audiences-top-content-cta Element visibility User views the generic error modal on the dashboard when an error occurs in response to clicking the CTA
setup_error_retry {viewContext}_audiences-top-content-cta Click User clicks "Retry" on the modal
setup_error_cancel {viewContext}_audiences-top-content-cta Click User clicks "Cancel" on the modal

Implementation Brief

  • Extract the conditional JSX block containing the Update CTA from the AudienceTilePagesMetricContent component to a new component e.g. CreateCustomDimensionCTA.
    • Wrap the CreateCustomDimensionCTA component in forwardRef() so a ref can be passed to it, and add the ref to its top-level rendered element.
  • In the AudienceTilePagesMetricContent component:
    • Create a version of CreateCustomDimensionCTA wrapped by the withIntersectionObserver() HOC, e.g. CreateCustomDimensionCTAWithIntersectionObserver. Render this in place of the existing CreateCustomDimensionCTA instance.
    • Add an onInView callback prop to CreateCustomDimensionCTAWithIntersectionObserver. In the callback, call trackEvent( '${viewContext}_audiences-top-content-cta', 'view_cta' ).
    • Create a handleCreateCustomDimension() callback:
      • Call trackEvent( '${viewContext}_audiences-top-content-cta', 'create_custom_dimension' ), followed by onCreateCustomDimension(). Chain the two calls using .finally().
    • Pass handleCreateCustomDimension to CreateCustomDimensionCTAWithIntersectionObserver instead of onCreateCustomDimension.
  • In the ModalDialog component:
    • Add an optional onOpen prop of type PropTypes.func, and pass the prop to the rendered Dialog component.
    • Pass the existing handleConfirm prop through to the Button instance that is rendered when buttonLink is provided.
  • In the AudienceErrorModal component:
    • Add a trackEventCategory prop of type PropTypes.string.
    • Add an onOpen callback prop to ModalDialog:
      • Determine the action for the GA event: auth_error for an OAuth error, insufficient_permissions_error for an insufficient permissions error, or setup_error for any other error.
      • In the callback, call trackEvent( trackEventCategory, action ).
    • Create a handleConfirm callback:
      • Determine the action for the GA event: auth_error_retry for an OAuth error, insufficient_permissions_error_request_access for an insufficient permissions error, or setup_error_retry for any other error.
      • Call trackEvent( trackEventCategory, action ), followed by onRetry() unless the error is an insufficient permissions error. Chain the two calls using .finally().
    • Replace onRetry with handleConfirm as the value for the handleConfirm prop that is passed to ModalDialog.
    • Create a handleDialog callback:
      • Determine the action for the GA event: auth_error_cancel for an OAuth error, insufficient_permissions_error_cancel for an insufficient permissions error, or setup_error_cancel for any other error.
      • Call trackEvent( trackEventCategory, action ), followed by onCancel(). Chain the two calls using .finally().
    • Replace onCancel with handleDialog as the value for the handleDialog prop that is passed to ModalDialog.
  • In the AudienceTilePagesMetric component:
    • Pass the trackEventCategory prop to AudienceErrorModal with the value ${viewContext}_audiences-top-content-cta.

Test Coverage

  • Add JS test coverage for the above changes where tests exist for the affected components.

QA Brief

CTA events

  • Set up Site Kit with the audienceSegmentation feature flag enabled, tracking enabled, and Analytics connected using a property which is out of the gathering data state.
  • Click on Enable groups to set up Audience Segmentation.
  • Archive the googlesitekit_post_type custom dimension in Analytics.
  • Back on Site Kit, clear session storage and refresh the page. Verify the Update CTA appears in the "Top content" metric area for the audience tile(s).
  • Using a mechanism for checking tracked Analytics events, e.g. Tag Assistant or the Google Analytics Debugger Chrome extension, verify the view_cta event is tracked as per the AC.
  • Click on an Update CTA and verify the create_custom_dimension event is tracked as per the AC.

Error Modal events

OAuth error

  • Follow the steps above to show the Update CTA for the audiences tile(s).
  • Delete the {db_prefix}_googlesitekit_additional_auth_scopes entry from the {db_prefix}_usermeta table and refresh the page to ensure the edit scope is needed.
  • Click on an Update CTA to enter the OAuth flow. Cancel out of the OAuth flow to return to Site Kit with an OAuth error.
  • Verify the auth_error event is tracked as per the AC.
  • Click Retry on the error modal and verify the auth_error_retry event is tracked as per the AC.
  • Cancel the OAuth flow again to re-show the error modal. Click Cancel on the modal and verify the auth_error_cancel event is tracked as per the AC.

Insufficient permissions error

  • Either use a connected GA property which you only have view access to, or simulate the insufficient permissions error using the following Tweak Chrome extension configuration:
    • URL: .*/wp-json/google-site-kit/v1/modules/analytics-4/data/create-custom-dimension.*
    • Enable the use of regular expression (.*)
    • HTTP Method: POST
    • Status code: 403
    • Response payload:
      {
        "code": 403,
        "message": "Insufficient Permissions Test Error",
        "data": {
          "status": 403,
          "reason": "insufficientPermissions"
        }
      }
  • Follow the steps above to show the Update CTA for the audiences tile(s).
  • Click on an Update CTA. Proceed through the OAuth flow if necessary. Upon returning to Site Kit the error modal should appear showing the insufficient permissions error message.
  • Verify the insufficient_permissions_error event is tracked as per the AC.
  • Click Request access on the modal and verify the insufficient_permissions_error_request_access event is tracked as per the AC.
  • Click Cancel on the modal and verify the insufficient_permissions_error_request_cancel event is tracked as per the AC.

Generic error

  • Simulate an API error other than the insufficient permissions error, for example a 500 error using the following Tweak configuration:
    • URL: .*/wp-json/google-site-kit/v1/modules/analytics-4/data/create-custom-dimension.*
    • Enable the use of regular expression (.*)
    • HTTP Method: POST
    • Status code: 500
    • Response payload:
      {
        "code": "internal_server_error",
        "message": "Internal server error",
        "data": {
          "status": 500
        }
      }
  • Follow the steps above to show the Update CTA for the audiences tile(s).
  • Click on an Update CTA. Proceed through the OAuth flow if necessary. Upon returning to Site Kit the error modal should appear showing the generic error message.
  • Verify the setup_error event is tracked as per the AC.
  • Click Retry on the modal and verify the setup_error_retry event is tracked as per the AC.
  • Click Cancel on the modal and verify the setup_error_request_cancel event is tracked as per the AC.

Changelog entry

  • Add opt-in event tracking for an audience tile's "Top content" metric area.
@techanvil techanvil added Module: Analytics Google Analytics module related issues P0 High priority Type: Enhancement Improvement of an existing feature labels Oct 11, 2024
@benbowler benbowler added the Team M Issues for Squad 2 label Oct 14, 2024
@techanvil techanvil self-assigned this Oct 18, 2024
@techanvil techanvil removed their assignment Oct 18, 2024
@nfmohit nfmohit self-assigned this Oct 18, 2024
@nfmohit
Copy link
Collaborator

nfmohit commented Oct 18, 2024

Thank you for drafting the IB, @techanvil !

In the AudienceTilePagesMetric component:

  • Pass the trackEventProperty prop AudienceErrorModal with the value ${viewContext}_audiences-top-content-cta.

Just to confirm, did you mean trackEventCategory instead of trackEventProperty?

Also, do you think it might be worth bumping up the estimate for this one by a notch considering the slightly wider surface area?

Thanks!

@nfmohit nfmohit assigned techanvil and unassigned nfmohit Oct 18, 2024
@techanvil
Copy link
Collaborator Author

I certainly did, thanks for another catch! I've fixed the typo, and bumped the estimate too, that SGTM. Back over to you, cheers!

@techanvil techanvil assigned nfmohit and unassigned techanvil Oct 18, 2024
@nfmohit
Copy link
Collaborator

nfmohit commented Oct 18, 2024

Thank you Tom! IB ✅

@kelvinballoo
Copy link
Collaborator

QA Update ⚠

Hi @techanvil ,
I've tried to simulate the 'Update' button for the "Top content" metric area but it won't appear.
I followed the QAB and did it a couple of times but in vain.

9495.update.button.doesn.t.appear.mov

@techanvil
Copy link
Collaborator Author

techanvil commented Oct 25, 2024

Hi @kelvinballoo, it looks like you have mock report data enabled in the Tester plugin. This scenario can't be tested using mock data as it relies on the insufficient permissions error that is returned by a real report. Please try again with mock report data disabled.

@techanvil techanvil removed their assignment Oct 25, 2024
@kelvinballoo
Copy link
Collaborator

QA Update ✅

The GA events were logged successfully for all the events.
Moving ticket to approval.

  • view_cta

    Image

  • create_custom_dimension

    Image

  • auth_error

    Image

  • auth_error_retry

    Image

  • auth_error_cancel

    Image

  • insufficient_permissions_error

    Image

  • insufficient_permissions_error_request_access

    Image

  • insufficient_permissions_error_cancel

    Image

  • setup_error

    Image

  • setup_error_retry

    Image

  • setup_error_cancel

    Image

@kelvinballoo kelvinballoo removed their assignment Oct 25, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Module: Analytics Google Analytics module related issues P0 High priority Team M Issues for Squad 2 Type: Enhancement Improvement of an existing feature
Projects
None yet
Development

No branches or pull requests

5 participants