-
Notifications
You must be signed in to change notification settings - Fork 78
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 PHP 8.0 support #169
Add PHP 8.0 support #169
Conversation
Hey all 👋 is there anything I can do to help this PR being merged? Would be great to be able to use this package with PHP 8 :) |
Hmm was hoping to run the tests but not much happens. |
I think it might have been because the branch wasn't on the main repo and the owner had not enabled GitHub Actions on it 🤔 Thanks for merging! |
Hmm I can't run it on 7.2 because of prophecy supports 7.3 and up. Removed it in #171 Any ideas for that? Otherwise it isn't the biggest problem in the world, but still.. We could just bump the PHP version to 7.3 I guess. |
To solve the - "phpspec/prophecy-phpunit": "^2.0"
+ "phpspec/prophecy-phpunit": "^1.1|^2.0" The problem is that the Prophecy API changed with 2.0 (as you'd expect with major versions), so the |
Just to clarify on PHP version, I believe I put 7.2 because this is what was in |
Agreed. Bumped to 7.3 in 9ddf4fa. Bumped the branch alias to 3.3 for testing so I suggest we release 3.3.0 sometimes with support for 7.3 and up. We can always still release a new 3.2.x version in case of issues. |
@judgej do you think we should release the commits before this PR as a new 3.2 version? And then tag this as 3.3? |
Yes, that seems the right thing to do. I have personally not had time to test these changes, but if people are using them in production, even if just their own branches, then go for it. I have some sites I need to uograde anyway, that will become very urgent soon, so will be available then for any tweaks or addiutional documentation. So I understand, v3.2 would be the last PHP 7.2 version, then |
(As i understand it) v3.3 would be PHP 7.3+ |
Yeah |
I think I'll be able to start testing this (off of |
I can confirm that at least the form methods work as expected with PHP 8.0 - is there anything I can do to help tag an official release? Or would you prefer to have some more testers e.g. for the other integration methods (server, direct)? :) |
Also volunteering if required to test against the Server integration |
@jamieburchell if you're happy with the update, could you use the specific branch / commit reference within your composer.json to enable use now? Obviously not ideal, but could be a temporary solution until they manage a release. |
@jamieburchell also see this: #173 could be worth a test? |
@benjam-es Sure, but I have no idea how stable that is or how much compatibility there is with PHP 8.x and I'd rather not be pointing production applications at random commits. I appreciate that maintainers have jobs and lives, but this repo hasn't had a release in nearly 3 years and I'm at the stage where I need to decide if I am going to fork this repo and take it on, or if there is something I can do to help this repo get a stable release. I will be doing some testing against the master branch, but I'm not familiar enough with the project or its development to be confident that it's doing what it should be. |
For now, to help out, I think if you and other users pointed a testing site to the master branch, and attempted to do some testing to ensure it works as you want it to, and hopefully do some testing to see if it works for protocol 4 given the latest merged pull request. I believe the tests which are also run on CI, give the proof that it they work for php 8.0, so you would likely have to review all code change to ensure you are happy before pointing to a commit/branch. In my case, I forked it, and I have my fork on a private satis so I use that instead until there are official releases. |
I pointed a PHP 7.4 testing site at master (protocol v4) and basic purchase transactions worked without issue. I also tested the abort from a client and from a timeout. |
This is absolute minimum for PHP 8.0 support.
My work here is only to get
composer run test
work without any warnings and deprecation messages.I did not run the code in any other way than through tests, so I'm not 100% confident about everything working correctly, but I have to leave now, so I may give it a bit more attention tomorrow ;)
This relates to issue #167