mirror of
https://github.com/deadc0de6/dotdrop.git
synced 2026-02-16 16:45:16 +00:00
fix instignore when installing link_children
This commit is contained in:
@@ -259,7 +259,8 @@ class Installer:
|
|||||||
ret, err = self.install(templater, src, tmp,
|
ret, err = self.install(templater, src, tmp,
|
||||||
LinkTypes.NOLINK,
|
LinkTypes.NOLINK,
|
||||||
actionexec=actionexec,
|
actionexec=actionexec,
|
||||||
is_template=is_template)
|
is_template=is_template,
|
||||||
|
ignore=ignore)
|
||||||
if not ret and not os.path.exists(tmp):
|
if not ret and not os.path.exists(tmp):
|
||||||
return ret, err
|
return ret, err
|
||||||
src = tmp
|
src = tmp
|
||||||
@@ -324,7 +325,8 @@ class Installer:
|
|||||||
ret2, err2 = self.install(templater, subsrc, tmp,
|
ret2, err2 = self.install(templater, subsrc, tmp,
|
||||||
LinkTypes.NOLINK,
|
LinkTypes.NOLINK,
|
||||||
actionexec=actionexec,
|
actionexec=actionexec,
|
||||||
is_template=is_template)
|
is_template=is_template,
|
||||||
|
ignore=ignore)
|
||||||
if not ret2 and err2 and not os.path.exists(tmp):
|
if not ret2 and err2 and not os.path.exists(tmp):
|
||||||
continue
|
continue
|
||||||
subsrc = tmp
|
subsrc = tmp
|
||||||
@@ -680,8 +682,6 @@ class Installer:
|
|||||||
self.log.dry('would mkdir -p {}'.format(directory))
|
self.log.dry('would mkdir -p {}'.format(directory))
|
||||||
return True
|
return True
|
||||||
self.log.dbg('mkdir -p {}'.format(directory))
|
self.log.dbg('mkdir -p {}'.format(directory))
|
||||||
if not self.comparing:
|
|
||||||
self.log.sub('create directory {}'.format(directory))
|
|
||||||
|
|
||||||
os.makedirs(directory, exist_ok=True)
|
os.makedirs(directory, exist_ok=True)
|
||||||
return os.path.exists(directory)
|
return os.path.exists(directory)
|
||||||
|
|||||||
112
tests-ng/install-link-children.sh
Executable file
112
tests-ng/install-link-children.sh
Executable file
@@ -0,0 +1,112 @@
|
|||||||
|
#!/usr/bin/env bash
|
||||||
|
# author: deadc0de6 (https://github.com/deadc0de6)
|
||||||
|
# Copyright (c) 2017, deadc0de6
|
||||||
|
#
|
||||||
|
# test link_dotfile_default
|
||||||
|
# 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"
|
||||||
|
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`
|
||||||
|
#echo "dotfile destination: ${tmpd}"
|
||||||
|
|
||||||
|
# create the config file
|
||||||
|
cfg="${tmps}/config.yaml"
|
||||||
|
|
||||||
|
cat > ${cfg} << _EOF
|
||||||
|
config:
|
||||||
|
backup: true
|
||||||
|
create: true
|
||||||
|
dotpath: dotfiles
|
||||||
|
link_dotfile_default: nolink
|
||||||
|
dotfiles:
|
||||||
|
d_dir1:
|
||||||
|
dst: ${tmpd}/dir1
|
||||||
|
src: dir1
|
||||||
|
link: link_children
|
||||||
|
instignore:
|
||||||
|
- '*ignore'
|
||||||
|
profiles:
|
||||||
|
p1:
|
||||||
|
dotfiles:
|
||||||
|
- d_dir1
|
||||||
|
_EOF
|
||||||
|
#cat ${cfg}
|
||||||
|
|
||||||
|
# create the dotfile
|
||||||
|
mkdir ${tmps}/dotfiles/dir1
|
||||||
|
mkdir ${tmps}/dotfiles/dir1/empty
|
||||||
|
echo "{{@@ profile @@}}" > ${tmps}/dotfiles/dir1/empty/this.ignore
|
||||||
|
mkdir ${tmps}/dotfiles/dir1/not-empty
|
||||||
|
echo "{{@@ profile @@}}" > ${tmps}/dotfiles/dir1/not-empty/file
|
||||||
|
mkdir ${tmps}/dotfiles/dir1/sub
|
||||||
|
mkdir ${tmps}/dotfiles/dir1/sub/empty
|
||||||
|
echo "{{@@ profile @@}}" > ${tmps}/dotfiles/dir1/sub/empty/that.ignore
|
||||||
|
|
||||||
|
# install
|
||||||
|
cd ${ddpath} | ${bin} install -f -c ${cfg} -p p1 -V
|
||||||
|
#cat ${cfg}
|
||||||
|
|
||||||
|
# checks normal
|
||||||
|
[ ! -d ${tmpd}/dir1 ] && exit 1
|
||||||
|
[ ! -d ${tmpd}/dir1/empty ] && exit 1
|
||||||
|
[ ! -d ${tmpd}/dir1/sub ] && exit 1
|
||||||
|
[ ! -d ${tmpd}/dir1/sub/empty ] && exit 1
|
||||||
|
[ ! -d ${tmpd}/dir1/not-empty ] && exit 1
|
||||||
|
|
||||||
|
[ ! -e ${tmpd}/dir1/not-empty/file ] && exit 1
|
||||||
|
|
||||||
|
# ignored files
|
||||||
|
[ -e ${tmpd}/dir1/empty/this.ignore ] && exit 1
|
||||||
|
[ -e ${tmpd}/dir1/sub/empty/that.ignore ] && exit 1
|
||||||
|
|
||||||
|
grep "p1" ${tmpd}/dir1/not-empty/file
|
||||||
|
|
||||||
|
## CLEANING
|
||||||
|
rm -rf ${tmps} ${tmpd}
|
||||||
|
|
||||||
|
echo "OK"
|
||||||
|
exit 0
|
||||||
Reference in New Issue
Block a user