Merge pull request #529 from davehatton/error_trapping_md5
improve error trapping for md5
This commit is contained in:
commit
035b9535db
2 changed files with 25 additions and 21 deletions
42
library/copy
42
library/copy
|
@ -37,6 +37,10 @@ def exit_kv(rc=0, **kwargs):
|
||||||
print dump_kv(kwargs)
|
print dump_kv(kwargs)
|
||||||
sys.exit(rc)
|
sys.exit(rc)
|
||||||
|
|
||||||
|
def md5_sum(f):
|
||||||
|
md5sum = os.popen("/usr/bin/md5sum %(file)s 2>/dev/null || /sbin/md5 -q %(file)s 2>/dev/null || /usr/bin/digest -a md5 -v %(file)s 2>/dev/null" % {"file": f}).read().split()[0]
|
||||||
|
return md5sum
|
||||||
|
|
||||||
if len(sys.argv) == 1:
|
if len(sys.argv) == 1:
|
||||||
exit_kv(rc=1, failed=1, msg="incorrect number of arguments given")
|
exit_kv(rc=1, failed=1, msg="incorrect number of arguments given")
|
||||||
|
|
||||||
|
@ -64,31 +68,31 @@ if dest:
|
||||||
|
|
||||||
# raise an error if there is no src file
|
# raise an error if there is no src file
|
||||||
if not os.path.exists(src):
|
if not os.path.exists(src):
|
||||||
exit_kv(rc=1, failed=1, msg="Source %s failed to transfer" % (src))
|
exit_kv(rc=1, failed=1, msg="Source %s failed to transfer" % (src))
|
||||||
|
|
||||||
if os.path.exists(dest):
|
# raise an error if there is no dest file
|
||||||
# raise an error if copy has no permission on dest
|
if not os.path.exists(dest):
|
||||||
if not os.access(dest, os.W_OK):
|
exit_kv(rc=1, failed=1, msg="Destination %s does not exist" % (dest))
|
||||||
exit_kv(rc=1, failed=1, msg="Destination %s not writable" % (dest))
|
|
||||||
elif not os.access(dest, os.R_OK):
|
|
||||||
exit_kv(rc=1, failed=1, msg="Destination %s not readable" % (dest))
|
|
||||||
else:
|
|
||||||
if not os.access(os.path.dirname(dest), os.W_OK):
|
|
||||||
exit_kv(rc=1, failed=1, msg="Destination %s not writable" % (dest))
|
|
||||||
|
|
||||||
md5sum = None
|
# raise an error if copy has no permission on dest
|
||||||
changed = False
|
if not os.access(dest, os.W_OK):
|
||||||
if os.path.exists(dest):
|
exit_kv(rc=1, failed=1, msg="Destination %s not writable" % (dest))
|
||||||
md5sum = os.popen("/usr/bin/md5sum %(file)s 2> /dev/null || /sbin/md5 -q %(file)s" % {"file": dest}).read().split()[0]
|
elif not os.access(dest, os.R_OK):
|
||||||
|
exit_kv(rc=1, failed=1, msg="Destination %s not readable" % (dest))
|
||||||
|
|
||||||
md5sum2 = os.popen("/usr/bin/md5sum %(file)s 2> /dev/null || /sbin/md5 -q %(file)s" % {"file": src}).read().split()[0]
|
md5sum_src = None
|
||||||
|
md5sum_src = md5_sum(src)
|
||||||
|
|
||||||
if md5sum != md5sum2:
|
md5sum_dest = None
|
||||||
|
md5sum_dest = md5_sum(dest)
|
||||||
|
|
||||||
|
if md5sum_src != md5sum_dest:
|
||||||
os.system("cp %s %s" % (src, dest))
|
os.system("cp %s %s" % (src, dest))
|
||||||
changed = True
|
changed = True
|
||||||
|
else:
|
||||||
|
changed = False
|
||||||
|
|
||||||
# mission accomplished
|
# mission accomplished
|
||||||
#print "md5sum=%s changed=%s" % (md5sum2, changed)
|
#print "md5sum=%s changed=%s" % (md5sum_dest, changed)
|
||||||
exit_kv(dest=dest, src=src, changed="md5sum=%s changed=%s" % (md5sum2, changed))
|
exit_kv(dest=dest, src=src, changed="md5sum=%s changed=%s" % (md5sum_dest, changed))
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -312,7 +312,7 @@ def ansible_facts():
|
||||||
return facts
|
return facts
|
||||||
|
|
||||||
def md5_sum(f):
|
def md5_sum(f):
|
||||||
md5sum = os.popen("/usr/bin/md5sum %(file)s 2> /dev/null || /sbin/md5 -q %(file)s 2> /dev/null || /usr/bin/digest -a md5 -v %(file)s" % {"file": f}).read().split()[0]
|
md5sum = os.popen("/usr/bin/md5sum %(file)s 2>/dev/null || /sbin/md5 -q %(file)s 2>/dev/null || /usr/bin/digest -a md5 -v %(file)s 2>/dev/null" % {"file": f}).read().split()[0]
|
||||||
return md5sum
|
return md5sum
|
||||||
|
|
||||||
# load config & template variables
|
# load config & template variables
|
||||||
|
|
Loading…
Add table
Reference in a new issue