| OLD | NEW | 
|---|
| 1 #!/usr/bin/env python | 1 #!/usr/bin/env python | 
| 2 # Copyright (c) 2012 The Chromium Authors. All rights reserved. | 2 # Copyright (c) 2012 The Chromium Authors. All rights reserved. | 
| 3 # Use of this source code is governed by a BSD-style license that can be | 3 # Use of this source code is governed by a BSD-style license that can be | 
| 4 # found in the LICENSE file. | 4 # found in the LICENSE file. | 
| 5 | 5 | 
| 6 """Unit tests for git_cl.py.""" | 6 """Unit tests for git_cl.py.""" | 
| 7 | 7 | 
| 8 import os | 8 import os | 
| 9 import StringIO | 9 import StringIO | 
| 10 import stat | 10 import stat | 
| (...skipping 295 matching lines...) Expand 10 before | Expand all | Expand 10 after  Loading... | 
| 306       ((['git', 'config', 'branch.master.rietveldissue'],), ''), | 306       ((['git', 'config', 'branch.master.rietveldissue'],), ''), | 
| 307       ((['git', 'config', 'branch.master.gerritissue'],), ''), | 307       ((['git', 'config', 'branch.master.gerritissue'],), ''), | 
| 308       ((['git', 'config', 'rietveld.server'],), | 308       ((['git', 'config', 'rietveld.server'],), | 
| 309        'codereview.example.com'), | 309        'codereview.example.com'), | 
| 310       ((['git', 'config', 'branch.master.merge'],), 'master'), | 310       ((['git', 'config', 'branch.master.merge'],), 'master'), | 
| 311       ((['git', 'config', 'branch.master.remote'],), 'origin'), | 311       ((['git', 'config', 'branch.master.remote'],), 'origin'), | 
| 312       ((['get_or_create_merge_base', 'master', 'master'],), | 312       ((['get_or_create_merge_base', 'master', 'master'],), | 
| 313        'fake_ancestor_sha'), | 313        'fake_ancestor_sha'), | 
| 314     ] + cls._git_sanity_checks('fake_ancestor_sha', 'master') + [ | 314     ] + cls._git_sanity_checks('fake_ancestor_sha', 'master') + [ | 
| 315       ((['git', 'rev-parse', '--show-cdup'],), ''), | 315       ((['git', 'rev-parse', '--show-cdup'],), ''), | 
| 316       ((['git', 'rev-parse', 'HEAD'],), '12345'), | 316       ((['git', 'rev-parse', 'refs/heads/master'],), '12345'), | 
| 317       ((['git', 'diff', '--name-status', '--no-renames', '-r', | 317       ((['git', 'diff', '--name-status', '--no-renames', '-r', | 
| 318          'fake_ancestor_sha...', '.'],), | 318          'fake_ancestor_sha...refs/heads/master', '.'],), | 
| 319         'M\t.gitignore\n'), | 319         'M\t.gitignore\n'), | 
| 320       ((['git', 'config', 'branch.master.rietveldpatchset'],), | 320       ((['git', 'config', 'branch.master.rietveldpatchset'],), | 
| 321        ''), | 321        ''), | 
| 322       ((['git', 'log', '--pretty=format:%s%n%n%b', | 322       ((['git', 'log', '--pretty=format:%s%n%n%b', | 
| 323          'fake_ancestor_sha...'],), | 323          'fake_ancestor_sha...refs/heads/master'],), | 
| 324        'foo'), | 324        'foo'), | 
| 325       ((['git', 'config', 'user.email'],), 'me@example.com'), | 325       ((['git', 'config', 'user.email'],), 'me@example.com'), | 
| 326       stat_call, | 326       stat_call, | 
| 327       ((['git', 'log', '--pretty=format:%s\n\n%b', | 327       ((['git', 'log', '--pretty=format:%s\n\n%b', | 
| 328          'fake_ancestor_sha..HEAD'],), | 328          'fake_ancestor_sha..HEAD'],), | 
| 329        'desc\n'), | 329        'desc\n'), | 
| 330       ((['git', 'config', 'rietveld.bug-prefix'],), ''), | 330       ((['git', 'config', 'rietveld.bug-prefix'],), ''), | 
| 331     ] | 331     ] | 
| 332 | 332 | 
| 333   @classmethod | 333   @classmethod | 
| (...skipping 42 matching lines...) Expand 10 before | Expand all | Expand 10 after  Loading... | 
| 376     ] | 376     ] | 
| 377 | 377 | 
| 378   @staticmethod | 378   @staticmethod | 
| 379   def _git_sanity_checks(diff_base, working_branch, get_remote_branch=True): | 379   def _git_sanity_checks(diff_base, working_branch, get_remote_branch=True): | 
| 380     fake_ancestor = 'fake_ancestor' | 380     fake_ancestor = 'fake_ancestor' | 
| 381     fake_cl = 'fake_cl_for_patch' | 381     fake_cl = 'fake_cl_for_patch' | 
| 382     return [ | 382     return [ | 
| 383       ((['git', | 383       ((['git', | 
| 384          'rev-parse', '--verify', diff_base],), fake_ancestor), | 384          'rev-parse', '--verify', diff_base],), fake_ancestor), | 
| 385       ((['git', | 385       ((['git', | 
| 386          'merge-base', fake_ancestor, 'HEAD'],), fake_ancestor), | 386          'merge-base', fake_ancestor, 'refs/heads/'+working_branch],), | 
|  | 387        fake_ancestor), | 
| 387       ((['git', | 388       ((['git', | 
| 388          'rev-list', '^' + fake_ancestor, 'HEAD'],), fake_cl), | 389          'rev-list', '^' + fake_ancestor, 'refs/heads/'+working_branch],), | 
|  | 390        fake_cl), | 
| 389       # Mock a config miss (error code 1) | 391       # Mock a config miss (error code 1) | 
| 390       ((['git', | 392       ((['git', | 
| 391          'config', 'gitcl.remotebranch'],), (('', None), 1)), | 393          'config', 'gitcl.remotebranch'],), (('', None), 1)), | 
| 392     ] + ([ | 394     ] + ([ | 
| 393       # Call to GetRemoteBranch() | 395       # Call to GetRemoteBranch() | 
| 394       ((['git', | 396       ((['git', | 
| 395          'config', 'branch.%s.merge' % working_branch],), | 397          'config', 'branch.%s.merge' % working_branch],), | 
| 396        'refs/heads/master'), | 398        'refs/heads/master'), | 
| 397       ((['git', | 399       ((['git', | 
| 398          'config', 'branch.%s.remote' % working_branch],), 'origin'), | 400          'config', 'branch.%s.remote' % working_branch],), 'origin'), | 
| (...skipping 43 matching lines...) Expand 10 before | Expand all | Expand 10 after  Loading... | 
| 442          '3fc18b62c4966193eb435baabe2d18a3810ec82e'), | 444          '3fc18b62c4966193eb435baabe2d18a3810ec82e'), | 
| 443       ((['git', | 445       ((['git', | 
| 444          'rev-list', '^3fc18b62c4966193eb435baabe2d18a3810ec82e', | 446          'rev-list', '^3fc18b62c4966193eb435baabe2d18a3810ec82e', | 
| 445          'refs/remotes/origin/master'],), ''), | 447          'refs/remotes/origin/master'],), ''), | 
| 446       ((['git', | 448       ((['git', | 
| 447          'merge-base', 'refs/remotes/origin/master', 'HEAD'],), | 449          'merge-base', 'refs/remotes/origin/master', 'HEAD'],), | 
| 448        'fake_ancestor_sha'), | 450        'fake_ancestor_sha'), | 
| 449     ] | 451     ] | 
| 450 | 452 | 
| 451   @classmethod | 453   @classmethod | 
| 452   def _dcommit_calls_normal(cls): | 454   def _dcommit_calls_normal(cls, working_branch='master'): | 
| 453     return [ | 455     return [ | 
| 454       ((['git', 'rev-parse', '--show-cdup'],), ''), | 456       ((['git', 'rev-parse', '--show-cdup'],), ''), | 
| 455       ((['git', 'rev-parse', 'HEAD'],), | 457       ((['git', 'rev-parse', 'refs/heads/'+working_branch],), | 
| 456           '00ff397798ea57439712ed7e04ab96e13969ef40'), | 458           '00ff397798ea57439712ed7e04ab96e13969ef40'), | 
| 457       ((['git', | 459       ((['git', | 
| 458          'diff', '--name-status', '--no-renames', '-r', 'fake_ancestor_sha...', | 460          'diff', '--name-status', '--no-renames', '-r', | 
| 459          '.'],), | 461          'fake_ancestor_sha...refs/heads/'+working_branch, '.'],), | 
| 460         'M\tPRESUBMIT.py'), | 462         'M\tPRESUBMIT.py'), | 
| 461       ((['git', | 463       ((['git', | 
| 462          'config', 'branch.working.rietveldpatchset'],), '31137'), | 464          'config', 'branch.working.rietveldpatchset'],), '31137'), | 
| 463       ((['git', 'config', 'branch.working.rietveldserver'],), | 465       ((['git', 'config', 'branch.working.rietveldserver'],), | 
| 464          'codereview.example.com'), | 466          'codereview.example.com'), | 
| 465       ((['git', 'config', 'user.email'],), 'author@example.com'), | 467       ((['git', 'config', 'user.email'],), 'author@example.com'), | 
| 466       ((['git', 'config', 'rietveld.tree-status-url'],), ''), | 468       ((['git', 'config', 'rietveld.tree-status-url'],), ''), | 
| 467   ] | 469   ] | 
| 468 | 470 | 
| 469   @classmethod | 471   @classmethod | 
| (...skipping 188 matching lines...) Expand 10 before | Expand all | Expand 10 after  Loading... | 
| 658           '--similarity.\n', | 660           '--similarity.\n', | 
| 659           stdout.getvalue()) | 661           stdout.getvalue()) | 
| 660       self.assertEqual( | 662       self.assertEqual( | 
| 661           'Must specify reviewers to send email.\n', stderr.getvalue()) | 663           'Must specify reviewers to send email.\n', stderr.getvalue()) | 
| 662 | 664 | 
| 663   def test_dcommit(self): | 665   def test_dcommit(self): | 
| 664     self.mock(git_cl.sys, 'stdout', StringIO.StringIO()) | 666     self.mock(git_cl.sys, 'stdout', StringIO.StringIO()) | 
| 665     self.calls = ( | 667     self.calls = ( | 
| 666         self._dcommit_calls_1() + | 668         self._dcommit_calls_1() + | 
| 667         self._git_sanity_checks('fake_ancestor_sha', 'working') + | 669         self._git_sanity_checks('fake_ancestor_sha', 'working') + | 
| 668         self._dcommit_calls_normal() + | 670         self._dcommit_calls_normal('working') + | 
| 669         self._dcommit_calls_3()) | 671         self._dcommit_calls_3()) | 
| 670     git_cl.main(['dcommit']) | 672     git_cl.main(['dcommit']) | 
| 671 | 673 | 
| 672   def test_dcommit_bypass_hooks(self): | 674   def test_dcommit_bypass_hooks(self): | 
| 673     self.mock(git_cl.sys, 'stdout', StringIO.StringIO()) | 675     self.mock(git_cl.sys, 'stdout', StringIO.StringIO()) | 
| 674     self.calls = ( | 676     self.calls = ( | 
| 675         self._dcommit_calls_1() + | 677         self._dcommit_calls_1() + | 
| 676         self._dcommit_calls_bypassed() + | 678         self._dcommit_calls_bypassed() + | 
| 677         self._dcommit_calls_3()) | 679         self._dcommit_calls_3()) | 
| 678     git_cl.main(['dcommit', '--bypass-hooks']) | 680     git_cl.main(['dcommit', '--bypass-hooks']) | 
| (...skipping 37 matching lines...) Expand 10 before | Expand all | Expand 10 after  Loading... | 
| 716         ((['git', 'config', 'branch.master.merge'],), 'refs/heads/master'), | 718         ((['git', 'config', 'branch.master.merge'],), 'refs/heads/master'), | 
| 717         ((['git', 'config', 'branch.master.remote'],), 'origin'), | 719         ((['git', 'config', 'branch.master.remote'],), 'origin'), | 
| 718         ((['get_or_create_merge_base', 'master', | 720         ((['get_or_create_merge_base', 'master', | 
| 719            'refs/remotes/origin/master'],), | 721            'refs/remotes/origin/master'],), | 
| 720          'fake_ancestor_sha'), | 722          'fake_ancestor_sha'), | 
| 721         # Calls to verify branch point is ancestor | 723         # Calls to verify branch point is ancestor | 
| 722       ] + (cls._gerrit_ensure_auth_calls(issue=issue) + | 724       ] + (cls._gerrit_ensure_auth_calls(issue=issue) + | 
| 723            cls._git_sanity_checks('fake_ancestor_sha', 'master', | 725            cls._git_sanity_checks('fake_ancestor_sha', 'master', | 
| 724                                   get_remote_branch=False)) + [ | 726                                   get_remote_branch=False)) + [ | 
| 725         ((['git', 'rev-parse', '--show-cdup'],), ''), | 727         ((['git', 'rev-parse', '--show-cdup'],), ''), | 
| 726         ((['git', 'rev-parse', 'HEAD'],), '12345'), | 728         ((['git', 'rev-parse', 'refs/heads/master'],), '12345'), | 
| 727 | 729 | 
| 728         ((['git', | 730         ((['git', | 
| 729            'diff', '--name-status', '--no-renames', '-r', | 731            'diff', '--name-status', '--no-renames', '-r', | 
| 730            'fake_ancestor_sha...', '.'],), | 732            'fake_ancestor_sha...refs/heads/master', '.'],), | 
| 731          'M\t.gitignore\n'), | 733          'M\t.gitignore\n'), | 
| 732         ((['git', 'config', 'branch.master.gerritpatchset'],), ''), | 734         ((['git', 'config', 'branch.master.gerritpatchset'],), ''), | 
| 733       ] + ([] if issue else [ | 735       ] + ([] if issue else [ | 
| 734         ((['git', | 736         ((['git', | 
| 735            'log', '--pretty=format:%s%n%n%b', 'fake_ancestor_sha...'],), | 737            'log', '--pretty=format:%s%n%n%b', | 
|  | 738            'fake_ancestor_sha...refs/heads/master'],), | 
| 736          'foo'), | 739          'foo'), | 
| 737       ]) + [ | 740       ]) + [ | 
| 738         ((['git', 'config', 'user.email'],), 'me@example.com'), | 741         ((['git', 'config', 'user.email'],), 'me@example.com'), | 
| 739         ((['git', | 742         ((['git', | 
| 740            'diff', '--no-ext-diff', '--stat', '--find-copies-harder', | 743            'diff', '--no-ext-diff', '--stat', '--find-copies-harder', | 
| 741            '-l100000', '-C50', 'fake_ancestor_sha', 'HEAD'],), | 744            '-l100000', '-C50', 'fake_ancestor_sha', 'HEAD'],), | 
| 742          '+dat'), | 745          '+dat'), | 
| 743       ] | 746       ] | 
| 744 | 747 | 
| 745   @classmethod | 748   @classmethod | 
| (...skipping 629 matching lines...) Expand 10 before | Expand all | Expand 10 after  Loading... | 
| 1375     # TODO(tandrii): consider testing just set-commit and set-commit --clear, | 1378     # TODO(tandrii): consider testing just set-commit and set-commit --clear, | 
| 1376     # but without copy-pasting tons of expectations, as modifying them later is | 1379     # but without copy-pasting tons of expectations, as modifying them later is | 
| 1377     # super tedious. | 1380     # super tedious. | 
| 1378     self.assertEqual(0, git_cl.main(['set-commit', '-d'])) | 1381     self.assertEqual(0, git_cl.main(['set-commit', '-d'])) | 
| 1379 | 1382 | 
| 1380 | 1383 | 
| 1381 if __name__ == '__main__': | 1384 if __name__ == '__main__': | 
| 1382   git_cl.logging.basicConfig( | 1385   git_cl.logging.basicConfig( | 
| 1383       level=git_cl.logging.DEBUG if '-v' in sys.argv else git_cl.logging.ERROR) | 1386       level=git_cl.logging.DEBUG if '-v' in sys.argv else git_cl.logging.ERROR) | 
| 1384   unittest.main() | 1387   unittest.main() | 
| OLD | NEW | 
|---|