Skip to content
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 1 addition & 1 deletion .ci-operator.yaml
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
build_root_image:
name: boilerplate
namespace: openshift
tag: image-v8.3.6
tag: image-v8.4.1
4 changes: 0 additions & 4 deletions .tekton/OWNERS

This file was deleted.

3 changes: 1 addition & 2 deletions OWNERS
Original file line number Diff line number Diff line change
Expand Up @@ -3,8 +3,7 @@ approvers:
- bergmannf
- tkong-redhat
- rbhilare
- srep-functional-leads
- srep-team-leads
- rosa-staff-engineers
reviewers:
- iamkirkbater
- bergmannf
Expand Down
66 changes: 36 additions & 30 deletions OWNERS_ALIASES
Original file line number Diff line number Diff line change
Expand Up @@ -26,7 +26,6 @@ aliases:
- cjnovak98
srep-functional-team-hulk:
- ravitri
- devppratik
- Tafhim
- tkong-redhat
- TheUndeadKing
Expand All @@ -51,15 +50,6 @@ aliases:
- Mhodesty
- nephomaniac
- tnierman
srep-functional-team-security:
- jaybeeunix
- sam-nguyen7
- wshearn
- dem4gus
- npecka
- pshickeydev
- casey-williams-rh
- boranx
srep-functional-team-thor:
- diakovnec
- MitaliBhalla
Expand All @@ -68,26 +58,42 @@ aliases:
- xiaoyu74
- Tessg22
- smarthall
srep-infra-cicd:
- ritmun
- yiqinzhang
- varunraokadaparthi
srep-functional-leads:
- clcollins
rosa-staff-engineers:
- Ajpantuso
- bergmannf
- theautoroboto
- smarthall
- sam-nguyen7
- ravitri
srep-team-leads:
- rafael-azevedo
- iamkirkbater
- dustman9000
- bmeng
- bpresnel-rh
- cdoan1
- clcollins
- dustman9000
- joshbranham
- jmelis
- lucasponce
- psav
- rafael-azevedo
- ravitri
- rbhilare
- robpblake
- smarthall
- syed
- theautoroboto
- tiwillia
- typeid
sre-group-leads:
- apahim
- maorfr
- rogbas
srep-architects:
- cblecker
rosa-managers:
- afreiberger
- c-e-brumm
- drewandersonnz
- evalis1
- geowa4
- jcaianirh
- jnewton75
- krishvoor
- kseiter-rh
- OliviaHY
- syncrou
- tdrozdowski
- tkiss28
- vkumar51
hp-architects:
- deads2k
- jhjaggars
2 changes: 1 addition & 1 deletion boilerplate/_data/backing-image-tag
Original file line number Diff line number Diff line change
@@ -1 +1 @@
image-v8.3.6
image-v8.4.1
2 changes: 1 addition & 1 deletion boilerplate/_data/last-boilerplate-commit
Original file line number Diff line number Diff line change
@@ -1 +1 @@
1cb129aed5a91f2098f70c0e141561e00b1e16fc
00d8a1c7487680d8ced308bea3468ca7f89ab866
7 changes: 6 additions & 1 deletion boilerplate/_lib/container-make
Original file line number Diff line number Diff line change
Expand Up @@ -29,12 +29,14 @@ if [[ "${CONTAINER_ENGINE##*/}" == "podman" ]] && [[ $OSTYPE == *"linux"* ]]; th
else
CE_OPTS="${CE_OPTS} -v $REPO_ROOT:$CONTAINER_MOUNT"
fi
container_id=$($CONTAINER_ENGINE run -d ${CE_OPTS} $IMAGE_PULL_PATH sleep infinity)
container_id=$($CONTAINER_ENGINE run --rm -d ${CE_OPTS} $IMAGE_PULL_PATH sleep infinity)

if [[ $? -ne 0 ]] || [[ -z "$container_id" ]]; then
err "Couldn't start detached container"
fi

trap "$CONTAINER_ENGINE stop $container_id >/dev/null 2>&1" EXIT

# Now run our `make` command in it with the right UID and working directory
args="exec -it -u $(id -u):0 -w $CONTAINER_MOUNT $container_id"
banner "Running: make $@"
Expand All @@ -52,6 +54,9 @@ if [[ $rc -ne 0 ]]; then
fi
fi

# Disarm the interrupt trap -- normal cleanup handles it from here
trap - EXIT

