blob: 853125bafe6c4040b8c11ba3575efd3be53c10f6 [file] [log] [blame]
Hirthanan Subenderan3e884d62020-01-23 13:12:45 -08001#!/usr/bin/env python3
2# -*- coding: utf-8 -*-"
3#
4# Copyright 2020 The Chromium OS Authors. All rights reserved.
5# Use of this source code is governed by a BSD-style license that can be
6# found in the LICENSE file.
7
8"""Module containing shared helper methods."""
9
10from __future__ import print_function
Hirthanan Subenderan3e884d62020-01-23 13:12:45 -080011import os
Hirthanan Subenderan3e884d62020-01-23 13:12:45 -080012import re
Hirthanan Subenderancfada212020-02-28 15:12:39 -080013from enum import Enum
14import MySQLdb
15
16import initdb_upstream
17import initdb_stable
18import initdb_chromeos
Hirthanan Subenderan3e884d62020-01-23 13:12:45 -080019
Hirthanan Subenderan00f18042020-02-11 17:24:38 -080020
21KERNEL_SITE = 'https://git.kernel.org/'
22UPSTREAM_REPO = KERNEL_SITE + 'pub/scm/linux/kernel/git/torvalds/linux'
23STABLE_REPO = KERNEL_SITE + 'pub/scm/linux/kernel/git/stable/linux-stable'
24
25CHROMIUM_SITE = 'https://chromium.googlesource.com/'
26CHROMEOS_REPO = CHROMIUM_SITE + 'chromiumos/third_party/kernel'
27CHROMIUM_REVIEW_BASEURL = 'https://chromium-review.googlesource.com/'
28
Hirthanan Subenderanc77dee32020-03-04 12:07:56 -080029# Order SUPPORTED_BRANCHES from oldest to newest
30SUPPORTED_BRANCHES = ['4.4', '4.14', '4.19', '5.4']
31UPSTREAM_START_BRANCH = 'v%s' % SUPPORTED_BRANCHES[0]
Hirthanan Subenderan00f18042020-02-11 17:24:38 -080032
Hirthanan Subenderan7d15b282020-03-02 16:29:08 -080033CHROMEOS_PATH = 'linux_chrome'
34STABLE_PATH = 'linux_stable'
35UPSTREAM_PATH = 'linux_upstream'
Hirthanan Subenderan00f18042020-02-11 17:24:38 -080036
Hirthanan Subenderan3e884d62020-01-23 13:12:45 -080037WORKDIR = os.getcwd()
Hirthanan Subenderan3e884d62020-01-23 13:12:45 -080038
39# "commit" is sometimes seen multiple times, such as with commit 6093aabdd0ee
40CHERRYPICK = re.compile(r'cherry picked from (commit )+([0-9a-f]+)')
41STABLE = re.compile(r'^\s*(commit )+([a-f0-9]+) upstream')
42STABLE2 = re.compile(r'^\s*\[\s*Upstream (commit )+([0-9a-f]+)\s*\]')
43
44
Hirthanan Subenderanb81acc22020-03-03 16:34:20 -080045class Status(Enum):
46 """Text representation of database enum to track status of gerrit CL."""
47 OPEN = 1 # Gerrit ticket was created for clean fix patch
48 MERGED = 2 # Gerrit ticket was merged and closed
49 ABANDONED = 3 # Gerrit ticket was abandoned
50 CONFLICT = 4 # Gerrit ticket NOT created since patch doesn't apply properly
51
52
Hirthanan Subenderancfada212020-02-28 15:12:39 -080053class Kernel(Enum):
54 """Enum representing which Kernel we are representing."""
55 linux_stable = 1
56 linux_chrome = 2
57 linux_upstream = 3
Hirthanan Subenderan3e884d62020-01-23 13:12:45 -080058
Hirthanan Subenderan00f18042020-02-11 17:24:38 -080059
Hirthanan Subenderan53dac7d2020-02-28 15:34:06 -080060class KernelMetadata(object):
61 """Object to group kernel Metadata."""
Hirthanan Subenderanc77dee32020-03-04 12:07:56 -080062 path = None
63 repo = None
Hirthanan Subenderan53dac7d2020-02-28 15:34:06 -080064 kernel_fixes_table = None
Hirthanan Subenderanc77dee32020-03-04 12:07:56 -080065 branches = None
66 tag_template = None
Hirthanan Subenderan53dac7d2020-02-28 15:34:06 -080067 get_kernel_branch = None
Hirthanan Subenderanc77dee32020-03-04 12:07:56 -080068 update_table = None
Hirthanan Subenderan53dac7d2020-02-28 15:34:06 -080069
Hirthanan Subenderanc77dee32020-03-04 12:07:56 -080070 def __init__(self, _path, _repo, _kernel_fixes_table, _branches, _tag_template,
71 _get_kernel_branch, _update_table):
72 self.path = _path
73 self.repo = _repo
Hirthanan Subenderan53dac7d2020-02-28 15:34:06 -080074 self.kernel_fixes_table = _kernel_fixes_table
Hirthanan Subenderanc77dee32020-03-04 12:07:56 -080075 self.branches = _branches
76 self.tag_template = _tag_template
Hirthanan Subenderan53dac7d2020-02-28 15:34:06 -080077 self.get_kernel_branch = _get_kernel_branch
Hirthanan Subenderanc77dee32020-03-04 12:07:56 -080078 self.update_table = _update_table
Hirthanan Subenderan53dac7d2020-02-28 15:34:06 -080079
80
Hirthanan Subenderan3e884d62020-01-23 13:12:45 -080081def stable_branch(version):
82 """Stable branch name"""
83 return 'linux-%s.y' % version
84
85
86def chromeos_branch(version):
87 """Chromeos branch name"""
88 return 'chromeos-%s' % version
89
90
91def patch_link(changeID):
92 """Link to patch on gerrit"""
93 return 'https://chromium-review.googlesource.com/q/%s' % changeID
94
Hirthanan Subenderancfada212020-02-28 15:12:39 -080095def update_previous_fetch(db, kernel, branch, last_sha):
96 """Updates the previous_fetch table for a kernel branch."""
97 c = db.cursor()
98 q = """UPDATE previous_fetch
99 SET sha_tip = %s
100 WHERE linux = %s AND branch = %s"""
101 c.execute(q, [last_sha, kernel.name, branch])
Hirthanan Subenderan3e884d62020-01-23 13:12:45 -0800102
Hirthanan Subenderancfada212020-02-28 15:12:39 -0800103 db.commit()
Hirthanan Subenderan3e884d62020-01-23 13:12:45 -0800104
105
Hirthanan Subenderanc77dee32020-03-04 12:07:56 -0800106def update_kernel_db(db, kernel_metadata):
Hirthanan Subenderancfada212020-02-28 15:12:39 -0800107 """Update (upstream/stable/chrome) previous_fetch, fixes and commits SQL tables."""
Hirthanan Subenderanc77dee32020-03-04 12:07:56 -0800108 path = kernel_metadata.path
Hirthanan Subenderancfada212020-02-28 15:12:39 -0800109
110 os.chdir(path)
111
Hirthanan Subenderanc77dee32020-03-04 12:07:56 -0800112 for branch in kernel_metadata.branches:
113 start = kernel_metadata.tag_template % branch
Hirthanan Subenderancfada212020-02-28 15:12:39 -0800114
Hirthanan Subenderanc77dee32020-03-04 12:07:56 -0800115 print('Handling %s' % kernel_metadata.get_kernel_branch(branch))
Hirthanan Subenderancfada212020-02-28 15:12:39 -0800116
117 try:
118 c = db.cursor()
119 q = """SELECT sha_tip
120 FROM previous_fetch
121 WHERE linux = %s AND branch = %s"""
122 c.execute(q, [path, branch])
123 sha = c.fetchone()
124 if sha and sha[0]:
125 start = sha[0]
126 else:
127 q = """INSERT INTO previous_fetch (linux, branch, sha_tip)
128 VALUES (%s, %s, %s)"""
129 c.execute(q, [path, branch, start])
130 except MySQLdb.Error as e: # pylint: disable=no-member
131 print('Make sure the tables have been initialized in \
Hirthanan Subenderanc77dee32020-03-04 12:07:56 -0800132 ./scripts/sql/initialize_sql_tables.sql')
133 raise e
Hirthanan Subenderan3e884d62020-01-23 13:12:45 -0800134
135
Hirthanan Subenderanc77dee32020-03-04 12:07:56 -0800136 kernel_metadata.update_table(branch, start, db)
137 db.commit()
Hirthanan Subenderan3e884d62020-01-23 13:12:45 -0800138
Hirthanan Subenderancfada212020-02-28 15:12:39 -0800139 os.chdir(WORKDIR)
Hirthanan Subenderan53dac7d2020-02-28 15:34:06 -0800140
Hirthanan Subenderanc77dee32020-03-04 12:07:56 -0800141def get_kernel_metadata(kernel):
142 """Returns KernelMetadata for each Kernel Enum"""
143 stable_kernel_metadata = KernelMetadata(STABLE_PATH, STABLE_REPO, 'stable_fixes',
144 SUPPORTED_BRANCHES, 'v%s', stable_branch, initdb_stable.update_stable_table)
145 chrome_kernel_metadata = KernelMetadata(CHROMEOS_PATH, CHROMEOS_REPO, 'chrome_fixes',
146 SUPPORTED_BRANCHES, 'v%s', chromeos_branch, initdb_chromeos.update_chrome_table)
147 upstream_kernel_metadata = KernelMetadata(UPSTREAM_PATH, 'upstream_fixes', UPSTREAM_REPO,
148 [UPSTREAM_START_BRANCH], '%s', lambda *args: 'master',
149 initdb_upstream.update_upstream_table)
150
151 kernel_metadata_lookup = {
152 Kernel.linux_stable: stable_kernel_metadata,
153 Kernel.linux_chrome: chrome_kernel_metadata,
154 Kernel.linux_upstream: upstream_kernel_metadata
155 }
156
157 try:
158 return kernel_metadata_lookup[kernel]
159 except KeyError as e:
160 raise KeyError('Conditionals should match Kernel Enum types.', e)