Commit 63ebf04d authored by maruel@chromium.org's avatar maruel@chromium.org

Fix the way the temporary directory is created.

It is much cleaner and works for cases where the directory is not writeable.

Also fix an unrelated unit test.

Review URL: http://codereview.chromium.org/464068

git-svn-id: svn://svn.chromium.org/chrome/trunk/tools/depot_tools@34080 0039d316-1c4b-4281-b951-d872f2087c98
parent 745435c3
...@@ -715,6 +715,13 @@ def GenerateDiff(files, root=None): ...@@ -715,6 +715,13 @@ def GenerateDiff(files, root=None):
else: else:
os.chdir(root) os.chdir(root)
# If the user specified a custom diff command in their svn config file,
# then it'll be used when we do svn diff, which we don't want to happen
# since we want the unified diff. Using --diff-cmd=diff doesn't always
# work, since they can have another diff executable in their path that
# gives different line endings. So we use a bogus temp directory as the
# config directory, which gets around these problems.
bogus_dir = tempfile.mkdtemp()
diff = [] diff = []
for filename in files: for filename in files:
# TODO(maruel): Use SVN.DiffItem(). # TODO(maruel): Use SVN.DiffItem().
...@@ -722,19 +729,6 @@ def GenerateDiff(files, root=None): ...@@ -722,19 +729,6 @@ def GenerateDiff(files, root=None):
# when the file is deleted. # when the file is deleted.
if SVN.CaptureInfo(filename).get('Node Kind') == 'directory': if SVN.CaptureInfo(filename).get('Node Kind') == 'directory':
continue continue
# If the user specified a custom diff command in their svn config file,
# then it'll be used when we do svn diff, which we don't want to happen
# since we want the unified diff. Using --diff-cmd=diff doesn't always
# work, since they can have another diff executable in their path that
# gives different line endings. So we use a bogus temp directory as the
# config directory, which gets around these problems.
if sys.platform.startswith("win"):
parent_dir = tempfile.gettempdir()
else:
parent_dir = sys.path[0] # tempdir is not secure.
bogus_dir = os.path.join(parent_dir, "temp_svn_config")
if not os.path.exists(bogus_dir):
os.mkdir(bogus_dir)
output = RunShell(["svn", "diff", "--config-dir", bogus_dir, filename]) output = RunShell(["svn", "diff", "--config-dir", bogus_dir, filename])
if output: if output:
diff.append(output) diff.append(output)
...@@ -745,6 +739,7 @@ def GenerateDiff(files, root=None): ...@@ -745,6 +739,7 @@ def GenerateDiff(files, root=None):
else: else:
# The file is not modified anymore. It should be removed from the set. # The file is not modified anymore. It should be removed from the set.
pass pass
shutil.rmtree(bogus_dir)
os.chdir(previous_cwd) os.chdir(previous_cwd)
return "".join(diff) return "".join(diff)
......
...@@ -41,7 +41,8 @@ class GclUnittest(GclTestsBase): ...@@ -41,7 +41,8 @@ class GclUnittest(GclTestsBase):
'OptionallyDoPresubmitChecks', 'PresubmitCL', 'REPOSITORY_ROOT', 'OptionallyDoPresubmitChecks', 'PresubmitCL', 'REPOSITORY_ROOT',
'ReadFile', 'RunShell', 'RunShellWithReturnCode', 'SVN', 'ReadFile', 'RunShell', 'RunShellWithReturnCode', 'SVN',
'SendToRietveld', 'TryChange', 'UnknownFiles', 'UploadCL', 'Warn', 'SendToRietveld', 'TryChange', 'UnknownFiles', 'UploadCL', 'Warn',
'WriteFile', 'gclient_utils', 'getpass', 'main', 'os', 'random', 're', 'WriteFile',
'breakpad', 'gclient_utils', 'getpass', 'main', 'os', 'random', 're',
'shutil', 'string', 'subprocess', 'sys', 'tempfile', 'upload', 'shutil', 'string', 'subprocess', 'sys', 'tempfile', 'upload',
'urllib2', 'urllib2',
] ]
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment