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

Travis CI re-enablement for s390x #15944

Closed
AlocJose opened this issue Sep 18, 2024 · 23 comments
Closed

Travis CI re-enablement for s390x #15944

AlocJose opened this issue Sep 18, 2024 · 23 comments

Comments

@AlocJose
Copy link

Description

Jobs have stopped running on Travis CI for s390x since 2024/08/09 and it says 'This is not an active repository. You don't have sufficient rights to enable this repo on Travis. Please contact the admin to enable it or to receive admin rights yourself.'
https://app.travis-ci.com/github/php/php-src
Php Travis CI was dropped via this commit 13f0411
All the issues related to Travis infra have been resolved. Would it be possible to kindly re-enable Travis CI for the s390x jobs? Please let me know if there is something I can do at my end to help add the support to CI.

PHP Version

master

Operating System

No response

@cmb69
Copy link
Member

cmb69 commented Sep 18, 2024

I wonder who has admin rights for our Travis account. @iluuu1994, would you know?

@iluuu1994
Copy link
Member

I wonder who has admin rights for our Travis account.

I believe I do.

@AlocJose Thank you for letting us know. We discussed this when the build stopped working and decided to drop the build. It didn't add much value and frequently errored spuriously. Is there something I need to do on the Travis side?

@cmb69
Copy link
Member

cmb69 commented Sep 18, 2024

Is there something I need to do on the Travis side?

I think you need to sign in, and activate the repo (see travis-ci/travis-ci#5629).

It didn't add much value, […]

Having at least one CI job for big-endian architectures appears to be sensible.

@zeriyoshi
Copy link
Contributor

If Travis is unstable and not suitable for use, how about running nightly tests in a QEMU-based environment?
This can be achieved relatively easily using Docker (although it will take an incredibly long time due to emulation)

https://github.com/zeriyoshi/php-containers-development

@iluuu1994
Copy link
Member

Yes, this is what has been suggested. We could try to cross-compile to some other architecture and then run tests using QEMU. However, I suspect this to be very slow, so maybe something we only run once a week or so.

@cmb69
Copy link
Member

cmb69 commented Sep 18, 2024

That instability may have been caused because php-src was not enabled via Travis, but only via GH. Why not give it a try again?

@iluuu1994
Copy link
Member

@cmb69 Note that the instability was unrelated to the issue we experienced when we dropped the build. The issue was only the catalyst.

@iluuu1994
Copy link
Member

@cmb69 I don't object to re-adding Travis in the meantime. It's unlikely we'll find an alternative big endian platform quickly. That said, the Travis build has sometimes not worked properly for weeks, so it's not like it was super reliable to begin with. We also have some people working on IBM, e.g. @NattyNarwhal (from what I understood). Let me know what your preference is.

@NattyNarwhal
Copy link
Member

I actually do have some spare Power hardware (mostly all POWER8) available for CI purposes. What would be the best way to make it available? I could rack it up on some personal infrastructure, or would it be better to put it in the hands of i.e. the foundation?

@cmb69
Copy link
Member

cmb69 commented Sep 19, 2024

That said, the Travis build has sometimes not worked properly for weeks, so it's not like it was super reliable to begin with.

Yeah, but I still wonder if this is a general Travis issue, or whether this was because we apparently never enabled php-src via Travis, but instead had enabled Travis via GH. If it is not much work, I'd give Travis a try; if it is still unstable, we can shut it down again.

I actually do have some spare Power hardware (mostly all POWER8) available for CI purposes. What would be the best way to make it available?

I'm afraid that is not supported as self-hosted runner. I don't know if there are work-arounds to still integrate such a machine into GH CI.

@NattyNarwhal
Copy link
Member

I think there's at least one third party implementation of the runner that runs on platforms that GH's doesn't, plus we could deploy some other CI thing (though I think everyone here wants to stick with Actions).

@iluuu1994
Copy link
Member

It's questionable whether a self-hosted runner (especially with custom, unsupported software) will be less buggy than a hosted one.

@cmb69
Copy link
Member

cmb69 commented Sep 19, 2024

Well, as they are saying: "Get CI running, or die trying."

@NattyNarwhal
Copy link
Member

Well, I'm installing Gentoo as we speak in a partition on a system I have already, so I'm on the "die trying" part. 😵‍💫 I'll get the system up and play with the funny third-party runner at least.

@NattyNarwhal
Copy link
Member

Well, I haven't died trying yet; I have Linux ready to go on the system, and I can give that runner tool a shot if someone who has the keys has time.

@iluuu1994
Copy link
Member

@NattyNarwhal You should be able to test it in your fork. If it works, I don't mind adding it to CI as long as it doesn't become a maintenance burden. I think nightly would be enough, but if you keep it running just for php-src I guess we might as well run it on push.

@NattyNarwhal
Copy link
Member

I have the branch ppc64-ci-test on my fork, and the machine provisioned. I'll get LLVM set up for *San and see how it goes.

@NattyNarwhal
Copy link
Member

NattyNarwhal commented Sep 22, 2024

It's running through tests finally, and even found some issues. (I hate debugging Actions though 😵‍💫)

I'll document the environment/runner config, but most of the deps other than LLVM for *San are in the emerge action on my fork's branch. It doesn't run them because it's not containerized (yet) and I don't want to give the runner user admin privileges.

The runner is also perhaps not the fastest - it's a partition with 32 threads out of the ~160 on that machine, and POWER8 is a little old. (Oh, and spinning rust does suck. It has enough RAM for a ramdisk though, so...)

@NattyNarwhal
Copy link
Member

NattyNarwhal commented Sep 24, 2024

Bringing this up again: the preliminary ppc64be CI I set up on my fork caught a regression already (less because BE, more because it's a platform without JIT support), before it made it into a release. I think that makes it worth trying to get it into at least nightly runs on php/php-src. If I can get better performance out of it (or more runners), push would be really nice too.

@AlocJose
Copy link
Author

@iluuu1994 @cmb69 Issues seen in s390x travis builds have been resolved recently and jobs look stable for other projects.
Having s390x CI running will help us catch issues early. Will it be possible to try triggering few s390x builds in Travis ?

@AlocJose
Copy link
Author

AlocJose commented Jan 8, 2025

@iluuu1994 @cmb69 Could you please consider the above comment? Please let me know your thoughts.

@NattyNarwhal
Copy link
Member

I think we're probably not interested in Travis, but I'm trying to get a different BE system going in GH-17258. For z specifically, I think we're looking into the IBM open source program for that.

@iluuu1994
Copy link
Member

@AlocJose Not at this time, but thank you for your consideration.

@iluuu1994 iluuu1994 closed this as not planned Won't fix, can't repro, duplicate, stale Jan 8, 2025
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

No branches or pull requests

5 participants