Skip to content

Conversation

@arnaud-lb
Copy link
Member

@arnaud-lb arnaud-lb commented Apr 9, 2024

This adds an Alpine job to the push workflow.

See #13877

The "Alpine CI" commit is based on #8621 (I will add @mvorisek as co-author).

I will open separate PRs for other changes:

Most changes are not musl-specific and benefit other platforms.

The musl iconv implementation's behavior differs considerably from the glibc one. Currently the iconv tests rely on the glibc behavior, and it is required to build the extension against the gnu-libiconv package. This solves discrependices in the iconv extension, but unfortunately some libraries use musl iconv, at least on Alpine. For instance libxml does, and this affects the library's ability to handle some charsets.

The icu-data-full package is also required because Alpine stripes locale data from the ICU package.

I believe that the hunspell-en and enchant2-hunspell packages also helped to make the enchant test suite pass.

@arnaud-lb arnaud-lb changed the title [wip] Alpine CI Alpine CI Jun 25, 2024
@arnaud-lb arnaud-lb marked this pull request as ready for review June 25, 2024 13:29
asan: false
- debug: true
zts: true
asan: true
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I would suggest just the latter, two builds seem like overkill to me. Instead, you could add both to nightly.

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Honestly, I wonder if it wouldn't be more useful to just move this to nightly but with all extensions enabled. WDYT? Or do you think this tests something unique (apart from alpine/musl)?

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Honestly, I wonder if it wouldn't be more useful to just move this to nightly but with all extensions enabled. WDYT? Or do you think this tests something unique (apart from alpine/musl)?

I planned to also add a nightly job after this, but I don't mind moving this to nightly initially.

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I won't object to either, but IMO the push itself is not a big value-add if it's unlikely to break, without the other builds breaking.

Copy link
Member Author

@arnaud-lb arnaud-lb Aug 14, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I've moved the job to nightly (tested in https://github.com/arnaud-lb/php-src/actions/runs/10388373807/job/28763941967). For now I didn't enable all extensions, but I may do later (in a separate change).

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This is not redundant. Have you seen the OpenSSL issue list: #14036 ? This already shows that there are significant enough differences. Catching issues after the merge usually takes time and it is also riskier for releases.

As I mentioned those are low resource jobs so the load on planet is minimal (you should really see what normally runs in enterprise pipelines where usually you don't see any nightly runs and lots of jobs are high resource ones - everything is often done on push).

The way how I see it is to have only long running and pipelines with not enough credits to be run in nightly. Anywya we don't probably agree on this so I will leave decision to you as you are the code owner for this part. Feel free to remove the push then.

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

As mentioned, I don't inherently object to increasing CI time, but I do think we should keep it minimal, rather than keep growing it until it becomes a problem. I don't know what the OpenSSL issue is about, but since this change wasn't even caused by us, it wouldn't have prevented the failing of release branches either.

Anyway, this discussion has already gone on too long to be useful. I'll leave it up to Arnaud to decide whether to keep push or remove it.

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@arnaud-lb I understand @iluuu1994 as any added CI pipeline increases the CI time meaning not only more energy used but also CI might delay other CIs for different PRs.

However I understand @bukka as well. Push CI pipelines are great for evaluating if PR or any commit is working properly.

I was neutral on this because of these pros and cons, but in past I strugled with #13771 many times and as reported there, many times this was left unnoticed for a while on master branch.

Based on this, I would support having Alpine tested on push with #13771, ie. one push job where the extensions would be build separately testing if the header files and dependencies of each extension are defined properly on push.

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I've decided to merge only the nightly job for now. I will add a push job if nightly fails regularly.

@mvorisek I think what you suggest in #13771 would solve your issue as it would detect issues less than 24 hours after they were introduced?

Copy link
Contributor

@mvorisek mvorisek Aug 28, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

#13771 about every second month the build was broken, so I would say it should be tested on push as it is not only an Alpine issue, but a build issue in general. But I am not the one who decide if it should be for nightly only or not.

And thank you for partnering in this PR and taking it to the finish line ❤🎉

@arnaud-lb arnaud-lb force-pushed the alpine-ci branch 2 times, most recently from 93987b0 to 197fb39 Compare July 9, 2024 13:27
@mvorisek
Copy link
Contributor

 =====================================================================
FAILED TEST SUMMARY
---------------------------------------------------------------------
XMLWriter::toStream() with encoding - test GBK [ext/xmlwriter/tests/xmlwriter_toStream_encoding_gbk.phpt]
=====================================================================

This test is failing on Alpine as GBK encoding is probably not present, can some extra Alpine dependency fix it or should it be skipped on Alpine?

Then is there anything else remaining in order to merge this PR?

@arnaud-lb
Copy link
Member Author

Yes I believe this is the last blocker. I'm trying to fix this test in #15072 :)

@bukka
Copy link
Member

bukka commented Jul 29, 2024

@arnaud-lb I guess all prereqs are merged, right? Would be good to get review from @iluuu1994 or @TimWolla . From the quick look, it looks good to me but will leave to code owners to do a proper review. It will be really great to have Alpine CI...

@arnaud-lb
Copy link
Member Author

@bukka yes all prereqs are merged and the build is stable. Reviews welcome :)

