mirror of
https://github.com/deadc0de6/dotdrop.git
synced 2026-02-13 01:05:13 +00:00
fix update issue with rights for #197
This commit is contained in:
@@ -148,6 +148,22 @@ class Updater:
|
|||||||
self.templater.restore_vars(self.tvars)
|
self.templater.restore_vars(self.tvars)
|
||||||
return self.templater.generate(tpath)
|
return self.templater.generate(tpath)
|
||||||
|
|
||||||
|
def _same_rights(self, left, right):
|
||||||
|
"""return True if files have the same modes"""
|
||||||
|
try:
|
||||||
|
l = os.stat(left)
|
||||||
|
r = os.stat(right)
|
||||||
|
return l.st_mode == r.st_mode
|
||||||
|
except OSError as e:
|
||||||
|
return False
|
||||||
|
|
||||||
|
def _mirror_rights(self, src, dst):
|
||||||
|
try:
|
||||||
|
rights = os.stat(src).st_mode
|
||||||
|
os.chmod(dst, rights)
|
||||||
|
except OSError as e:
|
||||||
|
self.log.err(e)
|
||||||
|
|
||||||
def _handle_file(self, path, dtpath, compare=True):
|
def _handle_file(self, path, dtpath, compare=True):
|
||||||
"""sync path (deployed file) and dtpath (dotdrop dotfile path)"""
|
"""sync path (deployed file) and dtpath (dotdrop dotfile path)"""
|
||||||
if self._ignore([path, dtpath]):
|
if self._ignore([path, dtpath]):
|
||||||
@@ -162,7 +178,8 @@ class Updater:
|
|||||||
if self.showpatch:
|
if self.showpatch:
|
||||||
self._show_patch(path, dtpath)
|
self._show_patch(path, dtpath)
|
||||||
return False
|
return False
|
||||||
if compare and filecmp.cmp(path, dtpath, shallow=True):
|
if compare and filecmp.cmp(path, dtpath, shallow=False) and \
|
||||||
|
self._same_rights(path, dtpath):
|
||||||
# no difference
|
# no difference
|
||||||
if self.debug:
|
if self.debug:
|
||||||
self.log.dbg('identical files: {} and {}'.format(path, dtpath))
|
self.log.dbg('identical files: {} and {}'.format(path, dtpath))
|
||||||
@@ -176,6 +193,7 @@ class Updater:
|
|||||||
if self.debug:
|
if self.debug:
|
||||||
self.log.dbg('cp {} {}'.format(path, dtpath))
|
self.log.dbg('cp {} {}'.format(path, dtpath))
|
||||||
shutil.copyfile(path, dtpath)
|
shutil.copyfile(path, dtpath)
|
||||||
|
self._mirror_rights(path, dtpath)
|
||||||
self.log.sub('\"{}\" updated'.format(dtpath))
|
self.log.sub('\"{}\" updated'.format(dtpath))
|
||||||
except IOError as e:
|
except IOError as e:
|
||||||
self.log.warn('{} update failed, do manually: {}'.format(path, e))
|
self.log.warn('{} update failed, do manually: {}'.format(path, e))
|
||||||
@@ -275,6 +293,7 @@ class Updater:
|
|||||||
if self.debug:
|
if self.debug:
|
||||||
self.log.dbg('cp {} {}'.format(exist, new))
|
self.log.dbg('cp {} {}'.format(exist, new))
|
||||||
shutil.copyfile(exist, new)
|
shutil.copyfile(exist, new)
|
||||||
|
self._mirror_rights(exist, new)
|
||||||
self.log.sub('\"{}\" added'.format(new))
|
self.log.sub('\"{}\" added'.format(new))
|
||||||
|
|
||||||
# remove files that don't exist in deployed version
|
# remove files that don't exist in deployed version
|
||||||
@@ -295,6 +314,13 @@ class Updater:
|
|||||||
remove(new)
|
remove(new)
|
||||||
self.log.sub('\"{}\" removed'.format(new))
|
self.log.sub('\"{}\" removed'.format(new))
|
||||||
|
|
||||||
|
# compare rights
|
||||||
|
for common in diff.common_files:
|
||||||
|
l = os.path.join(left, common)
|
||||||
|
r = os.path.join(right, common)
|
||||||
|
if not self._same_rights(l, r):
|
||||||
|
self._mirror_rights(l, r)
|
||||||
|
|
||||||
# Recursively decent into common subdirectories.
|
# Recursively decent into common subdirectories.
|
||||||
for subdir in diff.subdirs.values():
|
for subdir in diff.subdirs.values():
|
||||||
self._merge_dirs(subdir)
|
self._merge_dirs(subdir)
|
||||||
|
|||||||
101
tests-ng/update-rights.sh
Executable file
101
tests-ng/update-rights.sh
Executable file
@@ -0,0 +1,101 @@
|
|||||||
|
#!/usr/bin/env bash
|
||||||
|
# author: deadc0de6 (https://github.com/deadc0de6)
|
||||||
|
# Copyright (c) 2019, deadc0de6
|
||||||
|
#
|
||||||
|
# test updates and rights
|
||||||
|
# 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 -e "$(tput setaf 6)==> RUNNING $(basename $BASH_SOURCE) <==$(tput sgr0)"
|
||||||
|
|
||||||
|
################################################################
|
||||||
|
# this is the test
|
||||||
|
################################################################
|
||||||
|
|
||||||
|
# dotdrop directory
|
||||||
|
basedir=`mktemp -d --suffix='-dotdrop-tests' || mktemp -d`
|
||||||
|
echo "[+] dotdrop dir: ${basedir}"
|
||||||
|
echo "[+] dotpath dir: ${basedir}/dotfiles"
|
||||||
|
|
||||||
|
# the dotfile directory to be imported
|
||||||
|
tmpd=`mktemp -d --suffix='-dotdrop-tests' || mktemp -d`
|
||||||
|
# the dotfile file to be imported
|
||||||
|
tmpf=`mktemp`
|
||||||
|
|
||||||
|
# single file
|
||||||
|
echo 'file' > ${tmpf}
|
||||||
|
|
||||||
|
mkdir ${tmpd}/dir1
|
||||||
|
echo 'dir1file1' > ${tmpd}/dir1/file1
|
||||||
|
echo 'dir1file2' > ${tmpd}/dir1/file2
|
||||||
|
|
||||||
|
# create the config file
|
||||||
|
cfg="${basedir}/config.yaml"
|
||||||
|
create_conf ${cfg} # sets token
|
||||||
|
|
||||||
|
# import dir1
|
||||||
|
echo "[+] import"
|
||||||
|
cd ${ddpath} | ${bin} import -c ${cfg} ${tmpd}
|
||||||
|
cd ${ddpath} | ${bin} import -c ${cfg} ${tmpf}
|
||||||
|
|
||||||
|
# change file
|
||||||
|
chmod +x ${tmpf}
|
||||||
|
|
||||||
|
# update
|
||||||
|
echo "[+] updating"
|
||||||
|
cd ${ddpath} | ${bin} update -c ${cfg} -f --verbose ${tmpf}
|
||||||
|
|
||||||
|
# test change applied
|
||||||
|
[ "`stat -c '%a' ${tmpf}`" != "`stat -c '%a' ${basedir}/dotfiles/${tmpf}`" ] && exit 1
|
||||||
|
|
||||||
|
# change file
|
||||||
|
chmod +x ${tmpd}/dir1/file2
|
||||||
|
echo 'test' > ${tmpd}/dir1/newfile
|
||||||
|
chmod +x ${tmpd}/dir1/newfile
|
||||||
|
|
||||||
|
# update
|
||||||
|
echo "[+] updating"
|
||||||
|
cd ${ddpath} | ${bin} update -c ${cfg} -f --verbose ${tmpd}
|
||||||
|
|
||||||
|
# test change applied
|
||||||
|
[ "`stat -c '%a' ${tmpd}/dir1/newfile`" != "`stat -c '%a' ${basedir}/dotfiles/${tmpd}/dir1/newfile`" ] && exit 1
|
||||||
|
[ "`stat -c '%a' ${tmpd}/dir1/file2`" != "`stat -c '%a' ${basedir}/dotfiles/${tmpd}/dir1/file2`" ] && exit 1
|
||||||
|
|
||||||
|
## CLEANING
|
||||||
|
rm -rf ${basedir} ${tmpd}
|
||||||
|
|
||||||
|
echo "OK"
|
||||||
|
exit 0
|
||||||
Reference in New Issue
Block a user