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

Update guzzle major version from 5 to 7 #39387

Closed
15 of 20 tasks
phil-davis opened this issue Oct 21, 2021 · 13 comments
Closed
15 of 20 tasks

Update guzzle major version from 5 to 7 #39387

phil-davis opened this issue Oct 21, 2021 · 13 comments
Assignees
Labels
dependencies php Pull requests that update Php code

Comments

@phil-davis
Copy link
Contributor

phil-davis commented Oct 21, 2021

core dependabot PR #39368 has been merged. That bumps to 7.4.4
PR #40154 adds a bump to 7.4.5 on 2022-06-21

This is a major version update of the "guzzle" library. It provides a framework in PHP for doing outgoing client requests. It is used in things like federated sharing, where one oC10 server needs to send requests to another oC10 federated server. We have various acceptance tests for federated sharing, so automated CI will cover the common federated sharing scenarios.

Some oC10 apps mention guzzle in their composer files. We will need to coordinate update those in sync with core.

They are:

Apps that use the client, but most likely still work:

  • files_external_ftp - no direct use of guzzle. Needs manual testing.
  • oco_selfservice
  • Onlyoffice
  • Collabora
  • Encryption (HSM)

Other things considered:

Apps to pre-release:
The following apps have had their code updated so that it detects if Guzzle5 or Guzzle7 libraries are available in core, and makes the appropriate Guzzle calls. This has been done for apps that are "backend" plugins for core, that, for example, manage "core" storage of users. It is much easier to upgrade when these apps support both Guzzle5 and Guzzle7. The new version of the app can be installed while you are running core 10.9 or 10.10, and it works fine. Then you upgrade core to 10.11, and you don't have to think about how to upgrade the app "at the same time".

We can and should do QA and release new versions of these apps ASAP (well before releasing core 10.11).

@JammingBen
Copy link
Contributor

I updated the list above with the affected apps and PRs to make it work. Most of the pipelines won't succeed until the core PR is merged. updater is optional and can be done later as it's not a standard OC app. Note that all these apps then need a new version which requires minimum OC 10.9 (this is not included in those PRs yet).

That should be pretty much it. But we can only know for sure if we take the step and merge this upgrade. So, do we want to proceed? @phil-davis @micbar @pmaier1 any objections?

@JammingBen JammingBen added dependencies php Pull requests that update Php code labels Oct 22, 2021
@phil-davis
Copy link
Contributor Author

That should be pretty much it. But we can only know for sure if we take the step and merge this upgrade. So, do we want to proceed? @phil-davis @micbar @pmaier1 any objections?

No objection from me. IMO it will be good to get this stuff up-to-date.

@IljaN
Copy link
Contributor

IljaN commented Oct 25, 2021

Merge after 10.9, decided in planning.

Edit: 10.10 was released, and we have merged after 10.10, for release in core 10.11

@github-actions
Copy link

This issue has been automatically marked as stale because it has not had recent activity. It will be closed in 10 days if no further activity occurs. Thank you for your contributions.

@phil-davis
Copy link
Contributor Author

waiting on merge of #39368 to core, and then merging the various app PRs.

@phil-davis
Copy link
Contributor Author

Also see #40103 - a new patch release of v6 and v7 came out yesterday, giving this a kick along.

@phil-davis phil-davis self-assigned this Jun 17, 2022
@phil-davis
Copy link
Contributor Author

Assigned myself. The main core PR #39368 has been merged.

I will follow-up the oC10 app PRs and get all CI passing for apps. And make a release/test plan with what I think needs to be done in the coming "x" weeks to manually QA various combinations of core and apps to confirm that they work with Guzzle 7.

@jnweiger FYI

@jnweiger
Copy link
Contributor

And make a release/test plan with what I think needs to be done

@phil-davis I've started the smoke test plan in https://github.com/owncloud/enterprise/issues/5247#issuecomment-1160077407
Please feel free to expand the Changelog testing section!

@phil-davis
Copy link
Contributor Author

2022-06-28: PHP dependencies are up-to-date in all apps. Nightly CI passes in all apps.

IMO we are at the point where we could:

  • find anything else in https://github.com/owncloud/core/pulls that can/needs to be merged and merge it.
  • make a 10.11.0-alpha.1 tarball
  • make x.x.x-alpha.1 tarballs of each app that will need releasing
  • do some manual testing to see if we can find any edge-cases that have been missed

@jnweiger
Copy link
Contributor

jnweiger commented Jun 28, 2022

Thanks. That is a good state to start building packages.

  • I'd first do the alpha.1 for the apps, based on the list in the initial comment here.
  • Then a core alpha.1
  • For all apps (to be identified) that need updates (besides of guzzle) we probably need to do a double release, so that we can have a version that is compatible with core 10.9 / 10.10 -- e.g. we plan to release richdocuments-2.8.0 (without guzzle and min version oc 10.7) and simultaneoulsy richdocuments-2.9.0 (with guzzle and min version oc 10.11) -- hope that makes sense.

@phil-davis
Copy link
Contributor Author

@jnweiger I created release issues for each of the apps that we know have had code changes for Guzzle7, and put them in the Releases project. The process of making RC1 tarballs could start next week. I don't think that there is any other code waiting to merge, but maybe check the open PRs in each app to see if there is anything that should be followed-up.

@phil-davis
Copy link
Contributor Author

phil-davis commented Jul 13, 2022

@kiranadh1452 has done manual verification that the following apps still work without any obvious regressions when using the current core master (what will be 10.11.0 release) and the current code in the app repos (which will be released concurrently with core 10.11.0). So the formal QA of the release of each of these apps should be smooth.

owncloud/gallery#859

owncloud/market#1043

owncloud/calendar#1263

owncloud/files_external_ftp#99

owncloud/files_external_gdrive#77

https://github.com/owncloud/files_onedrive/issues/145

owncloud/files_external_dropbox#137

Reported Issue :

owncloud/files_external_dropbox#138

@jnweiger
Copy link
Contributor

updates are complete, All possible QA was done. The unticked items do not have a tet setup.

@jnweiger jnweiger added this to Releases Aug 8, 2024
@jnweiger jnweiger moved this to Release done 🎉 in Releases Aug 8, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
dependencies php Pull requests that update Php code
Projects
Status: Release done 🎉
Development

No branches or pull requests

4 participants