Fixing a broken TEMPLATE branch
If merge conflicts are resolved via the GitHub interface instead of after pulling changes to a fork as described in the sync
documentation, the commit history from the dev
branch will be merged into TEMPLATE
.
This leads to complex problems in later TEMPLATE
merges as the later updated TEMPLATE
branch removes all the pipeline-specific files that were accidentally included in problematic merge, resulting in many (in some cases >100!) of files to resolve conflicts in.
If during one of the automated syncs you see you have an usually high number of changed files you can check whether dev
was accidentally merged into TEMPLATE
by looking at how many commits the TEMPLATE
branch has (should be in the range of 5-15ish, depending on how many template updates your pipeline has had). You can also look at your repository’s GitHub Network Graph under the “Insights” tab or even look through the TEMPLATE
branch commit history to see if there is a commit described as ‘Merge branch dev
into TEMPLATE
’.
If so, the easiest solution is to start your TEMPLATE
branch from scratch.
-
Clone the main nf-core pipeline repository to your local machine (not your development fork)
-
Next, retrieve the commit hash when the original nf-core template was used to generate pipeline i.e. with
nf-core create
.-
Assuming you originally started with the nf-core template, you can simply look at your git log from within your repository:
-
The first commit will then typically represent the original template, with a commit message like
initial template build from nf-core/tools, version 1.9
-
-
Reset the
TEMPLATE
branch back to this commit, discarding all changes after that -
Push this cleaned branch back to the repository - use
--force
to overwrite the history there:- This will then replace the broken
TEMPLATE
branch on GitHub with a nice clean one, which can be viewable by checking the commit history.
WarningYou are irreversibly overwriting git history here - make sure that you get the branch names right!
- This will then replace the broken
-
We can switch back to
dev
, and runnf-core sync
to do it’s magic and get the latest version of the template. -
You probably want to now delete your local copy of the pipeline that you checked out from the main nf-core repository.
-
On your personal fork of the pipeline you’ll want to pull in this fresh template branch:
With this, you’re now ready to re-make the pull request from TEMPLATE
into dev
, and locally manually resolve conflicts (if required) following the git instructions in the sync
documentation.