Skip to content

EmergencyReparentShard: filter lagging candidates from relaylog wait, handle partial failures and split-brain #55878

EmergencyReparentShard: filter lagging candidates from relaylog wait, handle partial failures and split-brain

EmergencyReparentShard: filter lagging candidates from relaylog wait, handle partial failures and split-brain #55878

Workflow file for this run

name: region_example
on:
push:
branches:
- "main"
- "release-[0-9]+.[0-9]"
tags: '**'
pull_request:
branches: '**'
permissions: read-all
env:
BOOTSTRAP_VERSION: "ci"
BOOTSTRAP_FLAVOR: "mysql84"
jobs:
build:
name: Region Sharding example using ${{ matrix.topo }} on Ubuntu
runs-on: oracle-vm-16cpu-64gb-x86-64
strategy:
matrix:
topo: [etcd]
steps:
- name: Harden the runner (Audit all outbound calls)
uses: step-security/harden-runner@8d3c67de8e2fe68ef647c8db1e6a09f647780f40 # v2.19.0
with:
egress-policy: audit
- name: Skip CI
run: |
if [[ "${{contains( github.event.pull_request.labels.*.name, 'Skip CI')}}" == "true" ]]; then
echo "skipping CI due to the 'Skip CI' label"
exit 1
fi
- name: Check out code
uses: actions/checkout@de0fac2e4500dabe0009e67214ff5f5447ce83dd # v6.0.2
with:
persist-credentials: 'false'
- name: Check for changes in relevant files
uses: dorny/paths-filter@fbd0ab8f3e69293af611ebaee6363fc25e6d187d # v4.0.1
id: changes
with:
token: ''
filters: |
examples:
- 'test/config.json'
- 'go/**/*.go'
- 'test.go'
- 'Makefile'
- 'build.env'
- 'go.sum'
- 'go.mod'
- 'proto/*.proto'
- 'tools/**'
- 'config/**'
- 'bootstrap.sh'
- 'examples/**'
- '.github/workflows/region_example.yml'
- name: Build bootstrap images
if: steps.changes.outputs.examples == 'true'
timeout-minutes: 15
uses: ./.github/actions/build-bootstrap
- name: Set up Go
if: steps.changes.outputs.examples == 'true'
uses: actions/setup-go@4a3601121dd01d1626a1e23e37211e3254c1c06c # v6.4.0
with:
go-version-file: go.mod
cache: ${{ (github.base_ref == 'main' || (github.base_ref == '' && github.ref_name == 'main')) && 'true' || 'false' }}
- name: Tune the OS
if: steps.changes.outputs.examples == 'true'
timeout-minutes: 5
uses: ./.github/actions/tune-os
- name: Get dependencies
if: steps.changes.outputs.examples == 'true'
timeout-minutes: 5
run: |
go mod download
- name: Run make minimaltools
if: steps.changes.outputs.examples == 'true'
timeout-minutes: 5
run: |
make minimaltools
- name: Build
if: steps.changes.outputs.examples == 'true'
timeout-minutes: 10
run: |
make build
- name: region_example
if: steps.changes.outputs.examples == 'true'
timeout-minutes: 30
run: |
export TOPO=${{matrix.topo}}
if [ "${{matrix.os}}" = "macos-latest" ]; then
export PATH="/usr/local/opt/mysql@5.7/bin:$PATH"
fi
go run test.go -print-log -follow -pull=false -flavor=${{ env.BOOTSTRAP_FLAVOR }} -bootstrap-version=${{ env.BOOTSTRAP_VERSION }} region_example