blob: a9402fb273eb83b0984f2f83f3c9e5415e8cb3d7 [file] [log] [blame]
Steven Bennettsddf9bcd2017-06-14 14:07:43 -07001# Copyright 2017 The Chromium OS Authors. All rights reserved.
2# Use of this source code is governed by a BSD-style license that can be
3# found in the LICENSE file.
4
5"""Unit tests for the chrome_chromeos_lkgm program."""
6
Steven Bennettsddf9bcd2017-06-14 14:07:43 -07007import os
Ben Pastene6a8361a2021-08-19 19:52:05 -07008from unittest import mock
Ben Pasteneca7c71b2021-10-07 18:34:27 -07009import urllib.parse
Steven Bennettsddf9bcd2017-06-14 14:07:43 -070010
Steven Bennettsddf9bcd2017-06-14 14:07:43 -070011from chromite.lib import constants
Steven Bennettsddf9bcd2017-06-14 14:07:43 -070012from chromite.lib import cros_test_lib
13from chromite.lib import osutils
14from chromite.lib import partial_mock
Steven Bennettsddf9bcd2017-06-14 14:07:43 -070015from chromite.scripts import chrome_chromeos_lkgm
16
Achuith Bhandarkarec8d7a72018-03-01 16:56:22 -080017
Steven Bennettsddf9bcd2017-06-14 14:07:43 -070018# pylint: disable=protected-access
Benjamin Gordon121a2aa2018-05-04 16:24:45 -060019class ChromeLKGMCommitterTester(cros_test_lib.RunCommandTestCase,
Achuith Bhandarkardc3a3512018-03-16 15:10:57 -070020 cros_test_lib.MockTempDirTestCase):
Steven Bennettsddf9bcd2017-06-14 14:07:43 -070021 """Test cros_chromeos_lkgm.Committer."""
Achuith Bhandarkarec8d7a72018-03-01 16:56:22 -080022
Achuith Bhandarkardc3a3512018-03-16 15:10:57 -070023 def setUp(self):
24 """Common set up method for all tests."""
25 self.committer = chrome_chromeos_lkgm.ChromeLKGMCommitter(
Achuith Bhandarkarb6f40252019-12-09 16:31:34 -080026 'user@test.org', self.tempdir, '1001.0.0')
Achuith Bhandarkardc3a3512018-03-16 15:10:57 -070027 self.lkgm_file = os.path.join(self.tempdir, constants.PATH_TO_CHROME_LKGM)
28 self.old_lkgm = None
Steven Bennettsddf9bcd2017-06-14 14:07:43 -070029
Achuith Bhandarkardc3a3512018-03-16 15:10:57 -070030 def _createOldLkgm(self, *args, **kwargs): # pylint: disable=unused-argument
Steven Bennettsd36fc782017-11-08 14:45:43 -080031 # Write out an old lkgm file as if we got it from a git fetch.
Achuith Bhandarkardc3a3512018-03-16 15:10:57 -070032 osutils.SafeMakedirs(os.path.join(self.tempdir, '.git', 'info'))
Steven Bennettsd36fc782017-11-08 14:45:43 -080033 osutils.SafeMakedirs(os.path.dirname(self.lkgm_file))
34 osutils.WriteFile(self.lkgm_file, self.old_lkgm)
35
Steven Bennettsddf9bcd2017-06-14 14:07:43 -070036 def testCheckoutChromeLKGM(self):
Mike Frysinger3ef6d972019-08-24 20:07:42 -040037 """Tests that we can read/obtain the old LKGM from mocked out git."""
Steven Bennettsd36fc782017-11-08 14:45:43 -080038 self.old_lkgm = '1234.0.0'
Achuith Bhandarkardc3a3512018-03-16 15:10:57 -070039 self.rc.AddCmdResult(partial_mock.In('remote'), returncode=0,
Steven Bennettsd36fc782017-11-08 14:45:43 -080040 side_effect=self._createOldLkgm)
Achuith Bhandarkardc3a3512018-03-16 15:10:57 -070041 self.committer.CheckoutChrome()
Achuith Bhandarkarec8d7a72018-03-01 16:56:22 -080042
43 self.assertEqual(self.committer.lkgm_file, self.lkgm_file)
Achuith Bhandarkardc3a3512018-03-16 15:10:57 -070044 self.assertEqual(osutils.ReadFile(self.lkgm_file), self.old_lkgm)
Steven Bennettsddf9bcd2017-06-14 14:07:43 -070045
46 def testCommitNewLKGM(self):
47 """Tests that we can commit a new LKGM file."""
Achuith Bhandarkardc3a3512018-03-16 15:10:57 -070048 self.old_lkgm = '999.0.0'
49 self.rc.AddCmdResult(partial_mock.In('remote'), returncode=0,
50 side_effect=self._createOldLkgm)
51 self.committer.CheckoutChrome()
Steven Bennettsddf9bcd2017-06-14 14:07:43 -070052
Achuith Bhandarkardc3a3512018-03-16 15:10:57 -070053 self.assertEqual(self.committer.lkgm_file, self.lkgm_file)
54
55 self.committer.UpdateLKGM()
Steven Bennettsddf9bcd2017-06-14 14:07:43 -070056 self.committer.CommitNewLKGM()
57
58 # Check the file was actually written out correctly.
59 self.assertEqual(osutils.ReadFile(self.lkgm_file), self.committer._lkgm)
60 self.assertCommandContains(['git', 'commit'])
Achuith Bhandarkardc3a3512018-03-16 15:10:57 -070061 self.assertEqual(self.committer._old_lkgm, self.old_lkgm)
Steven Bennettsddf9bcd2017-06-14 14:07:43 -070062
Steven Bennetts4bc322a2017-08-28 09:37:39 -070063 def testOlderLKGMFails(self):
64 """Tests that trying to update to an older lkgm version fails."""
Steven Bennettsd36fc782017-11-08 14:45:43 -080065 self.old_lkgm = '1002.0.0'
Achuith Bhandarkardc3a3512018-03-16 15:10:57 -070066 self.rc.AddCmdResult(partial_mock.In('remote'), returncode=0,
Steven Bennettsd36fc782017-11-08 14:45:43 -080067 side_effect=self._createOldLkgm)
Steven Bennetts4bc322a2017-08-28 09:37:39 -070068
Achuith Bhandarkardc3a3512018-03-16 15:10:57 -070069 self.committer.CheckoutChrome()
Steven Bennetts4bc322a2017-08-28 09:37:39 -070070
Steven Bennetts4bc322a2017-08-28 09:37:39 -070071 self.assertRaises(chrome_chromeos_lkgm.LKGMNotValid,
Achuith Bhandarkardc3a3512018-03-16 15:10:57 -070072 self.committer.UpdateLKGM)
73 self.assertEqual(self.committer._old_lkgm, self.old_lkgm)
74 self.assertEqual(self.committer._lkgm, '1001.0.0')
75 self.assertEqual(osutils.ReadFile(self.lkgm_file), '1002.0.0')
Steven Bennetts4bc322a2017-08-28 09:37:39 -070076
77 def testVersionWithChromeBranch(self):
78 """Tests passing a version with a chrome branch strips the branch."""
Achuith Bhandarkar1b9180f2018-02-22 19:12:09 -080079 self.committer = chrome_chromeos_lkgm.ChromeLKGMCommitter(
Achuith Bhandarkarb6f40252019-12-09 16:31:34 -080080 'user@test.org', self.tempdir, '1003.0.0-rc2')
Steven Bennetts4bc322a2017-08-28 09:37:39 -070081
Achuith Bhandarkardc3a3512018-03-16 15:10:57 -070082 self.old_lkgm = '1002.0.0'
83 self.rc.AddCmdResult(partial_mock.In('remote'), returncode=0,
84 side_effect=self._createOldLkgm)
85
86 self.committer.CheckoutChrome()
87 self.committer.UpdateLKGM()
Steven Bennetts4bc322a2017-08-28 09:37:39 -070088 self.committer.CommitNewLKGM()
89
90 # Check the file was actually written out correctly.
91 stripped_lkgm = '1003.0.0'
92 self.assertEqual(osutils.ReadFile(self.lkgm_file), stripped_lkgm)
Achuith Bhandarkardc3a3512018-03-16 15:10:57 -070093 self.assertEqual(self.committer._old_lkgm, self.old_lkgm)
Ben Pastened3b93d42019-10-10 09:56:29 -070094
95 def testCommitMsg(self):
96 """Tests format of the commit message."""
Ben Pastened3b93d42019-10-10 09:56:29 -070097 self.committer._PRESUBMIT_BOTS = ['bot1', 'bot2']
Ben Pastenef0fb0622021-09-24 23:38:13 +000098 self.committer._buildbucket_id = 'some-build-id'
Ben Pastened3b93d42019-10-10 09:56:29 -070099 commit_msg_lines = self.committer.ComposeCommitMsg().splitlines()
Ben Pastene6a8361a2021-08-19 19:52:05 -0700100 self.assertIn('LKGM 1001.0.0 for chromeos.', commit_msg_lines)
Ben Pastenef0fb0622021-09-24 23:38:13 +0000101 self.assertIn(
102 'Uploaded by https://ci.chromium.org/b/some-build-id', commit_msg_lines)
Ben Pastened3b93d42019-10-10 09:56:29 -0700103 self.assertIn('CQ_INCLUDE_TRYBOTS=luci.chrome.try:bot1', commit_msg_lines)
104 self.assertIn('CQ_INCLUDE_TRYBOTS=luci.chrome.try:bot2', commit_msg_lines)
Ben Pastene6a8361a2021-08-19 19:52:05 -0700105
106 def testFindAlreadyOpenLKGMRoll(self):
107 already_open_issues = [123456]
Ben Pasteneca7c71b2021-10-07 18:34:27 -0700108 self.committer._commit_msg_header = 'A message with spaces'
Ben Pastene6a8361a2021-08-19 19:52:05 -0700109 with mock.patch.object(
110 self.committer._gerrit_helper, 'Query',
Ben Pasteneca7c71b2021-10-07 18:34:27 -0700111 return_value=already_open_issues) as mock_query:
Ben Pastene6a8361a2021-08-19 19:52:05 -0700112 self.assertEqual(
113 self.committer.FindAlreadyOpenLKGMRoll(),
114 already_open_issues[0])
Ben Pasteneca7c71b2021-10-07 18:34:27 -0700115 escaped_quotes = urllib.parse.quote('"')
116 message = mock_query.call_args.kwargs['message']
117 self.assertEqual(message.count(escaped_quotes), 2)
118 self.assertTrue(message.startswith(escaped_quotes))
119 self.assertTrue(message.endswith(escaped_quotes))
Ben Pastene6a8361a2021-08-19 19:52:05 -0700120 already_open_issues = [123456, 654321]
121 with mock.patch.object(
122 self.committer._gerrit_helper, 'Query',
123 return_value=already_open_issues):
124 self.assertRaises(
125 chrome_chromeos_lkgm.LKGMNotValid,
126 self.committer.FindAlreadyOpenLKGMRoll)
127
128 def testSubmitToCQ(self):
Ben Pastene33da0c22021-11-29 21:14:05 -0800129 self.committer._buildbucket_id = 'some-build-id'
Ben Pastene6a8361a2021-08-19 19:52:05 -0700130 already_open_issue = 123456
Ben Pastene33da0c22021-11-29 21:14:05 -0800131 with mock.patch.object(
132 self.committer._gerrit_helper, 'SetReview') as mock_review:
Ben Pastene6a8361a2021-08-19 19:52:05 -0700133 self.committer.SubmitToCQ(already_open_issue)
Ben Pastene33da0c22021-11-29 21:14:05 -0800134 self.assertIn(
135 self.committer._buildbucket_id, mock_review.call_args[1]['msg'])