| Akron | 88ddd4a | 2022-11-08 10:41:35 +0100 | [diff] [blame] | 1 | #!/usr/bin/env perl |
| 2 | use strict; |
| 3 | use warnings; |
| 4 | use Mojo::File 'tempfile'; |
| Akron | c7aeafd | 2026-04-29 12:05:49 +0200 | [diff] [blame] | 5 | use Mojo::JSON qw'decode_json encode_json'; |
| 6 | use Mojo::ByteStream 'b'; |
| Akron | 88ddd4a | 2022-11-08 10:41:35 +0100 | [diff] [blame] | 7 | use Mojo::UserAgent; |
| Akron | 88ddd4a | 2022-11-08 10:41:35 +0100 | [diff] [blame] | 8 | |
| Akron | c7aeafd | 2026-04-29 12:05:49 +0200 | [diff] [blame] | 9 | $ENV{MOJO_NO_JSON_XS} = 0; |
| 10 | |
| Akron | 88ddd4a | 2022-11-08 10:41:35 +0100 | [diff] [blame] | 11 | our @ARGV; |
| 12 | |
| Akron | 081c5d5 | 2024-01-11 13:10:22 +0100 | [diff] [blame] | 13 | my $JAVA8_HOME = '/usr/lib/jvm/java-1.8.0-openjdk-amd64'; |
| 14 | my $JAVA11_HOME = '/usr/lib/jvm/java-1.11.0-openjdk-amd64'; |
| 15 | my $JAVA17_HOME = '/usr/lib/jvm/java-1.17.0-openjdk-amd64'; |
| Akron | c0638a2 | 2025-11-17 10:18:48 +0100 | [diff] [blame] | 16 | my $JAVA21_HOME = '/usr/lib/jvm/java-1.21.0-openjdk-amd64'; |
| Akron | 081c5d5 | 2024-01-11 13:10:22 +0100 | [diff] [blame] | 17 | |
| Akron | 5762518 | 2024-01-24 13:45:27 +0100 | [diff] [blame] | 18 | unless (-d $JAVA17_HOME) { |
| Akron | 081c5d5 | 2024-01-11 13:10:22 +0100 | [diff] [blame] | 19 | $JAVA17_HOME = '/opt/java/jdk-17.0.2'; |
| 20 | }; |
| 21 | |
| Akron | c0638a2 | 2025-11-17 10:18:48 +0100 | [diff] [blame] | 22 | unless (-d $JAVA21_HOME) { |
| 23 | $JAVA21_HOME = '/opt/java/jdk-21.0.0'; |
| 24 | }; |
| 25 | |
| Akron | 807994a | 2026-05-08 09:54:47 +0200 | [diff] [blame] | 26 | # Check which main branch exists locally |
| 27 | my $branches = `git branch --list main master`; |
| 28 | chomp $branches; |
| 29 | |
| 30 | # Split into lines and clean up formatting (remove whitespace and asterisks) |
| 31 | my @branch_list = split /\n/, $branches; |
| 32 | @branch_list = map { s/^\s*\*?\s*//; $_ } @branch_list; |
| 33 | |
| 34 | # Determine which branch to use (prefer main over master) |
| 35 | my $main_branch; |
| 36 | if (grep { $_ eq 'main' } @branch_list) { |
| 37 | $main_branch = 'main'; |
| 38 | } elsif (grep { $_ eq 'master' } @branch_list) { |
| 39 | $main_branch = 'master'; |
| 40 | } else { |
| 41 | die "Error: Neither 'main' nor 'master' branch found locally\n"; |
| 42 | } |
| 43 | |
| Akron | c0638a2 | 2025-11-17 10:18:48 +0100 | [diff] [blame] | 44 | |
| Akron | 88ddd4a | 2022-11-08 10:41:35 +0100 | [diff] [blame] | 45 | my $url = $ARGV[0]; |
| 46 | |
| 47 | sub _check { |
| 48 | my $cmd = shift; |
| Akron | 53d1821 | 2022-11-15 15:25:17 +0100 | [diff] [blame] | 49 | CHECK: |
| Akron | 88ddd4a | 2022-11-08 10:41:35 +0100 | [diff] [blame] | 50 | print "\n\n" . 'Do "' . $cmd . '"? (y/n)', "\n"; |
| 51 | |
| 52 | my $x = <STDIN>; |
| 53 | chomp($x); |
| 54 | if ($x eq 'y' || $x eq 'Y') { |
| 55 | system $cmd; |
| Akron | 53d1821 | 2022-11-15 15:25:17 +0100 | [diff] [blame] | 56 | } elsif ($x eq 'n' || $x eq 'N') { |
| Akron | 88ddd4a | 2022-11-08 10:41:35 +0100 | [diff] [blame] | 57 | exit; |
| Akron | 53d1821 | 2022-11-15 15:25:17 +0100 | [diff] [blame] | 58 | } else { |
| 59 | print "Please answer with 'y' or 'n'.\n"; |
| 60 | goto CHECK; |
| Akron | 88ddd4a | 2022-11-08 10:41:35 +0100 | [diff] [blame] | 61 | }; |
| 62 | }; |
| 63 | |
| Akron | 74994cf | 2022-11-15 14:28:00 +0100 | [diff] [blame] | 64 | unless ($url) { |
| Helge | 4d96c36 | 2023-06-21 17:06:32 +0200 | [diff] [blame] | 65 | print 'git_gerrit_pull https://github.com/KorAP/.../pull/..' . "\n"; |
| Akron | 88ddd4a | 2022-11-08 10:41:35 +0100 | [diff] [blame] | 66 | exit; |
| 67 | }; |
| 68 | |
| Akron | 807994a | 2026-05-08 09:54:47 +0200 | [diff] [blame] | 69 | _check('git checkout ' . $main_branch); |
| Akron | 88ddd4a | 2022-11-08 10:41:35 +0100 | [diff] [blame] | 70 | |
| Akron | 807994a | 2026-05-08 09:54:47 +0200 | [diff] [blame] | 71 | _check('git pull origin ' . $main_branch); |
| Akron | 88ddd4a | 2022-11-08 10:41:35 +0100 | [diff] [blame] | 72 | |
| Akron | 74994cf | 2022-11-15 14:28:00 +0100 | [diff] [blame] | 73 | $url =~ m!KorAP/([^/]+?)/pull/(\d+?)$!; |
| Akron | 88ddd4a | 2022-11-08 10:41:35 +0100 | [diff] [blame] | 74 | |
| 75 | my $ua = Mojo::UserAgent->new; |
| 76 | |
| 77 | print "Fetch $url...\n"; |
| 78 | |
| Akron | 74994cf | 2022-11-15 14:28:00 +0100 | [diff] [blame] | 79 | my $project = $1; |
| 80 | my $pr = $2; |
| Akron | c7aeafd | 2026-04-29 12:05:49 +0200 | [diff] [blame] | 81 | my $pr_html = $ua->get($url)->res->dom; |
| 82 | my $branch = $pr_html->at('.commit-ref.head-ref'); |
| 83 | |
| 84 | # Legacy path |
| 85 | if ($branch) { |
| 86 | $branch = $branch->all_text; |
| 87 | } |
| 88 | |
| 89 | # JSON path |
| 90 | elsif (my $json = $pr_html->at('script[data-target=react-app.embeddedData]')) { |
| 91 | |
| 92 | $json = decode_json(b($json->all_text)->encode->to_string); |
| 93 | |
| 94 | $branch = $json |
| 95 | ->{payload} |
| 96 | ->{pullRequestsLayoutRoute} |
| 97 | ->{pullRequest} |
| 98 | ->{headBranch}; |
| 99 | |
| 100 | }; |
| 101 | |
| 102 | unless ($branch) { |
| 103 | warn 'Unable to retrieve branch name'; |
| 104 | exit; |
| 105 | }; |
| Akron | 88ddd4a | 2022-11-08 10:41:35 +0100 | [diff] [blame] | 106 | |
| 107 | _check('git fetch github pull/' . $pr . '/head:' . $branch); |
| 108 | _check('git checkout ' . $branch); |
| Akron | 807994a | 2026-05-08 09:54:47 +0200 | [diff] [blame] | 109 | _check('git rebase ' . $main_branch); |
| Akron | 88ddd4a | 2022-11-08 10:41:35 +0100 | [diff] [blame] | 110 | |
| 111 | |
| Akron | 88ddd4a | 2022-11-08 10:41:35 +0100 | [diff] [blame] | 112 | # Kustvakt |
| Akron | 74994cf | 2022-11-15 14:28:00 +0100 | [diff] [blame] | 113 | if ($project =~ m!^Kustvakt$!i) { |
| Akron | 01ea921 | 2024-01-24 13:42:01 +0100 | [diff] [blame] | 114 | _check('JAVA_HOME="'.$JAVA17_HOME.'" mvn clean test'); |
| Akron | 88ddd4a | 2022-11-08 10:41:35 +0100 | [diff] [blame] | 115 | } |
| 116 | |
| 117 | # KalamarExport-Plugin |
| Akron | 74994cf | 2022-11-15 14:28:00 +0100 | [diff] [blame] | 118 | elsif ($project =~ m!^Kalamar-Plugin-Export$!i) { |
| Akron | 5767da2 | 2026-05-08 10:53:38 +0200 | [diff] [blame^] | 119 | _check('JAVA_HOME="'.$JAVA21_HOME.'" mvn clean test'); |
| Akron | 88ddd4a | 2022-11-08 10:41:35 +0100 | [diff] [blame] | 120 | } |
| 121 | |
| Akron | 39dae91 | 2022-11-23 09:41:53 +0100 | [diff] [blame] | 122 | # Koral |
| 123 | elsif ($project =~ m!^Koral$!i) { |
| Akron | 9f85a20 | 2026-01-13 22:18:26 +0100 | [diff] [blame] | 124 | _check('JAVA_HOME="'.$JAVA21_HOME.'" mvn clean test'); |
| Akron | 39dae91 | 2022-11-23 09:41:53 +0100 | [diff] [blame] | 125 | } |
| 126 | |
| Akron | 36ae364 | 2024-01-24 13:42:56 +0100 | [diff] [blame] | 127 | # Krill |
| 128 | elsif ($project =~ m!^Krill$!i) { |
| Akron | c0638a2 | 2025-11-17 10:18:48 +0100 | [diff] [blame] | 129 | _check('JAVA_HOME="'.$JAVA21_HOME.'" mvn clean test'); |
| Akron | 36ae364 | 2024-01-24 13:42:56 +0100 | [diff] [blame] | 130 | } |
| 131 | |
| Akron | 579efe0 | 2023-02-28 09:52:26 +0100 | [diff] [blame] | 132 | # Kalamar-Plugin-ExternalResources |
| 133 | elsif ($project =~ m!^Kalamar-Plugin-ExternalResources$!i) { |
| 134 | _check('go test ./...'); |
| 135 | } |
| 136 | |
| Akron | 88ddd4a | 2022-11-08 10:41:35 +0100 | [diff] [blame] | 137 | # KorapSRU |
| Akron | 74994cf | 2022-11-15 14:28:00 +0100 | [diff] [blame] | 138 | elsif ($project =~ m!^KorapSRU$!i) { |
| Akron | 081c5d5 | 2024-01-11 13:10:22 +0100 | [diff] [blame] | 139 | _check('JAVA_HOME="'.$JAVA8_HOME.'" mvn clean test'); |
| Akron | 88ddd4a | 2022-11-08 10:41:35 +0100 | [diff] [blame] | 140 | } |
| 141 | |
| Akron | 081c5d5 | 2024-01-11 13:10:22 +0100 | [diff] [blame] | 142 | # Korap-Tokenizer |
| 143 | elsif ($project =~ m!^KorAP-Tokenizer$!i) { |
| 144 | _check('JAVA_HOME="'.$JAVA8_HOME.'" mvn clean test'); |
| 145 | } |
| 146 | |
| 147 | # Datok |
| Akron | 579efe0 | 2023-02-28 09:52:26 +0100 | [diff] [blame] | 148 | elsif ($project =~ m!^Datok$!i) { |
| 149 | _check('make test'); |
| 150 | } |
| 151 | |
| Akron | 95ea07d | 2026-05-08 10:15:38 +0200 | [diff] [blame] | 152 | # Koral-Mapper |
| 153 | elsif ($project =~ m!^Koral-Mapper$!i) { |
| 154 | _check('make test'); |
| 155 | } |
| 156 | |
| Akron | 74994cf | 2022-11-15 14:28:00 +0100 | [diff] [blame] | 157 | # Unknown Project |
| Akron | 88ddd4a | 2022-11-08 10:41:35 +0100 | [diff] [blame] | 158 | else { |
| Akron | 74994cf | 2022-11-15 14:28:00 +0100 | [diff] [blame] | 159 | print "Unknown project $project!\n\n"; |
| Akron | 88ddd4a | 2022-11-08 10:41:35 +0100 | [diff] [blame] | 160 | exit(1); |
| 161 | }; |
| 162 | |
| 163 | |
| 164 | |
| 165 | _check('git commit --amend --no-edit'); |
| 166 | |
| 167 | { |
| 168 | my $ret = `git log -1 --pretty=%B`; |
| 169 | my $newret = ''; |
| 170 | my $change_id = ''; |
| 171 | my $first = 1; |
| 172 | foreach my $line (split "\n", $ret) { |
| 173 | if ($first) { |
| 174 | chomp $line; |
| 175 | $line .= " (closes #$pr)\n"; |
| 176 | $first = 0; |
| 177 | } |
| 178 | elsif ($line =~ /^Change-Id: /) { |
| 179 | $change_id = $line; |
| 180 | next; |
| 181 | }; |
| 182 | $newret .= $line . "\n"; |
| 183 | }; |
| 184 | |
| 185 | if ($change_id) { |
| 186 | $newret .= "\n" . $change_id."\n\n"; |
| 187 | }; |
| 188 | |
| 189 | my $msg_file = tempfile(); |
| 190 | $msg_file->spurt($newret); |
| 191 | |
| 192 | print "===================================\n"; |
| 193 | print $newret; |
| 194 | print "===================================\n"; |
| 195 | |
| 196 | _check('git commit -F ' . $msg_file . ' --amend'); |
| 197 | }; |
| 198 | |
| Akron | 807994a | 2026-05-08 09:54:47 +0200 | [diff] [blame] | 199 | _check('git push origin HEAD:refs/for/' . $main_branch); |
| Akron | 88ddd4a | 2022-11-08 10:41:35 +0100 | [diff] [blame] | 200 | |
| Akron | 807994a | 2026-05-08 09:54:47 +0200 | [diff] [blame] | 201 | _check('git checkout ' . $main_branch); |
| Akron | 88ddd4a | 2022-11-08 10:41:35 +0100 | [diff] [blame] | 202 | _check('git branch -D ' . $branch); |
| 203 | |
| 204 | print "\n\nEverything done - thank you!\n\n" |
| 205 | |
| 206 | __END__ |
| 207 | |
| 208 | =pod |
| 209 | |
| 210 | This script is an alternative to C<import_github_pull_requests> |
| 211 | that ignores CI results on github and just requires the |
| 212 | URL of a specific GH pull request to send it through Gerrit. |
| Helge | 4d96c36 | 2023-06-21 17:06:32 +0200 | [diff] [blame] | 213 | |
| 214 | Prerequisites: |
| 215 | Remote repository "github" |
| 216 | For Kustvakt and Koral Java 11 at /usr/lib/jvm/java-1.11.0-openjdk-amd6 |
| Helge | 7cd2a61 | 2024-07-17 12:23:51 +0200 | [diff] [blame] | 217 | For KorapSRU Java 8 at /usr/lib/jvm/java-1.8.0-openjdk-amd6 |
| 218 | For KalamarExport-Plugin Java 17 at /usr/lib/jvm/java-17-openjdk-amd64 |