This GitHub action creates a new branch and pull request against the parent repository when submodules are updated
The end goal of this tool:
- Create a new branch on the parent repository and get all submodules updates
- Create a pull request from newly created branch
To use this GitHub Action you will need to complete the following in the submodule repository:
- Parent repository has
.gitmodules
configured - Store GitHub token into secrets with permissions to write to parent repository
- Create a new file in your repository called
.github/workflows/submodule-update.yml
- Copy the example workflow from below into that new file and modify as needed
- Commit that file to a new branch
- Observe the action working
This file should have the following code:
---
name: Submodule Updates
#############################
# Start the job on all push #
#############################
on:
push:
branches: [develop]
###############
# Set the Job #
###############
jobs:
build:
name: Submodule update
runs-on: ubuntu-latest
env:
PARENT_REPOSITORY: 'org/example-repository'
CHECKOUT_BRANCH: 'develop'
PR_AGAINST_BRANCH: 'develop'
OWNER: 'org'
steps:
##########################
# Checkout the code base #
##########################
- name: Checkout Code
uses: actions/checkout@v4
####################################
# Run the action against code base #
####################################
- name: run action
id: run_action
uses: releasehub-com/github-action-create-pr-parent-submodule@v4
with:
github_token: ${{ secrets.RELEASE_HUB_SECRET }}
parent_repository: ${{ env.PARENT_REPOSITORY }}
checkout_branch: ${{ env.CHECKOUT_BRANCH}}
pr_against_branch: ${{ env.PR_AGAINST_BRANCH }}
pr_title: 'Optional title to override the default'
pr_description: 'Optional description to override the default'
owner: ${{ env.OWNER }}
Working example from the CanDIG project: CanDIG/candigv2-ingest workflow file
This action builds on prior work by: