diff --git a/.github/workflows/create-draft-release.yml b/.github/workflows/create-draft-release.yml new file mode 100644 index 00000000000..44592276b3b --- /dev/null +++ b/.github/workflows/create-draft-release.yml @@ -0,0 +1,59 @@ +name: 'Create draft release from upstream' + +on: + workflow_dispatch: + inputs: + release: + description: 'Upstream release' + required: true + type: string + publish: + description: 'Whether to publish the release to GitHub on success' + type: boolean + required: false + default: false + +jobs: + publish-draft-release: + runs-on: ubuntu-latest + name: Publish draft release + steps: + - name: Checkout + uses: actions/checkout@v4 + with: + token: ${{ secrets.CREATE_RELEASE_AUTOMATION_TOKEN }} + - name: Configure git + run: | + git config --global user.name "shiftbot" + git config --global user.email "github@brendanforster.com" + git remote add upstream https://github.com/desktop/desktop.git + shell: bash + - name: Create baseline branch on fork + id: create-baseline-branch + env: + RELEASE_TAG: ${{ inputs.release }} + BASE_BRANCH: 'linux-${{ inputs.release }}' + run: | + git fetch upstream 'refs/tags/*:refs/tags/*' + git checkout -b $BASE_BRANCH $RELEASE_TAG + git push origin $BASE_BRANCH + git config -l --show-origin + shell: bash + - name: Rebase Linux customizations on top of upstream release branch + id: rebase-linux-branch + env: + HEAD_BRANCH: 'apply-changes-${{ inputs.release }}' + BASE_BRANCH: 'linux-${{ inputs.release }}' + run: | + git fetch origin linux + git fetch upstream development + git checkout -b development upstream/development + git checkout -b $HEAD_BRANCH linux + git submodule update + echo "Rebasing onto $BASE_BRANCH the difference between development and $HEAD_BRANCH" + echo "BASE_BRANCH: $(git rev-parse $BASE_BRANCH)" + echo "development: $(git rev-parse development)" + echo "HEAD_BRANCH: $(git rev-parse $HEAD_BRANCH)" + git rebase --onto $BASE_BRANCH development $HEAD_BRANCH + git push origin $HEAD_BRANCH + shell: bash