Tar --diff only sends output to stderr if a file is missing. Handle that case

Fixes #1064
This commit is contained in:
Toshio Kuratomi 2015-04-15 05:05:41 -07:00
parent b668ecc4a3
commit 761fc8d277

View file

@ -75,9 +75,14 @@ EXAMPLES = '''
- unarchive: src=/tmp/foo.zip dest=/usr/local/bin copy=no - unarchive: src=/tmp/foo.zip dest=/usr/local/bin copy=no
''' '''
import re
import os import os
from zipfile import ZipFile from zipfile import ZipFile
# String from tar that shows the tar contents are different from the
# filesystem
DIFFERENCE_RE = re.compile(r': (.*) differs$')
class UnarchiveError(Exception): class UnarchiveError(Exception):
pass pass
@ -168,9 +173,12 @@ class TgzArchive(object):
# What is different # What is different
changes = set() changes = set()
difference_re = re.compile(r': (.*) differs$') if err:
# Assume changes if anything returned on stderr
# * Missing files are known to trigger this
return dict(unarchived=unarchived, rc=rc, out=out, err=err, cmd=cmd)
for line in out.splitlines(): for line in out.splitlines():
match = difference_re.search(line) match = DIFFERENCE_RE.search(line)
if not match: if not match:
# Unknown tar output. Assume we have changes # Unknown tar output. Assume we have changes
return dict(unarchived=unarchived, rc=rc, out=out, err=err, cmd=cmd) return dict(unarchived=unarchived, rc=rc, out=out, err=err, cmd=cmd)