From dd2f093375f310a5fef4f6885aa3265233f2a121 Mon Sep 17 00:00:00 2001 From: deadc0de6 Date: Sat, 2 Jun 2018 09:25:52 +0200 Subject: [PATCH] adding more tests --- tests-ng/dir-import-update.sh | 2 + tests-ng/duplicate-key.sh | 93 +++++++++++++++++++++++++++++++++++ tests-ng/include.sh | 86 ++++++++++++++++++++++++++++++++ 3 files changed, 181 insertions(+) create mode 100755 tests-ng/duplicate-key.sh create mode 100755 tests-ng/include.sh diff --git a/tests-ng/dir-import-update.sh b/tests-ng/dir-import-update.sh index 99ed614..93b2f18 100755 --- a/tests-ng/dir-import-update.sh +++ b/tests-ng/dir-import-update.sh @@ -39,6 +39,8 @@ echo "pythonpath: ${PYTHONPATH}" # get the helpers source ${cur}/helpers +echo "RUNNING $(basename $BASH_SOURCE)" + ################################################################ # this is the test ################################################################ diff --git a/tests-ng/duplicate-key.sh b/tests-ng/duplicate-key.sh new file mode 100755 index 0000000..37e883d --- /dev/null +++ b/tests-ng/duplicate-key.sh @@ -0,0 +1,93 @@ +#!/usr/bin/env bash +# author: deadc0de6 (https://github.com/deadc0de6) +# Copyright (c) 2017, deadc0de6 +# +# test importing and updating entire directories +# returns 1 in case of error +# + +# exit on first error +set -e + +# all this crap to get current path +rl="readlink -f" +if ! ${rl} "${0}" >/dev/null 2>&1; then + rl="realpath" + + if ! hash ${rl}; then + echo "\"${rl}\" not found !" && exit 1 + fi +fi +cur=$(dirname "$(${rl} "${0}")") + +#hash dotdrop >/dev/null 2>&1 +#[ "$?" != "0" ] && echo "install dotdrop to run tests" && exit 1 + +#echo "called with ${1}" + +# dotdrop path can be pass as argument +ddpath="${cur}/../" +[ "${1}" != "" ] && ddpath="${1}" +[ ! -d ${ddpath} ] && echo "ddpath \"${ddpath}\" is not a directory" && exit 1 + +export PYTHONPATH="${ddpath}:${PYTHONPATH}" +bin="python3 -m dotdrop.dotdrop" + +echo "dotdrop path: ${ddpath}" +echo "pythonpath: ${PYTHONPATH}" + +# get the helpers +source ${cur}/helpers + +echo "RUNNING $(basename $BASH_SOURCE)" + +################################################################ +# this is the test +################################################################ + +# the dotfile source +tmps=`mktemp -d` +mkdir -p ${tmps}/dotfiles +# the dotfile destination +tmpd=`mktemp -d` + +# create the config file +cfg="${tmps}/config.yaml" + +cat > ${cfg} << _EOF +config: + backup: true + create: true + dotpath: dotfiles +dotfiles: + f_abc: + dst: ${tmpd}/abc + src: abc +profiles: + p1: + dotfiles: + - f_abc +_EOF + +# create the source +mkdir -p ${tmps}/dotfiles/${tmpd} +echo "test" > ${tmps}/dotfiles/${tmpd}/abc + +mkdir -p ${tmps}/dotfiles/${tmpd}/sub +echo "test2" > ${tmps}/dotfiles/${tmpd}/sub/abc + +mkdir -p ${tmps}/dotfiles/${tmpd}/sub/sub2 +echo "test2" > ${tmps}/dotfiles/${tmpd}/sub/sub2/abc + +# import +cd ${ddpath} | ${bin} import -c ${cfg} -p p2 \ + ${tmps}/dotfiles/${tmpd}/sub/abc \ + ${tmps}/dotfiles/${tmpd}/sub/abc \ + ${tmps}/dotfiles/${tmpd}/sub/sub2/abc + +cat ${cfg} + +## CLEANING +rm -rf ${tmps} ${tmpd} + +exit 0 diff --git a/tests-ng/include.sh b/tests-ng/include.sh new file mode 100755 index 0000000..fba0bb4 --- /dev/null +++ b/tests-ng/include.sh @@ -0,0 +1,86 @@ +#!/usr/bin/env bash +# author: deadc0de6 (https://github.com/deadc0de6) +# Copyright (c) 2017, deadc0de6 +# +# test importing and updating entire directories +# returns 1 in case of error +# + +# exit on first error +set -e + +# all this crap to get current path +rl="readlink -f" +if ! ${rl} "${0}" >/dev/null 2>&1; then + rl="realpath" + + if ! hash ${rl}; then + echo "\"${rl}\" not found !" && exit 1 + fi +fi +cur=$(dirname "$(${rl} "${0}")") + +#hash dotdrop >/dev/null 2>&1 +#[ "$?" != "0" ] && echo "install dotdrop to run tests" && exit 1 + +#echo "called with ${1}" + +# dotdrop path can be pass as argument +ddpath="${cur}/../" +[ "${1}" != "" ] && ddpath="${1}" +[ ! -d ${ddpath} ] && echo "ddpath \"${ddpath}\" is not a directory" && exit 1 + +export PYTHONPATH="${ddpath}:${PYTHONPATH}" +bin="python3 -m dotdrop.dotdrop" + +echo "dotdrop path: ${ddpath}" +echo "pythonpath: ${PYTHONPATH}" + +# get the helpers +source ${cur}/helpers + +echo "RUNNING $(basename $BASH_SOURCE)" + +################################################################ +# this is the test +################################################################ + +# the dotfile source +tmps=`mktemp -d` +mkdir -p ${tmps}/dotfiles +# the dotfile destination +tmpd=`mktemp -d` + +# create the config file +cfg="${tmps}/config.yaml" + +cat > ${cfg} << _EOF +config: + backup: true + create: true + dotpath: dotfiles +dotfiles: + f_abc: + dst: ${tmpd}/abc + src: abc +profiles: + p1: + dotfiles: + - f_abc + p2: + dotfiles: + include: p1 +_EOF + +# create the source +mkdir -p ${tmps}/dotfiles/${tmpd} +echo "test" > ${tmps}/dotfiles/${tmpd}/abc + +# compare +cd ${ddpath} | ${bin} compare -c ${cfg} -p p1 +cd ${ddpath} | ${bin} compare -c ${cfg} -p p2 + +## CLEANING +rm -rf ${tmps} ${tmpd} + +exit 0