blob: 43b95b1ff4b5b47cc67649505cf92db44a24674c [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 Subenderancfada212020-02-28 15:12:39 -080029# Order SUPPORTED_KERNELS from oldest to newest
Hirthanan Subenderan00f18042020-02-11 17:24:38 -080030SUPPORTED_KERNELS = ('4.4', '4.14', '4.19', '5.4')
Hirthanan Subenderancfada212020-02-28 15:12:39 -080031UPSTREAM_START_TAG = 'v%s' % SUPPORTED_KERNELS[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 Subenderan3e884d62020-01-23 13:12:45 -080060def stable_branch(version):
61 """Stable branch name"""
62 return 'linux-%s.y' % version
63
64
65def chromeos_branch(version):
66 """Chromeos branch name"""
67 return 'chromeos-%s' % version
68
69
70def patch_link(changeID):
71 """Link to patch on gerrit"""
72 return 'https://chromium-review.googlesource.com/q/%s' % changeID
73
Hirthanan Subenderancfada212020-02-28 15:12:39 -080074def update_previous_fetch(db, kernel, branch, last_sha):
75 """Updates the previous_fetch table for a kernel branch."""
76 c = db.cursor()
77 q = """UPDATE previous_fetch
78 SET sha_tip = %s
79 WHERE linux = %s AND branch = %s"""
80 c.execute(q, [last_sha, kernel.name, branch])
Hirthanan Subenderan3e884d62020-01-23 13:12:45 -080081
Hirthanan Subenderancfada212020-02-28 15:12:39 -080082 db.commit()
Hirthanan Subenderan3e884d62020-01-23 13:12:45 -080083
84
Hirthanan Subenderancfada212020-02-28 15:12:39 -080085def update_kernel_db(db, kernel):
86 """Update (upstream/stable/chrome) previous_fetch, fixes and commits SQL tables."""
87 get_branch_name = start = update_commits = None
Hirthanan Subenderan3e884d62020-01-23 13:12:45 -080088
Hirthanan Subenderancfada212020-02-28 15:12:39 -080089 if kernel == Kernel.linux_chrome:
90 get_branch_name = chromeos_branch
91 update_commits = initdb_chromeos.update_chrome_table
92 elif kernel == Kernel.linux_stable:
93 get_branch_name = stable_branch
94 update_commits = initdb_stable.update_stable_table
95 else:
96 get_branch_name = lambda *args: 'master'
97 update_commits = initdb_upstream.update_upstream_table
98
99 path = kernel.name
100 branches = [UPSTREAM_START_TAG] if kernel == Kernel.linux_upstream else SUPPORTED_KERNELS
101 start_template = '%s' if kernel == Kernel.linux_upstream else 'v%s'
102
103 os.chdir(path)
104
105 for branch in branches:
106 start = start_template % branch
107
108 print('Handling %s' % get_branch_name(branch))
109
110 try:
111 c = db.cursor()
112 q = """SELECT sha_tip
113 FROM previous_fetch
114 WHERE linux = %s AND branch = %s"""
115 c.execute(q, [path, branch])
116 sha = c.fetchone()
117 if sha and sha[0]:
118 start = sha[0]
119 else:
120 q = """INSERT INTO previous_fetch (linux, branch, sha_tip)
121 VALUES (%s, %s, %s)"""
122 c.execute(q, [path, branch, start])
123 except MySQLdb.Error as e: # pylint: disable=no-member
124 print('Make sure the tables have been initialized in \
125 ./scripts/sql/initialize_sql_tables.sql', e)
Hirthanan Subenderan3e884d62020-01-23 13:12:45 -0800126
127
Hirthanan Subenderancfada212020-02-28 15:12:39 -0800128 update_commits(branch, start, db)
Hirthanan Subenderan3e884d62020-01-23 13:12:45 -0800129
Hirthanan Subenderancfada212020-02-28 15:12:39 -0800130 os.chdir(WORKDIR)