Skip to content

Latest commit

 

History

History
85 lines (57 loc) · 5.28 KB

TEAM.md

File metadata and controls

85 lines (57 loc) · 5.28 KB

Editor Team Instructions

This document contains information used by the editors maintaining the specification.

Approving Pull Requests

  1. Use your judgement for approving editorial changes and improvements. In general we don't need lots of review for these changes. If a change improves the readability of the spec or corrects a typo then it doesn't represent a significant contribution from an IP perspective.

  2. Substantive normative changes should be approved by two editors. If the PR originated from outside the editorial team, then two editors should indicate their support before it is merged. If the PR was submitted by an editor, then another editor is able to merge it.

  3. If the Pull Request contains a normative change to the specification and the IPR check fails because the contributor is either not part of the working group or not yet known to the IPR checker then please contact the chairs and do not merge the PR. The chairs will either update the tool if the contributor is a member or otherwise resolve the issue.

  4. Travis-CI runs against all pull requests on the master branch. If the build fails due to a Bikeshed error then the pull request should not be merged until it has been corrected to build without errors. If a broken pull request is merged then the main spec build will be broken.

  5. The editors should review the contribution considerations listed in the README.md file.

  6. Use your judgement before approving a change that might be considered controversial. In general, such changes often need a wider review from the working group and should not be merged before that happens. Of course, we can revert or amend changes if it is clear that they don't represent WG consensus so it is a judgement call.

  7. Note: the editors don't need to create pull requests for editorial changes. Editors may commit these changes directly to the repository. Editors should create pull requests for normative changes associated with a bug or issue. Editors may merge their own pull requests if they are expected to be uncontroversial. Again, use good judgement .

Automatic build process

The spec is built by Travis-CI when a change is committed to the master branch. This rebuilds all the files in the gh-pages branch and replaces them in the repo. You should not edit or commit into the gh-pages branch since any changes here will be lost with the next build.

The build process uses an up-to-date version of the Bikeshed script but uses a cached version of the Bikeshed spec-data. This is to ensure that real-time changes to this data do not break the spec build. To update the cached data to the latest version, run bikeshed update locally and copy the spec-data files into the .spec-data folder in the master branch in the repo.

Handling Pull Requests

This spec does not use the green "Merge pull request" button. This ensures that each change is a single commit on the main master branch.

The following subsections contain instructions for merging. They assume the Bash functions that follow them are present.

Merging Pull Requests from Forks

  1. git checkout master

  2. pr <pull request ID>

  3. If the pull request contains multiple commits, squash them as appropriate.

    • In general, all commits and merges should be squashed into a single commit.
    • If commits or sets of commits represent multiple distinct actions (i.e. do something then rename a variable), then the branch might be squashed into two or more commits, each representing a distinct action.
    • Squash commits by running git rebase -i origin/master then using squash on the commit(s) to be squashed.
  4. If the commit message needs to be updated (i.e. To add "Fix #<bug ID>: "), do one of the following and update the message:

    • Run git rebase -i origin/master then use reword to select the commit(s) to reword.
    • Run git commit --amend and edit the last commit message.
  5. git push

  6. Close the pull request by following these steps in the web interface:

  7. Let hash be the the commit hash.

  8. Navigate to the pull request.

  9. Add a comment that say "Merged as hash." and click the "Close pull request" button to post that comment.

Merging Pull Requests from Branches

For pull requests coming from branches within this repository, use the same steps above except use mypr and there is no reason to use the web interface.

git push will automatically close the pull request and mark it as merged, since the commits contained there were updated.

Bash Functions

The following is based on https://github.com/whatwg/html/blob/master/TEAM.md.

pr () {
  git fetch origin refs/pull/$1/head:refs/remotes/origin/pr/$1 --force
  git checkout -b pr/$1 origin/pr/$1
  git rebase master
  git checkout master
  git merge pr/$1 --ff-only
}

Pulls down the PR into a local branch, using the special refs GitHub provides; rebases the PR's commits on top of master; and does a fast-forward only merge into master.

mypr () {
  git checkout $1
  git rebase master
  git push origin $1 --force
  git checkout master
  git merge $1 --ff-only
}

Rebases the PR on top of master; force-pushes it to the appropriate branch, thus updating the PR; and does the fast-forward only merge into master.