Copy link
Member

@TimWolla TimWolla left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Some remarks regarding the GitHub Action usage. Can't comment on the build steps themselves, because I have opinions about supporting Musl in the first place :-)

Comment on lines 3 to 5
testArtifacts:
default: null
required: false
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Unused.

- name: Test Tracing JIT
uses: ./.github/actions/test-alpine
with:
testArtifacts: ${{ matrix.debug && 'DEBUG' || 'RELEASE' }}_${{ matrix.zts && 'ZTS' || 'NTS' }}${{ matrix.asan && '_ASAN' || '' }}_Tracing JIT
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Unused.

--enable-fpm \
--with-pdo-mysql=mysqlnd \
--with-mysqli=mysqlnd \
${{ inputs.skipSlow == 'false' && '--with-pgsql' || '' }} \
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

There is no input called skipSlow.

@arnaud-lb
Copy link
Member Author

I will merge this week unless there are objections

Copy link
Member

@iluuu1994 iluuu1994 left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

LGTM otherwise

sapi/cli/php run-tests.php -P -q ${{ inputs.runTestsParameters }} \
-d opcache.jit=${{ inputs.jitType }} \
-d opcache.jit_buffer_size=64M \
-j$(($(nproc) - 1)) \
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

You can probably do -j$(nproc). The -1 was used as an attempt to fix crashes specific to macOS.

asan: false
- debug: true
zts: true
asan: true
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Honestly, I wonder if it wouldn't be more useful to just move this to nightly but with all extensions enabled. WDYT? Or do you think this tests something unique (apart from alpine/musl)?

@orlitzky
Copy link
Contributor

orlitzky commented Nov 7, 2024

There are a few user reports about the iconv/gettext stuff:

I investigated a little before giving up to work in the crypt() part, and to me it looked like gettext() wasn't working at all. If that's the case maybe the gettext extension should do a ./configure check and bail if the musl implementation is used (i.e. if gettext() doesn't work)?

@orlitzky
Copy link
Contributor

Ok, I spent the day debugging the gettext issues. Here's a stupid one I don't know how best to solve. Six of the tests fail because musl ignores the .UTF-8 part in the directory names. So we can fix six test failures right away by symlinking ext/gettext/tests/locale/en_US.UTF-8 to ext/gettext/tests/locale/en_US. But I am assuming we don't want symlinks in the git repo, so what's the best way to accomplish the same thing?

  • cp -r and just commit the duplicates
  • have ./configure do cp -r if not on windows
  • something else

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Projects

None yet

Development

Successfully merging this pull request may close these issues.

6 participants