 Chromium Code Reviews
 Chromium Code Reviews Issue 23072039:
  Fix R= line rewriter to handle TBRs well.  (Closed) 
  Base URL: https://chromium.googlesource.com/chromium/tools/depot_tools.git@master
    
  
    Issue 23072039:
  Fix R= line rewriter to handle TBRs well.  (Closed) 
  Base URL: https://chromium.googlesource.com/chromium/tools/depot_tools.git@master| 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 676 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 687 # DownloadHooks(True) | 687 # DownloadHooks(True) | 
| 688 ((commit_msg_path, os.X_OK,), True), | 688 ((commit_msg_path, os.X_OK,), True), | 
| 689 ] | 689 ] | 
| 690 git_cl.main(['config']) | 690 git_cl.main(['config']) | 
| 691 | 691 | 
| 692 def test_update_reviewers(self): | 692 def test_update_reviewers(self): | 
| 693 data = [ | 693 data = [ | 
| 694 ('foo', [], 'foo'), | 694 ('foo', [], 'foo'), | 
| 695 ('foo', ['a@c'], 'foo\n\nR=a@c'), | 695 ('foo', ['a@c'], 'foo\n\nR=a@c'), | 
| 696 ('foo\nBUG=', ['a@c'], 'foo\nBUG=\nR=a@c'), | 696 ('foo\nBUG=', ['a@c'], 'foo\nBUG=\nR=a@c'), | 
| 697 ('foo\nR=xx\nTBR=yy\nR=bar', ['a@c'], 'foo\nTBR=a@c'), | 697 ('foo\nR=xx\nTBR=yy\nR=bar', ['a@c'], 'foo\nR=a@c, xx, bar\nTBR=yy'), | 
| 
M-A Ruel
2013/08/23 15:22:53
Add a test with no R= line, only a TBR= line and a
 
agable
2013/08/23 18:43:00
To go along with the refactoring, I added a bunch
 | |
| 698 ('foo', ['a@c', 'b@c'], 'foo\n\nR=a@c, b@c'), | 698 ('foo', ['a@c', 'b@c'], 'foo\n\nR=a@c, b@c'), | 
| 699 ('foo\nBar\n\nR=\nBUG=', ['c@c'], 'foo\nBar\n\nR=c@c\nBUG='), | 699 ('foo\nBar\n\nR=\nBUG=', ['c@c'], 'foo\nBar\n\nR=c@c\nBUG='), | 
| 700 ('foo\nBar\n\nR=\nBUG=\nR=', ['c@c'], 'foo\nBar\n\nR=c@c\nBUG='), | 700 ('foo\nBar\n\nR=\nBUG=\nR=', ['c@c'], 'foo\nBar\n\nR=c@c\nBUG='), | 
| 701 # Same as the line before, but full of whitespaces. | 701 # Same as the line before, but full of whitespaces. | 
| 702 ( | 702 ( | 
| 703 'foo\nBar\n\n R = \n BUG = \n R = ', ['c@c'], | 703 'foo\nBar\n\n R = \n BUG = \n R = ', ['c@c'], | 
| 704 'foo\nBar\n\nR=c@c\n BUG =', | 704 'foo\nBar\n\nR=c@c\n BUG =', | 
| 705 ), | 705 ), | 
| 706 # Whitespaces aren't interpreted as new lines. | 706 # Whitespaces aren't interpreted as new lines. | 
| 707 ('foo BUG=allo R=joe ', ['c@c'], 'foo BUG=allo R=joe\n\nR=c@c'), | 707 ('foo BUG=allo R=joe ', ['c@c'], 'foo BUG=allo R=joe\n\nR=c@c'), | 
| 708 ] | 708 ] | 
| 709 expected = [i[2] for i in data] | 709 expected = [i[2] for i in data] | 
| 710 actual = [] | 710 actual = [] | 
| 711 for orig, reviewers, _expected in data: | 711 for orig, reviewers, _expected in data: | 
| 712 obj = git_cl.ChangeDescription(orig) | 712 obj = git_cl.ChangeDescription(orig) | 
| 713 obj.update_reviewers(reviewers) | 713 obj.update_reviewers(reviewers) | 
| 714 actual.append(obj.description) | 714 actual.append(obj.description) | 
| 715 self.assertEqual(expected, actual) | 715 self.assertEqual(expected, actual) | 
| 716 | 716 | 
| 717 | 717 | 
| 718 if __name__ == '__main__': | 718 if __name__ == '__main__': | 
| 719 git_cl.logging.basicConfig( | 719 git_cl.logging.basicConfig( | 
| 720 level=git_cl.logging.DEBUG if '-v' in sys.argv else git_cl.logging.ERROR) | 720 level=git_cl.logging.DEBUG if '-v' in sys.argv else git_cl.logging.ERROR) | 
| 721 unittest.main() | 721 unittest.main() | 
| OLD | NEW |