blob: db1ba62228a4471873df08e2dfce27636cfd3847 [file] [log] [blame] [view]
# Uploading New Java Version to CIPD
We store the Java Version package on CIPD for use on CI. For more information read the internal
docs [here](http://go/luci-cipd).
Some links in the instructions below are Google-internal.
## Steps
### Request Access to CIPD
1. Request temporary write access to upload packages to CIPD
via http://go/flutter-luci-cipd#requesting-write-read-access-to-cipd-packages.
2. Wait about 5-30 minutes for access rights to sync. To check if your rights have synced, see if
you are a member of this
group [here](https://chrome-infra-auth.appspot.com/auth/groups/google%2Fflutter-cipd-writers@twosync.google.com).
### Download the New Java Version and Set Up for CIPD Upload
3. Download the new Java version via OpenJDK (not Oracle's Java for licensing/legal
reasons) [here](https://openjdk.org/projects/jdk/) for the following platforms:
linux-amd64(aka x64), mac-arm64, mac-amd64, and windows-amd64.
4. Download the latest Java version from
CIPD [here](https://chrome-infra-packages.appspot.com/p/flutter/java/openjdk) for the following
platforms: linux-amd64(aka x64), mac-arm64, mac-amd64, and windows-amd64.
5. Unzip the new Java version and the latest version.
6. Add a file titled `openjdk.cipd.yaml` at the top-level directory. Copy the contents below into
the file and replace contents in <> for your new Java version package:
```sh
package: flutter/java/openjdk/<platform-architecture>
description: OpenJDK <java_version> for <platform>
install_mode: copy
data:
# This directory contains Java <platform-architecture> to be used in automated tests.
- dir: .
```
Note: `linux-amd64` is an example of `<platform-architecture>`
7. Ensure the file/directory structure of the new Java version package to be uploaded is the same as
the structure at the top-level of the latest from CIPD.
This involves potentially deleting contents of the top-level directory.
### Upload to CIPD
8. To run CIPD commands, please run this command:
```sh
cipd auth-login
```
9. To upload the new Java version to CIPD, please run this command:
```sh
cipd create -in <path_to_new_java_version_package> -name flutter/java/openjdk/<platform-architecture> -tag version:<java_version>
```
Note: Please check you have the correct name, tags, package structure before uploading to CIPD
because deleting the package on CIPD is difficult.
10. Check to see if your new Java version has successfully uploaded to CIPD by clicking on the
relevant platform [here](https://chrome-infra-packages.appspot.com/p/flutter/java/openjdk).
### Troubleshooting CIPD (Optional)
If you accidentally uploaded the incorrect package to CIPD, you can delete the tag using these
instructions [here](go/flutter-luci-playbook#remove-duplicated-cipd-tags).
Then, re-upload the correct Java version pacakge to CIPD.