mirror of
https://github.com/fish-shell/fish-shell
synced 2025-01-12 04:58:57 +00:00
Update docker files and cirrus config
- Ubuntu focal is the lowest LTS release that we can support with only distro packages (e.g. no rustup). - Remove tsan from Cirrus (it's not working currently, and also not really important). - Remove Centos (it passes tests but I'm not sure it's worth adding; there isn't even an official docker image for CentOS Stream).
This commit is contained in:
parent
3984725b80
commit
4df0adefc8
14 changed files with 75 additions and 126 deletions
28
.cirrus.yml
28
.cirrus.yml
|
@ -8,38 +8,18 @@ linux_task:
|
||||||
container: &step
|
container: &step
|
||||||
image: ghcr.io/fish-shell/fish-ci/alpine:latest
|
image: ghcr.io/fish-shell/fish-ci/alpine:latest
|
||||||
memory: 4GB
|
memory: 4GB
|
||||||
- name: bionic
|
- name: jammy
|
||||||
container:
|
container:
|
||||||
<<: *step
|
<<: *step
|
||||||
image: ghcr.io/fish-shell/fish-ci/bionic:latest
|
image: ghcr.io/fish-shell/fish-ci/jammy:latest
|
||||||
- name: bionic-asan-clang
|
- name: jammy-asan
|
||||||
container:
|
container:
|
||||||
<<: *step
|
<<: *step
|
||||||
image: ghcr.io/fish-shell/fish-ci/bionic-asan-clang:latest
|
image: ghcr.io/fish-shell/fish-ci/jammy-asan:latest
|
||||||
- name: bionic-tsan
|
|
||||||
container:
|
|
||||||
<<: *step
|
|
||||||
image: ghcr.io/fish-shell/fish-ci/bionic-tsan:latest
|
|
||||||
- name: bionic-tsan-clang
|
|
||||||
container:
|
|
||||||
<<: *step
|
|
||||||
image: ghcr.io/fish-shell/fish-ci/bionic-tsan-clang:latest
|
|
||||||
- name: centos7
|
|
||||||
container:
|
|
||||||
<<: *step
|
|
||||||
image: ghcr.io/fish-shell/fish-ci/centos7:latest
|
|
||||||
- name: centos8
|
|
||||||
container:
|
|
||||||
<<: *step
|
|
||||||
image: ghcr.io/fish-shell/fish-ci/centos8:latest
|
|
||||||
- name: focal-32bit
|
- name: focal-32bit
|
||||||
container:
|
container:
|
||||||
<<: *step
|
<<: *step
|
||||||
image: ghcr.io/fish-shell/fish-ci/focal-32bit:latest
|
image: ghcr.io/fish-shell/fish-ci/focal-32bit:latest
|
||||||
- name: xenial
|
|
||||||
container:
|
|
||||||
<<: *step
|
|
||||||
image: ghcr.io/fish-shell/fish-ci/xenial:latest
|
|
||||||
|
|
||||||
tests_script:
|
tests_script:
|
||||||
# cirrus at times gives us 32 procs and 2 GB of RAM
|
# cirrus at times gives us 32 procs and 2 GB of RAM
|
||||||
|
|
|
@ -11,6 +11,10 @@ if(DEFINED ASAN)
|
||||||
list(APPEND CARGO_FLAGS "-Z" "build-std")
|
list(APPEND CARGO_FLAGS "-Z" "build-std")
|
||||||
list(APPEND FISH_CRATE_FEATURES "asan")
|
list(APPEND FISH_CRATE_FEATURES "asan")
|
||||||
endif()
|
endif()
|
||||||
|
if(DEFINED TSAN)
|
||||||
|
list(APPEND CARGO_FLAGS "-Z" "build-std")
|
||||||
|
list(APPEND FISH_CRATE_FEATURES "tsan")
|
||||||
|
endif()
|
||||||
|
|
||||||
if (Rust_CARGO_TARGET)
|
if (Rust_CARGO_TARGET)
|
||||||
set(rust_target_dir "${FISH_RUST_BUILD_DIR}/${Rust_CARGO_TARGET}")
|
set(rust_target_dir "${FISH_RUST_BUILD_DIR}/${Rust_CARGO_TARGET}")
|
||||||
|
|
|
@ -139,6 +139,12 @@ if(DEFINED ASAN)
|
||||||
intended target triple")
|
intended target triple")
|
||||||
endif()
|
endif()
|
||||||
endif()
|
endif()
|
||||||
|
if(DEFINED TSAN)
|
||||||
|
if(NOT DEFINED Rust_CARGO_TARGET)
|
||||||
|
message(FATAL_ERROR "TSAN requires defining the CMake variable Rust_CARGO_TARGET to the
|
||||||
|
intended target triple")
|
||||||
|
endif()
|
||||||
|
endif()
|
||||||
|
|
||||||
if(DEFINED Rust_CARGO_TARGET)
|
if(DEFINED Rust_CARGO_TARGET)
|
||||||
list(APPEND cargo_test_flags "--target" ${Rust_CARGO_TARGET})
|
list(APPEND cargo_test_flags "--target" ${Rust_CARGO_TARGET})
|
||||||
|
|
|
@ -5,18 +5,21 @@ ENV LANG C.UTF-8
|
||||||
ENV LC_ALL C.UTF-8
|
ENV LC_ALL C.UTF-8
|
||||||
|
|
||||||
RUN apk add --no-cache \
|
RUN apk add --no-cache \
|
||||||
bash \
|
bash \
|
||||||
cmake \
|
cargo \
|
||||||
g++ \
|
cmake \
|
||||||
gettext-dev \
|
g++ \
|
||||||
git \
|
gettext-dev \
|
||||||
libintl \
|
git \
|
||||||
musl-dev \
|
libintl \
|
||||||
ninja \
|
musl-dev \
|
||||||
pcre2-dev \
|
ninja \
|
||||||
python3 \
|
pcre2-dev \
|
||||||
py3-pexpect \
|
py3-pexpect \
|
||||||
cargo
|
python3 \
|
||||||
|
rust \
|
||||||
|
sudo \
|
||||||
|
tmux
|
||||||
|
|
||||||
RUN addgroup -g 1000 fishuser
|
RUN addgroup -g 1000 fishuser
|
||||||
|
|
||||||
|
|
|
@ -1,32 +0,0 @@
|
||||||
FROM centos:7
|
|
||||||
LABEL org.opencontainers.image.source=https://github.com/fish-shell/fish-shell
|
|
||||||
|
|
||||||
# install epel first to get cmake3
|
|
||||||
RUN yum install --assumeyes epel-release https://repo.ius.io/ius-release-el7.rpm \
|
|
||||||
&& yum install --assumeyes \
|
|
||||||
cmake3 \
|
|
||||||
gcc-c++ \
|
|
||||||
git236 \
|
|
||||||
ninja-build \
|
|
||||||
python3 \
|
|
||||||
openssl \
|
|
||||||
pcre2-devel \
|
|
||||||
sudo \
|
|
||||||
&& yum clean all
|
|
||||||
|
|
||||||
# cmake is called "cmake3" on centos7.
|
|
||||||
RUN ln -s /usr/bin/cmake3 /usr/bin/cmake \
|
|
||||||
&& pip3 install pexpect
|
|
||||||
|
|
||||||
RUN groupadd -g 1000 fishuser \
|
|
||||||
&& useradd -p $(openssl passwd -1 fish) -d /home/fishuser -m -u 1000 -g 1000 fishuser -G wheel \
|
|
||||||
&& mkdir -p /home/fishuser/fish-build \
|
|
||||||
&& mkdir /fish-source \
|
|
||||||
&& chown -R fishuser:fishuser /home/fishuser /fish-source
|
|
||||||
|
|
||||||
USER fishuser
|
|
||||||
WORKDIR /home/fishuser
|
|
||||||
|
|
||||||
COPY fish_run_tests.sh /
|
|
||||||
|
|
||||||
CMD /fish_run_tests.sh
|
|
|
@ -1,4 +1,4 @@
|
||||||
FROM centos:8
|
FROM tgagor/centos-stream:latest
|
||||||
LABEL org.opencontainers.image.source=https://github.com/fish-shell/fish-shell
|
LABEL org.opencontainers.image.source=https://github.com/fish-shell/fish-shell
|
||||||
|
|
||||||
# See https://stackoverflow.com/questions/70963985/error-failed-to-download-metadata-for-repo-appstream-cannot-prepare-internal
|
# See https://stackoverflow.com/questions/70963985/error-failed-to-download-metadata-for-repo-appstream-cannot-prepare-internal
|
||||||
|
@ -13,19 +13,21 @@ RUN dnf -y install dnf-plugins-core \
|
||||||
&& dnf config-manager --set-enabled powertools \
|
&& dnf config-manager --set-enabled powertools \
|
||||||
&& yum install --assumeyes epel-release \
|
&& yum install --assumeyes epel-release \
|
||||||
&& yum install --assumeyes \
|
&& yum install --assumeyes \
|
||||||
|
cargo \
|
||||||
cmake \
|
cmake \
|
||||||
diffutils \
|
diffutils \
|
||||||
gcc-c++ \
|
gcc-c++ \
|
||||||
git \
|
git \
|
||||||
ninja-build \
|
ninja-build \
|
||||||
python3 \
|
python3 \
|
||||||
|
python3-pexpect \
|
||||||
openssl \
|
openssl \
|
||||||
pcre2-devel \
|
pcre2-devel \
|
||||||
|
rustc \
|
||||||
sudo \
|
sudo \
|
||||||
|
tmux \
|
||||||
&& yum clean all
|
&& yum clean all
|
||||||
|
|
||||||
RUN pip3 install pexpect
|
|
||||||
|
|
||||||
RUN groupadd -g 1000 fishuser \
|
RUN groupadd -g 1000 fishuser \
|
||||||
&& useradd -p $(openssl passwd -1 fish) -d /home/fishuser -m -u 1000 -g 1000 fishuser -G wheel \
|
&& useradd -p $(openssl passwd -1 fish) -d /home/fishuser -m -u 1000 -g 1000 fishuser -G wheel \
|
||||||
&& mkdir -p /home/fishuser/fish-build \
|
&& mkdir -p /home/fishuser/fish-build \
|
|
@ -3,7 +3,7 @@ LABEL org.opencontainers.image.source=https://github.com/fish-shell/fish-shell
|
||||||
|
|
||||||
ENV LANG C.UTF-8
|
ENV LANG C.UTF-8
|
||||||
ENV LC_ALL C.UTF-8
|
ENV LC_ALL C.UTF-8
|
||||||
ENV CXXFLAGS="-m32 -Werror=address -Werror=return-type" CFLAGS="-m32"
|
ENV CFLAGS="-m32"
|
||||||
ENV DEBIAN_FRONTEND=noninteractive
|
ENV DEBIAN_FRONTEND=noninteractive
|
||||||
|
|
||||||
RUN apt-get update \
|
RUN apt-get update \
|
||||||
|
@ -19,6 +19,7 @@ RUN apt-get update \
|
||||||
python3 \
|
python3 \
|
||||||
python3-pexpect \
|
python3-pexpect \
|
||||||
sudo \
|
sudo \
|
||||||
|
tmux \
|
||||||
&& locale-gen en_US.UTF-8 \
|
&& locale-gen en_US.UTF-8 \
|
||||||
&& apt-get clean
|
&& apt-get clean
|
||||||
|
|
||||||
|
@ -32,6 +33,11 @@ RUN groupadd -g 1000 fishuser \
|
||||||
USER fishuser
|
USER fishuser
|
||||||
WORKDIR /home/fishuser
|
WORKDIR /home/fishuser
|
||||||
|
|
||||||
|
RUN curl --proto '=https' --tlsv1.2 -sSf https://sh.rustup.rs > /tmp/rustup.sh \
|
||||||
|
&& sh /tmp/rustup.sh -y --default-toolchain nightly --component rust-src
|
||||||
|
|
||||||
COPY fish_run_tests.sh /
|
COPY fish_run_tests.sh /
|
||||||
|
|
||||||
CMD /fish_run_tests.sh
|
CMD . ~/.cargo/env \
|
||||||
|
&& rustup target add i686-unknown-linux-gnu \
|
||||||
|
&& /fish_run_tests.sh -DFISH_USE_SYSTEM_PCRE2=OFF -DRust_CARGO_TARGET=i686-unknown-linux-gnu
|
||||||
|
|
|
@ -8,8 +8,9 @@ ENV DEBIAN_FRONTEND=noninteractive
|
||||||
RUN apt-get update \
|
RUN apt-get update \
|
||||||
&& apt-get -y install \
|
&& apt-get -y install \
|
||||||
build-essential \
|
build-essential \
|
||||||
|
cargo \
|
||||||
cmake \
|
cmake \
|
||||||
clang-9 \
|
clang \
|
||||||
gettext \
|
gettext \
|
||||||
git \
|
git \
|
||||||
libpcre2-dev \
|
libpcre2-dev \
|
||||||
|
@ -17,7 +18,9 @@ RUN apt-get update \
|
||||||
ninja-build \
|
ninja-build \
|
||||||
python3 \
|
python3 \
|
||||||
python3-pexpect \
|
python3-pexpect \
|
||||||
|
rustc \
|
||||||
sudo \
|
sudo \
|
||||||
|
tmux \
|
||||||
&& locale-gen en_US.UTF-8 \
|
&& locale-gen en_US.UTF-8 \
|
||||||
&& apt-get clean
|
&& apt-get clean
|
||||||
|
|
||||||
|
|
|
@ -1,22 +1,25 @@
|
||||||
FROM ubuntu:18.04
|
FROM ubuntu:20.04
|
||||||
LABEL org.opencontainers.image.source=https://github.com/fish-shell/fish-shell
|
LABEL org.opencontainers.image.source=https://github.com/fish-shell/fish-shell
|
||||||
|
|
||||||
ENV LANG C.UTF-8
|
ENV LANG C.UTF-8
|
||||||
ENV LC_ALL C.UTF-8
|
ENV LC_ALL C.UTF-8
|
||||||
|
ENV DEBIAN_FRONTEND=noninteractive
|
||||||
|
|
||||||
RUN apt-get update \
|
RUN apt-get update \
|
||||||
&& apt-get -y install \
|
&& apt-get -y install \
|
||||||
build-essential \
|
build-essential \
|
||||||
|
cargo \
|
||||||
cmake \
|
cmake \
|
||||||
clang-9 \
|
|
||||||
gettext \
|
gettext \
|
||||||
git \
|
git \
|
||||||
libpcre2-dev \
|
|
||||||
locales \
|
locales \
|
||||||
ninja-build \
|
ninja-build \
|
||||||
|
pkg-config \
|
||||||
python3 \
|
python3 \
|
||||||
python3-pexpect \
|
python3-pexpect \
|
||||||
|
rustc \
|
||||||
sudo \
|
sudo \
|
||||||
|
tmux \
|
||||||
&& locale-gen en_US.UTF-8 \
|
&& locale-gen en_US.UTF-8 \
|
||||||
&& apt-get clean
|
&& apt-get clean
|
||||||
|
|
||||||
|
@ -32,5 +35,4 @@ WORKDIR /home/fishuser
|
||||||
|
|
||||||
COPY fish_run_tests.sh /
|
COPY fish_run_tests.sh /
|
||||||
|
|
||||||
ENV CXXFLAGS "-fsanitize=thread"
|
|
||||||
CMD /fish_run_tests.sh
|
CMD /fish_run_tests.sh
|
|
@ -3,12 +3,12 @@ LABEL org.opencontainers.image.source=https://github.com/fish-shell/fish-shell
|
||||||
|
|
||||||
ENV LANG C.UTF-8
|
ENV LANG C.UTF-8
|
||||||
ENV LC_ALL C.UTF-8
|
ENV LC_ALL C.UTF-8
|
||||||
ENV CXXFLAGS="-Werror=address -Werror=return-type -Wno-psabi"
|
|
||||||
ENV DEBIAN_FRONTEND=noninteractive
|
ENV DEBIAN_FRONTEND=noninteractive
|
||||||
|
|
||||||
RUN apt-get update \
|
RUN apt-get update \
|
||||||
&& apt-get -y install \
|
&& apt-get -y install \
|
||||||
build-essential \
|
build-essential \
|
||||||
|
cargo \
|
||||||
cmake \
|
cmake \
|
||||||
file \
|
file \
|
||||||
g++ \
|
g++ \
|
||||||
|
@ -20,7 +20,9 @@ RUN apt-get update \
|
||||||
pkg-config \
|
pkg-config \
|
||||||
python3 \
|
python3 \
|
||||||
python3-pexpect \
|
python3-pexpect \
|
||||||
|
rust \
|
||||||
sudo \
|
sudo \
|
||||||
|
tmux \
|
||||||
&& locale-gen en_US.UTF-8 \
|
&& locale-gen en_US.UTF-8 \
|
||||||
&& apt-get clean
|
&& apt-get clean
|
||||||
|
|
||||||
|
|
|
@ -16,9 +16,8 @@ RUN apt-get update \
|
||||||
ninja-build \
|
ninja-build \
|
||||||
python3 \
|
python3 \
|
||||||
python3-pexpect \
|
python3-pexpect \
|
||||||
tmux \
|
|
||||||
rustc \
|
|
||||||
sudo \
|
sudo \
|
||||||
|
tmux \
|
||||||
&& locale-gen en_US.UTF-8 \
|
&& locale-gen en_US.UTF-8 \
|
||||||
&& apt-get clean
|
&& apt-get clean
|
||||||
|
|
||||||
|
@ -42,9 +41,9 @@ COPY fish_run_tests.sh /
|
||||||
|
|
||||||
ENV \
|
ENV \
|
||||||
RUSTFLAGS=-Zsanitizer=address \
|
RUSTFLAGS=-Zsanitizer=address \
|
||||||
|
RUSTDOCFLAGS=-Zsanitizer=address \
|
||||||
CC=clang \
|
CC=clang \
|
||||||
CXX=clang++ \
|
CXX=clang++ \
|
||||||
CXXFLAGS=-DFISH_CI_SAN \
|
|
||||||
ASAN_OPTIONS=check_initialization_order=1:detect_stack_use_after_return=1:detect_leaks=1 \
|
ASAN_OPTIONS=check_initialization_order=1:detect_stack_use_after_return=1:detect_leaks=1 \
|
||||||
LSAN_OPTIONS=verbosity=0:log_threads=0:use_tls=1:print_suppressions=0:suppressions=/fish-source/build_tools/lsan_suppressions.txt \
|
LSAN_OPTIONS=verbosity=0:log_threads=0:use_tls=1:print_suppressions=0:suppressions=/fish-source/build_tools/lsan_suppressions.txt \
|
||||||
FISH_CI_SAN=1
|
FISH_CI_SAN=1
|
|
@ -1,4 +1,4 @@
|
||||||
FROM ubuntu:18.04
|
FROM ubuntu:jammy
|
||||||
LABEL org.opencontainers.image.source=https://github.com/fish-shell/fish-shell
|
LABEL org.opencontainers.image.source=https://github.com/fish-shell/fish-shell
|
||||||
|
|
||||||
ENV LANG C.UTF-8
|
ENV LANG C.UTF-8
|
||||||
|
@ -8,7 +8,7 @@ RUN apt-get update \
|
||||||
&& apt-get -y install \
|
&& apt-get -y install \
|
||||||
build-essential \
|
build-essential \
|
||||||
cmake \
|
cmake \
|
||||||
clang-9 \
|
clang \
|
||||||
gettext \
|
gettext \
|
||||||
git \
|
git \
|
||||||
libpcre2-dev \
|
libpcre2-dev \
|
||||||
|
@ -17,6 +17,7 @@ RUN apt-get update \
|
||||||
python3 \
|
python3 \
|
||||||
python3-pexpect \
|
python3-pexpect \
|
||||||
sudo \
|
sudo \
|
||||||
|
tmux \
|
||||||
&& locale-gen en_US.UTF-8 \
|
&& locale-gen en_US.UTF-8 \
|
||||||
&& apt-get clean
|
&& apt-get clean
|
||||||
|
|
||||||
|
@ -30,7 +31,15 @@ RUN groupadd -g 1000 fishuser \
|
||||||
USER fishuser
|
USER fishuser
|
||||||
WORKDIR /home/fishuser
|
WORKDIR /home/fishuser
|
||||||
|
|
||||||
|
RUN curl --proto '=https' --tlsv1.2 -sSf https://sh.rustup.rs > /tmp/rustup.sh \
|
||||||
|
&& sh /tmp/rustup.sh -y --default-toolchain nightly --component rust-src
|
||||||
|
|
||||||
COPY fish_run_tests.sh /
|
COPY fish_run_tests.sh /
|
||||||
|
|
||||||
ENV CXXFLAGS="-fsanitize=thread" CC=clang-9 CXX=clang++-9
|
ENV \
|
||||||
CMD /fish_run_tests.sh
|
RUSTFLAGS=-Zsanitizer=thread \
|
||||||
|
RUSTDOCFLAGS=-Zsanitizer=thread \
|
||||||
|
FISH_CI_SAN=1
|
||||||
|
|
||||||
|
CMD . ~/.cargo/env \
|
||||||
|
&& /fish_run_tests.sh -DTSAN=1 -DRust_CARGO_TARGET=x86_64-unknown-linux-gnu
|
|
@ -1,4 +1,4 @@
|
||||||
FROM ubuntu:18.04
|
FROM ubuntu:jammy
|
||||||
LABEL org.opencontainers.image.source=https://github.com/fish-shell/fish-shell
|
LABEL org.opencontainers.image.source=https://github.com/fish-shell/fish-shell
|
||||||
|
|
||||||
ENV LANG C.UTF-8
|
ENV LANG C.UTF-8
|
||||||
|
@ -7,8 +7,9 @@ ENV LC_ALL C.UTF-8
|
||||||
RUN apt-get update \
|
RUN apt-get update \
|
||||||
&& apt-get -y install \
|
&& apt-get -y install \
|
||||||
build-essential \
|
build-essential \
|
||||||
|
cargo \
|
||||||
cmake \
|
cmake \
|
||||||
clang-9 \
|
clang \
|
||||||
gettext \
|
gettext \
|
||||||
git \
|
git \
|
||||||
libpcre2-dev \
|
libpcre2-dev \
|
||||||
|
@ -16,7 +17,9 @@ RUN apt-get update \
|
||||||
ninja-build \
|
ninja-build \
|
||||||
python3 \
|
python3 \
|
||||||
python3-pexpect \
|
python3-pexpect \
|
||||||
|
rustc \
|
||||||
sudo \
|
sudo \
|
||||||
|
tmux \
|
||||||
&& locale-gen en_US.UTF-8 \
|
&& locale-gen en_US.UTF-8 \
|
||||||
&& apt-get clean
|
&& apt-get clean
|
||||||
|
|
|
@ -1,38 +0,0 @@
|
||||||
FROM ubuntu:16.04
|
|
||||||
LABEL org.opencontainers.image.source=https://github.com/fish-shell/fish-shell
|
|
||||||
|
|
||||||
ENV LANG C.UTF-8
|
|
||||||
ENV LC_ALL C.UTF-8
|
|
||||||
|
|
||||||
RUN apt-get update \
|
|
||||||
&& apt-get -y install \
|
|
||||||
build-essential \
|
|
||||||
cmake \
|
|
||||||
gettext \
|
|
||||||
git \
|
|
||||||
libpcre2-dev \
|
|
||||||
locales \
|
|
||||||
ninja-build \
|
|
||||||
python3 \
|
|
||||||
python3-pip \
|
|
||||||
sudo \
|
|
||||||
&& locale-gen en_US.UTF-8 \
|
|
||||||
&& apt-get clean
|
|
||||||
|
|
||||||
# The python3-pexpect package on Xenial doesn't allow delaybeforesend to be None.
|
|
||||||
# Install pexpect with pip which is newer.
|
|
||||||
RUN pip3 install pexpect
|
|
||||||
|
|
||||||
RUN groupadd -g 1000 fishuser \
|
|
||||||
&& useradd -p $(openssl passwd -1 fish) -d /home/fishuser -m -u 1000 -g 1000 fishuser \
|
|
||||||
&& adduser fishuser sudo \
|
|
||||||
&& mkdir -p /home/fishuser/fish-build \
|
|
||||||
&& mkdir /fish-source \
|
|
||||||
&& chown -R fishuser:fishuser /home/fishuser /fish-source
|
|
||||||
|
|
||||||
USER fishuser
|
|
||||||
WORKDIR /home/fishuser
|
|
||||||
|
|
||||||
COPY fish_run_tests.sh /
|
|
||||||
|
|
||||||
CMD /fish_run_tests.sh
|
|
Loading…
Reference in a new issue