/rollback-update-failure

Feature plugin to test zip rollback of plugin/theme update failures.

Primary LanguagePHPMIT LicenseMIT

Rollback Update Failure

Rollback Update Failure

  • Plugin Name: Rollback Update Failure
  • Contributors: afragen
  • Tags: feature plugin, update, failure, auto-update
  • License: MIT
  • Requires PHP: 5.6
  • Requires at least: 5.2
  • Stable Tag: main

Feature plugin for testing automatic rollback of a plugin or theme update failure.

Description

This is a feature plugin based on the PR for #51857.

The assumption is that most of the errors in large plugins/themes occur during the copy_dir() part of WP_Upgrader::install_package(). Trac ticket #52342 brought more error reporting to copy_dir() and Trac ticket #52831 provides a filter hook in order to process the rollback in the event of a plugin/theme update failure. As of WordPress 5.7-beta1 both of these tickets are in core.

It is during the WP_Upgrader::install_package() that the currently installed plugin/theme is deleted in anticipation of copying the new update into that location. Having an empty plugin/theme folder or an incompletely copied update seems to be the most common issue.

There will be messaging in the event of an error and successful or unsuccessful rollback.

Testing

There was much discussion regarding the thought that adding additional IO processes for the zip and unzip process could result in server timeout issues on resource starved shared hosts. Activating the feature plugin will result in the creation of a ZIP file of the installed plugin/theme being updated every time an update is performed. The unzip only occurs during testing or a WP_Error resulting from WP_Upgrader::install_package().

For the sake of testing assume any server timeout occurring during the update process might be releated to the additional IO processes creating the zipfile. Please report these in GitHub Issues and report your server details. ( Host, RAM, OS, etc. )

To simulate a failure, use the filter add_filter( 'rollback_update_testing', '__return_true' );

Alternatively you can install the Rollback Update Testing plugin, activating it as needed.

Reporting

Please submit issues and PRs to GitHub.

Changelog

Please see the Github repository: CHANGELOG.md.