Closed benbowler closed 3 months ago
FYI, this ticket was split from #8484 on 17 May 2024. #8484 is a blocker.
Hey @benbowler, thanks for drafting this IB. A few points:
AudienceTiles
doesn't seem to need the update - it's already being retrieved via getReport()
rather than getReportForAllAudiences()
, and seems fine as it is AFAICT.getPivotReport()
selector in line with the proposed changes to https://github.com/google/site-kit-wp/issues/8484, assuming they have been made.topContentPageTitlesReportOptions
should also be covered in the IB (including the refactoring of the restructuring code).AudienceTile
stories to use this new data-mock functionality" should refer to "the new data-mock functionality introduced in #8484" for the sake of clarity.Thanks for the update @benbowler. It looks like these two points have been missed, though, please can you take a look?
- The report with options
topContentPageTitlesReportOptions
should also be covered in the IB (including the refactoring of the restructuring code).- A minor point but the report option code blocks are slightly misaligned in places.
Thanks Ben! This IB LGTM. :white_check_mark:
This is ticket is ready to be moved to CR, but it should be done once #8484 is merged and tested successfully as #8484 is the dependency for this and any changes in 8484 may lead to the changes in this task.
Thanks @ankitrox - in cases like this, we don't tend to wait for the dependency to go through QA, simply having it merged is enough to move this to CR. Please remember to merge develop
into this issue's branch, and retarget the PR first :)
Thanks @techanvil . I will move this to CR as soon as #8484 gets merged. I will also take care to update base branch and merge it to feature one.
Thank you.
Hi @ankitrox, I have left a few comments on the PR, please take a look.
Additionally, reviewing the QAB I'd note that the code snippets aren't really needed - the feature is well enough integrated that it should be completely testable via the UI.
So, I'd suggest a bit of a rewrite with that in mind. Essentially it just needs a bit of a smoke test of the audience tiles to ensure that nothing has changed.
It would also be a useful to provide a brief QA:Eng section to verify that pivot reports can be seen in the devtools network tab.
@kelvinballoo as per our chat on Slack. I have assigned this to you. Once you have completed your testing please unassign yourself and we'll get an engineer to look over it for the QA:Eng
part.
Despite being simple, this is a bit difficult to smoke test because a lot of things could be because of other tickets not deployed yet.
The tiles are appearing as how they were previously. ✅ That said, the tricky part is about verifying whether data is intact . Here are some observations to be reviewed. (For context, I used oi.ie property for testing)
ITEM 1:
A round of smoke test to ensure that this feature has not changed anything in the Audience tiles widget. Also that data should be intact within those tiles.
https://github.com/google/site-kit-wp/assets/125576926/f9d8d6aa-59ba-4156-bc86-9a022e731367
ITEM 2:
Ensure that top cities are displaying in the widget. Verify the data from Google Analytics dashboard that it is displaying correctly.
The top cities are displaying but it's showing one of them as '(not set)'
ITEM 3:
Ensure that "Top content by pageviews" are displaying in the widget. Verify the data from Google Analytics dashboard that it is displaying correctly.
I've verified the number from GA and the tile for the 'All visitors' at the 'Top content by pageviews' section and they matched for the first 2 but not the third.
ITEM 4: I feel the results of the tiles are not properly matched.
Refer to the attached video for details
Hey @kelvinballoo, what I'd suggest for the smoke test is to refer back to this comment I left on #8763 where I point out that we can see the same metrics elsewhere on the dashboard.
It's worth noting that all of the metrics for an audience are viewable elsewhere in Site Kit, so when viewing the "all visitors" audience, we can cross reference other widgets as a sanity check for the figures. To illustrate the point, here's a map of the metrics on the Audience Tile to the same metrics on Key Metric tiles and the All Traffic widget:
You can cross reference the metrics like this to check if anything has changed.
If the wider dashboard matches the All Visitors audience tile but you find discrepancies between the figures and what you see on Analytics, this can be raised as a separate issue for investigation.
Thanks @techanvil , that really helps.
I've verified this way and I can confirm that the tiles data is matching the data on the other part of the SK dashboard. Marking this as Pass but not moving this to approval yet since it's a 'QA Eng' ticket.
While performing QA:Eng for this issue, I've had a horrible realisation that pivot reports aren't actually suitable for the audience tiles in the way we thought they were.
This has come to light while examining the report output for audiences which have visitors from different cities.
As can be seen in the current audience data for oi.ie
, the "Mauritius users" audience has visitors from London:
While "Returning visitors" has visitors from Dublin, "(not set)", and Cork:
However when both of these audiences are visible, we only see Dublin, "(not set)", and Cork for both audiences, with no sign of London:
This was admittedly made harder to spot by the fact we have the open "2nd tile has no data" bug, https://github.com/google/site-kit-wp/issues/8921 which adds a bit of ambiguity. However the drilling into the actual reports as returned by the API indicates this is indeed the case and the reports are simply not returning the data in the way that we would like.
Essentially, each pivot in the report effectively results in a sub-query to retrieve all the values for that query similar to a regular report where the dimensionFilter
and so forth come into play. It's then using the returned values as the values to pivot on. So when retrieving the top 3 cities while both audiences are included in the filter, it's always returning Dublin, "(not set)", and Cork, as these cities all have more totalUsers
than London.
It's only when we remove "Returning visitors" from the query - meaning our report is filtering results for just the "Mauritius users" audience - that London is returned, because the other cities are being excluded - they are only associated with the other audience which is no longer included in the filter.
To help to understand this further here are some illustrative reports and their responses to compare:
As can be seen, when just "Mauritius users" is included in the filter, the cities pivot values are as follows:
{
"pivotDimensionHeaders": [
{
"dimensionValues": [
{
"value": "London"
}
]
}
],
"rowCount": 1
},
When just "Returning visitors" is included in the filter, the values are as follows:
{
"pivotDimensionHeaders": [
{
"dimensionValues": [
{
"value": "Dublin"
}
]
},
{
"dimensionValues": [
{
"value": "(not set)"
}
]
},
{
"dimensionValues": [
{
"value": "Cork"
}
]
}
],
"rowCount": 151
},
When both audiences are included in the filter, the values are again as follows, because they are the top 3 cities that are associated with either of the audiences.
{
"pivotDimensionHeaders": [
{
"dimensionValues": [
{
"value": "Dublin"
}
]
},
{
"dimensionValues": [
{
"value": "(not set)"
}
]
},
{
"dimensionValues": [
{
"value": "Cork"
}
]
}
],
"rowCount": 151
},
Note that event if we completely remove audienceResourceName
from dimensionFilter
, the same three cities are returned - these are the top cities across all audiences.
The "cities" case has been illustrated but the general principle applies to the "top content" metric as well.
From what I've seen so far it doesn't seem possible to use a pivot report in the way we'd like to, returning a different selection of pivot values for each audience.
It could the case that I've missed something and there is some way to achieve this, and we can investigate this further at a later date, but for now we need to revert the changes in this issue.
Note that due to the above, this issue will be closed as "not planned" and not included in the forthcoming release.
The PR #8969 that reverts all changes made by this issue has been merged. As discussed above, I'm closing this issue as not planned.
Feature Description
As discussed on Slack, while we are initially implementing the Audience Tiles to use separate, per-audience reports to retrieve the cities and "top content" metrics (one report per audience per metric), we can reduce the number of reports needed by using pivot reports. This will allow us to retrieve metric data for all of the audiences in a single report (i.e., one report per metric).
We should add support for running pivot reports, and refactor the Audience Tiles to use them.
This is not critical to the release and can be done post-launch, hence the P2 priority.
Please also note this comment relating to the
AudienceTile
andAudienceTiles
refactoring: https://github.com/google/site-kit-wp/issues/8484#issuecomment-2059400367This ticket has been split from #8484, and only concerns updating the Audience Tiles to use the new pivot report infrastructure, which will be completed in that ticket.
Do not alter or remove anything below. The following sections will be managed by moderators only.
Acceptance criteria
AudienceTiles
component (introduced via https://github.com/google/site-kit-wp/issues/8136) should be refactored to use pivot reports for the "top cities" and "top content" metrics, thus reducing the corresponding request count by a factor of the number of selected audiences.AudienceTiles
andAudienceTile
components should be further refactored so the reports that are retrieved inAudienceTiles
are passed directly toAudienceTile
, and the corresponding data parsing/extraction logic is moved fromAudienceTiles
toAudienceTile
. Hopefully this logic can be simplified in the process.AudienceTile
stories to replace the hardwired mock data with generated mock report data.Implementation Brief
Audience Segmentation Report Updates
[ ] Update the
assets/js/modules/analytics-4/components/audience-segmentation/dashboard/AudienceTilesWidget.js
component:topCitiesReportOptions
to the following report structure:topCitiesReport
to use the newgetPivotReport
selector instead ofgetReportForAllAudiences
, passingtopCitiesReportOptions
as the only prop.topContentReportOptions
to the following report structure:topContentReport
to use the newgetPivotReport
selector instead ofgetReportForAllAudiences
, passingtopContentReportOptions
as the only prop.topContentPageTitlesReportOptions
to the following report structure:topContentPageTitlesReport
to use the newgetPivotReport
selector instead ofgetReportForAllAudiences
, passingtopContentPageTitlesReportOptions
as the only prop.[ ] Remove the
getReportForAllAudiences
selector and all related code/tests.[ ] Update
assets/js/modules/analytics-4/components/audience-segmentation/dashboard/AudienceTiles.js
:.rows
, based on thedimensionValues[0].value === audienceResourceName
, (audienceResourceName
is from the parent map). This will return two rows per metric, one for each date range.topContentPageTitlesReport
, filter the rows as in the previous bullet point, passing through all 15 top page titles and paths as theAudienceTilePagesMetric.js
component will continue to do the selection of titles based ontopContent
andtopContentTitles
props.percentageOfTotalPageviews
, by dividing thescreenPageViews
metric from the current date range, with theRESERVED_TOTAL
of thescreenPageViews
metric over the same date range.AudienceTile
component props.AudienceTile Updates
AudienceTile
to use the new prop structure defined above.AudienceTile
stories to use this new pivot report data-mock functionality defined in #8484Test Coverage
QA Brief
A round of smoke test to ensure that this feature has not changed anything in the Audience tiles widget. Also that data should be intact within those tiles.
Ensure that top cities are displaying in the widget. Verify the data from Google Analytics dashboard that it is displaying correctly.
Ensure that "Top content by pageviews" are displaying in the widget. Verify the data from Google Analytics dashboard that it is displaying correctly.
QA:Eng
In the browser dev tools check that pivot reports are loading and getting the response.
Changelog entry