Chromium Code Reviews| Index: tests/gclient_smoketest.py |
| diff --git a/tests/gclient_smoketest.py b/tests/gclient_smoketest.py |
| index c05bbf339de4f23118bb331f71976d199f1db9a0..148cff417aea0391256ae42a06a866906cd9da57 100755 |
| --- a/tests/gclient_smoketest.py |
| +++ b/tests/gclient_smoketest.py |
| @@ -13,6 +13,7 @@ This test assumes GClientSmokeBase.URL_BASE is valid. |
| import logging |
| import os |
| import re |
| +import socket |
| import subprocess |
| import sys |
| import unittest |
| @@ -776,7 +777,7 @@ class GClientSmokeSVN(GClientSmokeBase): |
| # Cripple src/third_party/foo and make sure gclient still succeeds. |
| gclient_utils.rmtree(join(third_party, 'foo', '.svn')) |
| - self.assertEquals(0, self.gclient(cmd)[-1]) |
| + self.assertEquals(0, self.gclient(cmd + ['--force'])[-1]) |
| class GClientSmokeSVNTransitive(GClientSmokeBase): |
| @@ -1103,7 +1104,7 @@ class GClientSmokeGIT(GClientSmokeBase): |
| self.assertTree(tree) |
| # Pre-DEPS hooks run when syncing with --nohooks. |
| - self.gclient(['sync', '--deps', 'mac', '--nohooks', |
| + self.gclient(['sync', '--deps', 'mac', '--nohooks', '--force', |
| '--revision', 'src@' + self.githash('repo_5', 2)]) |
| tree = self.mangle_git_tree(('repo_5@2', 'src'), |
| ('repo_1@2', 'src/repo1'), |
| @@ -1115,7 +1116,7 @@ class GClientSmokeGIT(GClientSmokeBase): |
| os.remove(join(self.root_dir, 'src', 'git_pre_deps_hooked')) |
| # Pre-DEPS hooks don't run with --noprehooks |
| - self.gclient(['sync', '--deps', 'mac', '--noprehooks', |
| + self.gclient(['sync', '--deps', 'mac', '--noprehooks', '--force', |
| '--revision', 'src@' + self.githash('repo_5', 2)]) |
| tree = self.mangle_git_tree(('repo_5@2', 'src'), |
| ('repo_1@2', 'src/repo1'), |
| @@ -1343,6 +1344,80 @@ class GClientSmokeBoth(GClientSmokeBase): |
| self.assertEquals(sorted(entries), sorted(expected)) |
| + # TODO(borenet): Enable this at the same time that the guard is removed in |
| + # gclient. |
| + if (os.environ.get('CHROME_HEADLESS') and |
| + socket.gethostname() in ('vm859-m1', 'build1-m1', 'vm630-m1')): |
|
borenet
2014/01/14 21:49:45
This is very, very stupid, but since there's a gua
iannucci
2014/01/14 22:40:02
What about mocking socket.gethostname to return 'v
M-A Ruel
2014/01/14 22:46:09
Mock enable_deletion_of_conflicting_checkouts inst
borenet
2014/01/15 13:53:27
These are much better solutions. Unfortunately, s
|
| + def testDeleteConflictingCheckout(self): |
| + if not self.enabled: |
| + return |
| + |
| + # Create an initial svn checkout. |
| + self.gclient(['config', '--spec', |
| + 'solutions=[' |
| + '{"name": "src",' |
| + ' "url": "' + self.svn_base + 'trunk/src"},' |
| + ']' |
| + ]) |
| + results = self.gclient(['sync', '--deps', 'mac']) |
| + self.assertEqual(results[2], 0, 'Sync failed!') |
| + |
| + # Verify that we have the expected svn checkout. |
| + results = self.gclient(['revinfo', '--deps', 'mac']) |
| + actual = results[0].splitlines() |
| + expected = [ |
| + 'src: %strunk/src' % self.svn_base, |
| + 'src/file/other: File("%strunk/other/DEPS")' % self.svn_base, |
| + 'src/other: %strunk/other' % self.svn_base, |
| + 'src/third_party/foo: %strunk/third_party/foo@1' % self.svn_base, |
| + ] |
| + self.assertEquals(actual, expected) |
| + |
| + # Change the desired checkout to git. |
| + self.gclient(['config', '--spec', |
| + 'solutions=[' |
| + '{"name": "src",' |
| + ' "url": "' + self.git_base + 'repo_1"},' |
| + ']' |
| + ]) |
| + |
| + # Verify that the sync succeeds with --force. |
| + results = self.gclient(['sync', '--deps', 'mac', '--force']) |
| + self.assertEqual(results[2], 0, 'Sync failed!') |
| + |
| + # Verify that we got the desired git checkout. |
| + results = self.gclient(['revinfo', '--deps', 'mac']) |
| + actual = results[0].splitlines() |
| + expected = [ |
| + 'src: %srepo_1' % self.git_base, |
| + 'src/repo2: %srepo_2@%s' % (self.git_base, self.githash('repo_2', 1)[:7]), |
|
M-A Ruel
2014/01/14 22:46:09
80 cols
|
| + 'src/repo2/repo_renamed: %srepo_3' % self.git_base, |
| + ] |
| + self.assertEquals(actual, expected) |
| + |
| + # Change the desired checkout back to svn. |
| + self.gclient(['config', '--spec', |
| + 'solutions=[' |
| + '{"name": "src",' |
| + ' "url": "' + self.svn_base + 'trunk/src"},' |
| + ']' |
| + ]) |
| + |
| + # Verify that the sync succeeds. |
| + results = self.gclient(['sync', '--deps', 'mac', '--force']) |
| + self.assertEqual(results[2], 0, 'Sync failed!') |
| + |
| + # Verify that we have the expected svn checkout. |
| + results = self.gclient(['revinfo', '--deps', 'mac']) |
| + actual = results[0].splitlines() |
| + expected = [ |
| + 'src: %strunk/src' % self.svn_base, |
| + 'src/file/other: File("%strunk/other/DEPS")' % self.svn_base, |
| + 'src/other: %strunk/other' % self.svn_base, |
| + 'src/third_party/foo: %strunk/third_party/foo@1' % self.svn_base, |
| + ] |
| + self.assertEquals(actual, expected) |
| + |
| class GClientSmokeFromCheckout(GClientSmokeBase): |
| # WebKit abuses this. It has a .gclient and a DEPS from a checkout. |