Skip to content

Commit

Permalink
Init new Go Minor Version v1.22.0 files. (#1337)
Browse files Browse the repository at this point in the history
Co-authored-by:  <>
  • Loading branch information
xdu31 authored Feb 9, 2024
1 parent e3d0783 commit 21044e4
Show file tree
Hide file tree
Showing 6 changed files with 199 additions and 1 deletion.
1 change: 1 addition & 0 deletions projects/golang/go/1.22/GIT_TAG
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
go1.22.0
27 changes: 27 additions & 0 deletions projects/golang/go/1.22/README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,27 @@
# EKS Golang 1.22

Current Release: `0`

Tracking Tag: `go1.22.0`

### Artifacts:
|Arch|Artifact|sha|
|:---:|:---:|:---:|
|noarch|[golang-src-1.22.0-0.amzn2.eks.noarch.rpm](https://distro.eks.amazonaws.com/golang-go1.22.0/releases/0/x86_64/RPMS/noarch/golang-src-1.22.0-0.amzn2.eks.noarch.rpm)|[golang-src-1.22.0-0.amzn2.eks.noarch.rpm.sha256](https://distro.eks.amazonaws.com/golang-go1.22.0/releases/0/x86_64/RPMS/noarch/golang-src-1.22.0-0.amzn2.eks.noarch.rpm.sha256)|
|x86_64|[golang-1.22.0-0.amzn2.eks.x86_64.rpm](https://distro.eks.amazonaws.com/golang-go1.22.0/releases/0/x86_64/RPMS/x86_64/golang-1.22.0-0.amzn2.eks.x86_64.rpm)|[golang-1.22.0-0.amzn2.eks.x86_64.rpm.sha256](https://distro.eks.amazonaws.com/golang-go1.22.0/releases/0/x86_64/RPMS/x86_64/golang-1.22.0-0.amzn2.eks.x86_64.rpm.sha256)|
|aarch64|[golang-1.22.0-0.amzn2.eks.aarch64.rpm](https://distro.eks.amazonaws.com/golang-go1.22.0/releases/0/aarch64/RPMS/aarch64/golang-1.22.0-0.amzn2.eks.aarch64.rpm)|[golang-1.22.0-0.amzn2.eks.aarch64.rpm.sha256](https://distro.eks.amazonaws.com/golang-go1.22.0/releases/0/aarch64/RPMS/aarch64/golang-1.22.0-0.amzn2.eks.aarch64.rpm.sha256)|
|arm64|[go1.22.0.linux-arm64.tar.gz](https://distro.eks.amazonaws.com/golang-go1.22.0/releases/0/archives/linux/arm64/go1.22.0.linux-arm64.tar.gz)|[go1.22.0.linux-arm64.tar.gz.sha256](https://distro.eks.amazonaws.com/golang-go1.22.0/releases/0/archives/linux/arm64/go1.22.0.linux-arm64.tar.gz.sha256)|
|amd64|[go1.22.0.linux-amd64.tar.gz](https://distro.eks.amazonaws.com/golang-go1.22.0/releases/0/archives/linux/amd64/go1.22.0.linux-amd64.tar.gz)|[go1.22.0.linux-amd64.tar.gz.sha256](https://distro.eks.amazonaws.com/golang-go1.22.0/releases/0/archives/linux/amd64/go1.22.0.linux-amd64.tar.gz.sha256)|


### ARM64 Builds
[![Build status](https://prow.eks.amazonaws.com/badge.svg?jobs=golang-1-22-ARM64-PROD-tooling-postsubmit)](https://prow.eks.amazonaws.com/?repo=aws%2Feks-distro-build-tooling&type=postsubmit)

### AMD64 Builds
[![Build status](https://prow.eks.amazonaws.com/badge.svg?jobs=golang-1-22-tooling-postsubmit)](https://prow.eks.amazonaws.com/?repo=aws%2Feks-distro-build-tooling&type=postsubmit)

### Patches
The patches in `./patches` include relevant utility fixes for go `1.22`.

### Spec
The RPM spec file in `./rpmbuild/SPECS` is sourced from the go 1.22 SRPM available on Fedora, and modified to include the relevant patches and build the `go1.22.0` source.
56 changes: 56 additions & 0 deletions projects/golang/go/1.22/rpmbuild/SOURCES/fedora.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,56 @@
Generate [an RPM Spec](https://rpm-software-management.github.io/rpm/manual/spec.html) for the target Go version.

EKS Go bases our RPM spec off of the upstream Amazon Linux or Fedora Golang RPM specs.
The best way to obtain a base RPMs for a given version of Go is to pull the upstream RPM from their package source,
unpack the RPM to obtain the spec file, and adapt the spec to build EKS Go at the appropriate path and tag, and apply our custom patches.

For example, to obtain a SPEC file for Go `1.19`, do the following:
1. Identify the proper RPM to base our EKS Go build on
1. identify the Amazon Linux 2 Golang RPM for the given version using `yum list —show-duplicates golang` on an Amazon Linux 2 machine.
1. If Amazon Linux does not yet support the given version of Golang, instead use [the Fedora yum repo](https://packages.fedoraproject.org/pkgs/golang/golang/) to find an appropriate RPM for the given Golang version.

1. Download and unpack the target RPM:
1. download the target RPM from the package repo and unpack it. The command below will download the target RPM and unpack it into the `~/rpmbuild` directory.
The `spec` file will be output to `~/rpmbuild/SPECS` and any sources (such as test files and patches) will be
output to `~/rpmbuild/SOURCES`.
```shell
yumdownloader --source golang-1.16.15-1.amzn2.0.1
rpm -ivh golang-1.16.15-1.amzn2.0.1.src.rpm
```
2. Copy the source files from `~/rpmbuild/SOURCES` to `projects/golang/go/$VERSION/rpmbuild/SOURCES`
1. Copy the spec file from `~rpmbuild/SPECS` to `projects/golang/go/$VERSION/rpmbuild/SPECS`.

1. Update the upstream Spec file with EKS Go conventions
1. EKS Go uses a specific RPM Release string to identify itself.
Find [the `RELEASE` string in the unpacked spec file](https://github.com/aws/eks-distro-build-tooling/blob/main/projects/golang/go/1.18/rpmbuild/SPECS/golang.spec#L121)
and modify it to use our format:
```shell
Release: %{?_buildid}%{?dist}.eks
```
2. EKS Go builds from cloned upstream source at build-time, rather than a pre-packaged source included with the RPM.
This means we need to modify the RPM setup directive to target the right directory.
Modify [the `autosetup` directive to follow the pattern we use in our other RPM spec files.](https://github.com/aws/eks-distro-build-tooling/blob/main/projects/golang/go/1.19/rpmbuild/SPECS/golang.spec#L293)
Specifically, ensure we're targeting the source directory of the format `go-go%{go_version}`.
1. Add EKS Go specific patches
Next, add any additional required patch files to the `SOURCES` directory, and [update the modified spec file to apply them](https://github.com/aws/eks-distro-build-tooling/blob/main/projects/golang/go/1.19/rpmbuild/SPECS/golang.spec#L165).
Golang RPM spec files after Go 1.16 use the RPM directive [`autosetup`](https://github.com/aws/eks-distro-build-tooling/blob/main/projects/golang/go/1.19/rpmbuild/SPECS/golang.spec#L293), so all you need to do to apply a patch at build time is define it as a Patch source in the spec.
EKS Go currently requires one custom patch for each Go version, above and beyond the security patches.
This patch allows us to skip specific Golang standard library tests in certain circumstances, such as skipping privilleged tests which call `mount` when we're building the RPM in a container[^1].
You can find [the Go 1.19 version of that patch here](../../1.19/patches/0104-add-method-to-skip-privd-tests-if-required.patch).



1. Document your work in the RPM spec changelog

Add [a changelog entry to the RPM spec](https://github.com/aws/eks-distro-build-tooling/blob/main/projects/golang/go/1.16/rpmbuild/SPECS/golang.spec#L558) outlining the changes made to the RPM spec

1. Commit the spec file, sources, and any other changes, and push to your fork of EKS Distro build tooling, and open a work-in-progress PR with a hold on it.
In the next step we'll set up prow jobs to will let us test all of this work by running a prow pre-submit against this PR.

Now that we've set up the project structure, sourced and customized a Golang Spec file, and applied our custom patches, we need to test!
The easiest way to do this is to set up the EKS Go pre-submits for the given version and let them do the testing.
That way, you can simply commit your new EKS Go minor version and create a PR to initiate the entire RPM spec build and test.

56 changes: 56 additions & 0 deletions projects/golang/go/1.22/rpmbuild/SOURCES/golang-gdbinit
Original file line number Diff line number Diff line change
@@ -0,0 +1,56 @@
Generate [an RPM Spec](https://rpm-software-management.github.io/rpm/manual/spec.html) for the target Go version.

EKS Go bases our RPM spec off of the upstream Amazon Linux or Fedora Golang RPM specs.
The best way to obtain a base RPMs for a given version of Go is to pull the upstream RPM from their package source,
unpack the RPM to obtain the spec file, and adapt the spec to build EKS Go at the appropriate path and tag, and apply our custom patches.

For example, to obtain a SPEC file for Go `1.19`, do the following:
1. Identify the proper RPM to base our EKS Go build on
1. identify the Amazon Linux 2 Golang RPM for the given version using `yum list —show-duplicates golang` on an Amazon Linux 2 machine.
1. If Amazon Linux does not yet support the given version of Golang, instead use [the Fedora yum repo](https://packages.fedoraproject.org/pkgs/golang/golang/) to find an appropriate RPM for the given Golang version.

1. Download and unpack the target RPM:
1. download the target RPM from the package repo and unpack it. The command below will download the target RPM and unpack it into the `~/rpmbuild` directory.
The `spec` file will be output to `~/rpmbuild/SPECS` and any sources (such as test files and patches) will be
output to `~/rpmbuild/SOURCES`.
```shell
yumdownloader --source golang-1.16.15-1.amzn2.0.1
rpm -ivh golang-1.16.15-1.amzn2.0.1.src.rpm
```
2. Copy the source files from `~/rpmbuild/SOURCES` to `projects/golang/go/$VERSION/rpmbuild/SOURCES`
1. Copy the spec file from `~rpmbuild/SPECS` to `projects/golang/go/$VERSION/rpmbuild/SPECS`.

1. Update the upstream Spec file with EKS Go conventions
1. EKS Go uses a specific RPM Release string to identify itself.
Find [the `RELEASE` string in the unpacked spec file](https://github.com/aws/eks-distro-build-tooling/blob/main/projects/golang/go/1.18/rpmbuild/SPECS/golang.spec#L121)
and modify it to use our format:
```shell
Release: %{?_buildid}%{?dist}.eks
```
2. EKS Go builds from cloned upstream source at build-time, rather than a pre-packaged source included with the RPM.
This means we need to modify the RPM setup directive to target the right directory.
Modify [the `autosetup` directive to follow the pattern we use in our other RPM spec files.](https://github.com/aws/eks-distro-build-tooling/blob/main/projects/golang/go/1.19/rpmbuild/SPECS/golang.spec#L293)
Specifically, ensure we're targeting the source directory of the format `go-go%{go_version}`.

1. Add EKS Go specific patches

Next, add any additional required patch files to the `SOURCES` directory, and [update the modified spec file to apply them](https://github.com/aws/eks-distro-build-tooling/blob/main/projects/golang/go/1.19/rpmbuild/SPECS/golang.spec#L165).
Golang RPM spec files after Go 1.16 use the RPM directive [`autosetup`](https://github.com/aws/eks-distro-build-tooling/blob/main/projects/golang/go/1.19/rpmbuild/SPECS/golang.spec#L293), so all you need to do to apply a patch at build time is define it as a Patch source in the spec.

EKS Go currently requires one custom patch for each Go version, above and beyond the security patches.
This patch allows us to skip specific Golang standard library tests in certain circumstances, such as skipping privilleged tests which call `mount` when we're building the RPM in a container[^1].
You can find [the Go 1.19 version of that patch here](../../1.19/patches/0104-add-method-to-skip-privd-tests-if-required.patch).



1. Document your work in the RPM spec changelog

Add [a changelog entry to the RPM spec](https://github.com/aws/eks-distro-build-tooling/blob/main/projects/golang/go/1.16/rpmbuild/SPECS/golang.spec#L558) outlining the changes made to the RPM spec

1. Commit the spec file, sources, and any other changes, and push to your fork of EKS Distro build tooling, and open a work-in-progress PR with a hold on it.
In the next step we'll set up prow jobs to will let us test all of this work by running a prow pre-submit against this PR.

Now that we've set up the project structure, sourced and customized a Golang Spec file, and applied our custom patches, we need to test!
The easiest way to do this is to set up the EKS Go pre-submits for the given version and let them do the testing.
That way, you can simply commit your new EKS Go minor version and create a PR to initiate the entire RPM spec build and test.

56 changes: 56 additions & 0 deletions projects/golang/go/1.22/rpmbuild/SOURCES/golang.spec
Original file line number Diff line number Diff line change
@@ -0,0 +1,56 @@
Generate [an RPM Spec](https://rpm-software-management.github.io/rpm/manual/spec.html) for the target Go version.

EKS Go bases our RPM spec off of the upstream Amazon Linux or Fedora Golang RPM specs.
The best way to obtain a base RPMs for a given version of Go is to pull the upstream RPM from their package source,
unpack the RPM to obtain the spec file, and adapt the spec to build EKS Go at the appropriate path and tag, and apply our custom patches.

For example, to obtain a SPEC file for Go `1.19`, do the following:
1. Identify the proper RPM to base our EKS Go build on
1. identify the Amazon Linux 2 Golang RPM for the given version using `yum list —show-duplicates golang` on an Amazon Linux 2 machine.
1. If Amazon Linux does not yet support the given version of Golang, instead use [the Fedora yum repo](https://packages.fedoraproject.org/pkgs/golang/golang/) to find an appropriate RPM for the given Golang version.

1. Download and unpack the target RPM:
1. download the target RPM from the package repo and unpack it. The command below will download the target RPM and unpack it into the `~/rpmbuild` directory.
The `spec` file will be output to `~/rpmbuild/SPECS` and any sources (such as test files and patches) will be
output to `~/rpmbuild/SOURCES`.
```shell
yumdownloader --source golang-1.16.15-1.amzn2.0.1
rpm -ivh golang-1.16.15-1.amzn2.0.1.src.rpm
```
2. Copy the source files from `~/rpmbuild/SOURCES` to `projects/golang/go/$VERSION/rpmbuild/SOURCES`
1. Copy the spec file from `~rpmbuild/SPECS` to `projects/golang/go/$VERSION/rpmbuild/SPECS`.

1. Update the upstream Spec file with EKS Go conventions
1. EKS Go uses a specific RPM Release string to identify itself.
Find [the `RELEASE` string in the unpacked spec file](https://github.com/aws/eks-distro-build-tooling/blob/main/projects/golang/go/1.18/rpmbuild/SPECS/golang.spec#L121)
and modify it to use our format:
```shell
Release: %{?_buildid}%{?dist}.eks
```
2. EKS Go builds from cloned upstream source at build-time, rather than a pre-packaged source included with the RPM.
This means we need to modify the RPM setup directive to target the right directory.
Modify [the `autosetup` directive to follow the pattern we use in our other RPM spec files.](https://github.com/aws/eks-distro-build-tooling/blob/main/projects/golang/go/1.19/rpmbuild/SPECS/golang.spec#L293)
Specifically, ensure we're targeting the source directory of the format `go-go%{go_version}`.

1. Add EKS Go specific patches

Next, add any additional required patch files to the `SOURCES` directory, and [update the modified spec file to apply them](https://github.com/aws/eks-distro-build-tooling/blob/main/projects/golang/go/1.19/rpmbuild/SPECS/golang.spec#L165).
Golang RPM spec files after Go 1.16 use the RPM directive [`autosetup`](https://github.com/aws/eks-distro-build-tooling/blob/main/projects/golang/go/1.19/rpmbuild/SPECS/golang.spec#L293), so all you need to do to apply a patch at build time is define it as a Patch source in the spec.

EKS Go currently requires one custom patch for each Go version, above and beyond the security patches.
This patch allows us to skip specific Golang standard library tests in certain circumstances, such as skipping privilleged tests which call `mount` when we're building the RPM in a container[^1].
You can find [the Go 1.19 version of that patch here](../../1.19/patches/0104-add-method-to-skip-privd-tests-if-required.patch).



1. Document your work in the RPM spec changelog

Add [a changelog entry to the RPM spec](https://github.com/aws/eks-distro-build-tooling/blob/main/projects/golang/go/1.16/rpmbuild/SPECS/golang.spec#L558) outlining the changes made to the RPM spec

1. Commit the spec file, sources, and any other changes, and push to your fork of EKS Distro build tooling, and open a work-in-progress PR with a hold on it.
In the next step we'll set up prow jobs to will let us test all of this work by running a prow pre-submit against this PR.

Now that we've set up the project structure, sourced and customized a Golang Spec file, and applied our custom patches, we need to test!
The easiest way to do this is to set up the EKS Go pre-submits for the given version and let them do the testing.
That way, you can simply commit your new EKS Go minor version and create a PR to initiate the entire RPM spec build and test.

4 changes: 3 additions & 1 deletion projects/golang/go/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -34,12 +34,14 @@ TODO for WIP:

## Supported Versions
EKS currently supports the following Golang versions:
- [`v1.22`](./1.22/GIT_TAG)
- [`v1.21`](./1.21/GIT_TAG)
- [`v1.20`](./1.20/GIT_TAG)
- [`v1.19`](./1.19/GIT_TAG)



## Deprecated Versions
- [`v1.19`](./1.19/GIT_TAG)
- [`v1.18`](./1.18/GIT_TAG)
- [`v1.17`](./1.16/GIT_TAG)
- [`v1.16`](./1.16/GIT_TAG)
Expand Down

0 comments on commit 21044e4

Please sign in to comment.