mirror of
https://github.com/deadc0de6/dotdrop.git
synced 2026-02-04 16:49:42 +00:00
fix #378 and add unittest
This commit is contained in:
@@ -760,12 +760,18 @@ class CfgYaml:
|
|||||||
if not entries:
|
if not entries:
|
||||||
# no entries in profile dict
|
# no entries in profile dict
|
||||||
continue
|
continue
|
||||||
# add "dotfiles:"" entry if not present
|
|
||||||
if self.key_profile_dotfiles not in entries:
|
# add "dotfiles:" entry if not present in local object
|
||||||
msg = f'\"{self.key_profile_dotfiles}\" entry is mandatory'
|
if self.key_profile_dotfiles not in entries or \
|
||||||
msg += f' and was not present in profile \"{pro}\".'
|
entries[self.key_profile_dotfiles] is None:
|
||||||
self._log.warn(msg)
|
|
||||||
entries[self.key_profile_dotfiles] = []
|
entries[self.key_profile_dotfiles] = []
|
||||||
|
|
||||||
|
# add "dotfiles:" entry if not present in yaml dict
|
||||||
|
dict_pro = self._yaml_dict[self.key_profiles][pro]
|
||||||
|
if self.key_profile_dotfiles not in dict_pro or \
|
||||||
|
dict_pro[self.key_profile_dotfiles] is None:
|
||||||
|
dict_pro[self.key_profile_dotfiles] = []
|
||||||
|
|
||||||
new[pro] = entries
|
new[pro] = entries
|
||||||
return new
|
return new
|
||||||
|
|
||||||
|
|||||||
162
tests-ng/compare-include.sh
vendored
Executable file
162
tests-ng/compare-include.sh
vendored
Executable file
@@ -0,0 +1,162 @@
|
|||||||
|
#!/usr/bin/env bash
|
||||||
|
# author: deadc0de6 (https://github.com/deadc0de6)
|
||||||
|
# Copyright (c) 2023, deadc0de6
|
||||||
|
#
|
||||||
|
# test compare in profile which includes another
|
||||||
|
#
|
||||||
|
|
||||||
|
# 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"
|
||||||
|
hash coverage 2>/dev/null && bin="coverage run -a --source=dotdrop -m dotdrop.dotdrop" || true
|
||||||
|
|
||||||
|
echo "dotdrop path: ${ddpath}"
|
||||||
|
echo "pythonpath: ${PYTHONPATH}"
|
||||||
|
|
||||||
|
# get the helpers
|
||||||
|
source ${cur}/helpers
|
||||||
|
|
||||||
|
echo -e "$(tput setaf 6)==> RUNNING $(basename $BASH_SOURCE) <==$(tput sgr0)"
|
||||||
|
|
||||||
|
################################################################
|
||||||
|
# this is the test
|
||||||
|
################################################################
|
||||||
|
|
||||||
|
# the dotfile source
|
||||||
|
tmps=`mktemp -d --suffix='-dotdrop-tests' || mktemp -d`
|
||||||
|
mkdir -p ${tmps}/dotfiles
|
||||||
|
# the dotfile destination
|
||||||
|
tmpd=`mktemp -d --suffix='-dotdrop-tests' || mktemp -d`
|
||||||
|
|
||||||
|
clear_on_exit "${tmps}"
|
||||||
|
clear_on_exit "${tmpd}"
|
||||||
|
|
||||||
|
# create the dotfiles already imported
|
||||||
|
echo "already in" > ${tmps}/dotfiles/abc
|
||||||
|
cp ${tmps}/dotfiles/abc ${tmpd}/abc
|
||||||
|
|
||||||
|
# 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:
|
||||||
|
p0:
|
||||||
|
dotfiles:
|
||||||
|
include:
|
||||||
|
- p1
|
||||||
|
- p2
|
||||||
|
p1:
|
||||||
|
dotfiles:
|
||||||
|
variables:
|
||||||
|
somevar: somevalue
|
||||||
|
p2:
|
||||||
|
dotfiles:
|
||||||
|
- f_abc
|
||||||
|
_EOF
|
||||||
|
cat ${cfg}
|
||||||
|
|
||||||
|
cd ${ddpath} | ${bin} files -c ${cfg} -p p0
|
||||||
|
|
||||||
|
cnt=`cd ${ddpath} | ${bin} files -c ${cfg} -p p0 | grep '^f_' | wc -l`
|
||||||
|
[ "${cnt}" != "1" ] && echo "this is bad" && exit 1
|
||||||
|
|
||||||
|
# compare
|
||||||
|
cd ${ddpath} | ${bin} compare -c ${cfg} -p p0
|
||||||
|
|
||||||
|
echo "modifying"
|
||||||
|
echo 'modified' > ${tmpd}/abc
|
||||||
|
|
||||||
|
# compare
|
||||||
|
set +e
|
||||||
|
cd ${ddpath} | ${bin} compare -c ${cfg} -p p0
|
||||||
|
ret=$?
|
||||||
|
[ "${ret}" = "0" ] && echo "compare should fail (returned ${ret})" && exit 1
|
||||||
|
set -e
|
||||||
|
|
||||||
|
# count
|
||||||
|
cnt=`cd ${ddpath} | ${bin} files -c ${cfg} -p p0 -b | grep '^f_' | wc -l`
|
||||||
|
[ "${cnt}" != "2" ] && echo "not enough dotfile" exit 1
|
||||||
|
|
||||||
|
## without dotfiles: entry
|
||||||
|
# reset dotfile content
|
||||||
|
echo "already in" > ${tmps}/dotfiles/abc
|
||||||
|
cp ${tmps}/dotfiles/abc ${tmpd}/abc
|
||||||
|
|
||||||
|
cat > ${cfg} << _EOF
|
||||||
|
config:
|
||||||
|
backup: true
|
||||||
|
create: true
|
||||||
|
dotpath: dotfiles
|
||||||
|
dotfiles:
|
||||||
|
f_abc:
|
||||||
|
dst: ${tmpd}/abc
|
||||||
|
src: abc
|
||||||
|
profiles:
|
||||||
|
p0:
|
||||||
|
include:
|
||||||
|
- p1
|
||||||
|
- p2
|
||||||
|
p1:
|
||||||
|
variables:
|
||||||
|
somevar: somevalue
|
||||||
|
p2:
|
||||||
|
dotfiles:
|
||||||
|
- f_abc
|
||||||
|
_EOF
|
||||||
|
cat ${cfg}
|
||||||
|
|
||||||
|
cd ${ddpath} | ${bin} files -c ${cfg} -p p0
|
||||||
|
|
||||||
|
cnt=`cd ${ddpath} | ${bin} files -c ${cfg} -p p0 | grep '^f_' | wc -l`
|
||||||
|
[ "${cnt}" != "1" ] && echo "this is bad" && exit 1
|
||||||
|
|
||||||
|
# compare
|
||||||
|
cd ${ddpath} | ${bin} compare -c ${cfg} -p p0
|
||||||
|
|
||||||
|
echo "modifying"
|
||||||
|
echo 'modified' > ${tmpd}/abc
|
||||||
|
|
||||||
|
# compare
|
||||||
|
set +e
|
||||||
|
cd ${ddpath} | ${bin} compare -c ${cfg} -p p0
|
||||||
|
ret=$?
|
||||||
|
[ "${ret}" = "0" ] && echo "compare should fail (returned ${ret})" && exit 1
|
||||||
|
set -e
|
||||||
|
|
||||||
|
# count
|
||||||
|
cnt=`cd ${ddpath} | ${bin} files -c ${cfg} -p p0 -b | grep '^f_' | wc -l`
|
||||||
|
[ "${cnt}" != "2" ] && echo "not enough dotfile" exit 1
|
||||||
|
|
||||||
|
echo "OK"
|
||||||
|
exit 0
|
||||||
2
tests-ng/import-include.sh
vendored
2
tests-ng/import-include.sh
vendored
@@ -85,7 +85,7 @@ cat ${cfg}
|
|||||||
cnt=`cd ${ddpath} | ${bin} files -c ${cfg} -p p0 | grep '^f_' | wc -l`
|
cnt=`cd ${ddpath} | ${bin} files -c ${cfg} -p p0 | grep '^f_' | wc -l`
|
||||||
[ "${cnt}" != "1" ] && echo "this is bad" && exit 1
|
[ "${cnt}" != "1" ] && echo "this is bad" && exit 1
|
||||||
|
|
||||||
# install
|
# import
|
||||||
cd ${ddpath} | ${bin} import -f -c ${cfg} -p p0 --verbose ${tmpd}/file
|
cd ${ddpath} | ${bin} import -f -c ${cfg} -p p0 --verbose ${tmpd}/file
|
||||||
|
|
||||||
[ ! -e ${tmps}/dotfiles/${tmpd}/file ] && echo "file not imported" && exit 1
|
[ ! -e ${tmps}/dotfiles/${tmpd}/file ] && echo "file not imported" && exit 1
|
||||||
|
|||||||
Reference in New Issue
Block a user