-
Notifications
You must be signed in to change notification settings - Fork 4
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
github actions: Add our standard set of github action workflows
Signed-off-by: Greg Rose <[email protected]>
- Loading branch information
1 parent
8856965
commit 1f73d66
Showing
6 changed files
with
415 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,129 @@ | ||
#!/usr/bin/env python3 | ||
# coding: utf-8 | ||
# | ||
|
||
import argparse | ||
import copy | ||
import difflib | ||
import io | ||
import git | ||
import os | ||
import re | ||
import subprocess | ||
import sys | ||
import tempfile | ||
|
||
verbose = False | ||
|
||
|
||
def get_upstream_commit(upstream, c): | ||
for l in c.message.splitlines(): | ||
try: | ||
sha = re.match('\s*commit\s+(?P<sha>\S+)', l).groups()[0].upper() | ||
return upstream.commit(sha) | ||
except: | ||
True | ||
|
||
def get_diff(d): | ||
dif = '' | ||
df = False | ||
for l in d.splitlines(): | ||
if l[:10] == 'diff --git': | ||
df = True | ||
if not df: | ||
continue | ||
dif = dif + l + '\n' | ||
return dif | ||
|
||
|
||
def trim_unchanged_files(lines): | ||
dl = [] | ||
ld = 0 # Last line with a 'diff --git' we saw | ||
hd = False # Have we seen a changed line since ld? | ||
i = 0 | ||
for i, l in enumerate(lines): | ||
if l[:4] == '+++ ' or l[:4] == '--- ' : | ||
continue | ||
if l[0] == '+' or l[0] == '-': | ||
hd = True | ||
if l[:11] == ' diff --git': | ||
if ld: # We are at a new diff now, last one started at 'ld' | ||
if not hd: | ||
dl.insert(0, (ld, i+1),) | ||
ld = i | ||
hd = False # Reset hasdiff to False as we start a new section | ||
# and check the tail | ||
if not hd: | ||
dl.insert(0, (ld, i+1),) | ||
# delete the unchanged file sections | ||
for d in dl: | ||
del lines[d[0]:d[1]] | ||
return lines | ||
|
||
|
||
if __name__ == "__main__": | ||
parser = argparse.ArgumentParser() | ||
parser.add_argument('-v', action='store_true', help='Verbose') | ||
parser.add_argument('--colour', action='store_true', help='Colorize the diff. Green for additions, red for deletions') | ||
parser.add_argument('--commit', help='Commit in current tree to diffdiff. Default is the most recent commit.') | ||
parser.add_argument('--upstream', help='A directory that contains the current upstream of linus kernel tree where we can find the commits we reference. Default is the current repo') | ||
args = parser.parse_args() | ||
|
||
|
||
if args.v: | ||
verbose = True | ||
|
||
srcgit = git.Repo.init('.') | ||
upstream = git.Repo.init(args.upstream) | ||
c = srcgit.head.commit if not args.commit else srcgit.commit(args.commit) | ||
uc = get_upstream_commit(upstream, c) | ||
|
||
dc = get_diff(srcgit.git.show(c)) | ||
duc = get_diff(upstream.git.show(uc)) | ||
|
||
with open('c.diff', 'w') as f: | ||
f.write(dc) | ||
with open('u.diff', 'w') as f: | ||
f.write(duc) | ||
|
||
res = subprocess.run(['diff', '-u', 'u.diff', 'c.diff'], | ||
check=False, stdout=subprocess.PIPE) | ||
lines = res.stdout.splitlines() | ||
dd = [] | ||
for l in lines: | ||
l = str(l)[2:-1] | ||
if l[:6] == '-index': | ||
continue | ||
if l[:6] == '+index': | ||
continue | ||
if l[:3] == '-@@': | ||
continue | ||
if l[:3] == '+@@': | ||
dd.append(' ' + l[1:]) | ||
continue | ||
dd.append(l) | ||
|
||
# trim diffs for files that did not change | ||
lines = trim_unchanged_files(dd) | ||
|
||
# colorize the diff | ||
diffs = 0 | ||
if args.colour: | ||
dd = [] | ||
for l in lines: | ||
if l[0:4] != '+++ ' and l[0:4] != '--- ': | ||
if l[0] == '+': | ||
l = '\033[42m' + l + '\033[0m' | ||
diffs = diffs + 1 | ||
if l[0] == '-': | ||
l = '\033[41m' + l + '\033[0m' | ||
diffs = diffs + 1 | ||
dd.append(l) | ||
lines = dd | ||
|
||
|
||
if diffs: | ||
for l in lines: | ||
print(l) | ||
|
||
sys.exit(diffs) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,26 @@ | ||
name: GitHub Actions Sanity Check | ||
run-name: ${{ github.actor }} is running actions - this runs as a sanity check 🚀 | ||
on: | ||
push: | ||
branches: | ||
- '**' | ||
- '!mainline' | ||
|
||
jobs: | ||
Explore-GitHub-Actions: | ||
runs-on: ubuntu-latest | ||
steps: | ||
- run: echo "🎉 The job was automatically triggered by a ${{ github.event_name }} event." | ||
- run: echo "🐧 This job is now running on a ${{ runner.os }} server hosted by GitHub!" | ||
- run: echo "🔎 The name of your branch is ${{ github.ref }} and your repository is ${{ github.repository }}." | ||
- name: Check out repository code | ||
uses: actions/checkout@v4 | ||
- run: echo "💡 The ${{ github.repository }} repository has been cloned to the runner." | ||
- run: echo "🖥️ The workflow is now ready to test your code on the runner." | ||
- name: List files in the repository | ||
run: | | ||
ls ${{ github.workspace }} | ||
df . | ||
df / | ||
pwd | ||
- run: echo "🍏 This job's status is ${{ job.status }}." |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,140 @@ | ||
require 'open3' | ||
|
||
requestors = { "gvrose8192" => "" } | ||
|
||
def file_prepend(file, str) | ||
new_contents = "" | ||
File.open(file, 'r') do |fd| | ||
contents = fd.read | ||
new_contents = str << contents | ||
end | ||
# Overwrite file but now with prepended string on it | ||
File.open(file, 'w') do |fd| | ||
fd.write(new_contents) | ||
end | ||
end | ||
|
||
def process_git_request(fname, target_branch, source_branch, prj_dir) | ||
retcode = 200 #presume success | ||
# puts "Opening file " + fname | ||
file = File.new(fname, "w") | ||
working_dir = prj_dir | ||
# puts "Working Dir : " + working_dir | ||
Dir.chdir working_dir | ||
# puts "pwd : " + Dir.pwd | ||
git_cmd = "git log --oneline --no-abbrev-commit origin/" + target_branch + ".." + "origin/" + source_branch | ||
# puts git_cmd | ||
out, err, status = Open3.capture3(git_cmd) | ||
if status.exitstatus != 0 | ||
puts "Command error output is " + err | ||
file.write("Command error output is " + err) | ||
file.close | ||
retcode = 201 | ||
return retcode | ||
end | ||
output_lines = out.split(' ') | ||
# we just want the commit sha IDs | ||
output_lines.each { |x| | ||
# puts "This is output_lines " + x | ||
upstream_diff = false | ||
if !x[/\H/] | ||
if x.length < 40 | ||
next | ||
end | ||
git_cmd = "git show " + x | ||
gitlog_out, gitlog_err, gitlog_status = Open3.capture3(git_cmd) | ||
if gitlog_status.exitstatus != 0 | ||
file.write("git show command error output is " + gitlog_err) | ||
retcode = 201 | ||
end | ||
loglines = gitlog_out.lines.map(&:chomp) | ||
lines_counted = 0 | ||
local_diffdiff_sha = "" | ||
upstream_diffdiff_sha = "" | ||
loglines.each { |logline| | ||
lines_counted = lines_counted + 1 | ||
if lines_counted == 1 | ||
local_commit_sha = logline.match("[0-9a-f]\{40\}") | ||
local_diffdiff_sha = local_commit_sha.to_s | ||
# puts "Local : " + local_diffdiff_sha | ||
file.write("Merge Request sha: " + local_diffdiff_sha) | ||
file.write("\n") | ||
end | ||
if lines_counted == 2 #email address | ||
if !logline.downcase.include? "ciq.com" | ||
# Bad Author | ||
s = "error:\nBad " + logline + "\n" | ||
puts s | ||
file.write(s) | ||
retcode = 201 | ||
else | ||
file.write("\t" + logline + "\n") | ||
end | ||
end | ||
if lines_counted > 1 | ||
if logline.downcase.include? "jira" | ||
file.write("\t" + logline + "\n") | ||
end | ||
if logline.downcase.include? "upstream-diff" | ||
upstream_diff = true | ||
end | ||
if logline.downcase.include? "commit" | ||
commit_sha = logline.match("[0-9a-f]\{40\}") | ||
upstream_diffdiff_sha = commit_sha.to_s | ||
# puts "Upstream : " + upstream_diffdiff_sha | ||
if (!upstream_diffdiff_sha.empty?) | ||
file.write("\tUpstream sha: " + upstream_diffdiff_sha) | ||
file.write("\n") | ||
end | ||
end | ||
end | ||
if lines_counted > 8 #Everything we need should be in the first 8 lines | ||
break | ||
end | ||
} | ||
if !local_diffdiff_sha.empty? && !upstream_diffdiff_sha.empty? | ||
diff_cmd = Dir.pwd + "/.github/workflows/diffdiff.py --colour --commit " + local_diffdiff_sha | ||
puts "diffdiff: " + diff_cmd | ||
diff_out, diff_err, diff_status = Open3.capture3(diff_cmd) | ||
if diff_status.exitstatus != 0 && !upstream_diff | ||
puts "diffdiff out: " + diff_out | ||
puts "diffdiff err: " + diff_err | ||
retcode = 201 | ||
file.write("error:\nCommit: " + local_diffdiff_sha + " differs with no upstream tag in commit message\n") | ||
end | ||
end | ||
end | ||
} | ||
file.close | ||
return retcode | ||
end | ||
|
||
first_arg, *argv_in = ARGV | ||
if argv_in.length < 5 | ||
puts "Not enough arguments: fname, target_branch, source_branch, prj_dir, pull_request, requestor" | ||
exit | ||
end | ||
fname = first_arg.to_s | ||
fname = "tmp-" + fname | ||
# puts "filename is " + fname | ||
target_branch = argv_in[0].to_s | ||
# puts "target branch is " + target_branch | ||
source_branch = argv_in[1].to_s | ||
# puts "source branch is " + source_branch | ||
prj_dir = argv_in[2].to_s | ||
# puts "project dir is " + prj_dir | ||
pullreq = argv_in[3].to_s | ||
# puts "pull request is " + pullreq | ||
requestor = argv_in[4].to_s | ||
retcode = process_git_request(fname, target_branch, source_branch, prj_dir) | ||
if retcode != 200 | ||
File.open(fname, 'r') do |fd| | ||
contents = fd.read | ||
puts contents | ||
end | ||
exit(1) | ||
else | ||
puts "Done" | ||
end | ||
exit(0) | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,54 @@ | ||
# This workflow uses actions that are not certified by GitHub. | ||
# They are provided by a third-party and are governed by | ||
# separate terms of service, privacy policy, and support | ||
# documentation. | ||
|
||
name: Pull Request Checker | ||
|
||
on: | ||
pull_request: | ||
branches: | ||
- '**' | ||
- '!mainline' | ||
|
||
permissions: | ||
contents: read | ||
|
||
jobs: | ||
test: | ||
|
||
runs-on: ubuntu-latest | ||
strategy: | ||
matrix: | ||
ruby-version: ['3.0'] | ||
|
||
steps: | ||
- uses: actions/checkout@v4 | ||
- name: Set up Ruby | ||
# To automatically get bug fixes and new Ruby versions for ruby/setup-ruby, | ||
# change this to (see https://github.com/ruby/setup-ruby#versioning): | ||
uses: ruby/setup-ruby@v1 | ||
# uses: ruby/setup-ruby@55283cc23133118229fd3f97f9336ee23a179fcf # v1.146.0 | ||
with: | ||
ruby-version: ${{ matrix.ruby-version }} | ||
bundler-cache: true # runs 'bundle install' and caches installed gems automatically | ||
- name: Set up Python | ||
uses: actions/setup-python@v5 | ||
- name: Run tests | ||
run: | | ||
/usr/bin/pip3 install gitPython | ||
python -c "import sys; import git; print(sys.version)" | ||
git fetch origin ${{ github.base_ref }} | ||
git fetch origin ${{ github.head_ref }} | ||
git remote add linux https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git | ||
git fetch --shallow-since="3 years ago" linux | ||
echo "Will run process-git-request.rb with:" | ||
echo "fname = ${{ github.run_id }}" | ||
echo "target_branch = ${{ github.base_ref }}" | ||
echo "source_branch = ${{ github.head_ref }}" | ||
echo "prj_dir = ${{ github.workspace }}" | ||
echo "pull_request = ${{ github.ref }}" | ||
echo "requestor = ${{ github.actor }}" | ||
cd ${{ github.workspace }} | ||
/usr/bin/ruby .github/workflows/process-git-request.rb ${{ github.run_id }} ${{ github.base_ref }} \ | ||
${{ github.head_ref }} ${{ github.workspace }} ${{ github.ref }} ${{ github.actor }} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,33 @@ | ||
name: CI | ||
on: | ||
push: | ||
branches: | ||
- '**' | ||
- '!mainline' | ||
|
||
jobs: | ||
kernel-build-job: | ||
runs-on: | ||
labels: kernel-build-arm64 | ||
container: | ||
image: rockylinux:9 | ||
env: | ||
ROCKY_ENV: rocky9 | ||
ports: | ||
- 80 | ||
options: --cpus 8 | ||
steps: | ||
- name: Install tools and Libraries | ||
run: | | ||
dnf groupinstall 'Development Tools' -y | ||
dnf install --enablerepo=crb bc dwarves kernel-devel openssl-devel elfutils-libelf-devel -y | ||
- name: Checkout code | ||
uses: actions/checkout@v4 | ||
with: | ||
fetch-depth: 0 | ||
- name: Build the Kernel | ||
run: | | ||
git config --global --add safe.directory /__w/kernel-src-git/kernel-src-git | ||
cp configs/kernel-5.14.0-aarch64.config .config | ||
make olddefconfig | ||
make -j8 |
Oops, something went wrong.