Skip to content
Dave Gill edited this page Jul 13, 2020 · 25 revisions

The purpose of this document is to provide the necessary steps for a user to issue a Pull Request (PR) to the WRF source code. A PR is the only way that new code is introduced into the WRF system. There are two types of modifications that the WRF model accepts: bug fixes (typically smaller and fairly limited in scope), or development (typically larger and usually associated with a new feature).

Depending on the type of modification you are making, your workflow will slightly vary. Following these instructions will help to guide you through the process to create a PR. As mentioned, there are two types of workflows: 1) bug-fix, 2) development. If you are doing modifications for a bug-fix, you will want to base your modifications from the upcoming “release-*” branch, which uses the naming convention release-vX.X.X (e.g., release release-v4.2.1). If you are doing developmental work (or anything large enough that is not simply a bug fix), you will base you modifications from the “develop” branch.

The following are the sections in this document:

Table of Contents

  • Creating a Fork
  • Cloning Your Fork
  • Setting up Aliases for Code Updates
  • Creating a Branch
    • Creating a Branch for Bug Fix Modifications
    • Creating a Branch for Development Work
  • Staging Changes for a Commit
  • Committing Changes
  • Pushing a Branch
  • Creating a Pull Request

Creating a Fork

In order to be able to make changes to the code, you will need to first go to the wrf-model/WRF GitHub home page and create your own fork from the main remote wrf-model repository. At the top right-hand corner of the page, click “Fork,” which will allow GitHub to create a copy of the original repository, and then fork it to your own account. This automatically gives you read/write/administer permissions over your personal fork. The fork will contain all branches that existed in the original repository at the time of creation. You only need to do the "create a fork step" a single time.

Cloning the wrf-model Fork

To begin the process of creating a PR, you must create a local copy of the WRF repository. In this step you will be obtaining the wrf-model fork from the GitHub, and putting that entire repository on your local machine. From a terminal window, type:
git clone https://github.com/wrf-model/WRF

This will give you a new directory called “WRF” that will contain everything from the wrf-model remote fork. If you wish to clone this repository to a directory name other than “WRF” (which is recommended), you can use the command as follows:
git clone https://github.com/wrf-model/WRF WRF_NAME_OF_YOUR_CHOICE

Setting up Aliases for Code Updates

Go into your local copy of the WRF repository (from above, it would be cd WRF_NAME_OF_YOUT_CHOICE). When you cloned this wrf-model fork, the clone command set up an alias named “origin.” The origin identifier points to the the wrf-model GitHub fork. You also need to set your a remote to your fork, which is later used as the location when your new modifications are "pushed" to GitHub.
git remote add my_fork https://github.com/<My GitHub ID>/WRF

You can check that these point to the correct locations with:
git remote -v

Creating a Branch

If you have not previously made any changes in your local WRF repository, by default you are on the “master” branch. If interested, you can verify this:
git branch

This will list your working branches, with a " * " beside the branch you are currently on. When choosing your new working branch names, it is important to create descriptive and useful branch names to help remind yourself what these modifications are for. It is also important to branch off of the correct place: the most recent release branch (specifically for bug fixes) or the develop branch (specifically for new features or extensive restructuring).

Creating a Branch for Bug Fix Modifications

Bug fix modifications must ultimately be merged into a “release-vX.X.X” branch. An easy way to determine the release branch to target is to look at the labels for the existing pull requests:
https://github.com/wrf-model/WRF/pulls
The labels for the top several pull requests (PRs) typically identify either a specific release branch or the develop branch where these PRs are slated for. The indicated version from these release branch labels is what to select as the base branch for the modifications (and eventually where to propose the modifications).

  1. Use the following command to determine whether the appropriate release branch exists:
    git branch -a
    which will list all the available branches on the remote. You will see the appropriate release branch name (that was identified with the PR labels above); "check out" that branch:
    git checkout <most_recent_release_bug_fix_branch>

  2. Use the following command to ensure that your copy of the release branch is up-to-date:
    git pull origin <most_recent_release_bug_fix_branch>

  3. From the current branch, you can now create your new branch name (again, be descriptive for you own benefit), to which you will begin making modifications:
    git checkout -b <my_branch>
    You want to use a different name other than "develop" for your local copy of the development branch name. Typically a short description that is associated with the modification that you are making is helpful: "PBL_divide_by_zero", "initialize_nml_for_FDDA", etc.

You will now automatically be on the new branch (<my_branch>, or whatever you’ve named it). You can use the git branch command to see your current branch. At this point you are ready to make all the necessary bug-fix code modifications, and perform any necessary testing to your working branch.

Creating a Branch for Development Work

Developmental modifications must be made from the “develop” branch.

  1. Checkout the develop branch:
    git checkout develop
    You should now be able to see the develop branch if you issue git branch -a

  2. Use the following command to ensure that the branch is up-to-date:
    git pull origin develop

  3. From the current branch (develop), you can now create your new branch name, to which you will begin making modifications:
    git checkout -b <my_branch>

You will now automatically be on the new branch (<my_branch>, or whatever you’ve name it). Again, you can use the git branch command to see your current branch. At this point you are ready to make all the necessary developmental code modifications, and perform any necessary testing to your working branch.

Staging Changes for a Commit

Once you are happy with the modifications, you will need to stage the changes:
git status -uno

This will show you all files that have been modified that are under GitHub control. If you have added a new file, GitHub will not list this file yet. The files will be highlighted in red, meaning they have not yet been staged.
git add <modified path/file name>

You will do this for each file that you’d like to commit from the above list (including the list of new files, if you have any). Once you have added all the files, you can re-issue git status -uno and all files that will go into the commit will be highlighted in green.

Committing Changes

After staging your changes, and before pushing the changes to your remote fork, you will need to commit them to your local repository:
git commit

A text window will pop up for you to describe the modifications. The WRF code has a template to follow for the structure of the commit message. A user can either include that template at this point (located in WRF/tools/commit_form.txt) or use the template that is later available on GitHub. Enter either a short one-line description or use the template from tools/commit_form.txt, and then save the file.

#Pushing a Branch The next step will be to push the changes from this local branch to your remote fork of your repository: /WRF):
git push -u my_fork <my_branch>

#Creating a Pull Request Now that you have pushed your changes to your remote fork, you will need to go to the remote site and create a pull request (PR). This is a request to ask permission for your modifications to be merged into the main repository (either the WRF release branch, or the develop branch), that will eventually be included in the next minor/major release.

  1. Go to the wrf-model/WRF GitHub home page and at the top there will be a highlighted box that asks if you want to create a new pull request. Click it to do so.

  2. A commit message template will automatically be in the PR text box. Fill it out appropriately if you have not already done so. At the top of the PR edit page, you will see something like:
    " wants to merge 1 commit into base:master from :<my_branch>"

  3. You might need to select "compare across forks" so that the available options switch from: original
    to:
    develop
    or:
    release

Using the drop-down box, you will need to modify the "base" in that sentence to the newest release branch (e.g., base:release-v4.0.1), if you are submitting a bug fix PR (if it does not exist yet, you can leave the base as "master" for now, and the development team will create a new branch and correct the target), or to the “develop” branch if you are submitting a development PR. Once the development committee has approved the pull request, it will either be merged into the code by a member, or you will get a message that says that it’s ready to be merged. At that point, you can follow the link to the page, from your email, and click on the green "merge" button.