-
Notifications
You must be signed in to change notification settings - Fork 3.8k
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
[ci] [R-package] use R 4.2.1 in Windows CI jobs (fixes #4881) #5503
Conversation
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I'm approving to unblock but I'm not the best person to review this. Hopefully someone else can provide their review.
Co-authored-by: José Morales <[email protected]>
Thanks for much for that honesty, @jmoralez , much appreciated! I agree, it would have been better to have @guolinke or @shiyu1994 review this. Normally I'd wait for one of them, but since #5525 is so time-sensitive, I'm going to merge this to unblock testing there. These changes will make it into that PR so they'll have another chance to review there, and I think all of the extra testing with win-builder and R Hub there will be give us high confidence that this is working (or catch any issues with it 😬 ). |
@jameslamb no problems, this PR looks good to me. |
ok thank you! |
This pull request has been automatically locked since there has not been any recent activity since it was closed. To start a new related discussion, open a new issue at https://github.com/microsoft/LightGBM/issues including a reference to this. |
Fixes #4881.
Replaces #5274.
Changes in this PR
VERSION.txt
intotest_r_package_windows.ps1
(instead of relying on wildcards likelightgbm_*.tar.gz
Why did the check in
configure.win
need to change?Compiling the test program used to check for
inet_pton
with the compiler that ships with RTools42 (gcc 10.3), results in the following error.To avoid that casting, this PR proposes just assigning the address of
inet_pton
to a function pointer for a function with exactly the same signature as the one LightGBM's code expects.Why does the use of
"lightgbm_*.tar.gz"
need to be replaced with"lightgbm_$env:LGB_VER.tar.gz"
?I'm not sure...probably related to R or some tool shipping with RTools42 not working well with wildcards. While testing in #4881, I saw errors like the following:
Notes for Reviewers
#4881 refers to creating a comment-triggered workflow for the UCRT toolchain for Windows builds, but I don't think that's necessary any more now that R 4.2.0 has actually been released and Rtools42 contains the UCRT build tools.
I closed #4881 in favor of this because that PR was getting very busy with debugging commits and comments.
References
There is some documentation about Rtools42 adding its own compilers to PATH, but I think that just means to R's PATH (referenced by
R CMD
commands).e.g., see https://cran.r-project.org/bin/windows/base/howto-R-4.2.html
and r-lib/actions#574 (comment)
Some additional relevant information in the
r-lib/actions
project:How I tested this
Given the changes to
configure.win
, I also tested the project on R Hub and win-builder.Generated the CRAN source distribution like this:
Then used that
.tar.gz
to test on win-builder and R Hub.passing on win-builder (click me)
R-release
(logs)R-devel
(logs)R-oldrelease
(logs)See https://win-builder.r-project.org/. This project is run by some of the CRAN maintainers, and very closely matches the Windows builds on CRAN.
There are functions in
{devtools}
to automate uploading to this service, e.g.devtools::check_win_release()
. Unfortunately, those only take a director to be packaged withR CMD build
. That doesn't work with the custom stuffbuild-cran-package.sh
has to do to build vignettes:LightGBM/build-cran-package.sh
Line 206 in dc4794b
So I manually changed the maintainer to myself in
DESCRIPTION
, built the package withbuild-cran-package.sh
, then uploaded manually at https://win-builder.r-project.org/upload.aspx.passing on R Hub (click me)
I tried checking the package built from this branch on all 4 platforms supported by R Hub.
windows-x86_64-devel
(logs)windows-x86_64-oldrel
(logs)windows-x86_64-patched
(logs)windows-x86_64-release
(logs)