Skip to content

Commit

Permalink
Update devcontainer to Rust 1.80.1 (#352)
Browse files Browse the repository at this point in the history
* Update devcontainer to Rust 1.80.1

Issue-Id: #89

* Move dev container from debian to ubuntu

* Use own shell config

Issue-Id: #89

* Use new container in GHA

Issue-Id: #89

* Improve shell prompt config

Issue-Id: #89

* Add default linker for x86_64

* Use new dev container in CI
  • Loading branch information
windsource authored Aug 22, 2024
1 parent fed2801 commit 3120962
Show file tree
Hide file tree
Showing 9 changed files with 229 additions and 19 deletions.
3 changes: 3 additions & 0 deletions .cargo/config.toml
Original file line number Diff line number Diff line change
Expand Up @@ -3,3 +3,6 @@ target = "x86_64-unknown-linux-musl"

[target.aarch64-unknown-linux-musl]
linker="aarch64-linux-gnu-gcc"

[target.x86_64-unknown-linux-musl]
linker="x86_64-linux-gnu-gcc"
2 changes: 1 addition & 1 deletion .devcontainer/Dockerfile
Original file line number Diff line number Diff line change
Expand Up @@ -12,7 +12,7 @@
#
# SPDX-License-Identifier: Apache-2.0

FROM ghcr.io/eclipse-ankaios/devcontainer-base:0.9.2
FROM ghcr.io/eclipse-ankaios/devcontainer-base:0.10.1

ARG USERNAME=vscode

Expand Down
59 changes: 48 additions & 11 deletions .devcontainer/Dockerfile.base
Original file line number Diff line number Diff line change
Expand Up @@ -12,13 +12,26 @@
#
# SPDX-License-Identifier: Apache-2.0

FROM mcr.microsoft.com/devcontainers/rust:1-1-bookworm
FROM ubuntu:24.04

ARG USERNAME=vscode
ARG TARGETARCH
ARG USERNAME=vscode

RUN apt-get update && export DEBIAN_FRONTEND=noninteractive \
&& apt-get -y install \
# All the packages we need
RUN export DEBIAN_FRONTEND=noninteractive \
&& apt update && \
if [ "$TARGETARCH" = "amd64" ]; then \
apt install -y gcc-aarch64-linux-gnu; \
elif [ "$TARGETARCH" = "arm64" ]; then \
apt install -y gcc-x86-64-linux-gnu; \
fi \
&& apt -y install \
# Basics
git \
zsh \
curl \
iputils-ping \
sudo \
# java for plantuml
default-jre \
graphviz \
Expand All @@ -35,7 +48,6 @@ RUN apt-get update && export DEBIAN_FRONTEND=noninteractive \
# Others
protobuf-compiler \
protobuf-compiler-grpc \
gcc-aarch64-linux-gnu \
tmux \
vim \
uidmap \
Expand All @@ -45,8 +57,37 @@ RUN apt-get update && export DEBIAN_FRONTEND=noninteractive \
podman \
# TLS
musl-tools \
&& \
rm -rf /var/lib/apt/lists/*
# Cleanup
&& rm -rf /var/lib/apt/lists/*

# User management
RUN (userdel -r ubuntu || true) \
&& groupadd rustlang \
&& useradd -s /bin/bash -d /home/${USERNAME} -m -G rustlang ${USERNAME} \
&& echo "${USERNAME} ALL=(root) NOPASSWD:ALL" > /etc/sudoers.d/${USERNAME}

# Prepare shells
USER ${USERNAME}
COPY --chown=${USERNAME}:${USERNAME} dot_bashrc /home/${USERNAME}/.bashrc
COPY --chown=${USERNAME}:${USERNAME} dot_zshrc /home/${USERNAME}/.zshrc
COPY --chown=${USERNAME}:${USERNAME} dot_tmux.conf /home/${USERNAME}/.tmux.conf
RUN curl -sS https://starship.rs/install.sh | sh -s -- -y \
&& echo 'eval "$(starship init bash)"' >> /home/${USERNAME}/.bashrc \
&& echo 'eval "$(starship init zsh)"' >> /home/${USERNAME}/.zshrc
COPY --chown=${USERNAME}:${USERNAME} starship.toml /home/${USERNAME}/.config/
USER root

# Rust
ENV RUSTUP_HOME=/usr/local/rustup
ENV CARGO_HOME=/usr/local/cargo
ENV PATH=/usr/local/cargo/bin:$PATH
RUN mkdir -p -m 2777 $RUSTUP_HOME \
&& chgrp rustlang $RUSTUP_HOME \
&& mkdir -p -m 2777 $CARGO_HOME \
&& chgrp rustlang $CARGO_HOME \
&& curl --proto '=https' --tlsv1.2 -sSf https://sh.rustup.rs | \
sh -s -- -y --default-toolchain 1.80.1 --target x86_64-unknown-linux-musl aarch64-unknown-linux-musl --no-modify-path \
&& chmod -R ag+w $RUSTUP_HOME $CARGO_HOME

VOLUME /var/lib/containers

Expand Down Expand Up @@ -90,8 +131,4 @@ RUN cargo install cargo-llvm-cov --locked; \
cargo install cargo-deny --locked; \
cargo install cargo-about --locked

# Install required cargo targets and toolchains
RUN rustup target add x86_64-unknown-linux-musl \
&& rustup target add aarch64-unknown-linux-musl

USER root
118 changes: 118 additions & 0 deletions .devcontainer/dot_bashrc
Original file line number Diff line number Diff line change
@@ -0,0 +1,118 @@
# ~/.bashrc: executed by bash(1) for non-login shells.
# see /usr/share/doc/bash/examples/startup-files (in the package bash-doc)
# for examples

# If not running interactively, don't do anything
case $- in
*i*) ;;
*) return;;
esac

# don't put duplicate lines or lines starting with space in the history.
# See bash(1) for more options
HISTCONTROL=ignoreboth

# append to the history file, don't overwrite it
shopt -s histappend

# for setting history length see HISTSIZE and HISTFILESIZE in bash(1)
HISTSIZE=1000
HISTFILESIZE=2000

# check the window size after each command and, if necessary,
# update the values of LINES and COLUMNS.
shopt -s checkwinsize

# If set, the pattern "**" used in a pathname expansion context will
# match all files and zero or more directories and subdirectories.
#shopt -s globstar

# make less more friendly for non-text input files, see lesspipe(1)
[ -x /usr/bin/lesspipe ] && eval "$(SHELL=/bin/sh lesspipe)"

# set variable identifying the chroot you work in (used in the prompt below)
if [ -z "${debian_chroot:-}" ] && [ -r /etc/debian_chroot ]; then
debian_chroot=$(cat /etc/debian_chroot)
fi

# set a fancy prompt (non-color, unless we know we "want" color)
case "$TERM" in
xterm-color|*-256color) color_prompt=yes;;
esac

# uncomment for a colored prompt, if the terminal has the capability; turned
# off by default to not distract the user: the focus in a terminal window
# should be on the output of commands, not on the prompt
#force_color_prompt=yes

if [ -n "$force_color_prompt" ]; then
if [ -x /usr/bin/tput ] && tput setaf 1 >&/dev/null; then
# We have color support; assume it's compliant with Ecma-48
# (ISO/IEC-6429). (Lack of such support is extremely rare, and such
# a case would tend to support setf rather than setaf.)
color_prompt=yes
else
color_prompt=
fi
fi

if [ "$color_prompt" = yes ]; then
PS1='${debian_chroot:+($debian_chroot)}\[\033[01;32m\]\u@\h\[\033[00m\]:\[\033[01;34m\]\w\[\033[00m\]\$ '
else
PS1='${debian_chroot:+($debian_chroot)}\u@\h:\w\$ '
fi
unset color_prompt force_color_prompt

# If this is an xterm set the title to user@host:dir
case "$TERM" in
xterm*|rxvt*)
PS1="\[\e]0;${debian_chroot:+($debian_chroot)}\u@\h: \w\a\]$PS1"
;;
*)
;;
esac

# enable color support of ls and also add handy aliases
if [ -x /usr/bin/dircolors ]; then
test -r ~/.dircolors && eval "$(dircolors -b ~/.dircolors)" || eval "$(dircolors -b)"
alias ls='ls --color=auto'
#alias dir='dir --color=auto'
#alias vdir='vdir --color=auto'

alias grep='grep --color=auto'
alias fgrep='fgrep --color=auto'
alias egrep='egrep --color=auto'
fi

# colored GCC warnings and errors
#export GCC_COLORS='error=01;31:warning=01;35:note=01;36:caret=01;32:locus=01:quote=01'

# some more ls aliases
alias ll='ls -alF'
alias la='ls -A'
alias l='ls -CF'

# Add an "alert" alias for long running commands. Use like so:
# sleep 10; alert
alias alert='notify-send --urgency=low -i "$([ $? = 0 ] && echo terminal || echo error)" "$(history|tail -n1|sed -e '\''s/^\s*[0-9]\+\s*//;s/[;&|]\s*alert$//'\'')"'

# Alias definitions.
# You may want to put all your additions into a separate file like
# ~/.bash_aliases, instead of adding them here directly.
# See /usr/share/doc/bash-doc/examples in the bash-doc package.

if [ -f ~/.bash_aliases ]; then
. ~/.bash_aliases
fi

# enable programmable completion features (you don't need to enable
# this, if it's already enabled in /etc/bash.bashrc and /etc/profile
# sources /etc/bash.bashrc).
if ! shopt -oq posix; then
if [ -f /usr/share/bash-completion/bash_completion ]; then
. /usr/share/bash-completion/bash_completion
elif [ -f /etc/bash_completion ]; then
. /etc/bash_completion
fi
fi

2 changes: 2 additions & 0 deletions .devcontainer/dot_tmux.conf
Original file line number Diff line number Diff line change
@@ -0,0 +1,2 @@
set -g mouse on
set-option -g default-shell /bin/zsh
40 changes: 40 additions & 0 deletions .devcontainer/dot_zshrc
Original file line number Diff line number Diff line change
@@ -0,0 +1,40 @@
# Set up the prompt

#autoload -Uz promptinit
#promptinit
#prompt adam1

setopt histignorealldups sharehistory

# Use emacs keybindings even if our EDITOR is set to vi
bindkey -e

# Keep 1000 lines of history within the shell and save it to ~/.zsh_history:
HISTSIZE=1000
SAVEHIST=1000
HISTFILE=~/.zsh_history

# Use modern completion system
autoload -Uz compinit
compinit

#zstyle ':completion:*' auto-description 'specify: %d'
#zstyle ':completion:*' completer _expand _complete _correct _approximate
#zstyle ':completion:*' format 'Completing %d'
#zstyle ':completion:*' group-name ''
#zstyle ':completion:*' menu select=2
#eval "$(dircolors -b)"
#zstyle ':completion:*:default' list-colors ${(s.:.)LS_COLORS}
#zstyle ':completion:*' list-colors ''
#zstyle ':completion:*' list-prompt %SAt %p: Hit TAB for more, or the character to insert%s
#zstyle ':completion:*' matcher-list '' 'm:{a-z}={A-Z}' 'm:{a-zA-Z}={A-Za-z}' 'r:|[._-]=* r:|=* l:|=*'
#zstyle ':completion:*' menu select=long
#zstyle ':completion:*' select-prompt %SScrolling active: current selection at %p%s
#zstyle ':completion:*' use-compctl false
#zstyle ':completion:*' verbose true

#zstyle ':completion:*:*:kill:*:processes' list-colors '=(#b) #([0-9]#)*=0=01;31'
#zstyle ':completion:*:kill:*' command 'ps -u $USER -o pid,%cpu,tty,cputime,cmd'

export EDITOR=/usr/bin/vim

10 changes: 10 additions & 0 deletions .devcontainer/starship.toml
Original file line number Diff line number Diff line change
@@ -0,0 +1,10 @@
add_newline = true
command_timeout = 2000

[container]
disabled = true

# We need to replace the first character to fix https://github.com/microsoft/vscode/issues/143103
[character]
success_symbol = '[>](bold green)'
error_symbol = '[>](bold red)'
12 changes: 6 additions & 6 deletions .github/workflows/build.yml
Original file line number Diff line number Diff line change
Expand Up @@ -19,7 +19,7 @@ jobs:
name: Build and run system tests Linux amd64
runs-on: ubuntu-latest
container:
image: ghcr.io/eclipse-ankaios/devcontainer-base:0.9.2
image: ghcr.io/eclipse-ankaios/devcontainer-base:0.10.1
options: --privileged
steps:
- uses: actions/checkout@v4.1.1
Expand Down Expand Up @@ -50,7 +50,7 @@ jobs:
name: Run unit tests Linux amd64
runs-on: ubuntu-latest
container:
image: ghcr.io/eclipse-ankaios/devcontainer-base:0.9.2
image: ghcr.io/eclipse-ankaios/devcontainer-base:0.10.1
options: --privileged
steps:
- uses: actions/checkout@v4.1.1
Expand Down Expand Up @@ -78,7 +78,7 @@ jobs:
name: Create code coverage report
runs-on: ubuntu-latest
container:
image: ghcr.io/eclipse-ankaios/devcontainer-base:0.9.2
image: ghcr.io/eclipse-ankaios/devcontainer-base:0.10.1
options: --privileged
steps:
- uses: actions/checkout@v4.1.1
Expand All @@ -96,7 +96,7 @@ jobs:
name: Build Linux amd64 debian package
runs-on: ubuntu-latest
container:
image: ghcr.io/eclipse-ankaios/devcontainer-base:0.9.2
image: ghcr.io/eclipse-ankaios/devcontainer-base:0.10.1
options: --privileged
steps:
- uses: actions/checkout@v4.1.1
Expand Down Expand Up @@ -127,7 +127,7 @@ jobs:
name: Build Linux arm64 debian package
runs-on: ubuntu-latest
container:
image: ghcr.io/eclipse-ankaios/devcontainer-base:0.9.2
image: ghcr.io/eclipse-ankaios/devcontainer-base:0.10.1
options: --user root
steps:
- uses: actions/checkout@v4.1.1
Expand All @@ -154,7 +154,7 @@ jobs:
name: Build requirements tracing
runs-on: ubuntu-latest
container:
image: ghcr.io/eclipse-ankaios/devcontainer-base:0.9.2
image: ghcr.io/eclipse-ankaios/devcontainer-base:0.10.1
options: --user root
steps:
- uses: actions/checkout@v4.1.1
Expand Down
2 changes: 1 addition & 1 deletion .github/workflows/documentation.yml
Original file line number Diff line number Diff line change
Expand Up @@ -38,7 +38,7 @@ jobs:
if: ${{ needs.documentation_changes.outputs.documentation == 'true' || github.ref_name == 'main' || github.ref_type == 'tag' }}
runs-on: ubuntu-latest
container:
image: ghcr.io/eclipse-ankaios/devcontainer-base:0.9.2
image: ghcr.io/eclipse-ankaios/devcontainer-base:0.10.1
steps:
- uses: actions/checkout@v4.1.1
- name: Prepare commit to branch gh-pages
Expand Down

0 comments on commit 3120962

Please sign in to comment.