Merge branch 'devel' into 'main'

Shellcheck and General fixes

See merge request release-engineering/public/toolkit!2
This commit is contained in:
Louis Abel 2021-07-06 20:25:13 +00:00
commit e47d87a03b
34 changed files with 108 additions and 69 deletions

View file

@ -28,12 +28,15 @@ function r_checkExitStatus() {
# just having the files named differently, but that seemed more annoying than # just having the files named differently, but that seemed more annoying than
# just setting +x # just setting +x
function r_processor() { function r_processor() {
# shellcheck disable=SC2068
exec 8< $@ exec 8< $@
# shellcheck disable=SC2162
while read -u 8 file; do while read -u 8 file; do
# shellcheck disable=SC2086
if [[ "$(basename ${file})" =~ README|^\.|^_ ]]; then if [[ "$(basename ${file})" =~ README|^\.|^_ ]]; then
continue continue
fi fi
[ -x ${file} ] && ${file} [ -x "${file}" ] && "${file}"
done done
return 0 return 0
} }
@ -45,6 +48,7 @@ function r_processor() {
# Args: Any number of $1..X # Args: Any number of $1..X
function p_installPackageNormal() { function p_installPackageNormal() {
r_log "internal" "Attempting install: $*" r_log "internal" "Attempting install: $*"
# shellcheck disable=SC2086
/usr/bin/dnf --assumeyes --debuglevel ${DNFDEBUG} install "$@" /usr/bin/dnf --assumeyes --debuglevel ${DNFDEBUG} install "$@"
r_checkExitStatus $? r_checkExitStatus $?
} }
@ -54,6 +58,7 @@ function p_installPackageNormal() {
# Args: Any number of $1..X # Args: Any number of $1..X
function p_installPackageNoWeaks() { function p_installPackageNoWeaks() {
r_log "internal" "Attempting install: $*" r_log "internal" "Attempting install: $*"
# shellcheck disable=SC2086
/usr/bin/dnf --assumeyes --debuglevel ${DNFDEBUG} --setopt install_weak_deps=0 install "$@" /usr/bin/dnf --assumeyes --debuglevel ${DNFDEBUG} --setopt install_weak_deps=0 install "$@"
r_checkExitStatus $? r_checkExitStatus $?
} }
@ -62,6 +67,7 @@ function p_installPackageNoWeaks() {
# Args: Any number of $1..X # Args: Any number of $1..X
function p_removePackage() { function p_removePackage() {
r_log "internal" "Attempting uninstall: $*" r_log "internal" "Attempting uninstall: $*"
# shellcheck disable=SC2086
/usr/bin/dnf --assumeyes --debuglevel ${DNFDEBUG} remove "$@" /usr/bin/dnf --assumeyes --debuglevel ${DNFDEBUG} remove "$@"
r_checkExitStatus $? r_checkExitStatus $?
} }
@ -70,6 +76,7 @@ function p_removePackage() {
# Args: Any number of $1..X # Args: Any number of $1..X
function p_enableModule() { function p_enableModule() {
r_log "internal" "Enabling module: $*" r_log "internal" "Enabling module: $*"
# shellcheck disable=SC2086
/usr/bin/dnf --assumeyes --debuglevel ${DNFDEBUG} module enable "$@" /usr/bin/dnf --assumeyes --debuglevel ${DNFDEBUG} module enable "$@"
r_checkExitStatus $? r_checkExitStatus $?
} }
@ -78,20 +85,21 @@ function p_enableModule() {
# Args: Any number of $1..X # Args: Any number of $1..X
function p_resetModule() { function p_resetModule() {
r_log "internal" "Resetting module: $*" r_log "internal" "Resetting module: $*"
# shellcheck disable=SC2086
/usr/bin/dnf --assumeyes --debuglevel ${DNFDEBUG} module reset "$@" /usr/bin/dnf --assumeyes --debuglevel ${DNFDEBUG} module reset "$@"
r_checkExitStatus $? r_checkExitStatus $?
} }
function p_getPackageRelease() { function p_getPackageRelease() {
rpm -q --queryformat '%{RELEASE}' $1 rpm -q --queryformat '%{RELEASE}' "$1"
} }
function p_getPackageArch() { function p_getPackageArch() {
rpm -q --queryformat '%{ARCH}' $1 rpm -q --queryformat '%{ARCH}' "$1"
} }
function p_getDist() { function p_getDist() {
rpm -q $(rpm -qf /etc/redhat-release) --queryformat '%{version}\n' | cut -d'.' -f1 rpm -q "$(rpm -qf /etc/redhat-release)" --queryformat '%{version}\n' | cut -d'.' -f1
} }
################################################################################ ################################################################################
@ -101,10 +109,13 @@ function p_getDist() {
# prevent potential race conditions. # prevent potential race conditions.
function m_serviceCycler() { function m_serviceCycler() {
if [ "$2" = "cycle" ]; then if [ "$2" = "cycle" ]; then
# shellcheck disable=SC2086
/bin/systemctl stop $1 /bin/systemctl stop $1
sleep 3 sleep 3
# shellcheck disable=SC2086
/bin/systemctl start $1 /bin/systemctl start $1
else else
# shellcheck disable=SC2086
/bin/systemctl $2 $1 /bin/systemctl $2 $1
fi fi
sleep 3 sleep 3
@ -113,6 +124,7 @@ function m_serviceCycler() {
function m_checkForPort() { function m_checkForPort() {
while true; do while true; do
sleep 1 sleep 1
# shellcheck disable=SC2086
if echo > /dev/tcp/localhost/$1 >/dev/null 2>&1; then if echo > /dev/tcp/localhost/$1 >/dev/null 2>&1; then
r_log "internal" "Waiting for TCP port $1 to start listening" r_log "internal" "Waiting for TCP port $1 to start listening"
break break

View file

@ -68,7 +68,7 @@ r_log "archive" "Check that -r functions"
mkdir /var/tmp/gziptest mkdir /var/tmp/gziptest
touch /var/tmp/gziptest/{a,b} touch /var/tmp/gziptest/{a,b}
gzip -r /var/tmp/gziptest gzip -r /var/tmp/gziptest
[ "$(ls /var/tmp/gziptest/*.gz | wc -l)" -eq "2" ] || r_checkExitStatus 1 [ "$(find /var/tmp/gziptest/*.gz | wc -l)" -eq "2" ] || r_checkExitStatus 1
# check different compression levels # check different compression levels
r_log "archive" "Check compression levels" r_log "archive" "Check compression levels"

View file

@ -1,4 +1,4 @@
#!/bin/bash #!/bin/bash
r_log "bc" "Testing simple calculations" r_log "bc" "Testing simple calculations"
test $(echo "8 + 5 * 2 / 10 - 1" | bc) -eq "8" test "$(echo "8 + 5 * 2 / 10 - 1" | bc)" -eq "8"
r_checkExitStatus $? r_checkExitStatus $?

View file

@ -1,6 +1,8 @@
#!/bin/bash #!/bin/bash
r_log "coreutils" "Testing pathchk" r_log "coreutils" "Testing pathchk"
pathchk -p "<>" 2> /dev/null pathchk -p "<>" 2> /dev/null
# shellcheck disable=SC2181
[ $? -eq 1 ] && pathchk /var/tmp/fakePathAndFile [ $? -eq 1 ] && pathchk /var/tmp/fakePathAndFile
# shellcheck disable=SC2181
[ $? -eq 0 ] && pathchk /var/tmp [ $? -eq 0 ] && pathchk /var/tmp
r_checkExitStatus $? r_checkExitStatus $?

View file

@ -6,6 +6,7 @@ touch -t 199104230420 /tmp/touch-1
touch -t 199104240420 /tmp/touch-2 touch -t 199104240420 /tmp/touch-2
r_log "coreutils" "Verify that the oldest file is last" r_log "coreutils" "Verify that the oldest file is last"
# shellcheck disable=SC2012
ls -lt /tmp/touch-? | tail -n 1 | grep -q 'touch-1' ls -lt /tmp/touch-? | tail -n 1 | grep -q 'touch-1'
r_checkExitStatus $? r_checkExitStatus $?

View file

@ -3,6 +3,7 @@ r_log "coreutils" "Test the yes command"
touch /var/tmp/yes-123 touch /var/tmp/yes-123
touch /var/tmp/yes-345 touch /var/tmp/yes-345
# shellcheck disable=SC2216
yes | /bin/rm -i /var/tmp/yes-* || r_checkExitStatus 1 yes | /bin/rm -i /var/tmp/yes-* || r_checkExitStatus 1
deleted=1 deleted=1

View file

@ -11,6 +11,7 @@ PASSER=/var/tmp/cpio/pass
r_log "cpio" "Test basic copy out" r_log "cpio" "Test basic copy out"
mkdir -p "$OUTTER" "$INNER" "$PASSER" mkdir -p "$OUTTER" "$INNER" "$PASSER"
# shellcheck disable=2012
ls /tmp | cpio -o > "$OUTTER"/cpio.out ls /tmp | cpio -o > "$OUTTER"/cpio.out
r_checkExitStatus $? r_checkExitStatus $?

View file

@ -7,5 +7,5 @@ if [ -z "$pngFile" ]; then
exit 0 exit 0
fi fi
file -i $pngFile | grep -q 'image/png' file -i "$pngFile" | grep -q 'image/png'
r_checkExitStatus $? r_checkExitStatus $?

View file

@ -5,7 +5,7 @@ TMPDIR=/var/tmp/find
[ -e $TMPDIR ] && rm -rf "$TMPDIR" [ -e $TMPDIR ] && rm -rf "$TMPDIR"
mkdir -p "$TMPDIR" || { r_log "findutils" "Can't create $TMPDIR"; exit $FAIL; } mkdir -p "$TMPDIR" || { r_log "findutils" "Can't create $TMPDIR"; exit "$FAIL"; }
touch "$TMPDIR/file1" touch "$TMPDIR/file1"
touch "$TMPDIR/file with a space" touch "$TMPDIR/file with a space"
r_log "findutils" "Check that find just works(tm)" r_log "findutils" "Check that find just works(tm)"
@ -23,7 +23,7 @@ fi
r_log "findutils" "Prepare for xargs test" r_log "findutils" "Prepare for xargs test"
LINES=$(find "$TMPDIR" -print0 | wc -l) LINES=$(find "$TMPDIR" -print0 | wc -l)
if [ $LINES -eq 0 ]; then if [ "$LINES" -eq 0 ]; then
r_checkExitStatus 0 r_checkExitStatus 0
else else
r_checkExitStatus 1 r_checkExitStatus 1
@ -34,8 +34,10 @@ find "$TMPDIR" -type f -print0 | xargs -0 ls &> /dev/null
r_checkExitStatus $? r_checkExitStatus $?
r_log "findutils" "Perform for xargs test: fails with spaces in the name" r_log "findutils" "Perform for xargs test: fails with spaces in the name"
find "$TMPDIR" -type f | xargs ls &> /dev/null && { r_log "findutils" "Why did this get a 0 exit?"; exit $FAIL; } # shellcheck disable=SC2038
if [ $? -ne 0 ]; then find "$TMPDIR" -type f | xargs ls &> /dev/null && { r_log "findutils" "Why did this get a 0 exit?"; exit "$FAIL"; }
ret_val=$?
if [ "$ret_val" -ne 0 ]; then
r_checkExitStatus $? r_checkExitStatus $?
fi fi

View file

@ -2,8 +2,8 @@
r_log "gcc" "Ensure gcc can build a simple program" r_log "gcc" "Ensure gcc can build a simple program"
OUTPUTPROG=$(mktemp) OUTPUTPROG=$(mktemp)
gcc ./common/files/hello.c -o $OUTPUTPROG gcc ./common/files/hello.c -o "$OUTPUTPROG"
$OUTPUTPROG | grep -q "Hello!" "$OUTPUTPROG" | grep -q "Hello!"
r_checkExitStatus $? r_checkExitStatus $?
rm $OUTPUTPROG rm "$OUTPUTPROG"

View file

@ -2,8 +2,8 @@
r_log "gcc" "Ensure g++ can build a simple program" r_log "gcc" "Ensure g++ can build a simple program"
OUTPUTPROG=$(mktemp) OUTPUTPROG=$(mktemp)
g++ -x c++ ./common/files/hello.cpp -o $OUTPUTPROG g++ -x c++ ./common/files/hello.cpp -o "$OUTPUTPROG"
$OUTPUTPROG | grep -q "Hello!" "$OUTPUTPROG" | grep -q "Hello!"
r_checkExitStatus $? r_checkExitStatus $?
rm $OUTPUTPROG rm "$OUTPUTPROG"

View file

@ -2,7 +2,7 @@
r_log "kernel" "Testing the kernel keyring (GPG)" r_log "kernel" "Testing the kernel keyring (GPG)"
ARCH=$(uname -m) ARCH=$(uname -m)
KERNEL=$(uname -r | cut -d'-' -f1) #KERNEL=$(uname -r | cut -d'-' -f1)
if [ "${ARCH}" == "aarch64" ]; then if [ "${ARCH}" == "aarch64" ]; then
r_log "kernel" "Architecture not tested: $ARCH" r_log "kernel" "Architecture not tested: $ARCH"

View file

@ -1,8 +1,7 @@
#!/bin/bash #!/bin/bash
r_log "kernel" "Testing debrand" r_log "kernel" "Testing debrand"
kernver=$(uname -r)
strings /boot/vmlinuz-$(uname -r) | grep -qi rhel strings "/boot/vmlinuz-$(uname -r)" | grep -qi rhel
ret_val=$? ret_val=$?
if [ "$ret_val" -eq "0" ]; then if [ "$ret_val" -eq "0" ]; then

View file

@ -4,7 +4,7 @@ r_log "network" "Checking that iptraf runs and returns non-zero"
TMPFILE=/var/tmp/iptraf TMPFILE=/var/tmp/iptraf
[ -e ${TMPFILE} ] && rm ${TMPFILE} [ -e ${TMPFILE} ] && rm ${TMPFILE}
[ ${EUID} -eq 0 ] || { r_log "network" "SKIP: Not running as root."; exit $PASS; } [ ${EUID} -eq 0 ] || { r_log "network" "SKIP: Not running as root."; exit "$PASS"; }
mkdir -p ${TMPFILE} mkdir -p ${TMPFILE}
@ -14,7 +14,7 @@ KILL=$(which iptraf-ng)
STAT=$(which iptraf-ng) STAT=$(which iptraf-ng)
for x in $IPTRAF $PING $KILL $STAT; do for x in $IPTRAF $PING $KILL $STAT; do
[ ! -f "$x" ] && { r_log "network" "$x not found. This is likely a problem."; exit $FAIL; } [ ! -f "$x" ] && { r_log "network" "$x not found. This is likely a problem."; exit "$FAIL"; }
done done
r_log "network" "Run iptraf on all available interfaces" r_log "network" "Run iptraf on all available interfaces"
@ -24,6 +24,7 @@ r_log "network" "Do a simple ping for iptraf"
${PING} -c 6 127.0.0.12 &> /dev/null ${PING} -c 6 127.0.0.12 &> /dev/null
LOGSIZE=$(stat -c '%s' ${TMPFILE}) LOGSIZE=$(stat -c '%s' ${TMPFILE})
# shellcheck disable=SC2086
kill -USR2 "$(pidof $IPTRAF)" kill -USR2 "$(pidof $IPTRAF)"
r_log "network" "Verifying that iptraf log has data" r_log "network" "Verifying that iptraf log has data"

View file

@ -2,12 +2,13 @@
r_log "network" "Test bridging functionality (non-network manager)" r_log "network" "Test bridging functionality (non-network manager)"
bridge=dummybr0 bridge=dummybr0
# shellcheck disable=SC1091
. "$(dirname "$0")"/imports.sh . "$(dirname "$0")"/imports.sh
r_log "network" "Add a dummy bridge $bridge" r_log "network" "Add a dummy bridge $bridge"
ret_val=$(iproute_add_bridge $bridge) ret_val=$(iproute_add_bridge $bridge)
r_checkExitStatus $ret_val r_checkExitStatus "$ret_val"
r_log "network" "Clean up/Remove bridge" r_log "network" "Clean up/Remove bridge"
ret_val=$(iproute_del_bridge $bridge) ret_val=$(iproute_del_bridge $bridge)
r_checkExitStatus $ret_val r_checkExitStatus "$ret_val"

View file

@ -9,7 +9,7 @@ m_serviceCycler nfs-server restart
r_log "nfs" "Mount NFS share" r_log "nfs" "Mount NFS share"
mount -t nfs 127.0.0.1:/export/rotest /mnt mount -t nfs 127.0.0.1:/export/rotest /mnt
ls -la /mnt | grep -q "nfsfile" find /mnt | grep -q "nfsfile"
r_checkExitStatus $? r_checkExitStatus $?
umount /mnt umount /mnt

View file

@ -10,7 +10,7 @@ m_serviceCycler nfs-server restart
r_log "nfs" "Mount NFS share" r_log "nfs" "Mount NFS share"
mount -t nfs 127.0.0.1:/export/rwtest /mnt mount -t nfs 127.0.0.1:/export/rwtest /mnt
ls -la /mnt | grep -q "nfsfile" find /mnt | grep -q "nfsfile"
r_checkExitStatus $? r_checkExitStatus $?
r_log "nfs" "Test that the NFS share is writeable" r_log "nfs" "Test that the NFS share is writeable"

View file

@ -15,7 +15,7 @@ m_serviceCycler nfs-server restart
m_serviceCycler rpcbind restart m_serviceCycler rpcbind restart
m_serviceCycler autofs restart m_serviceCycler autofs restart
r_log "nfs" "Attempt to access /export/autotest via autofs" r_log "nfs" "Attempt to access /export/autotest via autofs"
ls -la /mnt/autofs | grep -q autofile find /mnt/autofs | grep -q autofile
r_checkExitStatus $? r_checkExitStatus $?
# Remove unneeded configuration # Remove unneeded configuration

View file

@ -46,7 +46,8 @@ else
fi fi
cp "$DROPDIR/openssl.crt" "$SSLPATH/certs/" cp "$DROPDIR/openssl.crt" "$SSLPATH/certs/"
HASH=$(openssl x509 -noout -hash -in $SSLPATH/certs/openssl.crt) # shellcheck disable=SC2086
HASH="$(openssl x509 -noout -hash -in $SSLPATH/certs/openssl.crt)"
ret_val=$? ret_val=$?
if [ $ret_val -ne 0 ]; then if [ $ret_val -ne 0 ]; then
r_log "openssl" "Could not create hash" r_log "openssl" "Could not create hash"

View file

@ -2,7 +2,8 @@
r_log "postfix" "Test basic MTA" r_log "postfix" "Test basic MTA"
REGEX='250\ 2\.0\.0\ Ok\:\ queued\ as\ ([0-9A-Z]*).*' REGEX='250\ 2\.0\.0\ Ok\:\ queued\ as\ ([0-9A-Z]*).*'
mailresp=$(echo -e "helo localhost\nmail from: root@localhost\nrcpt to: root@localhost\ndata\nt_functional test\n.\nquit\n" | nc -w 5 127.0.0.1 25 | grep queued) mailresp=$(echo -e "helo localhost\nmail from: root@localhost\nrcpt to: root@localhost\ndata\nt_functional test\n.\nquit\n" | nc -w 5 127.0.0.1 25 | grep queued)
if [ $? -eq 0 ]; then ret_val=$?
if [ "$ret_val" -eq 0 ]; then
r_log "postfix" "Mail queued successfully" r_log "postfix" "Mail queued successfully"
MTA_ACCEPTED=0 MTA_ACCEPTED=0
else else
@ -13,7 +14,7 @@ fi
sleep 2 sleep 2
# Verify that /var/log/maillog is working, if not dump it out # Verify that /var/log/maillog is working, if not dump it out
mailresp_id=$(echo $mailresp | cut -d' ' -f6) mailresp_id=$(echo "$mailresp" | cut -d' ' -f6)
grep -q "${mailresp_id}" /var/log/maillog grep -q "${mailresp_id}" /var/log/maillog
if [ $? -eq 1 ]; then if [ $? -eq 1 ]; then
journalctl -u postfix >> /var/log/maillog journalctl -u postfix >> /var/log/maillog

View file

@ -14,7 +14,7 @@ echo "Obsidian is the Release Name" > /srv/smb/test.txt
mount -t cifs -o guest,ro //127.0.0.1/rocky /mnt/smb mount -t cifs -o guest,ro //127.0.0.1/rocky /mnt/smb
sleep 1 sleep 1
cat /mnt/smb/test.txt | grep -q "Obsidian" grep -q "Obsidian" /mnt/smb/test.txt
ret_val=$? ret_val=$?
umount /mnt/smb umount /mnt/smb

View file

@ -28,6 +28,7 @@ r_checkExitStatus $?
# lastlog # lastlog
r_log "shadow" "Verify lastlog" r_log "shadow" "Verify lastlog"
# shellcheck disable=SC2063
lastlog -u obsidian | grep -q "**Never logged in**" lastlog -u obsidian | grep -q "**Never logged in**"
r_checkExitStatus $? r_checkExitStatus $?

View file

@ -23,6 +23,8 @@ r_checkExitStatus $?
# newgrp # newgrp
r_log "shadow" "Attempt to use newgrp for onyxuser" r_log "shadow" "Attempt to use newgrp for onyxuser"
groups onyxuser | grep -q "onyxuser onyxgroup" || { r_log "shadow" "Groups information is incorrect."; r_checkExitStatus 1; } groups onyxuser | grep -q "onyxuser onyxgroup" || { r_log "shadow" "Groups information is incorrect."; r_checkExitStatus 1; }
# I'll fix this eventually
# shellcheck disable=SC2046,SC2005
echo $( su - onyxuser << EOF echo $( su - onyxuser << EOF
newgrp onyxgroup newgrp onyxgroup
groups groups
@ -73,7 +75,7 @@ fi
r_log "shadow" "Make sure that when a group is a primary user group, groupdel returns 8" r_log "shadow" "Make sure that when a group is a primary user group, groupdel returns 8"
groupdel onyxuser groupdel onyxuser
ret_val=$? ret_val=$?
if [ "$retval" -eq 8 ]; then if [ "$ret_val" -eq 8 ]; then
r_checkExitStatus 0 r_checkExitStatus 0
else else
r_log "shadow" "The group was removed..." r_log "shadow" "The group was removed..."
@ -108,6 +110,6 @@ r_log "shadow" "Test sg"
sg onyxuser "touch /var/tmp/onyxsg" sg onyxuser "touch /var/tmp/onyxsg"
r_checkExitStatus $? r_checkExitStatus $?
r_log "shadow" "Verify sg worked" r_log "shadow" "Verify sg worked"
ls -l /var/tmp/onyxsg | grep -q onyxuser stat --format="%U" /var/tmp/onyxsg | grep -q onyxuser
r_checkExitStatus $? r_checkExitStatus $?
rm /var/tmp/onyxsg rm /var/tmp/onyxsg

View file

@ -1,6 +1,5 @@
#!/bin/bash #!/bin/bash
r_log "strace" "Run basic strace tests" r_log "strace" "Run basic strace tests"
STRACE=$(which strace)
/usr/bin/strace ls &> /dev/null /usr/bin/strace ls &> /dev/null
ret_val=$? ret_val=$?

View file

@ -4,7 +4,7 @@ r_log "sysstat" "Test basic iostat disk measurements"
TMPFILE=/var/tmp/iostat.disk TMPFILE=/var/tmp/iostat.disk
BLOCKS=4096 BLOCKS=4096
COUNT=10100 COUNT=10100
SUM="$(expr $BLOCKS \* $COUNT / 1024)" SUM="$(( BLOCKS * COUNT / 1024 ))"
DISK="$(fdisk -l | grep -Po -m1 '^/dev/[\D]+')" DISK="$(fdisk -l | grep -Po -m1 '^/dev/[\D]+')"
[ -e $TMPFILE ] && /bin/rm -f $TMPFILE [ -e $TMPFILE ] && /bin/rm -f $TMPFILE
@ -13,13 +13,13 @@ DISK="$(fdisk -l | grep -Po -m1 '^/dev/[\D]+')"
echo 1 > /proc/sys/vm/drop_caches echo 1 > /proc/sys/vm/drop_caches
r_log "sysstat" "Running iostat on $DISK" r_log "sysstat" "Running iostat on $DISK"
/usr/bin/iostat -dkx 1 5 $DISK > $TMPFILE & /usr/bin/iostat -dkx 1 5 "$DISK" > $TMPFILE &
# wait # wait
sleep 4 sleep 4
# Generate traffic # Generate traffic
/bin/dd if=$DISK of=/dev/null bs=$BLOCKS count=$COUNT &> /dev/null /bin/dd if="$DISK" of=/dev/null bs=$BLOCKS count=$COUNT &> /dev/null
# wait # wait
sleep 6 sleep 6

View file

@ -17,7 +17,7 @@ echo 1 > /proc/sys/vm/drop_caches
# wait # wait
sleep 5 sleep 5
/bin/dd if=$DISK bs=$BLOCKS count=$COUNT 2> /dev/null | sha256sum -b - &> /dev/null /bin/dd if="$DISK" bs=$BLOCKS count=$COUNT 2> /dev/null | sha256sum -b - &> /dev/null
# wait # wait
sleep 5 sleep 5

View file

@ -1,8 +1,8 @@
#!/bin/bash #!/bin/bash
r_log "telnet" "Basic telnet test" r_log "telnet" "Basic telnet test"
telnet_sshd_test=`telnet 127.0.0.1 22 << EOF telnet_sshd_test=$(telnet 127.0.0.1 22 << EOF
EOF` EOF
)
echo "$telnet_sshd_test" | grep -q "Escape character is '^]'" echo "$telnet_sshd_test" | grep -q "Escape character is '^]'"
r_checkExitStatus $? r_checkExitStatus $?

View file

@ -17,11 +17,12 @@ SELINUX=$(getenforce)
# End # End
################################################################################ ################################################################################
# shellcheck source=/dev/null # shellcheck source=/dev/null disable=SC2015
[ -f $COMMON_EXPORTS ] && source $COMMON_EXPORTS || { echo -e "\n[-] $(date): Variables cannot be sourced."; exit 1; } [ -f $COMMON_EXPORTS ] && source $COMMON_EXPORTS || { echo -e "\n[-] $(date): Variables cannot be sourced."; exit 1; }
# shellcheck source=/dev/null # shellcheck source=/dev/null disable=SC2015
[ -f $COMMON_IMPORTS ] && source $COMMON_IMPORTS || { echo -e "\n[-] $(date): Functions cannot be sourced."; exit 1; } [ -f $COMMON_IMPORTS ] && source $COMMON_IMPORTS || { echo -e "\n[-] $(date): Functions cannot be sourced."; exit 1; }
# Init log # Init log
# shellcheck disable=SC2015
[ -e "$LOGFILE" ] && m_recycleLog || touch "$LOGFILE" [ -e "$LOGFILE" ] && m_recycleLog || touch "$LOGFILE"
# SELinux check # SELinux check
if [ "$SELINUX" != "Enforcing" ]; then if [ "$SELINUX" != "Enforcing" ]; then
@ -37,10 +38,12 @@ r_log "internal" "Starting Release Engineering Core Tests"
# Skip tests in a list - some tests are already -x, so it won't be an issue # Skip tests in a list - some tests are already -x, so it won't be an issue
if [ -e skip.list ]; then if [ -e skip.list ]; then
r_log "internal" "Disabling tests" r_log "internal" "Disabling tests"
# shellcheck disable=SC2162
grep -E "^${RL_VER}" skip.list | while read line; do grep -E "^${RL_VER}" skip.list | while read line; do
testFile=$(echo $line | cut -d '|' -f 2) # shellcheck disable=SC2086
testFile="$(echo $line | cut -d '|' -f 2)"
r_log "internal" "SKIP ${testFile}" r_log "internal" "SKIP ${testFile}"
chmod -x ${testFile} chmod -x "${testFile}"
done done
r_log "internal" "WARNING: Tests above were disabled." r_log "internal" "WARNING: Tests above were disabled."
fi fi

View file

@ -22,11 +22,14 @@ cleanup_repo () {
# plus is actually 'rockyplus'. Others may as well(?) # plus is actually 'rockyplus'. Others may as well(?)
if [[ "${repo}" =~ ^(plus)$ ]]; then if [[ "${repo}" =~ ^(plus)$ ]]; then
repo="rocky${repo}" repo="rocky${repo}"
# nfv is actually 'NFV'
elif [[ "${repo}" =~ ^(nfv)$ ]]; then elif [[ "${repo}" =~ ^(nfv)$ ]]; then
repo="${repo^^}" repo="${repo^^}"
else
repo="${repo}"
fi fi
# Everything has an 8 appended to it
repo="${repo}-8"
return 0 return 0
} }
@ -38,17 +41,18 @@ for repo in "${ALL_REPOS[@]}"; do
# Print a nice header # Print a nice header
printf "================\n${repo}\n================\n" printf "================\n${repo}\n================\n"
for arch in "${ARCHES[@]}" "source"; do for arch in "${ARCHES[@]}" "source"; do
# Source is treated as its own architecture
if [[ "${arch}" == "source" ]]; then if [[ "${arch}" == "source" ]]; then
_repo="${repo}-8-source" repo="${repo}-source"
else
_repo="${repo}-8"
fi fi
result=$(curl -s "${MIRRORLIST_BASE}?repo=${_repo}&arch=${arch}&time&country=global") # Get the normal repo/arch combinations
result=$(curl -s "${MIRRORLIST_BASE}?repo=${repo}&arch=${arch}&time&country=global")
print_result print_result
# x86 and a64 have 'debug' types, as well
if [[ "${arch}" =~ ^(x86_|aarch)64$ ]]; then if [[ "${arch}" =~ ^(x86_|aarch)64$ ]]; then
result=$(curl -s "${MIRRORLIST_BASE}?repo=${_repo}-debug&arch=${arch}&time&country=global") result=$(curl -s "${MIRRORLIST_BASE}?repo=${repo}-debug&arch=${arch}&time&country=global")
print_result print_result
fi fi
done done

View file

@ -0,0 +1,10 @@
#!/bin/bash
# Performs a full on sync of a minor release, directories and all. It calls the
# other scripts in this directory to assist.
# Source common variables
# shellcheck disable=SC2046,1091
source $(dirname "$0")/common
# sync all pieces of a release, including extras, nfv, etc
# move around the ISOs a bit, make things comfortable

View file

@ -12,6 +12,7 @@
# Compose dir example: /mnt/repos-staging/mirror/pub/rocky/8.4-RC2 # Compose dir example: /mnt/repos-staging/mirror/pub/rocky/8.4-RC2
# Source common variables # Source common variables
# shellcheck disable=SC2046,1091
source $(dirname "$0")/common source $(dirname "$0")/common
echo "** Updating source repos" echo "** Updating source repos"
@ -64,7 +65,7 @@ for x in "${ARCHES[@]}"; do
if [ "$ret_val" -eq 0 ]; then if [ "$ret_val" -eq 0 ]; then
createrepo --update "${STAGING_ROOT}/${RELEASE_DIR}/${y}/${x}/os" \ createrepo --update "${STAGING_ROOT}/${RELEASE_DIR}/${y}/${x}/os" \
--groupfile="/mnt/compose/8/latest-Rocky-8/work/${x}/comps/comps-${y}.${x}.xml" \ --groupfile="/mnt/compose/8/latest-Rocky-8/work/${x}/comps/comps-${y}.${x}.xml" \
--xz --revision=${REVISION} \ --xz --revision="${REVISION}" \
"--distro=cpe:/o:rocky:rocky:${REVISION:0:1},Rocky Linux ${REVISION:0:1}" \ "--distro=cpe:/o:rocky:rocky:${REVISION:0:1},Rocky Linux ${REVISION:0:1}" \
--workers=8 --checksum=sha256 --workers=8 --checksum=sha256
else else

View file

@ -2,18 +2,17 @@
# Syncs everything from staging to production # Syncs everything from staging to production
# Source common variables # Source common variables
# shellcheck disable=SC2046,1091
source $(dirname "$0")/common source $(dirname "$0")/common
REV=${1} REV=${1}
cd "${STAGING_ROOT}/${CATEGORY_STUB}/${REV}" cd "${STAGING_ROOT}/${CATEGORY_STUB}/${REV}" || { echo "Failed to change directory"; ret_val=1; exit 1; }
ret_val=$? ret_val=$?
if [ $ret_val -eq "0" ]; then if [ $ret_val -eq "0" ]; then
TARGET="${PRODUCTION_ROOT}/${CATEGORY_STUB}/${REV:0:3}" TARGET="${PRODUCTION_ROOT}/${CATEGORY_STUB}/${REV:0:3}"
mkdir -p "${TARGET}" mkdir -p "${TARGET}"
sudo -l && find **/* -maxdepth 0 -type d | parallel --will-cite -j 18 sudo rsync -av --chown=10004:10005 --progress --relative --human-readable \ sudo -l && find **/* -maxdepth 0 -type d | parallel --will-cite -j 18 sudo rsync -av --chown=10004:10005 --progress --relative --human-readable \
{} ${TARGET} {} "${TARGET}"
else
echo "Failed to change directory"
fi fi

View file

@ -1,6 +1,7 @@
#!/bin/bash #!/bin/bash
# Source common variables # Source common variables
# shellcheck disable=SC2046,1091
source $(dirname "$0")/common source $(dirname "$0")/common
# Major Version (eg, 8) # Major Version (eg, 8)
@ -12,14 +13,12 @@ REV=${3}
# Note, this should be lowercase. eg, storage. # Note, this should be lowercase. eg, storage.
SIG=${4} SIG=${4}
cd /mnt/compose/${MAJ}/latest-${SHORT}-${MAJ} cd "/mnt/compose/${MAJ}/latest-${SHORT}-${MAJ}" || { echo "Failed to change directory"; ret_val=1; exit 1; }
ret_val=$? ret_val=$?
if [ $ret_val -eq "0" ]; then if [ $ret_val -eq "0" ]; then
local TARGET=${STAGING_ROOT}/${CATEGORY_STUB}/${REV}/${SIG} TARGET=${STAGING_ROOT}/${CATEGORY_STUB}/${REV}/${SIG}
mkdir -p ${TARGET} mkdir -p "${TARGET}"
sudo -l && find **/* -maxdepth 0 -type d | parallel --will-cite -j 18 sudo rsync -av --chown=10004:10005 --progress --relative --human-readable \ sudo -l && find **/* -maxdepth 0 -type d | parallel --will-cite -j 18 sudo rsync -av --chown=10004:10005 --progress --relative --human-readable \
{} ${TARGET} {} "${TARGET}"
else
echo "Failed to change directory"
fi fi

View file

@ -1,6 +1,7 @@
#!/bin/bash #!/bin/bash
# Source common variables # Source common variables
# shellcheck disable=SC2046,1091
source $(dirname "$0")/common source $(dirname "$0")/common
# Major Version (eg, 8) # Major Version (eg, 8)
@ -10,14 +11,12 @@ SHORT=${2}
# The directory where we're going to, usually MAJOR.MINOR, sometimes it's MAJOR.MINOR-RCX # The directory where we're going to, usually MAJOR.MINOR, sometimes it's MAJOR.MINOR-RCX
REV=${3} REV=${3}
cd /mnt/compose/${MAJ}/latest-${SHORT}-${MAJ} cd "/mnt/compose/${MAJ}/latest-${SHORT}-${MAJ}" || { echo "Failed to change directory"; ret_val=1; exit 1; }
ret_val=$? ret_val=$?
if [ $ret_val -eq "0" ]; then if [ $ret_val -eq "0" ]; then
local TARGET=${STAGING_ROOT}/${CATEGORY_STUB}/${REV} TARGET="${STAGING_ROOT}/${CATEGORY_STUB}/${REV}"
mkdir -p ${TARGET} mkdir -p "${TARGET}"
sudo -l && find **/* -maxdepth 0 -type d | parallel --will-cite -j 18 sudo rsync -av --chown=10004:10005 --progress --relative --human-readable \ sudo -l && find **/* -maxdepth 0 -type d | parallel --will-cite -j 18 sudo rsync -av --chown=10004:10005 --progress --relative --human-readable \
{} ${TARGET} {} "${TARGET}"
else
echo "Failed to change directory"
fi fi