Opened 4 years ago
Last modified 4 weeks ago
#51928 assigned task (blessed)
Provide plugin/theme update failure data to dot org
Reported by: | afragen | Owned by: | |
---|---|---|---|
Milestone: | Future Release | Priority: | normal |
Severity: | normal | Version: | |
Component: | Upgrade/Install | Keywords: | has-patch dev-feedback reporter-feedback has-unit-tests |
Focuses: | Cc: |
Description (last modified by )
With plugin auto-updates in core there have been instances of update failures leaving the user's site without the update and without any idea why the update failed. We receive core auto-update failure data to dot org and receiving plugin/theme failure data would help significantly in determining the causes of these failures.
I'm mostly guessing from how class-core-upgrader.php
sends failure data via wp_version_check( $stats )
and I've added similar data and a call to wp_update_{plugins|themes}( $stats )
in class-wp-upgrader.php
Thanks @pbiron
If it actually does send the data to dot org it could be useful. This requires the return of WP_Error
s at potential points of failure. I have added one of these in #51857.
Feedback from the dot org maintainers will be needed.
Attachments (9)
Change History (93)
#1
@
4 years ago
- Summary changed from Provide plugin update failure data to dot org to Provide plugin/theme update failure data to dot org
#2
@
4 years ago
Updated to provide for more universal failure reporting. 51928.2.diff should now report failure data to dot org for either plugins or themes.
This ticket was mentioned in Slack in #core-auto-updates by afragen. View the logs.
4 years ago
#5
@
4 years ago
51928.3.diff is the same as 51928.2.diff except it calls wp_update_plugins( $stats )
or wp_update_themes( $stats )
instead of wp_version_check( $stats )
to report the failure.
I'll have to check how we can report translation update failures...will update the patch when I've had a chance to do that.
#8
@
4 years ago
Looking at 51928.3.diff:
'fs_method_direct' => ! empty( $GLOBALS['_wp_filesystem_direct_method'] ) ? $GLOB['_wp_filesystem_direct_method'] : ''
$GLOB
variable truncated.
'wp_error' => $result,
I'm not sure how WP_Error
will JSON serialize here, it might be better to simply add the error_code
and error_data
instead. It'd also be worthwhile checking what error_data
actually holds in these cases, as for core we specifically "anonymised" it by removing ABSPATH from the data: https://core.trac.wordpress.org/browser/tags/5.5.1/src/wp-admin/includes/update-core.php?marks=1106#L1103
I can make the WordPress.org APIs store/process/etc the data that gets sent from this in whatever format is decided, it's just easier to be able to do less processing as it makes aggregating the data far simpler.
Another data point that might make sense adding here, is whether it was an auto-update or manually triggered update. It'll allow the resulting aggregated data to focus on failures that happen via autoupdates, to add protections to avoid autoupdates when that scenario is detected.
#9
@
4 years ago
51928.3.2.diff changed to per recommendations by @dd32 .
Also passes data re:automatic vs manual update. Unfortunately the Automatic Upgrader Skin
doesn't contain much specific data.
#10
@
4 years ago
51928.4.diff puts the telemetry data into a method and calls that at each failure point in WP_Upgrader::run()
.
#11
@
4 years ago
51928.5.diff adds the creation of a ZipArchive of the plugin/theme being upgraded to wp-content/upgrade/rollback
The rollback directory gets cleared at the next plugin/theme upgrade.
#12
@
4 years ago
51928.6.diff this is an initial pass at zipping the upgrade from the source and if a WP_Error is encountered restoring the original package.
Requires patch in #51857
This ticket was mentioned in Slack in #core by afragen. View the logs.
4 years ago
This ticket was mentioned in Slack in #core-auto-updates by afragen. View the logs.
4 years ago
This ticket was mentioned in Slack in #core by afragen. View the logs.
4 years ago
This ticket was mentioned in Slack in #core by afragen. View the logs.
4 years ago
This ticket was mentioned in Slack in #core by afragen. View the logs.
4 years ago
#20
@
4 years ago
- Milestone changed from 5.7 to 5.6.1
As per today's devchat, let's consider this for 5.6.1 inclusion so it could hoepfully give some insights for #51857 :-)
This ticket was mentioned in PR #850 on WordPress/wordpress-develop by hellofromtonya.
4 years ago
#22
- Keywords has-unit-tests added; needs-unit-tests removed
Trac ticket: https://core.trac.wordpress.org/ticket/51928
- Applies telemetry patch
- Changes
time()
tomicrotime( true )
- Adds unit tests for sending (or not sending) error report
This ticket was mentioned in Slack in #core-auto-updates by audrasjb. View the logs.
4 years ago
#24
follow-up:
↓ 25
@
4 years ago
- Keywords dev-feedback removed
The PR 850 is ready for review. It includes unit tests for:
Theme_Upgrader::install
Theme_Upgrader::upgrade
Theme_Upgrader::bulk_upgrade
Plugin_Upgrader::install
Plugin_Upgrader::upgrade
Plugin_Upgrader::bulk_upgrade
Hey @dd32, Andy and I were talking about whether to use time()
or microtime()
. Do you have a preference for the time_taken
in the error data?
#25
in reply to:
↑ 24
@
4 years ago
Replying to hellofromTonya:
whether to use
time()
ormicrotime()
. Do you have a preference for thetime_taken
in the error data?
IMHO: time()
; measuring anything less than seconds (or parts thereof) doesn't seem like it's useful to anyone to me. The only data points you would really want to track in bulk out of it are things like "90% of updates complete in 5s or less" or "1% of updates takes more than 30s, why?"
Measuring in microtime()
would make sense for local logging inside WordPress though (of which there is none currently... ) but not on dotorg. Of course, if you were to use microtime()
here it could still be stored as an int
on the dotorg side in stats.
This ticket was mentioned in Slack in #core by hellofromtonya. View the logs.
4 years ago
#27
@
4 years ago
Thank you @dd32 for your explanation and insights. Reverted it back to time()
in this commit.
This ticket was mentioned in Slack in #core-auto-updates by pbiron. View the logs.
4 years ago
This ticket was mentioned in Slack in #core-auto-updates by afragen. View the logs.
4 years ago
This ticket was mentioned in Slack in #core by afragen. View the logs.
4 years ago
This ticket was mentioned in Slack in #core-auto-updates by audrasjb. View the logs.
4 years ago
#32
follow-up:
↓ 34
@
4 years ago
Sorry for the delays in getting back to y'all on this.
Reviewing PR 850 above, I have two main questions, neither of which is a blocker:
- Is it possible to send the Slug of the plugin/theme being updated, rather than it's Name?
- Like above, is it possible to pass through the Slug/Version of automatic updates too?
I suspect I know the answer here, being that it's hard to retrieve those details, but I'm thinking maybe the Automatic updater skin could act as a temporary store of what is currently being processed. This could be done in a follow up change I guess.
- Due to error_message being translated it's not really storable for aggregate stats, Is process & error_code enough of a unique error with error_data as context?
It can either be kept in the stats blob for easier debugging or removed, either is fine, it just won't get stored api-server-side.
I'm going to attempt to get some storage running for this today/tomorrow, but don't let that block this ticket proceeding. Nothing should break by sending this through (at worst, it'll be disregarded as junk input, at best, it'll be recorded as successful rather than a failure).
This ticket was mentioned in Slack in #core by afragen. View the logs.
4 years ago
#34
in reply to:
↑ 32
;
follow-up:
↓ 35
@
4 years ago
Replying to dd32:
Reviewing PR 850 above, I have two main questions, neither of which is a blocker:
- Is it possible to send the Slug of the plugin/theme being updated, rather than it's Name?
- Like above, is it possible to pass through the Slug/Version of automatic updates too?
I suspect I know the answer here, being that it's hard to retrieve those details, but I'm thinking maybe the Automatic updater skin could act as a temporary store of what is currently being processed. This could be done in a follow up change I guess.
Unfortunately that data isn't available in the Upgrader object. Depending upon the data passed in the WP_Error, it might show the slug by reference to the destination folder. I know, not necessarily the same thing.
- Due to error_message being translated it's not really storable for aggregate stats, Is process & error_code enough of a unique error with error_data as context?
It can either be kept in the stats blob for easier debugging or removed, either is fine, it just won't get stored api-server-side.
I'm going to attempt to get some storage running for this today/tomorrow, but don't let that block this ticket proceeding. Nothing should break by sending this through (at worst, it'll be disregarded as junk input, at best, it'll be recorded as successful rather than a failure).
I'm of the opinion that more data is better, but you're the one crunching the data so I'll defer to whatever you need/want here. Certainly something that can be adjusted in another ticket/later time.
I have made a small PR to @hellofromTonya's PR https://github.com/WordPress/wordpress-develop/pull/850 to include error reporting for copy_dir()
errors.
#35
in reply to:
↑ 34
@
4 years ago
I've been testing PR 850 and it's data storage on dotorg, and I can happily say the data is being saved correctly now, however..
Replying to afragen:
I suspect I know the answer here, being that it's hard to retrieve those details, but I'm thinking maybe the Automatic updater skin could act as a temporary store of what is currently being processed. This could be done in a follow up change I guess.
Unfortunately that data isn't available in the Upgrader object. Depending upon the data passed in the WP_Error, it might show the slug by reference to the destination folder. I know, not necessarily the same thing.
In my testing of this PR, it looks like it's actually very common for it to not have even the name available. The current way that it's retrieving the details isn't reliable enough and only covers a singular use-case (Plugin/Theme upgrade via the ajax upgrader).
It also incorrectly identifies most plugin upgrade/install attempts as automatic_plugin_update
.
I have made a small PR to @hellofromTonya's PR https://github.com/WordPress/wordpress-develop/pull/850 to include error reporting for
copy_dir()
errors.
Currently the PR as is, actually sends two API pings, with your proposed changes, it sends 3 :)
I'm not sure I understand what the 'process' field is for, as the WP_Error objects should have a unique error_code value that specifies the issues being encountered... The inclusion of that is what was causing double api pings to be sent.
I've made some significant-ish changes via PR2 on PR850 (my branch) which simplifies the process a little, and ensures that slug/version context is always sent with the failure pings, which makes the data much more useful.
I've ditched the process
key, relying upon the WP_Error error codes being unique enough.
I've also removed most of the pings from WP_Upgrader, relegating the failure catching to ::install(), ::upgrade(), and ::bulk_upgrade()
instead.
I haven't tested this with Background auto-updates, but I think it should catch those upgrades correctly, and identify them as such.
I've ignored the unit tests, because I'm almost 100% certain it'll now be failing after these changes, and as far as I can tell was probably too decoupled from it anyway to catch anything useful.
The tests also include some platform-specific error codes, PCLZIP_ERR_MISSING_FILE
which to me suggests the existing tests probably would've failed on a PHP with the zip
extension enabled.
I'd highly support not including any unit testing what so ever of this change.
This ticket was mentioned in Slack in #core by audrasjb. View the logs.
4 years ago
#37
@
4 years ago
- Milestone changed from 5.6.1 to 5.6.2
Just a heads up, I think we are still working on this, so I am bumping to the 5.6.2 milestone to clear up 5.6.1 for the release next week.
#38
@
4 years ago
So sorry everyone, I didn't see that a PR was submitted to my forked copy of the repo. Doh. Just merged @dd32's changes into PR 850.
@dd32
- Did you get a chance to test it out with Background auto-updates?
I haven't tested this with Background auto-updates, but I think it should catch those upgrades correctly, and identify them as such.
- Excluding the tests (which I can clean up_, is the implementation ready to go?
#39
@
4 years ago
- Milestone changed from 5.6.2 to Future Release
5.6.2 RC is set to be packaged in a few hours, and this one needs another review. Going to punt to Future Release
for now, but feel free to re-milestone appropriately after a review happens.
#40
@
4 years ago
- Keywords early added
- Milestone changed from Future Release to 5.8
Updated milestone for 5.8 as this would really help provide update failure data to dot org. This will be especially important for the Rollback Update Failure feature plugin scope.
This ticket was mentioned in Slack in #core by afragen. View the logs.
4 years ago
This ticket was mentioned in Slack in #core-auto-updates by afragen. View the logs.
4 years ago
#44
@
3 years ago
I think this one just needs a review from @dd32.
If everyone can review and is comfortable with the changes this week, I think this can make it in to 5.8. If it takes longer than that I think we'd pass a reasonable early
cutoff.
#45
@
3 years ago
While I haven't tested the patches here recently, assuming the shortcomings of my previous comment was taken into account, and the team working on updates still wants this data (I have no need for it personally since I'm not working on updates), I have no issue with it as-is.
After it's in core, I'll follow up with the team with the data we're seeing, and flagging any duplicate API requests / missing data points / etc along with the aggregated data generated.
(I don't see this as needing to be early
as such, other than that it needs time for the team to evaluate the data and fix any bugs before it going out in a release)
This ticket was mentioned in Slack in #core-auto-updates by audrasjb. View the logs.
3 years ago
This ticket was mentioned in Slack in #core by desrosj. View the logs.
3 years ago
#49
@
3 years ago
- Milestone changed from 5.8 to 5.9
I was hoping to review this for 5.8, but unfortunately, we've just run out of time. The tests here are quite extensive (which is great), but not sure I'm comfortable committing without reviewing more thoroughly. Especially where it makes changes to the upgrade code.
This ticket was mentioned in Slack in #core-auto-updates by pbiron. View the logs.
3 years ago
This ticket was mentioned in Slack in #core by afragen. View the logs.
3 years ago
This ticket was mentioned in Slack in #core by audrasjb. View the logs.
3 years ago
#54
@
3 years ago
- Keywords early added
- Milestone changed from 5.9 to 6.0
We're getting close to 5.9 beta 1, let's move this ticket to the next milestone
#56
@
3 years ago
- Owner desrosj deleted
Removing myself as owner so other interested contributors do not hesitate to take this on. Won't have time to tackle this in the next 2-3 months.
This ticket was mentioned in Slack in #core by mike. View the logs.
2 years ago
#59
@
2 years ago
It looks like this patch doesn’t apply anymore, and will need a refresh to move forward.
2 years ago
#60
Merge conflicts should be fixed in https://github.com/hellofromtonya/wordpress-develop/pull/4
#61
@
2 years ago
- Keywords needs-refresh removed
Merge conflicts should be fixed in @hellofromTonya's PR via above PR.
This ticket was mentioned in Slack in #core-auto-updates by afragen. View the logs.
2 years ago
#63
@
2 years ago
- Milestone changed from 6.0 to 6.1
With 6.0 RC1 tomorrow, I'm moving this ticket to the 6.1 milestone.
This ticket was mentioned in Slack in #core-auto-updates by costdev. View the logs.
2 years ago
This ticket was mentioned in Slack in #core-auto-updates by costdev. View the logs.
2 years ago
This ticket was mentioned in Slack in #meta by costdev. View the logs.
2 years ago
#67
@
2 years ago
- Milestone changed from 6.1 to 6.2
With WP 6.1 RC 1 scheduled today (Oct 11, 2022), there is not much time left to address this ticket. Let's move it to the next milestone.
Ps: if you were about to send a patch and if you feel it is realistic to commit it in the next few hours, please feel free to move this ticket back to milestone 6.1.
This ticket was mentioned in Slack in #core-upgrade-install by costdev. View the logs.
21 months ago
#69
@
21 months ago
- Keywords needs-refresh dev-feedback added
PR 850 still has merge conflicts to resolve.
@hellofromTonya Do you have time to take a look at this PR to your branch to resolve the conflicts?
If not, let me know and I'll take a look 🙂
This ticket was mentioned in Slack in #core by mukeshpanchal27. View the logs.
19 months ago
#71
@
19 months ago
Thanks @afragen for ticket.
This ticket was discussed during the recent bug scrub. It looks like it's unlikely that work will be done on this during the 6.2 cycle.
@hellofromTonya @dd32 Do you have time to take a look, or should it be moved to Future Release
for now?
#72
@
19 months ago
I have no quarms with the approach, if it's useful to those who are working on the Upgrade/Update components.
The only request I have (that I have repeated in previous conversations) is to avoid sending data just 'cos and only when it'll actually be something worthwhile logging and reviewing.
I'll defer to @afragen and @pbiron here.
#73
@
19 months ago
- Keywords reporter-feedback added
I agree with @dd32 about making sure there's value-add in ALL of the data being collected.
So I think this ticket goes back to:
- What data is most valuable?
- How will the data be used to provide insights?
#74
@
19 months ago
Also, I defer to my 6.2 co-Core Tech Lead, @audrasjb about its readiness and value-add need for the 6.2 cycle or whether to punt.
#75
follow-ups:
↓ 76
↓ 77
@
19 months ago
There is still some conflicts in the PR, so I'd suggest to see if they can be resolved before beta 3 and to move the ticket to 6.3 if it is not ready next week.
#76
in reply to:
↑ 75
@
19 months ago
- Milestone changed from 6.2 to 6.3
Replying to audrasjb:
There is still some conflicts in the PR, so I'd suggest to see if they can be resolved before beta 3 and to move the ticket to 6.3 if it is not ready next week.
@afragen and I discussed this the other day. I'm moving to 6.3, so that we can concentrate on more important matters in the final stretches of 6.2.
#77
in reply to:
↑ 75
@
19 months ago
Replying to audrasjb:
There is still some conflicts in the PR, so I'd suggest to see if they can be resolved before beta 3 and to move the ticket to 6.3 if it is not ready next week.
PR conflicts were fixed in PR to @hellofromTonya’s PR. It just needs to be merged.
This ticket was mentioned in Slack in #core-upgrade-install by afragen. View the logs.
17 months ago
This ticket was mentioned in Slack in #core-upgrade-install by afragen. View the logs.
17 months ago
This ticket was mentioned in PR #4344 on WordPress/wordpress-develop by @costdev.
17 months ago
#80
- Keywords has-unit-tests added; needs-refresh removed
This refreshes #850.
Trac ticket: https://core.trac.wordpress.org/ticket/51928
This ticket was mentioned in Slack in #core-upgrade-install by afragen. View the logs.
16 months ago
This ticket was mentioned in Slack in #core-upgrade-install by costdev. View the logs.
15 months ago
#83
@
15 months ago
- Milestone changed from 6.3 to Future Release
This ticket was mentioned during the Upgrade/Install component meeting.
As the PR still has test failures that require investigation, I'm moving this to Future Release
until we can get time to resolve these and move the ticket towards a release milestone.
more universal failure reporting