blob: a9b5d69a33acdfbd01cd1ccfe293dd63d291d498 [file] [log] [blame]
Mike Frysingere58c0e22017-10-04 15:43:30 -04001# -*- coding: utf-8 -*-
Steven Bennettsddf9bcd2017-06-14 14:07:43 -07002# Copyright 2017 The Chromium OS Authors. All rights reserved.
3# Use of this source code is governed by a BSD-style license that can be
4# found in the LICENSE file.
5
6"""Unit tests for the chrome_chromeos_lkgm program."""
7
8from __future__ import print_function
9
10import os
Steven Bennettsddf9bcd2017-06-14 14:07:43 -070011
Steven Bennettsddf9bcd2017-06-14 14:07:43 -070012from chromite.lib import constants
Steven Bennettsddf9bcd2017-06-14 14:07:43 -070013from chromite.lib import cros_test_lib
14from chromite.lib import osutils
15from chromite.lib import partial_mock
Steven Bennettsddf9bcd2017-06-14 14:07:43 -070016from chromite.scripts import chrome_chromeos_lkgm
17
Achuith Bhandarkarec8d7a72018-03-01 16:56:22 -080018
Steven Bennettsddf9bcd2017-06-14 14:07:43 -070019# pylint: disable=protected-access
Benjamin Gordon121a2aa2018-05-04 16:24:45 -060020class ChromeLKGMCommitterTester(cros_test_lib.RunCommandTestCase,
Achuith Bhandarkardc3a3512018-03-16 15:10:57 -070021 cros_test_lib.MockTempDirTestCase):
Steven Bennettsddf9bcd2017-06-14 14:07:43 -070022 """Test cros_chromeos_lkgm.Committer."""
Achuith Bhandarkarec8d7a72018-03-01 16:56:22 -080023
Achuith Bhandarkardc3a3512018-03-16 15:10:57 -070024 def setUp(self):
25 """Common set up method for all tests."""
26 self.committer = chrome_chromeos_lkgm.ChromeLKGMCommitter(
Achuith Bhandarkarb6f40252019-12-09 16:31:34 -080027 'user@test.org', self.tempdir, '1001.0.0')
Achuith Bhandarkardc3a3512018-03-16 15:10:57 -070028 self.lkgm_file = os.path.join(self.tempdir, constants.PATH_TO_CHROME_LKGM)
29 self.old_lkgm = None
Steven Bennettsddf9bcd2017-06-14 14:07:43 -070030
Achuith Bhandarkardc3a3512018-03-16 15:10:57 -070031 def _createOldLkgm(self, *args, **kwargs): # pylint: disable=unused-argument
Steven Bennettsd36fc782017-11-08 14:45:43 -080032 # Write out an old lkgm file as if we got it from a git fetch.
Achuith Bhandarkardc3a3512018-03-16 15:10:57 -070033 osutils.SafeMakedirs(os.path.join(self.tempdir, '.git', 'info'))
Steven Bennettsd36fc782017-11-08 14:45:43 -080034 osutils.SafeMakedirs(os.path.dirname(self.lkgm_file))
35 osutils.WriteFile(self.lkgm_file, self.old_lkgm)
36
Steven Bennettsddf9bcd2017-06-14 14:07:43 -070037 def testCheckoutChromeLKGM(self):
Mike Frysinger3ef6d972019-08-24 20:07:42 -040038 """Tests that we can read/obtain the old LKGM from mocked out git."""
Steven Bennettsd36fc782017-11-08 14:45:43 -080039 self.old_lkgm = '1234.0.0'
Achuith Bhandarkardc3a3512018-03-16 15:10:57 -070040 self.rc.AddCmdResult(partial_mock.In('remote'), returncode=0,
Steven Bennettsd36fc782017-11-08 14:45:43 -080041 side_effect=self._createOldLkgm)
Achuith Bhandarkardc3a3512018-03-16 15:10:57 -070042 self.committer.CheckoutChrome()
Achuith Bhandarkarec8d7a72018-03-01 16:56:22 -080043
44 self.assertEqual(self.committer.lkgm_file, self.lkgm_file)
Achuith Bhandarkardc3a3512018-03-16 15:10:57 -070045 self.assertEqual(osutils.ReadFile(self.lkgm_file), self.old_lkgm)
Steven Bennettsddf9bcd2017-06-14 14:07:43 -070046
47 def testCommitNewLKGM(self):
48 """Tests that we can commit a new LKGM file."""
Achuith Bhandarkardc3a3512018-03-16 15:10:57 -070049 self.old_lkgm = '999.0.0'
50 self.rc.AddCmdResult(partial_mock.In('remote'), returncode=0,
51 side_effect=self._createOldLkgm)
52 self.committer.CheckoutChrome()
Steven Bennettsddf9bcd2017-06-14 14:07:43 -070053
Achuith Bhandarkardc3a3512018-03-16 15:10:57 -070054 self.assertEqual(self.committer.lkgm_file, self.lkgm_file)
55
56 self.committer.UpdateLKGM()
Steven Bennettsddf9bcd2017-06-14 14:07:43 -070057 self.committer.CommitNewLKGM()
58
59 # Check the file was actually written out correctly.
60 self.assertEqual(osutils.ReadFile(self.lkgm_file), self.committer._lkgm)
61 self.assertCommandContains(['git', 'commit'])
Achuith Bhandarkardc3a3512018-03-16 15:10:57 -070062 self.assertEqual(self.committer._old_lkgm, self.old_lkgm)
Steven Bennettsddf9bcd2017-06-14 14:07:43 -070063
Steven Bennetts4bc322a2017-08-28 09:37:39 -070064 def testOlderLKGMFails(self):
65 """Tests that trying to update to an older lkgm version fails."""
Steven Bennettsd36fc782017-11-08 14:45:43 -080066 self.old_lkgm = '1002.0.0'
Achuith Bhandarkardc3a3512018-03-16 15:10:57 -070067 self.rc.AddCmdResult(partial_mock.In('remote'), returncode=0,
Steven Bennettsd36fc782017-11-08 14:45:43 -080068 side_effect=self._createOldLkgm)
Steven Bennetts4bc322a2017-08-28 09:37:39 -070069
Achuith Bhandarkardc3a3512018-03-16 15:10:57 -070070 self.committer.CheckoutChrome()
Steven Bennetts4bc322a2017-08-28 09:37:39 -070071
Steven Bennetts4bc322a2017-08-28 09:37:39 -070072 self.assertRaises(chrome_chromeos_lkgm.LKGMNotValid,
Achuith Bhandarkardc3a3512018-03-16 15:10:57 -070073 self.committer.UpdateLKGM)
74 self.assertEqual(self.committer._old_lkgm, self.old_lkgm)
75 self.assertEqual(self.committer._lkgm, '1001.0.0')
76 self.assertEqual(osutils.ReadFile(self.lkgm_file), '1002.0.0')
Steven Bennetts4bc322a2017-08-28 09:37:39 -070077
78 def testVersionWithChromeBranch(self):
79 """Tests passing a version with a chrome branch strips the branch."""
Achuith Bhandarkar1b9180f2018-02-22 19:12:09 -080080 self.committer = chrome_chromeos_lkgm.ChromeLKGMCommitter(
Achuith Bhandarkarb6f40252019-12-09 16:31:34 -080081 'user@test.org', self.tempdir, '1003.0.0-rc2')
Steven Bennetts4bc322a2017-08-28 09:37:39 -070082
Achuith Bhandarkardc3a3512018-03-16 15:10:57 -070083 self.old_lkgm = '1002.0.0'
84 self.rc.AddCmdResult(partial_mock.In('remote'), returncode=0,
85 side_effect=self._createOldLkgm)
86
87 self.committer.CheckoutChrome()
88 self.committer.UpdateLKGM()
Steven Bennetts4bc322a2017-08-28 09:37:39 -070089 self.committer.CommitNewLKGM()
90
91 # Check the file was actually written out correctly.
92 stripped_lkgm = '1003.0.0'
93 self.assertEqual(osutils.ReadFile(self.lkgm_file), stripped_lkgm)
Achuith Bhandarkardc3a3512018-03-16 15:10:57 -070094 self.assertEqual(self.committer._old_lkgm, self.old_lkgm)
Ben Pastened3b93d42019-10-10 09:56:29 -070095
96 def testCommitMsg(self):
97 """Tests format of the commit message."""
98 self.committer._lkgm = '12345.0.0'
99 self.committer._PRESUBMIT_BOTS = ['bot1', 'bot2']
100 commit_msg_lines = self.committer.ComposeCommitMsg().splitlines()
101 self.assertIn('LKGM 12345.0.0 for chromeos.', commit_msg_lines)
102 self.assertIn('CQ_INCLUDE_TRYBOTS=luci.chrome.try:bot1', commit_msg_lines)
103 self.assertIn('CQ_INCLUDE_TRYBOTS=luci.chrome.try:bot2', commit_msg_lines)