mirror of
https://github.com/deadc0de6/dotdrop.git
synced 2026-02-11 16:39:00 +00:00
fix issues with variables expansions
This commit is contained in:
98
tests-ng/dotfiles-dyn-paths.sh
Executable file
98
tests-ng/dotfiles-dyn-paths.sh
Executable file
@@ -0,0 +1,98 @@
|
||||
#!/usr/bin/env bash
|
||||
# author: deadc0de6 (https://github.com/deadc0de6)
|
||||
# Copyright (c) 2019, deadc0de6
|
||||
#
|
||||
# test dotfile dynamic paths
|
||||
# returns 1 in case of error
|
||||
#
|
||||
|
||||
# exit on first error
|
||||
set -e
|
||||
#set -v
|
||||
|
||||
# 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 -e "\e[96m\e[1m==> RUNNING $(basename $BASH_SOURCE) <==\e[0m"
|
||||
|
||||
################################################################
|
||||
# this is the test
|
||||
################################################################
|
||||
|
||||
# the dotfile source
|
||||
tmps=`mktemp -d --suffix='-dotdrop-tests'`
|
||||
mkdir -p ${tmps}/dotfiles
|
||||
echo "dotfiles source (dotpath): ${tmps}"
|
||||
# the dotfile destination
|
||||
tmpd=`mktemp -d --suffix='-dotdrop-tests'`
|
||||
echo "dotfiles destination: ${tmpd}"
|
||||
|
||||
# create the config file
|
||||
cfg="${tmps}/config.yaml"
|
||||
|
||||
cat > ${cfg} << _EOF
|
||||
config:
|
||||
backup: true
|
||||
create: true
|
||||
dotpath: dotfiles
|
||||
variables:
|
||||
dst: "${tmpd}/abc"
|
||||
dynvariables:
|
||||
src: "echo abc"
|
||||
dotfiles:
|
||||
f_abc:
|
||||
dst: "{{@@ dst @@}}"
|
||||
src: "{{@@ src @@}}"
|
||||
profiles:
|
||||
p1:
|
||||
dotfiles:
|
||||
- f_abc
|
||||
_EOF
|
||||
#cat ${cfg}
|
||||
|
||||
# create the dotfiles
|
||||
echo "abc" > ${tmps}/dotfiles/abc
|
||||
|
||||
###########################
|
||||
# test install and compare
|
||||
###########################
|
||||
|
||||
# install
|
||||
cd ${ddpath} | ${bin} install -f -c ${cfg} -p p1 -b -V
|
||||
[ "$?" != "0" ] && exit 1
|
||||
|
||||
# checks
|
||||
[ ! -e ${tmpd}/abc ] && exit 1
|
||||
|
||||
## CLEANING
|
||||
rm -rf ${tmps} ${tmpd}
|
||||
|
||||
echo "OK"
|
||||
exit 0
|
||||
@@ -68,6 +68,7 @@ variables:
|
||||
var3: "{{@@ var2 @@}} var3"
|
||||
var4: "{{@@ dvar4 @@}}"
|
||||
varx: "test"
|
||||
provar: "local"
|
||||
dynvariables:
|
||||
dvar1: "echo dvar1"
|
||||
dvar2: "{{@@ dvar1 @@}} dvar2"
|
||||
@@ -83,16 +84,15 @@ profiles:
|
||||
- f_abc
|
||||
variables:
|
||||
varx: profvarx
|
||||
provar: provar
|
||||
_EOF
|
||||
#cat ${cfg}
|
||||
|
||||
# create the external variables file
|
||||
cat > ${extvars} << _EOF
|
||||
variables:
|
||||
var1: "extvar1"
|
||||
varx: "exttest"
|
||||
dynvariables:
|
||||
dvar1: "echo extdvar1"
|
||||
evar1: "echo extevar1"
|
||||
_EOF
|
||||
|
||||
@@ -103,19 +103,22 @@ echo "var4: {{@@ var4 @@}}" >> ${tmps}/dotfiles/abc
|
||||
echo "dvar4: {{@@ dvar4 @@}}" >> ${tmps}/dotfiles/abc
|
||||
echo "varx: {{@@ varx @@}}" >> ${tmps}/dotfiles/abc
|
||||
echo "evar1: {{@@ evar1 @@}}" >> ${tmps}/dotfiles/abc
|
||||
echo "provar: {{@@ provar @@}}" >> ${tmps}/dotfiles/abc
|
||||
|
||||
#cat ${tmps}/dotfiles/abc
|
||||
|
||||
# install
|
||||
cd ${ddpath} | ${bin} install -f -c ${cfg} -p p1 -V
|
||||
|
||||
echo "check1"
|
||||
cat ${tmpd}/abc
|
||||
grep '^var3: extvar1 var2 var3' ${tmpd}/abc >/dev/null
|
||||
grep '^dvar3: extdvar1 dvar2 dvar3' ${tmpd}/abc >/dev/null
|
||||
grep '^var4: echo extvar1 var2 var3' ${tmpd}/abc >/dev/null
|
||||
grep '^dvar4: extvar1 var2 var3' ${tmpd}/abc >/dev/null
|
||||
grep '^varx: profvarx' ${tmpd}/abc >/dev/null
|
||||
grep '^var3: var1 var2 var3' ${tmpd}/abc >/dev/null
|
||||
grep '^dvar3: dvar1 dvar2 dvar3' ${tmpd}/abc >/dev/null
|
||||
grep '^var4: echo var1 var2 var3' ${tmpd}/abc >/dev/null
|
||||
grep '^dvar4: var1 var2 var3' ${tmpd}/abc >/dev/null
|
||||
grep '^varx: exttest' ${tmpd}/abc >/dev/null
|
||||
grep '^evar1: extevar1' ${tmpd}/abc >/dev/null
|
||||
grep '^provar: provar' ${tmpd}/abc >/dev/null
|
||||
|
||||
rm -f ${tmpd}/abc
|
||||
|
||||
@@ -137,6 +140,7 @@ profiles:
|
||||
- f_abc
|
||||
variables:
|
||||
varx: profvarx
|
||||
vary: profvary
|
||||
_EOF
|
||||
#cat ${cfg}
|
||||
|
||||
@@ -161,19 +165,21 @@ echo "dvar3: {{@@ dvar3 @@}}" >> ${tmps}/dotfiles/abc
|
||||
echo "var4: {{@@ var4 @@}}" >> ${tmps}/dotfiles/abc
|
||||
echo "dvar4: {{@@ dvar4 @@}}" >> ${tmps}/dotfiles/abc
|
||||
echo "varx: {{@@ varx @@}}" >> ${tmps}/dotfiles/abc
|
||||
echo "vary: {{@@ vary @@}}" >> ${tmps}/dotfiles/abc
|
||||
|
||||
#cat ${tmps}/dotfiles/abc
|
||||
|
||||
# install
|
||||
cd ${ddpath} | ${bin} install -f -c ${cfg} -p p1 -V
|
||||
|
||||
echo "test2"
|
||||
cat ${tmpd}/abc
|
||||
|
||||
grep '^var3: extvar1 var2 var3' ${tmpd}/abc >/dev/null
|
||||
grep '^dvar3: extdvar1 dvar2 dvar3' ${tmpd}/abc >/dev/null
|
||||
grep '^var4: echo extvar1 var2 var3' ${tmpd}/abc >/dev/null
|
||||
grep '^dvar4: extvar1 var2 var3' ${tmpd}/abc >/dev/null
|
||||
grep '^varx: profvarx' ${tmpd}/abc >/dev/null
|
||||
grep '^varx: exttest' ${tmpd}/abc >/dev/null
|
||||
grep '^vary: profvary' ${tmpd}/abc >/dev/null
|
||||
|
||||
## CLEANING
|
||||
rm -rf ${tmps} ${tmpd}
|
||||
|
||||
@@ -109,7 +109,7 @@ echo "===================" >> ${tmps}/dotfiles/abc
|
||||
# install
|
||||
cd ${ddpath} | ${bin} install -f -c ${cfg} -p p1 -V
|
||||
|
||||
#cat ${tmpd}/abc
|
||||
cat ${tmpd}/abc
|
||||
|
||||
# test variables
|
||||
grep '^local1' ${tmpd}/abc >/dev/null
|
||||
|
||||
@@ -92,6 +92,7 @@ echo "test" >> ${tmps}/dotfiles/abc
|
||||
# install
|
||||
cd ${ddpath} | ${bin} install -f -c ${cfg} -p p1
|
||||
|
||||
cat ${tmpd}/abc
|
||||
grep '^this is some sub-test' ${tmpd}/abc >/dev/null
|
||||
grep '^12' ${tmpd}/abc >/dev/null
|
||||
grep '^another test' ${tmpd}/abc >/dev/null
|
||||
@@ -99,7 +100,8 @@ grep '^another test' ${tmpd}/abc >/dev/null
|
||||
# install
|
||||
cd ${ddpath} | ${bin} install -f -c ${cfg} -p p2
|
||||
|
||||
grep '^this is some sub-test' ${tmpd}/abc >/dev/null
|
||||
cat ${tmpd}/abc
|
||||
grep '^this is some test' ${tmpd}/abc >/dev/null
|
||||
grep '^42' ${tmpd}/abc >/dev/null
|
||||
grep '^another test' ${tmpd}/abc >/dev/null
|
||||
|
||||
|
||||
Reference in New Issue
Block a user