aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/test/linux-home/test.sh
diff options
context:
space:
mode:
authorEgor Tensin <Egor.Tensin@gmail.com>2023-05-21 20:40:16 +0200
committerEgor Tensin <Egor.Tensin@gmail.com>2023-05-21 20:40:16 +0200
commitddd150b7d16d289ed0d0ca8dbbcaa335761ad4f2 (patch)
tree7de243930d1359dca8efc32d317441f677f212ac /test/linux-home/test.sh
parentdebian: 2.0.3-5 (diff)
parentmove comments from links-update to README (diff)
downloadconfig-links-ddd150b7d16d289ed0d0ca8dbbcaa335761ad4f2.tar.gz
config-links-ddd150b7d16d289ed0d0ca8dbbcaa335761ad4f2.zip
Merge tag 'v2.0.4' into debian
Diffstat (limited to 'test/linux-home/test.sh')
-rwxr-xr-xtest/linux-home/test.sh95
1 files changed, 95 insertions, 0 deletions
diff --git a/test/linux-home/test.sh b/test/linux-home/test.sh
new file mode 100755
index 0000000..edb2d5b
--- /dev/null
+++ b/test/linux-home/test.sh
@@ -0,0 +1,95 @@
+#!/usr/bin/env bash
+
+set -o errexit -o nounset -o pipefail
+shopt -s inherit_errexit 2> /dev/null || true
+shopt -s lastpipe
+
+script_dir="$( dirname -- "${BASH_SOURCE[0]}" )"
+script_dir="$( cd -- "$script_dir" && pwd )"
+readonly script_dir
+script_name="$( basename -- "${BASH_SOURCE[0]}" )"
+readonly script_name
+
+root_dir="$( git -C "$script_dir" rev-parse --show-toplevel )"
+readonly root_dir
+
+src_name='linux-home'
+readonly src_name
+src_url="https://github.com/egor-tensin/$src_name.git"
+readonly src_url
+
+test_root_dir=
+test_src_dir=
+
+new_test() {
+ local test_name=
+ [ "${#FUNCNAME[@]}" -gt 1 ] && test_name="${FUNCNAME[1]}"
+ [ "$#" -gt 0 ] && test_name="$1"
+
+ echo
+ echo ======================================================================
+ echo "New test: $test_name"
+
+ test_root_dir="$( mktemp -d )"
+ # mktemp returns /var/..., which is actually in /private/var/... on macOS.
+ test_root_dir="$( readlink -e -- "$test_root_dir" )"
+ test_src_dir="$test_root_dir/$src_name"
+
+ echo "Root directory: $test_root_dir"
+ echo "Shared directory: $test_src_dir"
+ echo ======================================================================
+
+ git clone -q -- "$src_url" "$test_src_dir"
+ cd -- "$test_src_dir"
+}
+
+call_bin_script() {
+ echo
+ echo -n 'Executing script:'
+
+ printf -- ' %q' "$@" --shared-dir "$test_src_dir" --database "$test_root_dir/links.bin"
+ printf -- '\n'
+
+ echo
+ "$@" --shared-dir "$test_src_dir" --database "$test_root_dir/links.bin"
+}
+
+call_update() {
+ call_bin_script "$root_dir/links-update" "$@"
+}
+
+call_remove() {
+ call_bin_script "$root_dir/links-remove"
+}
+
+call_chmod() {
+ call_bin_script "$root_dir/links-chmod" "$@"
+}
+
+test_my_dotfiles_work() {
+ new_test
+ call_update
+ # Again:
+ call_update
+}
+
+show_env() {
+ echo
+ echo ======================================================================
+ echo Environment
+ echo ======================================================================
+
+ bash --version
+}
+
+main() {
+ if [ -z "${CI:+x}" ]; then
+ echo "$script_name: please don't run it outside of CI runs" >&2
+ exit 1
+ fi
+
+ show_env
+ test_my_dotfiles_work
+}
+
+main