mirror of
https://github.com/deadc0de6/dotdrop.git
synced 2026-02-12 01:18:59 +00:00
fix ignore for import and update
This commit is contained in:
@@ -50,14 +50,23 @@ class Importer:
|
|||||||
self.safe = safe
|
self.safe = safe
|
||||||
self.debug = debug
|
self.debug = debug
|
||||||
self.keepdot = keepdot
|
self.keepdot = keepdot
|
||||||
self.ignore = ignore or []
|
self.ignore = []
|
||||||
|
self.log = Logger(debug=self.debug)
|
||||||
|
|
||||||
|
# patch ignore patterns
|
||||||
|
for ign in ignore:
|
||||||
|
if ign.startswith('*/'):
|
||||||
|
self.ignore.append(ign)
|
||||||
|
continue
|
||||||
|
newign = f'*/{ign}'
|
||||||
|
self.log.dbg(f'patching ignore {ign} to {newign}')
|
||||||
|
self.ignore.append(newign)
|
||||||
|
|
||||||
self.templater = Templategen(variables=self.variables,
|
self.templater = Templategen(variables=self.variables,
|
||||||
base=self.dotpath,
|
base=self.dotpath,
|
||||||
debug=self.debug)
|
debug=self.debug)
|
||||||
|
|
||||||
self.umask = get_umask()
|
self.umask = get_umask()
|
||||||
self.log = Logger(debug=self.debug)
|
|
||||||
|
|
||||||
def import_path(self, path, import_as=None,
|
def import_path(self, path, import_as=None,
|
||||||
import_link=LinkTypes.NOLINK,
|
import_link=LinkTypes.NOLINK,
|
||||||
|
|||||||
@@ -288,7 +288,7 @@ def must_ignore(paths, ignores, debug=False):
|
|||||||
if not ignores:
|
if not ignores:
|
||||||
return False
|
return False
|
||||||
if debug:
|
if debug:
|
||||||
LOG.dbg(f'must ignore? \"{paths}\" against {ignores}',
|
LOG.dbg(f'must ignore? \"{paths}\" against pattern(s): {ignores}',
|
||||||
force=True)
|
force=True)
|
||||||
nign, ign = categorize(
|
nign, ign = categorize(
|
||||||
lambda ign: ign.startswith('!'), ignores)
|
lambda ign: ign.startswith('!'), ignores)
|
||||||
@@ -336,6 +336,9 @@ def copytree_with_ign(src, dst, ignore_func=None, debug=False):
|
|||||||
for entry in os.listdir(src):
|
for entry in os.listdir(src):
|
||||||
srcf = os.path.join(src, entry)
|
srcf = os.path.join(src, entry)
|
||||||
dstf = os.path.join(dst, entry)
|
dstf = os.path.join(dst, entry)
|
||||||
|
if ignore_func:
|
||||||
|
if ignore_func(srcf):
|
||||||
|
continue
|
||||||
if os.path.isdir(srcf):
|
if os.path.isdir(srcf):
|
||||||
if debug:
|
if debug:
|
||||||
LOG.dbg(f'mkdir \"{dstf}\"',
|
LOG.dbg(f'mkdir \"{dstf}\"',
|
||||||
|
|||||||
66
tests-ng/import-ignore-in-dotpath.sh
vendored
Executable file
66
tests-ng/import-ignore-in-dotpath.sh
vendored
Executable file
@@ -0,0 +1,66 @@
|
|||||||
|
#!/usr/bin/env bash
|
||||||
|
# author: deadc0de6 (https://github.com/deadc0de6)
|
||||||
|
# Copyright (c) 2023, deadc0de6
|
||||||
|
#
|
||||||
|
# test ignore import in dotpath
|
||||||
|
# returns 1 in case of error
|
||||||
|
#
|
||||||
|
|
||||||
|
## start-cookie
|
||||||
|
set -e
|
||||||
|
cur=$(cd "$(dirname "${0}")" && pwd)
|
||||||
|
ddpath="${cur}/../"
|
||||||
|
export PYTHONPATH="${ddpath}:${PYTHONPATH}"
|
||||||
|
altbin="python3 -m dotdrop.dotdrop"
|
||||||
|
if hash coverage 2>/dev/null; then
|
||||||
|
mkdir -p coverages/
|
||||||
|
altbin="coverage run -p --data-file coverages/coverage --source=dotdrop -m dotdrop.dotdrop"
|
||||||
|
fi
|
||||||
|
bin="${DT_BIN:-${altbin}}"
|
||||||
|
# shellcheck source=tests-ng/helpers
|
||||||
|
source "${cur}"/helpers
|
||||||
|
echo -e "$(tput setaf 6)==> RUNNING $(basename "${BASH_SOURCE[0]}") <==$(tput sgr0)"
|
||||||
|
## end-cookie
|
||||||
|
|
||||||
|
################################################################
|
||||||
|
# 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)
|
||||||
|
mkdir -p "${tmpd}"
|
||||||
|
#echo "dotfile destination: ${tmpd}"
|
||||||
|
|
||||||
|
clear_on_exit "${tmps}"
|
||||||
|
clear_on_exit "${tmpd}"
|
||||||
|
|
||||||
|
# create to-be-imported files
|
||||||
|
mkdir -p "${tmpd}"/test
|
||||||
|
echo 'original' > "${tmpd}"/test/config1
|
||||||
|
mkdir -p "${tmpd}"/test/ignoreme
|
||||||
|
echo 'original' > "${tmpd}"/test/ignoreme/config2
|
||||||
|
|
||||||
|
# create the config file
|
||||||
|
cfg="${tmps}/config.yaml"
|
||||||
|
cat > "${cfg}" << _EOF
|
||||||
|
config:
|
||||||
|
backup: false
|
||||||
|
create: true
|
||||||
|
dotpath: dotfiles
|
||||||
|
impignore:
|
||||||
|
- "ignoreme"
|
||||||
|
dotfiles:
|
||||||
|
profiles:
|
||||||
|
_EOF
|
||||||
|
|
||||||
|
# import
|
||||||
|
echo "[+] import"
|
||||||
|
cd "${ddpath}" | ${bin} import -c "${cfg}" -f --verbose --profile=p1 "${tmpd}"/test
|
||||||
|
|
||||||
|
[ -d "${tmps}"/dotfiles/"${tmpd}"/test/ignoreme ] && echo "ignoreme not ignored" && exit 1
|
||||||
|
|
||||||
|
echo "OK"
|
||||||
|
exit 0
|
||||||
65
tests-ng/update-ignore-in-dotpath.sh
vendored
Executable file
65
tests-ng/update-ignore-in-dotpath.sh
vendored
Executable file
@@ -0,0 +1,65 @@
|
|||||||
|
#!/usr/bin/env bash
|
||||||
|
# author: deadc0de6 (https://github.com/deadc0de6)
|
||||||
|
# Copyright (c) 2023, deadc0de6
|
||||||
|
#
|
||||||
|
# test ignore update in dotpath
|
||||||
|
# returns 1 in case of error
|
||||||
|
#
|
||||||
|
|
||||||
|
## start-cookie
|
||||||
|
set -e
|
||||||
|
cur=$(cd "$(dirname "${0}")" && pwd)
|
||||||
|
ddpath="${cur}/../"
|
||||||
|
export PYTHONPATH="${ddpath}:${PYTHONPATH}"
|
||||||
|
altbin="python3 -m dotdrop.dotdrop"
|
||||||
|
if hash coverage 2>/dev/null; then
|
||||||
|
mkdir -p coverages/
|
||||||
|
altbin="coverage run -p --data-file coverages/coverage --source=dotdrop -m dotdrop.dotdrop"
|
||||||
|
fi
|
||||||
|
bin="${DT_BIN:-${altbin}}"
|
||||||
|
# shellcheck source=tests-ng/helpers
|
||||||
|
source "${cur}"/helpers
|
||||||
|
echo -e "$(tput setaf 6)==> RUNNING $(basename "${BASH_SOURCE[0]}") <==$(tput sgr0)"
|
||||||
|
## end-cookie
|
||||||
|
|
||||||
|
################################################################
|
||||||
|
# this is the test
|
||||||
|
################################################################
|
||||||
|
|
||||||
|
# dotdrop directory
|
||||||
|
tmps=$(mktemp -d --suffix='-dotdrop-tests' || mktemp -d)
|
||||||
|
# fs dotfiles
|
||||||
|
tmpd=$(mktemp -d --suffix='-dotdrop-tests' || mktemp -d)
|
||||||
|
dt="${tmps}/dotfiles"
|
||||||
|
mkdir -p "${dt}"
|
||||||
|
|
||||||
|
clear_on_exit "${tmps}"
|
||||||
|
clear_on_exit "${tmpd}"
|
||||||
|
|
||||||
|
# create to-be-imported files
|
||||||
|
mkdir -p "${tmpd}"/test
|
||||||
|
echo 'original' > "${tmpd}"/test/config1
|
||||||
|
mkdir -p "${tmpd}"/test/ignoreme
|
||||||
|
echo 'original' > "${tmpd}"/test/ignoreme/config2
|
||||||
|
|
||||||
|
# create the config file
|
||||||
|
cfg="${tmps}/config.yaml"
|
||||||
|
create_conf "${cfg}" # sets token
|
||||||
|
|
||||||
|
# import
|
||||||
|
echo "[+] import"
|
||||||
|
cd "${ddpath}" | ${bin} import -c "${cfg}" -f --verbose --profile=p1 "${tmpd}"/test
|
||||||
|
|
||||||
|
# remove ignoreme
|
||||||
|
echo "[+] remove ignoreme"
|
||||||
|
rm -r "${tmpd}"/test/ignoreme
|
||||||
|
|
||||||
|
# update
|
||||||
|
echo "[+] update"
|
||||||
|
cd "${ddpath}" | ${bin} update -f -c "${cfg}" --verbose --profile=p1 --key d_test
|
||||||
|
|
||||||
|
# check files haven't been updated
|
||||||
|
[ -d "${dt}"/"${tmpd}"/test/ignoreme ] && echo "ignoreme should have been removed" && exit 1
|
||||||
|
|
||||||
|
echo "OK"
|
||||||
|
exit 0
|
||||||
Reference in New Issue
Block a user