mirror of
https://github.com/rocky-linux/peridot.git
synced 2024-12-18 17:08:29 +00:00
Prow deployment manifests
This commit is contained in:
parent
ce3a4c0373
commit
891d1bae2c
0
infrastructure/prow/BUILD.bazel
Normal file
0
infrastructure/prow/BUILD.bazel
Normal file
127
infrastructure/prow/configmaps.yaml
Normal file
127
infrastructure/prow/configmaps.yaml
Normal file
@ -0,0 +1,127 @@
|
||||
# Updated using inrepoconfig, initial should be uncommented
|
||||
# ---
|
||||
# apiVersion: v1
|
||||
# kind: ConfigMap
|
||||
# metadata:
|
||||
# namespace: prow
|
||||
# name: plugins
|
||||
# data:
|
||||
# plugins.yaml: |
|
||||
# plugins:
|
||||
# rocky-linux/peridot:
|
||||
# plugins:
|
||||
# - approve
|
||||
# - assign
|
||||
# - blunderbuss
|
||||
# - cat
|
||||
# - config-updater
|
||||
# - dog
|
||||
# - help
|
||||
# - heart
|
||||
# - hold
|
||||
# - label
|
||||
# - lgtm
|
||||
# - trigger
|
||||
# - verify-owners
|
||||
# - wip
|
||||
# - yuks
|
||||
# config_updater:
|
||||
# maps:
|
||||
# config/prow/config.yaml:
|
||||
# name: config
|
||||
# config/prow/plugins.yaml:
|
||||
# name: plugins
|
||||
# config/jobs/**/*.{yaml,yml}:
|
||||
# name: job-config
|
||||
# gzip: true
|
||||
# ---
|
||||
# apiVersion: v1
|
||||
# kind: ConfigMap
|
||||
# metadata:
|
||||
# namespace: prow
|
||||
# name: config
|
||||
# data:
|
||||
# config.yaml: |
|
||||
# prowjob_namespace: prow
|
||||
# pod_namespace: test-pods
|
||||
# allowed_clusters:
|
||||
# rocky-linux/peridot:
|
||||
# - default
|
||||
# deck:
|
||||
# spyglass:
|
||||
# lenses:
|
||||
# - lens:
|
||||
# name: metadata
|
||||
# required_files:
|
||||
# - started.json|finished.json
|
||||
# - lens:
|
||||
# config:
|
||||
# name: buildlog
|
||||
# required_files:
|
||||
# - build-log.txt
|
||||
# - lens:
|
||||
# name: junit
|
||||
# required_files:
|
||||
# - bazel-testlogs/.*/test.xml
|
||||
# - lens:
|
||||
# name: podinfo
|
||||
# required_files:
|
||||
# - podinfo.json
|
||||
# plank:
|
||||
# job_url_prefix_config:
|
||||
# "*": https://prow.build.resf.org/view/
|
||||
# report_templates:
|
||||
# '*': >-
|
||||
# [Full PR test history](https://prow.build.resf.org/pr-history?org={{.Spec.Refs.Org}}&repo={{.Spec.Refs.Repo}}&pr={{with index .Spec.Refs.Pulls 0}}{{.Number}}{{end}}).
|
||||
# [Your PR dashboard](https://prow.build.resf.org/pr?query=is:pr+state:open+author:{{with
|
||||
# index .Spec.Refs.Pulls 0}}{{.Author}}{{end}}).
|
||||
# default_decoration_configs:
|
||||
# "*":
|
||||
# gcs_configuration:
|
||||
# bucket: s3://resf-prod-prow-logs
|
||||
# path_strategy: explicit
|
||||
# s3_credentials_secret: s3-credentials
|
||||
# utility_images:
|
||||
# clonerefs: gcr.io/k8s-prow/clonerefs:v20221028-a8625c1f93
|
||||
# entrypoint: gcr.io/k8s-prow/entrypoint:v20221028-a8625c1f93
|
||||
# initupload: gcr.io/k8s-prow/initupload:v20221028-a8625c1f93
|
||||
# sidecar: gcr.io/k8s-prow/sidecar:v20221028-a8625c1f93
|
||||
# tide:
|
||||
# queries:
|
||||
# - labels:
|
||||
# - lgtm
|
||||
# - approved
|
||||
# missingLabels:
|
||||
# - needs-rebase
|
||||
# - do-not-merge/hold
|
||||
# - do-not-merge/work-in-progress
|
||||
# - do-not-merge/invalid-owners-file
|
||||
# repos:
|
||||
# - rocky-linux/peridot
|
||||
# decorate_all_jobs: true
|
||||
# presubmits:
|
||||
# rocky-linux/peridot:
|
||||
# - name: pull-peridot-validate-prow-yaml
|
||||
# run_if_changed: '^(config/prow/(config|plugins).yaml$|config/jobs/.*.yaml$)'
|
||||
# decorate: true
|
||||
# spec:
|
||||
# containers:
|
||||
# - image: gcr.io/k8s-prow/checkconfig:v20221028-a8625c1f93
|
||||
# command:
|
||||
# - checkconfig
|
||||
# args:
|
||||
# - --config-path=config/prow/config.yaml
|
||||
# - --job-config-path=config/jobs
|
||||
# - --plugin-config=config/prow/plugins.yaml
|
||||
# - --strict
|
||||
#
|
||||
# - name: pull-peridot-unit-test
|
||||
# branches:
|
||||
# - main
|
||||
# always_run: true
|
||||
# decorate: true
|
||||
# spec:
|
||||
# containers:
|
||||
# - image: alpine
|
||||
# command:
|
||||
# - /bin/date
|
518
infrastructure/prow/deployments.yaml
Normal file
518
infrastructure/prow/deployments.yaml
Normal file
@ -0,0 +1,518 @@
|
||||
---
|
||||
apiVersion: apps/v1
|
||||
kind: Deployment
|
||||
metadata:
|
||||
namespace: prow
|
||||
name: hook
|
||||
labels:
|
||||
app: hook
|
||||
spec:
|
||||
replicas: 2
|
||||
strategy:
|
||||
type: RollingUpdate
|
||||
rollingUpdate:
|
||||
maxSurge: 1
|
||||
maxUnavailable: 1
|
||||
selector:
|
||||
matchLabels:
|
||||
app: hook
|
||||
template:
|
||||
metadata:
|
||||
labels:
|
||||
app: hook
|
||||
spec:
|
||||
serviceAccountName: "hook"
|
||||
terminationGracePeriodSeconds: 180
|
||||
containers:
|
||||
- name: hook
|
||||
image: gcr.io/k8s-prow/hook:v20221028-a8625c1f93
|
||||
imagePullPolicy: Always
|
||||
args:
|
||||
- --dry-run=false
|
||||
- --config-path=/etc/config/config.yaml
|
||||
- --github-endpoint=http://ghproxy
|
||||
- --github-endpoint=https://api.github.com
|
||||
- --github-app-id=$(GITHUB_APP_ID)
|
||||
- --github-app-private-key-path=/etc/github/cert
|
||||
env:
|
||||
- name: GITHUB_APP_ID
|
||||
valueFrom:
|
||||
secretKeyRef:
|
||||
name: github-token
|
||||
key: appid
|
||||
ports:
|
||||
- name: http
|
||||
containerPort: 8888
|
||||
volumeMounts:
|
||||
- name: hmac
|
||||
mountPath: /etc/webhook
|
||||
readOnly: true
|
||||
- name: github-token
|
||||
mountPath: /etc/github
|
||||
readOnly: true
|
||||
- name: config
|
||||
mountPath: /etc/config
|
||||
readOnly: true
|
||||
- name: plugins
|
||||
mountPath: /etc/plugins
|
||||
readOnly: true
|
||||
livenessProbe:
|
||||
httpGet:
|
||||
path: /healthz
|
||||
port: 8081
|
||||
initialDelaySeconds: 3
|
||||
periodSeconds: 3
|
||||
readinessProbe:
|
||||
httpGet:
|
||||
path: /healthz/ready
|
||||
port: 8081
|
||||
initialDelaySeconds: 10
|
||||
periodSeconds: 3
|
||||
timeoutSeconds: 600
|
||||
volumes:
|
||||
- name: hmac
|
||||
secret:
|
||||
secretName: hmac-token
|
||||
- name: github-token
|
||||
secret:
|
||||
secretName: github-token
|
||||
- name: config
|
||||
configMap:
|
||||
name: config
|
||||
- name: plugins
|
||||
configMap:
|
||||
name: plugins
|
||||
---
|
||||
apiVersion: apps/v1
|
||||
kind: Deployment
|
||||
metadata:
|
||||
namespace: prow
|
||||
name: sinker
|
||||
labels:
|
||||
app: sinker
|
||||
spec:
|
||||
selector:
|
||||
matchLabels:
|
||||
app: sinker
|
||||
replicas: 1
|
||||
template:
|
||||
metadata:
|
||||
labels:
|
||||
app: sinker
|
||||
spec:
|
||||
serviceAccountName: "sinker"
|
||||
containers:
|
||||
- name: sinker
|
||||
image: gcr.io/k8s-prow/sinker:v20221028-a8625c1f93
|
||||
args:
|
||||
- --config-path=/etc/config/config.yaml
|
||||
- --dry-run=false
|
||||
volumeMounts:
|
||||
- name: config
|
||||
mountPath: /etc/config
|
||||
readOnly: true
|
||||
volumes:
|
||||
- name: config
|
||||
configMap:
|
||||
name: config
|
||||
---
|
||||
apiVersion: apps/v1
|
||||
kind: Deployment
|
||||
metadata:
|
||||
namespace: prow
|
||||
name: deck
|
||||
labels:
|
||||
app: deck
|
||||
spec:
|
||||
replicas: 2
|
||||
strategy:
|
||||
type: RollingUpdate
|
||||
rollingUpdate:
|
||||
maxSurge: 1
|
||||
maxUnavailable: 1
|
||||
selector:
|
||||
matchLabels:
|
||||
app: deck
|
||||
template:
|
||||
metadata:
|
||||
labels:
|
||||
app: deck
|
||||
spec:
|
||||
serviceAccountName: "deck"
|
||||
terminationGracePeriodSeconds: 30
|
||||
containers:
|
||||
- name: deck
|
||||
image: gcr.io/k8s-prow/deck:v20221028-a8625c1f93
|
||||
args:
|
||||
- --config-path=/etc/config/config.yaml
|
||||
- --plugin-config=/etc/plugins/plugins.yaml
|
||||
- --tide-url=http://tide/
|
||||
- --hook-url=http://hook:8888/plugin-help
|
||||
- --github-endpoint=http://ghproxy
|
||||
- --github-endpoint=https://api.github.com
|
||||
- --github-graphql-endpoint=http://ghproxy/graphql
|
||||
- --s3-credentials-file=/etc/s3-credentials/service-account.json
|
||||
- --spyglass=true
|
||||
- --github-app-id=$(GITHUB_APP_ID)
|
||||
- --github-app-private-key-path=/etc/github/cert
|
||||
env:
|
||||
- name: GITHUB_APP_ID
|
||||
valueFrom:
|
||||
secretKeyRef:
|
||||
name: github-token
|
||||
key: appid
|
||||
ports:
|
||||
- name: http
|
||||
containerPort: 8080
|
||||
volumeMounts:
|
||||
- name: config
|
||||
mountPath: /etc/config
|
||||
readOnly: true
|
||||
- name: github-token
|
||||
mountPath: /etc/github
|
||||
readOnly: true
|
||||
- name: plugins
|
||||
mountPath: /etc/plugins
|
||||
readOnly: true
|
||||
- name: s3-credentials
|
||||
mountPath: /etc/s3-credentials
|
||||
readOnly: true
|
||||
livenessProbe:
|
||||
httpGet:
|
||||
path: /healthz
|
||||
port: 8081
|
||||
initialDelaySeconds: 3
|
||||
periodSeconds: 3
|
||||
readinessProbe:
|
||||
httpGet:
|
||||
path: /healthz/ready
|
||||
port: 8081
|
||||
initialDelaySeconds: 10
|
||||
periodSeconds: 3
|
||||
timeoutSeconds: 600
|
||||
volumes:
|
||||
- name: config
|
||||
configMap:
|
||||
name: config
|
||||
- name: github-token
|
||||
secret:
|
||||
secretName: github-token
|
||||
- name: plugins
|
||||
configMap:
|
||||
name: plugins
|
||||
- name: s3-credentials
|
||||
secret:
|
||||
secretName: s3-credentials
|
||||
---
|
||||
apiVersion: apps/v1
|
||||
kind: Deployment
|
||||
metadata:
|
||||
namespace: prow
|
||||
name: horologium
|
||||
labels:
|
||||
app: horologium
|
||||
spec:
|
||||
replicas: 1 # Do not scale up.
|
||||
strategy:
|
||||
type: Recreate
|
||||
selector:
|
||||
matchLabels:
|
||||
app: horologium
|
||||
template:
|
||||
metadata:
|
||||
labels:
|
||||
app: horologium
|
||||
spec:
|
||||
serviceAccountName: "horologium"
|
||||
terminationGracePeriodSeconds: 30
|
||||
containers:
|
||||
- name: horologium
|
||||
image: gcr.io/k8s-prow/horologium:v20221028-a8625c1f93
|
||||
args:
|
||||
- --dry-run=false
|
||||
- --config-path=/etc/config/config.yaml
|
||||
volumeMounts:
|
||||
- name: config
|
||||
mountPath: /etc/config
|
||||
readOnly: true
|
||||
volumes:
|
||||
- name: config
|
||||
configMap:
|
||||
name: config
|
||||
---
|
||||
apiVersion: apps/v1
|
||||
kind: Deployment
|
||||
metadata:
|
||||
namespace: prow
|
||||
name: tide
|
||||
labels:
|
||||
app: tide
|
||||
spec:
|
||||
replicas: 1 # Do not scale up.
|
||||
strategy:
|
||||
type: Recreate
|
||||
selector:
|
||||
matchLabels:
|
||||
app: tide
|
||||
template:
|
||||
metadata:
|
||||
labels:
|
||||
app: tide
|
||||
spec:
|
||||
serviceAccountName: "tide"
|
||||
containers:
|
||||
- name: tide
|
||||
image: gcr.io/k8s-prow/tide:v20221028-a8625c1f93
|
||||
args:
|
||||
- --dry-run=false
|
||||
- --config-path=/etc/config/config.yaml
|
||||
- --github-endpoint=http://ghproxy
|
||||
- --github-endpoint=https://api.github.com
|
||||
- --github-graphql-endpoint=http://ghproxy/graphql
|
||||
- --s3-credentials-file=/etc/s3-credentials/service-account.json
|
||||
- --status-path=s3://resf-prod-prow-tide/tide-status
|
||||
- --history-uri=s3://resf-prod-prow-tide/tide-history.json
|
||||
- --github-app-id=$(GITHUB_APP_ID)
|
||||
- --github-app-private-key-path=/etc/github/cert
|
||||
env:
|
||||
- name: GITHUB_APP_ID
|
||||
valueFrom:
|
||||
secretKeyRef:
|
||||
name: github-token
|
||||
key: appid
|
||||
ports:
|
||||
- name: http
|
||||
containerPort: 8888
|
||||
volumeMounts:
|
||||
- name: github-token
|
||||
mountPath: /etc/github
|
||||
readOnly: true
|
||||
- name: config
|
||||
mountPath: /etc/config
|
||||
readOnly: true
|
||||
- name: s3-credentials
|
||||
mountPath: /etc/s3-credentials
|
||||
readOnly: true
|
||||
volumes:
|
||||
- name: github-token
|
||||
secret:
|
||||
secretName: github-token
|
||||
- name: config
|
||||
configMap:
|
||||
name: config
|
||||
- name: s3-credentials
|
||||
secret:
|
||||
secretName: s3-credentials
|
||||
---
|
||||
apiVersion: apps/v1
|
||||
kind: Deployment
|
||||
metadata:
|
||||
name: statusreconciler
|
||||
namespace: prow
|
||||
labels:
|
||||
app: statusreconciler
|
||||
spec:
|
||||
replicas: 1
|
||||
selector:
|
||||
matchLabels:
|
||||
app: statusreconciler
|
||||
template:
|
||||
metadata:
|
||||
labels:
|
||||
app: statusreconciler
|
||||
spec:
|
||||
serviceAccountName: statusreconciler
|
||||
terminationGracePeriodSeconds: 180
|
||||
containers:
|
||||
- name: statusreconciler
|
||||
image: gcr.io/k8s-prow/status-reconciler:v20221028-a8625c1f93
|
||||
args:
|
||||
- --dry-run=false
|
||||
- --continue-on-error=true
|
||||
- --plugin-config=/etc/plugins/plugins.yaml
|
||||
- --config-path=/etc/config/config.yaml
|
||||
- --github-endpoint=http://ghproxy
|
||||
- --github-endpoint=https://api.github.com
|
||||
- --s3-credentials-file=/etc/s3-credentials/service-account.json
|
||||
- --status-path=s3://resf-prod-prow-status-reconciler/status-reconciler-status
|
||||
- --github-app-id=$(GITHUB_APP_ID)
|
||||
- --github-app-private-key-path=/etc/github/cert
|
||||
env:
|
||||
- name: GITHUB_APP_ID
|
||||
valueFrom:
|
||||
secretKeyRef:
|
||||
name: github-token
|
||||
key: appid
|
||||
volumeMounts:
|
||||
- name: github-token
|
||||
mountPath: /etc/github
|
||||
readOnly: true
|
||||
- name: config
|
||||
mountPath: /etc/config
|
||||
readOnly: true
|
||||
- name: plugins
|
||||
mountPath: /etc/plugins
|
||||
readOnly: true
|
||||
- name: s3-credentials
|
||||
mountPath: /etc/s3-credentials
|
||||
readOnly: true
|
||||
volumes:
|
||||
- name: github-token
|
||||
secret:
|
||||
secretName: github-token
|
||||
- name: config
|
||||
configMap:
|
||||
name: config
|
||||
- name: plugins
|
||||
configMap:
|
||||
name: plugins
|
||||
- name: s3-credentials
|
||||
secret:
|
||||
secretName: s3-credentials
|
||||
---
|
||||
apiVersion: apps/v1
|
||||
kind: Deployment
|
||||
metadata:
|
||||
namespace: prow
|
||||
name: ghproxy
|
||||
labels:
|
||||
app: ghproxy
|
||||
spec:
|
||||
selector:
|
||||
matchLabels:
|
||||
app: ghproxy
|
||||
strategy:
|
||||
type: Recreate
|
||||
# GHProxy does not support HA
|
||||
replicas: 1
|
||||
template:
|
||||
metadata:
|
||||
labels:
|
||||
app: ghproxy
|
||||
spec:
|
||||
containers:
|
||||
- name: ghproxy
|
||||
image: gcr.io/k8s-prow/ghproxy:v20221028-a8625c1f93
|
||||
args:
|
||||
- --cache-dir=/cache
|
||||
- --cache-sizeGB=99
|
||||
- --serve-metrics=true
|
||||
ports:
|
||||
- containerPort: 8888
|
||||
volumeMounts:
|
||||
- name: cache
|
||||
mountPath: /cache
|
||||
volumes:
|
||||
- name: cache
|
||||
persistentVolumeClaim:
|
||||
claimName: ghproxy
|
||||
---
|
||||
apiVersion: apps/v1
|
||||
kind: Deployment
|
||||
metadata:
|
||||
namespace: prow
|
||||
name: prow-controller-manager
|
||||
labels:
|
||||
app: prow-controller-manager
|
||||
spec:
|
||||
replicas: 1
|
||||
selector:
|
||||
matchLabels:
|
||||
app: prow-controller-manager
|
||||
template:
|
||||
metadata:
|
||||
labels:
|
||||
app: prow-controller-manager
|
||||
spec:
|
||||
serviceAccountName: prow-controller-manager
|
||||
containers:
|
||||
- name: prow-controller-manager
|
||||
args:
|
||||
- --dry-run=false
|
||||
- --config-path=/etc/config/config.yaml
|
||||
- --github-endpoint=http://ghproxy
|
||||
- --github-endpoint=https://api.github.com
|
||||
- --enable-controller=plank
|
||||
- --github-app-id=$(GITHUB_APP_ID)
|
||||
- --github-app-private-key-path=/etc/github/cert
|
||||
env:
|
||||
- name: GITHUB_APP_ID
|
||||
valueFrom:
|
||||
secretKeyRef:
|
||||
name: github-token
|
||||
key: appid
|
||||
image: gcr.io/k8s-prow/prow-controller-manager:v20221028-a8625c1f93
|
||||
volumeMounts:
|
||||
- name: github-token
|
||||
mountPath: /etc/github
|
||||
readOnly: true
|
||||
- name: config
|
||||
mountPath: /etc/config
|
||||
readOnly: true
|
||||
volumes:
|
||||
- name: github-token
|
||||
secret:
|
||||
secretName: github-token
|
||||
- name: config
|
||||
configMap:
|
||||
name: config
|
||||
---
|
||||
apiVersion: apps/v1
|
||||
kind: Deployment
|
||||
metadata:
|
||||
namespace: prow
|
||||
name: crier
|
||||
labels:
|
||||
app: crier
|
||||
spec:
|
||||
replicas: 1
|
||||
selector:
|
||||
matchLabels:
|
||||
app: crier
|
||||
template:
|
||||
metadata:
|
||||
labels:
|
||||
app: crier
|
||||
spec:
|
||||
serviceAccountName: crier
|
||||
terminationGracePeriodSeconds: 30
|
||||
containers:
|
||||
- name: crier
|
||||
image: gcr.io/k8s-prow/crier:v20221028-a8625c1f93
|
||||
args:
|
||||
- --blob-storage-workers=10
|
||||
- --config-path=/etc/config/config.yaml
|
||||
- --s3-credentials-file=/etc/s3-credentials/service-account.json
|
||||
- --github-endpoint=http://ghproxy
|
||||
- --github-endpoint=https://api.github.com
|
||||
- --github-workers=10
|
||||
- --kubernetes-blob-storage-workers=10
|
||||
- --github-app-id=$(GITHUB_APP_ID)
|
||||
- --github-app-private-key-path=/etc/github/cert
|
||||
env:
|
||||
- name: GITHUB_APP_ID
|
||||
valueFrom:
|
||||
secretKeyRef:
|
||||
name: github-token
|
||||
key: appid
|
||||
volumeMounts:
|
||||
- name: config
|
||||
mountPath: /etc/config
|
||||
readOnly: true
|
||||
- name: github-token
|
||||
mountPath: /etc/github
|
||||
readOnly: true
|
||||
- name: s3-credentials
|
||||
mountPath: /etc/s3-credentials
|
||||
readOnly: true
|
||||
volumes:
|
||||
- name: config
|
||||
configMap:
|
||||
name: config
|
||||
- name: github-token
|
||||
secret:
|
||||
secretName: github-token
|
||||
- name: s3-credentials
|
||||
secret:
|
||||
secretName: s3-credentials
|
||||
---
|
12
infrastructure/prow/namespaces.yaml
Normal file
12
infrastructure/prow/namespaces.yaml
Normal file
@ -0,0 +1,12 @@
|
||||
---
|
||||
apiVersion: v1
|
||||
kind: Namespace
|
||||
metadata:
|
||||
name: prow
|
||||
labels:
|
||||
istio-injection: enabled
|
||||
---
|
||||
apiVersion: v1
|
||||
kind: Namespace
|
||||
metadata:
|
||||
name: test-pods
|
14
infrastructure/prow/pvcs.yaml
Normal file
14
infrastructure/prow/pvcs.yaml
Normal file
@ -0,0 +1,14 @@
|
||||
---
|
||||
kind: PersistentVolumeClaim
|
||||
apiVersion: v1
|
||||
metadata:
|
||||
namespace: prow
|
||||
labels:
|
||||
app: ghproxy
|
||||
name: ghproxy
|
||||
spec:
|
||||
accessModes:
|
||||
- ReadWriteOnce
|
||||
resources:
|
||||
requests:
|
||||
storage: 100Gi
|
162
infrastructure/prow/rolebindings.yaml
Normal file
162
infrastructure/prow/rolebindings.yaml
Normal file
@ -0,0 +1,162 @@
|
||||
---
|
||||
kind: RoleBinding
|
||||
apiVersion: rbac.authorization.k8s.io/v1
|
||||
metadata:
|
||||
namespace: prow
|
||||
name: "deck"
|
||||
roleRef:
|
||||
apiGroup: rbac.authorization.k8s.io
|
||||
kind: Role
|
||||
name: "deck"
|
||||
subjects:
|
||||
- kind: ServiceAccount
|
||||
name: "deck"
|
||||
---
|
||||
kind: RoleBinding
|
||||
apiVersion: rbac.authorization.k8s.io/v1
|
||||
metadata:
|
||||
namespace: test-pods
|
||||
name: "deck"
|
||||
roleRef:
|
||||
apiGroup: rbac.authorization.k8s.io
|
||||
kind: Role
|
||||
name: "deck"
|
||||
subjects:
|
||||
- kind: ServiceAccount
|
||||
name: "deck"
|
||||
namespace: prow
|
||||
---
|
||||
kind: RoleBinding
|
||||
apiVersion: rbac.authorization.k8s.io/v1
|
||||
metadata:
|
||||
namespace: prow
|
||||
name: "horologium"
|
||||
roleRef:
|
||||
apiGroup: rbac.authorization.k8s.io
|
||||
kind: Role
|
||||
name: "horologium"
|
||||
subjects:
|
||||
- kind: ServiceAccount
|
||||
name: "horologium"
|
||||
---
|
||||
kind: RoleBinding
|
||||
apiVersion: rbac.authorization.k8s.io/v1
|
||||
metadata:
|
||||
namespace: prow
|
||||
name: "sinker"
|
||||
roleRef:
|
||||
apiGroup: rbac.authorization.k8s.io
|
||||
kind: Role
|
||||
name: "sinker"
|
||||
subjects:
|
||||
- kind: ServiceAccount
|
||||
name: "sinker"
|
||||
---
|
||||
kind: RoleBinding
|
||||
apiVersion: rbac.authorization.k8s.io/v1
|
||||
metadata:
|
||||
namespace: test-pods
|
||||
name: "sinker"
|
||||
roleRef:
|
||||
apiGroup: rbac.authorization.k8s.io
|
||||
kind: Role
|
||||
name: "sinker"
|
||||
subjects:
|
||||
- kind: ServiceAccount
|
||||
name: "sinker"
|
||||
namespace: prow
|
||||
---
|
||||
kind: RoleBinding
|
||||
apiVersion: rbac.authorization.k8s.io/v1
|
||||
metadata:
|
||||
namespace: prow
|
||||
name: "hook"
|
||||
roleRef:
|
||||
apiGroup: rbac.authorization.k8s.io
|
||||
kind: Role
|
||||
name: "hook"
|
||||
subjects:
|
||||
- kind: ServiceAccount
|
||||
name: "hook"
|
||||
---
|
||||
kind: RoleBinding
|
||||
apiVersion: rbac.authorization.k8s.io/v1
|
||||
metadata:
|
||||
namespace: prow
|
||||
name: "tide"
|
||||
roleRef:
|
||||
apiGroup: rbac.authorization.k8s.io
|
||||
kind: Role
|
||||
name: "tide"
|
||||
subjects:
|
||||
- kind: ServiceAccount
|
||||
name: "tide"
|
||||
---
|
||||
kind: RoleBinding
|
||||
apiVersion: rbac.authorization.k8s.io/v1
|
||||
metadata:
|
||||
namespace: prow
|
||||
name: "statusreconciler"
|
||||
roleRef:
|
||||
apiGroup: rbac.authorization.k8s.io
|
||||
kind: Role
|
||||
name: "statusreconciler"
|
||||
subjects:
|
||||
- kind: ServiceAccount
|
||||
name: "statusreconciler"
|
||||
---
|
||||
kind: RoleBinding
|
||||
apiVersion: rbac.authorization.k8s.io/v1
|
||||
metadata:
|
||||
namespace: prow
|
||||
name: prow-controller-manager
|
||||
roleRef:
|
||||
apiGroup: rbac.authorization.k8s.io
|
||||
kind: Role
|
||||
name: prow-controller-manager
|
||||
subjects:
|
||||
- kind: ServiceAccount
|
||||
name: prow-controller-manager
|
||||
---
|
||||
kind: RoleBinding
|
||||
apiVersion: rbac.authorization.k8s.io/v1
|
||||
metadata:
|
||||
namespace: test-pods
|
||||
name: prow-controller-manager
|
||||
roleRef:
|
||||
apiGroup: rbac.authorization.k8s.io
|
||||
kind: Role
|
||||
name: prow-controller-manager
|
||||
subjects:
|
||||
- kind: ServiceAccount
|
||||
name: prow-controller-manager
|
||||
namespace: prow
|
||||
---
|
||||
kind: RoleBinding
|
||||
apiVersion: rbac.authorization.k8s.io/v1
|
||||
metadata:
|
||||
name: crier
|
||||
namespace: prow
|
||||
roleRef:
|
||||
apiGroup: rbac.authorization.k8s.io
|
||||
kind: Role
|
||||
name: crier
|
||||
subjects:
|
||||
- kind: ServiceAccount
|
||||
name: crier
|
||||
namespace: prow
|
||||
---
|
||||
kind: RoleBinding
|
||||
apiVersion: rbac.authorization.k8s.io/v1
|
||||
metadata:
|
||||
name: crier
|
||||
namespace: test-pods
|
||||
roleRef:
|
||||
apiGroup: rbac.authorization.k8s.io
|
||||
kind: Role
|
||||
name: crier
|
||||
subjects:
|
||||
- kind: ServiceAccount
|
||||
name: crier
|
||||
namespace: prow
|
||||
|
262
infrastructure/prow/roles.yaml
Normal file
262
infrastructure/prow/roles.yaml
Normal file
@ -0,0 +1,262 @@
|
||||
---
|
||||
kind: Role
|
||||
apiVersion: rbac.authorization.k8s.io/v1
|
||||
metadata:
|
||||
namespace: prow
|
||||
name: "deck"
|
||||
rules:
|
||||
- apiGroups:
|
||||
- "prow.k8s.io"
|
||||
resources:
|
||||
- prowjobs
|
||||
verbs:
|
||||
- get
|
||||
- list
|
||||
- watch
|
||||
---
|
||||
kind: Role
|
||||
apiVersion: rbac.authorization.k8s.io/v1
|
||||
metadata:
|
||||
namespace: test-pods
|
||||
name: "deck"
|
||||
rules:
|
||||
- apiGroups:
|
||||
- ""
|
||||
resources:
|
||||
- pods/log
|
||||
verbs:
|
||||
- get
|
||||
---
|
||||
kind: Role
|
||||
apiVersion: rbac.authorization.k8s.io/v1
|
||||
metadata:
|
||||
namespace: prow
|
||||
name: "horologium"
|
||||
rules:
|
||||
- apiGroups:
|
||||
- "prow.k8s.io"
|
||||
resources:
|
||||
- prowjobs
|
||||
verbs:
|
||||
- create
|
||||
- list
|
||||
- watch
|
||||
---
|
||||
kind: Role
|
||||
apiVersion: rbac.authorization.k8s.io/v1
|
||||
metadata:
|
||||
namespace: prow
|
||||
name: "sinker"
|
||||
rules:
|
||||
- apiGroups:
|
||||
- "prow.k8s.io"
|
||||
resources:
|
||||
- prowjobs
|
||||
verbs:
|
||||
- delete
|
||||
- list
|
||||
- watch
|
||||
- get
|
||||
- apiGroups:
|
||||
- coordination.k8s.io
|
||||
resources:
|
||||
- leases
|
||||
resourceNames:
|
||||
- prow-sinker-leaderlock
|
||||
verbs:
|
||||
- get
|
||||
- update
|
||||
- apiGroups:
|
||||
- coordination.k8s.io
|
||||
resources:
|
||||
- leases
|
||||
verbs:
|
||||
- create
|
||||
- apiGroups:
|
||||
- ""
|
||||
resources:
|
||||
- configmaps
|
||||
resourceNames:
|
||||
- prow-sinker-leaderlock
|
||||
verbs:
|
||||
- get
|
||||
- update
|
||||
- apiGroups:
|
||||
- ""
|
||||
resources:
|
||||
- configmaps
|
||||
- events
|
||||
verbs:
|
||||
- create
|
||||
---
|
||||
kind: Role
|
||||
apiVersion: rbac.authorization.k8s.io/v1
|
||||
metadata:
|
||||
namespace: test-pods
|
||||
name: "sinker"
|
||||
rules:
|
||||
- apiGroups:
|
||||
- ""
|
||||
resources:
|
||||
- pods
|
||||
verbs:
|
||||
- delete
|
||||
- list
|
||||
- watch
|
||||
- get
|
||||
- patch
|
||||
---
|
||||
kind: Role
|
||||
apiVersion: rbac.authorization.k8s.io/v1
|
||||
metadata:
|
||||
namespace: prow
|
||||
name: "hook"
|
||||
rules:
|
||||
- apiGroups:
|
||||
- "prow.k8s.io"
|
||||
resources:
|
||||
- prowjobs
|
||||
verbs:
|
||||
- create
|
||||
- get
|
||||
- list
|
||||
- update
|
||||
- apiGroups:
|
||||
- ""
|
||||
resources:
|
||||
- configmaps
|
||||
verbs:
|
||||
- create
|
||||
- get
|
||||
- update
|
||||
---
|
||||
kind: Role
|
||||
apiVersion: rbac.authorization.k8s.io/v1
|
||||
metadata:
|
||||
namespace: prow
|
||||
name: "tide"
|
||||
rules:
|
||||
- apiGroups:
|
||||
- "prow.k8s.io"
|
||||
resources:
|
||||
- prowjobs
|
||||
verbs:
|
||||
- create
|
||||
- list
|
||||
- get
|
||||
- watch
|
||||
---
|
||||
kind: Role
|
||||
apiVersion: rbac.authorization.k8s.io/v1
|
||||
metadata:
|
||||
namespace: prow
|
||||
name: "statusreconciler"
|
||||
rules:
|
||||
- apiGroups:
|
||||
- "prow.k8s.io"
|
||||
resources:
|
||||
- prowjobs
|
||||
verbs:
|
||||
- create
|
||||
---
|
||||
kind: Role
|
||||
apiVersion: rbac.authorization.k8s.io/v1
|
||||
metadata:
|
||||
namespace: prow
|
||||
name: prow-controller-manager
|
||||
rules:
|
||||
- apiGroups:
|
||||
- "prow.k8s.io"
|
||||
resources:
|
||||
- prowjobs
|
||||
verbs:
|
||||
- get
|
||||
- list
|
||||
- watch
|
||||
- update
|
||||
- patch
|
||||
- apiGroups:
|
||||
- coordination.k8s.io
|
||||
resources:
|
||||
- leases
|
||||
resourceNames:
|
||||
- prow-controller-manager-leader-lock
|
||||
verbs:
|
||||
- get
|
||||
- update
|
||||
- apiGroups:
|
||||
- coordination.k8s.io
|
||||
resources:
|
||||
- leases
|
||||
verbs:
|
||||
- create
|
||||
- apiGroups:
|
||||
- ""
|
||||
resources:
|
||||
- configmaps
|
||||
resourceNames:
|
||||
- prow-controller-manager-leader-lock
|
||||
verbs:
|
||||
- get
|
||||
- update
|
||||
- apiGroups:
|
||||
- ""
|
||||
resources:
|
||||
- configmaps
|
||||
- events
|
||||
verbs:
|
||||
- create
|
||||
---
|
||||
kind: Role
|
||||
apiVersion: rbac.authorization.k8s.io/v1
|
||||
metadata:
|
||||
namespace: test-pods
|
||||
name: prow-controller-manager
|
||||
rules:
|
||||
- apiGroups:
|
||||
- ""
|
||||
resources:
|
||||
- pods
|
||||
verbs:
|
||||
- delete
|
||||
- list
|
||||
- watch
|
||||
- create
|
||||
- patch
|
||||
---
|
||||
kind: Role
|
||||
apiVersion: rbac.authorization.k8s.io/v1
|
||||
metadata:
|
||||
namespace: prow
|
||||
name: crier
|
||||
rules:
|
||||
- apiGroups:
|
||||
- "prow.k8s.io"
|
||||
resources:
|
||||
- "prowjobs"
|
||||
verbs:
|
||||
- "get"
|
||||
- "watch"
|
||||
- "list"
|
||||
- "patch"
|
||||
---
|
||||
kind: Role
|
||||
apiVersion: rbac.authorization.k8s.io/v1
|
||||
metadata:
|
||||
namespace: test-pods
|
||||
name: crier
|
||||
rules:
|
||||
- apiGroups:
|
||||
- ""
|
||||
resources:
|
||||
- "pods"
|
||||
- "events"
|
||||
verbs:
|
||||
- "get"
|
||||
- "list"
|
||||
- apiGroups:
|
||||
- ""
|
||||
resources:
|
||||
- "pods"
|
||||
verbs:
|
||||
- "patch"
|
41
infrastructure/prow/secrets.yaml
Normal file
41
infrastructure/prow/secrets.yaml
Normal file
@ -0,0 +1,41 @@
|
||||
---
|
||||
# Get this from Github
|
||||
# apiVersion: v1
|
||||
# kind: Secret
|
||||
# metadata:
|
||||
# namespace: prow
|
||||
# name: github-token
|
||||
# stringData:
|
||||
# cert: <<insert-downloaded-cert-here>>
|
||||
# appid: <<insert-the-app-id-here>>
|
||||
# ---
|
||||
# Generate this manually
|
||||
# apiVersion: v1
|
||||
# kind: Secret
|
||||
# metadata:
|
||||
# namespace: prow
|
||||
# name: hmac-token
|
||||
# stringData:
|
||||
# # Generate via `openssl rand -hex 20`. This is the secret used in the GitHub webhook configuration
|
||||
# hmac: << insert-hmac-token-here >>
|
||||
apiVersion: v1
|
||||
kind: Secret
|
||||
metadata:
|
||||
namespace: prow
|
||||
name: s3-credentials
|
||||
stringData:
|
||||
service-account.json: |
|
||||
{
|
||||
"region": "us-east-2"
|
||||
}
|
||||
---
|
||||
apiVersion: v1
|
||||
kind: Secret
|
||||
metadata:
|
||||
namespace: test-pods
|
||||
name: s3-credentials
|
||||
stringData:
|
||||
service-account.json: |
|
||||
{
|
||||
"region": "us-east-2"
|
||||
}
|
64
infrastructure/prow/serviceaccounts.yaml
Normal file
64
infrastructure/prow/serviceaccounts.yaml
Normal file
@ -0,0 +1,64 @@
|
||||
---
|
||||
kind: ServiceAccount
|
||||
apiVersion: v1
|
||||
metadata:
|
||||
namespace: prow
|
||||
name: "deck"
|
||||
annotations:
|
||||
eks.amazonaws.com/role-arn: arn:aws:iam::893168113496:role/resf-prow-peridot
|
||||
---
|
||||
kind: ServiceAccount
|
||||
apiVersion: v1
|
||||
metadata:
|
||||
namespace: prow
|
||||
name: "horologium"
|
||||
annotations:
|
||||
eks.amazonaws.com/role-arn: arn:aws:iam::893168113496:role/resf-prow-peridot
|
||||
---
|
||||
kind: ServiceAccount
|
||||
apiVersion: v1
|
||||
metadata:
|
||||
namespace: prow
|
||||
name: "sinker"
|
||||
annotations:
|
||||
eks.amazonaws.com/role-arn: arn:aws:iam::893168113496:role/resf-prow-peridot
|
||||
---
|
||||
apiVersion: v1
|
||||
kind: ServiceAccount
|
||||
metadata:
|
||||
namespace: prow
|
||||
name: "hook"
|
||||
annotations:
|
||||
eks.amazonaws.com/role-arn: arn:aws:iam::893168113496:role/resf-prow-peridot
|
||||
---
|
||||
apiVersion: v1
|
||||
kind: ServiceAccount
|
||||
metadata:
|
||||
namespace: prow
|
||||
name: "tide"
|
||||
annotations:
|
||||
eks.amazonaws.com/role-arn: arn:aws:iam::893168113496:role/resf-prow-peridot
|
||||
---
|
||||
apiVersion: v1
|
||||
kind: ServiceAccount
|
||||
metadata:
|
||||
namespace: prow
|
||||
name: "statusreconciler"
|
||||
annotations:
|
||||
eks.amazonaws.com/role-arn: arn:aws:iam::893168113496:role/resf-prow-peridot
|
||||
---
|
||||
apiVersion: v1
|
||||
kind: ServiceAccount
|
||||
metadata:
|
||||
namespace: prow
|
||||
name: prow-controller-manager
|
||||
annotations:
|
||||
eks.amazonaws.com/role-arn: arn:aws:iam::893168113496:role/resf-prow-peridot
|
||||
---
|
||||
kind: ServiceAccount
|
||||
apiVersion: v1
|
||||
metadata:
|
||||
name: crier
|
||||
namespace: prow
|
||||
annotations:
|
||||
eks.amazonaws.com/role-arn: arn:aws:iam::893168113496:role/resf-prow-peridot
|
54
infrastructure/prow/services.yaml
Normal file
54
infrastructure/prow/services.yaml
Normal file
@ -0,0 +1,54 @@
|
||||
---
|
||||
apiVersion: v1
|
||||
kind: Service
|
||||
metadata:
|
||||
namespace: prow
|
||||
name: hook
|
||||
spec:
|
||||
selector:
|
||||
app: hook
|
||||
ports:
|
||||
- port: 8888
|
||||
---
|
||||
apiVersion: v1
|
||||
kind: Service
|
||||
metadata:
|
||||
namespace: prow
|
||||
name: deck
|
||||
spec:
|
||||
selector:
|
||||
app: deck
|
||||
ports:
|
||||
- port: 80
|
||||
targetPort: 8080
|
||||
---
|
||||
apiVersion: v1
|
||||
kind: Service
|
||||
metadata:
|
||||
namespace: prow
|
||||
name: tide
|
||||
spec:
|
||||
selector:
|
||||
app: tide
|
||||
ports:
|
||||
- port: 80
|
||||
targetPort: 8888
|
||||
---
|
||||
apiVersion: v1
|
||||
kind: Service
|
||||
metadata:
|
||||
labels:
|
||||
app: ghproxy
|
||||
namespace: prow
|
||||
name: ghproxy
|
||||
spec:
|
||||
ports:
|
||||
- name: main
|
||||
port: 80
|
||||
protocol: TCP
|
||||
targetPort: 8888
|
||||
- name: metrics
|
||||
port: 9090
|
||||
selector:
|
||||
app: ghproxy
|
||||
type: ClusterIP
|
29
infrastructure/prow/virtualservice.yaml
Normal file
29
infrastructure/prow/virtualservice.yaml
Normal file
@ -0,0 +1,29 @@
|
||||
---
|
||||
apiVersion: networking.istio.io/v1beta1
|
||||
kind: VirtualService
|
||||
metadata:
|
||||
name: prow
|
||||
namespace: prow
|
||||
annotations:
|
||||
external-dns.alpha.kubernetes.io/target: ingress.build.resf.org
|
||||
spec:
|
||||
gateways:
|
||||
- istio-system/base-gateway-public
|
||||
hosts:
|
||||
- prow.build.resf.org
|
||||
http:
|
||||
- name: hook
|
||||
match:
|
||||
- uri:
|
||||
prefix: "/hook"
|
||||
route:
|
||||
- destination:
|
||||
host: hook.prow.svc.cluster.local
|
||||
port:
|
||||
number: 8888
|
||||
- name: deck
|
||||
route:
|
||||
- destination:
|
||||
host: deck.prow.svc.cluster.local
|
||||
port:
|
||||
number: 80
|
Loading…
Reference in New Issue
Block a user