From 20038184bc11454e2f9b8487e40eeced3d0e4428 Mon Sep 17 00:00:00 2001 From: Igor Pecovnik Date: Fri, 11 Oct 2024 13:08:16 +0200 Subject: [PATCH] Desktops: refactor desktop install, enable working ones, add unit tests --- .github/workflows/unit-tests.yml | 24 +- lib/armbian-configng/config.ng.jobs.json | 280 +++++++++++++++++++---- lib/armbian-configng/config.ng.system.sh | 162 ++++++++----- tests/DE01.conf | 2 + tests/DE11.conf | 2 + tests/DE21.conf | 2 + tests/DE31.conf | 2 + 7 files changed, 364 insertions(+), 110 deletions(-) create mode 100644 tests/DE01.conf create mode 100644 tests/DE11.conf create mode 100644 tests/DE21.conf create mode 100644 tests/DE31.conf diff --git a/.github/workflows/unit-tests.yml b/.github/workflows/unit-tests.yml index ecc8ead3a..a8947fa4f 100644 --- a/.github/workflows/unit-tests.yml +++ b/.github/workflows/unit-tests.yml @@ -6,8 +6,6 @@ on: - cron: '0 2 * * *' pull_request: types: [opened, reopened, edited, synchronize, review_requested] -# paths: -# - 'tests/*.conf' env: GH_TOKEN: ${{ secrets.GITHUB_TOKEN }} @@ -47,17 +45,20 @@ jobs: # define docker images where we will run test install dockerimages=("debian:bookworm" "ubuntu:jammy" "ubuntu:noble") - # read tests cases and loop them + # go to repo folder + cd config + # read tests cases if [[ -n "${{ steps.changed-files.outputs.all_changed_files }}" ]]; then - tests=($(echo ${{ steps.changed-files.outputs.all_changed_files }} | tr " " "\n" | cut -d"." -f1 | cut -d"/" -f2)) + tests=($(grep -rw ${{ steps.changed-files.outputs.all_changed_files }} -e "ENABLED=true" | cut -d":" -f1)) else - tests=($(grep -rw config/tests/*.conf -e "ENABLED=true" | cut -d"/" -f3 | cut -d"." -f1)) + tests=($(grep -rw tests/*.conf -e "ENABLED=true" | cut -d":" -f1)) fi + # loop enabled tests for i in "${tests[@]}"; do unset RELEASE - source config/tests/${i}.conf + source "${i}" if [[ -z "${RELEASE}" ]]; then RELEASE=all; fi # if we speficy releases, we need to loop docker images and use if there is a match if [[ $RELEASE != all || -z $RELEASE ]]; then @@ -101,12 +102,15 @@ jobs: run: | # source vars - . "config/tests/${{ matrix.image.package }}.conf" + . "config/${{ matrix.image.package }}" echo ${TEST_TITLE} export DEBIAN_FRONTEND=noninteractive + #echo "Europe/Ljubljana" > /etc/timezone RELEASE=$(echo "${{ matrix.image.image }}" | cut -d":" -f2) + TEST_ID=$(echo "${{ matrix.image.package }}" | cut -d "/" -f2 | cut -d "." -f1) apt update + DEBIAN_FRONTEND=noninteractive TZ=Etc/UTC apt-get -y install tzdata apt -y install wget gpg # add armbian repository @@ -125,13 +129,13 @@ jobs: export DEBIAN_FRONTEND=noninteractive cd config eval "$PREINSTALL" - sudo bash bin/armbian-configng --cmd "${{ matrix.image.package }}" + sudo bash bin/armbian-configng --cmd "$TEST_ID" eval "$CONDITION" # stats - FILENAME="data-"$(echo ${{ matrix.image.image }} | sed "s/:/-/g")"-${{ matrix.image.package }}.teststats" + FILENAME="data-"$(echo ${{ matrix.image.image }} | sed "s/:/-/g")"-${TEST_ID}.teststats" echo $RELEASE >> ../${FILENAME} - bash bin/armbian-configng --cmd | grep "${{ matrix.image.package }}" | xargs >> ../${FILENAME} + bash bin/armbian-configng --cmd | grep "${TEST_ID}" | xargs >> ../${FILENAME} echo " " >> ../${FILENAME} - name: Upload test diff --git a/lib/armbian-configng/config.ng.jobs.json b/lib/armbian-configng/config.ng.jobs.json index 45ecb1b13..8a264c526 100644 --- a/lib/armbian-configng/config.ng.jobs.json +++ b/lib/armbian-configng/config.ng.jobs.json @@ -574,67 +574,249 @@ "sub": [ { "id": "Desktops", - "description": "Install Desktop Environments", + "description": "Desktop Environments", "sub": [ { - "id": "SW02", - "description": "Install XFCE desktop", - "command": [ - "install_de \"xfce\"" - ], - "status": "Preview", - "doc_link": "", - "src_reference": "", - "author": "", - "condition": "" + "id": "DE00", + "description": "XFCE desktop", + "sub": [ + { + "id": "DE01", + "description": "XFCE desktop Install", + "command": [ + "manage_desktops 'xfce' 'install'" + ], + "status": "Stable", + "author": "@igorpecovnik", + "condition": "[ ! -f /usr/share/xsessions/xfce.desktop ]" + }, + { + "id": "DE02", + "description": "Uninstall", + "command": [ + "manage_desktops 'xfce' 'uninstall'" + ], + "status": "Stable", + "author": "@igorpecovnik", + "condition": "[ -f /usr/share/xsessions/xfce.desktop ]" + }, + { + "id": "DE03", + "description": "Enable autologin", + "command": [ + "manage_desktops 'xfce' 'auto'" + ], + "status": "Stable", + "author": "@igorpecovnik", + "condition": "[ -f /usr/share/xsessions/xfce.desktop ] && [ ! -f /etc/lightdm/lightdm.conf.d/22-armbian-autologin.conf ]" + }, + { + "id": "DE04", + "description": "Disable autologin", + "command": [ + "manage_desktops 'xfce' 'manual'" + ], + "status": "Stable", + "author": "@igorpecovnik", + "condition": "[ -f /usr/share/xsessions/xfce.desktop ] && [ -f /etc/lightdm/lightdm.conf.d/22-armbian-autologin.conf ]" + } + ] }, { - "id": "SW03", - "description": "Install Gnome desktop", - "command": [ - "install_de \"gnome\"" - ], - "status": "Preview", - "doc_link": "", - "src_reference": "", - "author": "", - "condition": "" + "id": "DE10", + "description": "Gnome desktop", + "sub": [ + { + "id": "DE11", + "description": "Gnome desktop Install", + "command": [ + "manage_desktops 'gnome' 'install'" + ], + "status": "Stable", + "author": "@igorpecovnik", + "condition": "[ ! -f /usr/share/xsessions/gnome.desktop ]" + }, + { + "id": "DE12", + "description": "Uninstall", + "command": [ + "manage_desktops 'gnome' 'uninstall'" + ], + "status": "Stable", + "author": "@igorpecovnik", + "condition": "[ -f /usr/share/xsessions/gnome.desktop ]" + }, + { + "id": "DE13", + "description": "Enable autologin", + "command": [ + "manage_desktops 'gnome' 'auto'" + ], + "status": "Stable", + "author": "@igorpecovnik", + "condition": "[ -f /usr/share/xsessions/gnome.desktop ] && ! cat /etc/gdm3/custom.conf 2>/dev/null | grep AutomaticLoginEnable | grep true >/dev/null" + }, + { + "id": "DE14", + "description": "Disable autologin", + "command": [ + "manage_desktops 'gnome' 'manual'" + ], + "status": "Stable", + "author": "@igorpecovnik", + "condition": "[ -f /usr/share/xsessions/gnome.desktop ] && cat /etc/gdm3/custom.conf 2>/dev/null | grep AutomaticLoginEnable | grep true >/dev/null" + } + ] }, { - "id": "SW04", - "description": "Install i3-wm desktop", - "command": [ - "install_de \"i3-wm\"" - ], - "status": "Preview", - "doc_link": "", - "src_reference": "", - "author": "", - "condition": "" + "id": "DE20", + "description": "i3-wm desktop", + "status": "Disabled", + "sub": [ + { + "id": "DE21", + "description": "i3 desktop Install", + "command": [ + "manage_desktops 'i3-wm' 'install'" + ], + "status": "Stable", + "author": "@igorpecovnik", + "condition": "[ ! -f /usr/share/xsessions/i3.desktop ]" + }, + { + "id": "DE22", + "description": "i3 desktop uninstall", + "command": [ + "manage_desktops 'i3-wm' 'uninstall'" + ], + "status": "Stable", + "author": "@igorpecovnik", + "condition": "[ -f /usr/share/xsessions/i3.desktop ]" + }, + { + "id": "DE23", + "description": "Enable autologin", + "command": [ + "manage_desktops 'i3-wm' 'auto'" + ], + "status": "Stable", + "author": "@igorpecovnik", + "condition": "[ -f /usr/share/xsessions/i3.desktop ] && [ ! -f /etc/lightdm/lightdm.conf.d/22-armbian-autologin.conf ]" + }, + { + "id": "DE24", + "description": "Disable autologin", + "command": [ + "manage_desktops 'i3-wm' 'manual'" + ], + "status": "Stable", + "author": "@igorpecovnik", + "condition": "[ -f /usr/share/xsessions/i3.desktop ] && [ -f /etc/lightdm/lightdm.conf.d/22-armbian-autologin.conf ]" + } + ] }, { - "id": "SW05", - "description": "Install Cinnamon desktop", - "command": [ - "install_de \"cinnamon\"" - ], - "status": "Preview", - "doc_link": "", - "src_reference": "", - "author": "", - "condition": "" + "id": "DE30", + "description": "Cinnamon desktop", + "sub": [ + { + "id": "DE31", + "description": "Cinnamon desktop Install", + "command": [ + "manage_desktops 'cinnamon' 'install'" + ], + "status": "Stable", + "author": "@igorpecovnik", + "condition": "[ ! -f /usr/share/xsessions/cinnamon.desktop ] && [ ! -f /usr/share/xsessions/cinnamon2d.desktop ]" + }, + { + "id": "DE32", + "description": "Cinnamon desktop uninstall", + "command": [ + "manage_desktops 'cinnamon' 'uninstall'" + ], + "status": "Stable", + "author": "@igorpecovnik", + "condition": "[ -f /usr/share/xsessions/cinnamon.desktop ] || [ -f /usr/share/xsessions/cinnamon2d.desktop ]" + }, + { + "id": "DE33", + "description": "Enable autologin", + "command": [ + "manage_desktops 'cinnamon' 'auto'" + ], + "status": "Stable", + "author": "@igorpecovnik", + "condition": "[ -f /usr/share/xsessions/cinnamon.desktop ] && [ ! -f /etc/lightdm/lightdm.conf.d/22-armbian-autologin.conf ]" + }, + { + "id": "DE34", + "description": "Disable autologin", + "command": [ + "manage_desktops 'cinnamon' 'manual'" + ], + "status": "Stable", + "author": "@igorpecovnik", + "condition": "[ -f /usr/share/xsessions/cinnamon.desktop ] && [ -f /etc/lightdm/lightdm.conf.d/22-armbian-autologin.conf ]" + } + ] + }, + { + "id": "DE40", + "description": "Kde-neon desktop", + "status": "Disabled", + "sub": [ + { + "id": "DE41", + "description": "Kde-neon desktop Install", + "command": [ + "manage_desktops 'kde-neon' 'install'" + ], + "status": "Stable", + "author": "@igorpecovnik", + "condition": "[ ! -f /usr/share/xsessions/gnome.desktop ]" + }, + { + "id": "DE42", + "description": "Uninstall", + "command": [ + "manage_desktops 'kde-neon' 'uninstall'" + ], + "status": "Stable", + "author": "@igorpecovnik", + "condition": "[ -f /usr/share/xsessions/gnome.desktop ]" + }, + { + "id": "DE43", + "description": "Enable autologin", + "command": [ + "manage_desktops 'kde-neon' 'auto'" + ], + "status": "Stable", + "author": "@igorpecovnik", + "condition": "[ -f /usr/share/xsessions/gnome.desktop ] && [ ! -f /etc/lightdm/lightdm.conf.d/22-armbian-autologin.conf ]" + }, + { + "id": "DE44", + "description": "Disable autologin", + "command": [ + "manage_desktops 'kde-neon' 'manual'" + ], + "status": "Stable", + "author": "@igorpecovnik", + "condition": "[ -f /usr/share/xsessions/gnome.desktop ] && [ -f /etc/lightdm/lightdm.conf.d/22-armbian-autologin.conf ]" + } + ] }, { - "id": "SW06", - "description": "Install kde-neon desktop", + "id": "DE99", + "description": "Improve application search speed", "command": [ - "install_de \"kde-neon\"" + "update-apt-xapian-index -u; sleep 3" ], - "status": "Preview", - "doc_link": "", - "src_reference": "", - "author": "", - "condition": "" + "status": "Stable", + "author": "@igorpecovnik", + "condition": "systemctl is-active --quiet service display-manager" } ] }, diff --git a/lib/armbian-configng/config.ng.system.sh b/lib/armbian-configng/config.ng.system.sh index ec51c2dfd..8e4faa485 100644 --- a/lib/armbian-configng/config.ng.system.sh +++ b/lib/armbian-configng/config.ng.system.sh @@ -13,12 +13,12 @@ module_options+=( # function apt_install_wrapper() { - if [ -t 0 ]; then - debconf-apt-progress -- "$@" - else + #if [ -t 0 ]; then + # debconf-apt-progress -- "$@" + #else # Terminal not defined - proceed without TUI "$@" - fi + #fi } module_options+=( @@ -87,64 +87,124 @@ release_upgrade(){ } module_options+=( - ["install_de,author"]="Igor Pecovnik" - ["install_de,ref_link"]="" - ["install_de,feature"]="install_de" - ["install_de,desc"]="Install DE" - ["install_de,example"]="install_de" - ["install_de,status"]="Active" + ["manage_desktops,author"]="@igorpecovnik" + ["manage_desktops,ref_link"]="" + ["manage_desktops,feature"]="install_de" + ["manage_desktops,desc"]="Install Desktop environment" + ["manage_desktops,example"]="manage_desktops xfce install" + ["manage_desktops,status"]="Active" ) # # Install desktop # -function install_de() { +function manage_desktops() { + + local desktop=$1 + local command=$2 # get user who executed this script if [ $SUDO_USER ]; then local user=$SUDO_USER; else local user=$(whoami); fi - #debconf-apt-progress -- - apt-get update - #debconf-apt-progress -- - apt-get -o Dpkg::Options::="--force-confold" -y --install-recommends install armbian-${DISTROID}-desktop-$1 # armbian-bsp-desktop-${BOARD}-${BRANCH} - - # clean apt cache - apt-get -y clean - - # add user to groups - for additionalgroup in sudo netdev audio video dialout plugdev input bluetooth systemd-journal ssh; do - usermod -aG ${additionalgroup} ${user} 2> /dev/null - done - - # Recreating Synaptic search index - update-apt-xapian-index -u + case "$command" in + install) + apt_install_wrapper dpkg --configure -a + apt_install_wrapper apt-get -o Dpkg::Options::="--force-confold" -y --install-recommends install armbian-${DISTROID}-desktop-${desktop} + # add user to groups + for additionalgroup in sudo netdev audio video dialout plugdev input bluetooth systemd-journal ssh; do + usermod -aG ${additionalgroup} ${user} 2> /dev/null + done + + # set up profile sync daemon on desktop systems + which psd > /dev/null 2>&1 + if [[ $? -eq 0 && -z $(grep overlay-helper /etc/sudoers) ]]; then + echo "${user} ALL=(ALL) NOPASSWD: /usr/bin/psd-overlay-helper" >> /etc/sudoers + touch /home/${user}/.activate_psd + fi + # update skel + update_skel - # set up profile sync daemon on desktop systems - which psd > /dev/null 2>&1 - if [[ $? -eq 0 && -z $(grep overlay-helper /etc/sudoers) ]]; then - echo "${user} ALL=(ALL) NOPASSWD: /usr/bin/psd-overlay-helper" >> /etc/sudoers - touch /home/${user}/.activate_psd - fi + # desktops has different default login managers + case "$desktop" in + gnome) + echo "/usr/sbin/gdm3" > /etc/X11/default-display-manager + ;; + kde-neon) + # sddm + ;; + *) + echo "/usr/sbin/lightdm" > /etc/X11/default-display-manager + #ln -s /lib/systemd/system/lightdm.service /etc/systemd/system/display-manager.service > /dev/null 2>&1 + #service lightdm start > /dev/null 2>&1 + ;; + esac + + # enable auto login + manage_desktops "$desktop" "auto" + + # stop display managers in case we are switching them + service gdm3 stop + service lightdm stop + service sddm stop + + # start new default display manager + service display-manager restart + ;; + uninstall) + # we are uninstalling all variants until build time packages are fixed to prevent installing one over another + service display-manager stop + apt_install_wrapper apt-get -o Dpkg::Options::="--force-confold" -y --install-recommends purge armbian-${DISTROID}-desktop-$1 \ + xfce4-session gnome-session slick-greeter lightdm gdm3 sddm cinnamon-session i3-wm + apt_install_wrapper apt-get -y autoremove + # disable autologins + rm -f /etc/gdm3/custom.conf + rm -f /etc/sddm.conf.d/autologin.conf + rm -f /etc/lightdm/lightdm.conf.d/22-armbian-autologin.conf + ;; + auto) + # desktops has different login managers and autologin methods + case "$desktop" in + gnome) + # gdm3 autologin + mkdir -p /etc/gdm3 + cat <<- EOF > /etc/gdm3/custom.conf + [daemon] + AutomaticLoginEnable = true + AutomaticLogin = ${user} + EOF + ;; + kde-neon) + # sddm autologin + cat <<- EOF > "/etc/sddm.conf.d/autologin.conf" + [Autologin] + User=${user} + EOF + ;; + *) + # lightdm autologin + mkdir -p /etc/lightdm/lightdm.conf.d + cat <<- EOF > "/etc/lightdm/lightdm.conf.d/22-armbian-autologin.conf" + [Seat:*] + autologin-user=${user} + autologin-user-timeout=0 + user-session=xfce + EOF - # update skel - update_skel - - # desktops has different default login managers - case "$1" in - gnome) - # gdm3 - ;; - *) - # lightdm - mkdir -p /etc/lightdm/lightdm.conf.d - echo "[Seat:*]" > /etc/lightdm/lightdm.conf.d/22-armbian-autologin.conf - echo "autologin-user=${username}" >> /etc/lightdm/lightdm.conf.d/22-armbian-autologin.conf - echo "autologin-user-timeout=0" >> /etc/lightdm/lightdm.conf.d/22-armbian-autologin.conf - echo "user-session=xfce" >> /etc/lightdm/lightdm.conf.d/22-armbian-autologin.conf - ln -s /lib/systemd/system/lightdm.service /etc/systemd/system/display-manager.service > /dev/null 2>&1 - service lightdm start > /dev/null 2>&1 - ;; + ;; + esac + # restart after selection + service display-manager restart + ;; + manual) + case "$desktop" in + gnome) rm -f /etc/gdm3/custom.conf ;; + kde-neon) rm -f /etc/sddm.conf.d/autologin.conf ;; + *) rm -f /etc/lightdm/lightdm.conf.d/22-armbian-autologin.conf ;; + esac + # restart after selection + service display-manager restart + ;; esac - exit + } module_options+=( diff --git a/tests/DE01.conf b/tests/DE01.conf new file mode 100644 index 000000000..b3791ce57 --- /dev/null +++ b/tests/DE01.conf @@ -0,0 +1,2 @@ +ENABLED=true +CONDITION="[ -f /usr/share/xsessions/xfce.desktop ]" diff --git a/tests/DE11.conf b/tests/DE11.conf new file mode 100644 index 000000000..4b8a9090b --- /dev/null +++ b/tests/DE11.conf @@ -0,0 +1,2 @@ +ENABLED=true +CONDITION="[ -f /usr/share/xsessions/gnome.desktop ]" diff --git a/tests/DE21.conf b/tests/DE21.conf new file mode 100644 index 000000000..e281459ad --- /dev/null +++ b/tests/DE21.conf @@ -0,0 +1,2 @@ +ENABLED=false +CONDITION="[ -f /usr/share/xsessions/i3.desktop ]" diff --git a/tests/DE31.conf b/tests/DE31.conf new file mode 100644 index 000000000..890259d47 --- /dev/null +++ b/tests/DE31.conf @@ -0,0 +1,2 @@ +ENABLED=true +CONDITION="[ -f /usr/share/xsessions/cinnamon.desktop ]"