Skip to content

Commit

Permalink
Migrate to ghcr.io
Browse files Browse the repository at this point in the history
Signed-off-by: Daichi Sakaue <daichi-sakaue@cybozu.co.jp>
  • Loading branch information
yokaze committed Feb 8, 2024
1 parent 3776877 commit 9250b4a
Show file tree
Hide file tree
Showing 10 changed files with 31 additions and 24 deletions.
12 changes: 8 additions & 4 deletions .github/workflows/release.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -5,18 +5,22 @@ on:
- 'v*'
jobs:
image:
name: Push images to quay.io
name: Push container images
runs-on: ubuntu-22.04
steps:
- uses: actions/checkout@v3
- uses: actions/setup-go@v4
with:
go-version-file: go.mod
- name: Log in quay.io
run: echo ${{ secrets.QUAY_PASSWORD }} | docker login -u ${{ secrets.QUAY_USER }} --password-stdin quay.io
- name: Login to GitHub Container Registry
uses: docker/login-action@v3
with:
registry: ghcr.io
username: ${{ github.actor }}
password: ${{ secrets.GITHUB_TOKEN }}
- run: make setup
- run: make image
- run: make tag push IMAGE_PREFIX=quay.io/cybozu/ IMAGE_TAG=${GITHUB_REF#refs/tags/v}
- run: make tag push IMAGE_PREFIX=ghcr.io/cybozu-go/ IMAGE_TAG=${GITHUB_REF#refs/tags/v}
release:
name: Release on GitHub
needs: image
Expand Down
8 changes: 5 additions & 3 deletions Dockerfile
Original file line number Diff line number Diff line change
@@ -1,10 +1,11 @@
FROM quay.io/cybozu/golang:1.20-jammy as builder
FROM ghcr.io/cybozu/golang:1.20-jammy as builder

WORKDIR /workspace
COPY . .
RUN make build

FROM quay.io/cybozu/ubuntu:22.04 as controller
FROM ghcr.io/cybozu/ubuntu:22.04 as controller
LABEL org.opencontainers.image.source="https://github.com/cybozu-go/meows"

COPY --from=builder /workspace/tmp/bin/controller /usr/local/bin
COPY --from=builder /workspace/tmp/bin/slack-agent /usr/local/bin
Expand All @@ -13,7 +14,8 @@ COPY --from=builder /workspace/tmp/bin/meows /usr/local/bin
USER 10000:10000
ENTRYPOINT ["controller"]

FROM quay.io/cybozu/ubuntu:22.04 as runner
FROM ghcr.io/cybozu/ubuntu:22.04 as runner
LABEL org.opencontainers.image.source="https://github.com/cybozu-go/meows"

# Even if the version of the runner is out of date, it will self-update at job execution time. So there is no problem to update it when you notice.
# TODO: Until https://github.com/cybozu-go/meows/issues/137 is fixed, update it manually.
Expand Down
6 changes: 3 additions & 3 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -41,8 +41,8 @@ You can run jobs in your GitHub Actions workflows on your Kubernetes cluster wit

## Docker images

Docker images are available on [Quay.io](https://quay.io/repository/cybozu)
- [Controller](https://quay.io/repository/cybozu/meows-controller)
- [Runner](https://quay.io/repository/cybozu/meows-runner)
Docker images are available on [ghcr.io](https://github.com/orgs/cybozu-go/packages?repo_name=meows)
- [Controller](https://github.com/cybozu-go/meows/pkgs/container/meows-controller)
- [Runner](https://github.com/cybozu-go/meows/pkgs/container/meows-runner)

[releases]: https://github.com/cybozu-go/meows/releases
2 changes: 1 addition & 1 deletion cmd/controller/cmd/root.go
Original file line number Diff line number Diff line change
Expand Up @@ -12,7 +12,7 @@ import (
"sigs.k8s.io/controller-runtime/pkg/log/zap"
)

const defaultRunnerImage = "quay.io/cybozu/meows-runner:" + constants.Version
const defaultRunnerImage = "ghcr.io/cybozu-go/meows-runner:" + constants.Version

var config struct {
zapOpts zap.Options
Expand Down
2 changes: 1 addition & 1 deletion config/agent/kustomization.yaml
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
namespace: meows

images:
- name: quay.io/cybozu/meows-controller
- name: ghcr.io/cybozu-go/meows-controller
newTag: 0.13.0

commonLabels:
Expand Down
2 changes: 1 addition & 1 deletion config/agent/manifests.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -47,7 +47,7 @@ spec:
spec:
containers:
- name: agent
image: quay.io/cybozu/meows-controller:latest
image: ghcr.io/cybozu-go/meows-controller:latest
command:
- "slack-agent"
envFrom:
Expand Down
2 changes: 1 addition & 1 deletion config/controller/deployment.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -19,7 +19,7 @@ spec:
runAsNonRoot: true
containers:
- name: controller
image: quay.io/cybozu/meows-controller:latest
image: ghcr.io/cybozu-go/meows-controller:latest
env:
- name: POD_NAMESPACE
valueFrom:
Expand Down
2 changes: 1 addition & 1 deletion config/controller/kustomization.yaml
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
namespace: meows

images:
- name: quay.io/cybozu/meows-controller
- name: ghcr.io/cybozu-go/meows-controller
newTag: 0.13.0

namePrefix: meows-
Expand Down
13 changes: 4 additions & 9 deletions kindtest/helper_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,6 @@ import (
"bytes"
"context"
"encoding/json"
"errors"
"fmt"
"os"
"os/exec"
Expand Down Expand Up @@ -190,16 +189,12 @@ func findDebuggingPod(pods *corev1.PodList) (*corev1.Pod, *runner.Status) {
func waitJobCompletion(namespace, runnerpool string) (*corev1.Pod, *runner.Status) {
var po *corev1.Pod
var status *runner.Status
EventuallyWithOffset(1, func() error {
EventuallyWithOffset(1, func(g Gomega) {
pods, err := fetchRunnerPods(namespace, runnerpool)
if err != nil {
return err
}
g.Expect(err).NotTo(HaveOccurred())

po, status = findDebuggingPod(pods)
if po == nil {
return errors.New("one pod should become debugging state")
}
return nil
g.Expect(po).NotTo(BeNil(), "one pod should become debugging state")
}, 3*time.Minute, 500*time.Millisecond).ShouldNot(HaveOccurred())
return po, status
}
Expand Down
6 changes: 6 additions & 0 deletions kindtest/runner_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -124,6 +124,12 @@ func testRunner() {
})))

By("checking pdb")
Eventually(func(g Gomega) {
_, stderr, err := kubectl("get", "pdb", "-n", repoRunner1NS, assignedPod.Name)
g.Expect(err).NotTo(HaveOccurred(), fmt.Errorf("stderr: %s", stderr))
}).Should(Succeed())

By("trying to evict the pod")
_, stderr, err := kubectl("evict", "-n", repoRunner1NS, assignedPod.Name)
Expect(err).Should(HaveOccurred())
// The error message should be: "Error: Cannot evict pod as it would violate the pod's disruption budget."
Expand Down

0 comments on commit 9250b4a

Please sign in to comment.