# Finally, remove the container
banner "Cleaning up the container"
$CONTAINER_ENGINE rm -f $container_id >/dev/null
Expand Down
141 changes: 113 additions & 28 deletions boilerplate/_lib/subscriber-propose-update
Original file line number Diff line number Diff line change
Expand Up @@ -25,7 +25,7 @@ Quirks and Limitations:
- Is still slightly interactive, because 'gh pr create' likes to ask
questions about your origin and upstream.
EOF
exit -1
exit 1
}

source $REPO_ROOT/boilerplate/_lib/subscriber.sh
Expand All @@ -34,47 +34,101 @@ source $REPO_ROOT/boilerplate/_lib/subscriber.sh
[[ $# -eq 0 ]] && usage

TMPD=$(mktemp -d)
echo $TMPD;
trap "rm -fr $TMPD" EXIT

run_step() {
local title=$1
local log_file="$TMPD/$title.log"
log_file=$(tr '[:upper:]' '[:lower:]' <<< "$log_file")
log_file=$(tr ' ' '-' <<< "$log_file")
shift

if [[ $1 != "--" ]]; then
echo "ERR: expected '--' but got '$1'"
exit 1
fi
shift
echo -n "$title... "

if ! "$@" > "$log_file" 2>&1; then
echo " FAILED"
echo "!!!"
echo "!!! Boilerplate update failed for $subscriber"
echo "!!!"
echo ""
cat "$log_file"
exit 1
fi
echo " DONE"
}

sync_main() {
local main_branch=$1
shift

git pull upstream $main_branch
git push origin $main_branch
}

git_clean_and_push() {
local branch=$1
shift

git push --delete origin $branch || true
git push -u origin $branch
}

propose_update() {
local subscriber=$1
local proj=${subscriber#*/}

if [[ -z "$DRY_RUN" ]]; then
echo "DRY RUN: Would propose update for $subscriber"
return 0
fi

(
# Clone my fork of the subscriber repo
cd $TMPD
# This
# - uses the existing fork if one exists
# - sets 'origin' and 'upstream' remotes
gh repo fork $subscriber --clone=true --remote=true
# only clones the default branch to save disk space and time

run_step "Creating fork" -- gh repo fork $subscriber --clone=true --default-branch-only
cd $proj

# Current branch is 'master' or 'main'
cur_branch=$(current_branch .)
# Make sure our origin is synced with upstream, so our update
# commit is based off of the latest code.
# WARNING: This changes your fork!
git pull upstream $cur_branch
git push origin $cur_branch

# Create the update commit
make boilerplate-update
make boilerplate-commit

# And create the PR
# TODO: This is interactive. How do we tell gh "Yes, please use
# upstream as upstream and origin as origin?"
gh pr create -f
# Current branch is 'master' or 'main' or 'trunk'
main_branch=$(current_branch .)
run_step "Syncing Fork" -- sync_main $main_branch
# run_step "Pushing fork" -- git push origin $main_branch

# Create the update commit - only cat logs if something goes wrong.
run_step "Updating boilerplate" -- make boilerplate-update
run_step "Committing boilerplate update" -- make boilerplate-commit

boilerplate_branch=$(git rev-parse --abbrev-ref HEAD)
# By pushing to the origin boilerplate branch explicitly before opening a PR,
# we make don't get prompted for the branch to push to.
# If we still find that it's giving us an interactive prompt, we can otherwise
# use `gh api` to create the PR programmatically.
if [[ "$boilerplate_branch" == "$main_branch" ]]; then
echo "CRITICAL ERROR: boilerplate branch '$boilerplate_branch' is the same as main branch '$main_branch'"
echo "If you see this, something has gone terribly wrong"
echo "Skipping"
exit 20
fi
run_step "pushing update" -- git_clean_and_push $boilerplate_branch

gh pr create --repo $subscriber -f $DRY_RUN_FLAG
)
}

bp_master=$(git rev-parse master)

DRY_RUN_FLAG=""
if [[ -z "$DRY_RUN" ]]; then
echo "DRY RUN: ENABLED"
DRY_RUN_FLAG="--dry-run"
fi


for subscriber in $(subscriber_args "$@"); do

# Does this one need an update?
Expand All @@ -89,14 +143,45 @@ for subscriber in $(subscriber_args "$@"); do
continue
fi

# Is there already a PR proposed for this level?
existing_pr=$(gh pr list --repo $subscriber | grep -P ":boilerplate-\S+-$bp_master\s")
# Is there already a PR proposed for this commit?
pr_list=$(gh pr list --repo $subscriber --json headRefName,url,number | jq -r '. | map(select(.headRefName | startswith("boilerplate-update--")))')
existing_pr=$(jq -r ".[] | select(.headRefName == \"boilerplate-update--$bp_master\")" <<< "$pr_list")
if [[ -n "$existing_pr" ]]; then
echo "Subscriber '$subscriber' already has an open PR:"
echo "https://github.com/$subscriber/pull/$existing_pr"
echo "Subscriber '$subscriber' already has an open PR for this boilerplate commit:"
jq -r .url <<< "$existing_pr"
continue
fi

# Pull the trigger
propose_update "$subscriber"
if ! propose_update "$subscriber"; then
echo "Error: failed to propose update for '$subscriber'"
continue
fi

new_pr="XXXX"
# Get the new PR URL
# only run if not dry-run - otherwise the new_pr var will be empty
if [[ -n $DRY_RUN ]]; then
new_pr=$(gh pr list --repo $subscriber --json headRefName,number | jq -r ".[] | select(.headRefName == \"boilerplate-update--$bp_master\") | .number")
if [[ -z "$new_pr" ]]; then
echo "error: unable to find new PR for boilerplate update '$bp_master' on subscriber '$subscriber'"
continue
fi
fi

# Add comments to existing PRs to say they're superseded by this new one
if [[ -n "$pr_list" ]]; then
prs=$(jq -r '. | map(.number) | @tsv' <<< "$pr_list")
echo "Closing old PRs: $prs"
for pr in $prs; do
if [[ -z $DRY_RUN ]]; then
echo "Dry run - would close $pr with comment:"
echo " \"Superseded by #$new_pr.\""
continue
fi

gh pr close --repo $subscriber --comment "Superseded by #$new_pr." $pr
done
fi

done
4 changes: 2 additions & 2 deletions boilerplate/openshift/golang-osd-e2e/OWNERS
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
reviewers:
- srep-infra-cicd
- rosa-staff-engineers
approvers:
- srep-infra-cicd
- rosa-staff-engineers
11 changes: 8 additions & 3 deletions boilerplate/openshift/golang-osd-e2e/update
Original file line number Diff line number Diff line change
Expand Up @@ -12,25 +12,30 @@ source $CONVENTION_ROOT/_lib/common.sh

REPO_ROOT=$(git rev-parse --show-toplevel)
OPERATOR_NAME=$(sed -n 's/.*OperatorName .*=.*"\([^"]*\)".*/\1/p' "${REPO_ROOT}/config/config.go")
GO_MODULE_PATH=$(awk '/^module / { print $2; exit }' "${REPO_ROOT}/go.mod")
E2E_SUITE_DIRECTORY=$REPO_ROOT/test/e2e

if [[ -z "${GO_MODULE_PATH}" ]]; then
err "Could not read module path from ${REPO_ROOT}/go.mod"
fi

# Update operator name in templates
OPERATOR_UNDERSCORE_NAME=${OPERATOR_NAME//-/_}
OPERATOR_PROPER_NAME=$(echo "$OPERATOR_NAME" | sed 's/-/ /g' | awk '{for(i=1;i<=NF;i++){ $i=toupper(substr($i,1,1)) substr($i,2) }}1')
OPERATOR_NAME_CAMEL_CASE=${OPERATOR_PROPER_NAME// /}

mkdir -p "${E2E_SUITE_DIRECTORY}"

E2E_SUITE_BUILDER_IMAGE=registry.ci.openshift.org/openshift/release:rhel-9-release-golang-1.25-openshift-4.21
E2E_SUITE_BUILDER_IMAGE=registry.ci.openshift.org/openshift/release:rhel-9-release-golang-1.26-openshift-4.22
if [[ -n ${KONFLUX_BUILDS} ]]; then
E2E_SUITE_BUILDER_IMAGE="brew.registry.redhat.io/rh-osbs/openshift-golang-builder:rhel_9_1.25"
E2E_SUITE_BUILDER_IMAGE="brew.registry.redhat.io/rh-osbs/openshift-golang-builder:rhel_9_1.26"
fi

echo "syncing ${E2E_SUITE_DIRECTORY}/Dockerfile"
tee "${E2E_SUITE_DIRECTORY}/Dockerfile" <<EOF
# THIS FILE IS GENERATED BY BOILERPLATE. DO NOT EDIT.
FROM ${E2E_SUITE_BUILDER_IMAGE} as builder
WORKDIR /go/src/github.com/openshift/$OPERATOR_NAME/
WORKDIR /go/src/${GO_MODULE_PATH}/
COPY . .
RUN CGO_ENABLED=0 GOFLAGS="-mod=mod" go test ./test/e2e -v -c --tags=osde2e -o /e2e.test

Expand Down
Loading