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 Your Fork

To begin the process of creating a PR, you must create a local copy of the GitHub repository. In this step you will be obtaining the wrf-model fork from the GitHub web interface and putting it 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 your remote fork. If you wish to clone this directory to a name other than “WRF” (which is recommeded), 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 directory of WRF (from above, it would be WRF_NAME_OF_YOUT_CHOICE). When you cloned this wrf-model fork, the clone command set up an alias named “origin.” Origin points to the the wrf-model GitHub fork. You also need to set your a remote to your fork, which is later used to issue a pull request
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 you choose 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.0.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 that is identified by the PR labels, check it out:
    git checkout <most_recent_release_bug_fix_branch>

  2. From the current branch, 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 named 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 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>
    Use a different name other than "release-v4.x.y" for your local branch name. Typically it is a short description that is associated with the modification that you are making: "PBL_divide_by_zero", "initialize_nml_for_FDDA", etc.

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. A user can either include that template at this point (located in WRF/tools/commit_form.txt) or use the same template that is 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. At the top of the PR edit page, you will see something like:
    " wants to merge 1 commit into base:master from :my_branch>"

    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.