Inconsistencies with CRAN fedora-clang-devel
gowerc opened this issue · 4 comments
We have been trying to track down a bug in our package that only appears on CRAN fredora-clang-devel. Whilst investigating it looks like there are a number of inconsistencies between the image on Rhub vs what CRAN are running. That being said I'm not very experienced with this system configuration stuff so apologies if I have got this wrong.
In particular:
-
It looks like you are using Fedora 33 whilst they are using Fedora 36
-
They are using clang-15 whereas it looks like you are using the rpms clang which appears to be clang-11
-
It looks like you are using different Makevars compared to them
The impact though is that my unit tests are running fine on your image via rhub::check(platform = "fedora-clang-devel")
even though they are failing to run on CRAN.
I've observed the same thing with the debian-clang-devel
images.
The images are using clang
14
docker run \
--rm \
rhub/debian-clang-devel:latest \
clang --version
Debian clang version 14.0.6
Target: x86_64-pc-linux-gnu
Thread model: posix
But according to https://cran.r-project.org/web/checks/check_flavors.html#r-devel-linux-x86_64-debian-clang, CRAN is using clang
15.
Over in {lightgbm}
, we recently experienced an issue where CRAN raised a warning for the r-devel-linux-x86_64-debian-clang
check flavor (link to logs) that we didn't observe running R CMD check --as-cran
in the rhub/debian-clang-devel
image published here.
Found the following significant warnings:
io/json11.cpp:207:47: warning: unqualified call to 'std::move' [-Wunqualified-std-cast-call]
...
I just found that I was able to reproduce the warning I see over on CRAN by running the following in a container using that image, to upgrade to clang
v15.
# remove clang stuff that comes installed in the image
apt-get autoremove -y --purge \
clang-* \
libclang-* \
libunwind-* \
llvm-*
# download equivalent clang-15 packages
apt-get update -y
apt-get install --no-install-recommends -y \
gnupg \
lsb-release \
software-properties-common \
wget
wget -O - https://apt.llvm.org/llvm-snapshot.gpg.key | apt-key add -
add-apt-repository "deb http://apt.llvm.org/bullseye/ llvm-toolchain-bullseye-15 main"
apt-get install -y --no-install-recommends \
clang-15 \
clangd-15 \
clang-format-15 \
clang-tidy-15 \
clang-tools-15 \
lldb-15 \
lld-15 \
llvm-15-dev \
llvm-15-tools \
libomp-15-dev \
libc++-15-dev \
libc++abi-15-dev \
libclang-common-15-dev \
libclang-15-dev \
libclang-cpp15-dev \
libunwind-15-dev
# overwrite everything in /usr/bin with the new v15 versions
cp --remove-destination /usr/lib/llvm-15/bin/* /usr/bin/
@gaborcsardi @maelle are you open to a pull request with something similar to this, to upgrade the debian and fedora images to clang
15? I'd be happy to work on such a change, test it, and propose a pull request if you support the general idea.
We are planning on rolling out new images in a week or so.
Oh great, glad to hear it! Thanks so much.
My offer still stands, I'm happy to help out here any time if you want. I depend on these images so much.