Skip to content
This repository has been archived by the owner on Apr 29, 2019. It is now read-only.

Maintainer Guide

Tan Wang Leng edited this page Apr 29, 2019 · 3 revisions

Note: The following pages are archived and may be outdated. Please visit https://markbind.org/devdocs/ for the latest version.


PR Merging Workflow

Approval

  • Once the first approval is given from a developer, assign a version milestone to the PR (this is usually the next version, unless there is a justification for delaying the merging to future versions).
    • Note: Should there be a subsequent rejection by other reviewers (or an error is spotted), the version milestone is removed immediately. The version milestone should only be restored once the new approvals come in.
  • Once the second approval is given from a senior developer (or there are >= 3 approvals given from anyone), the PR can be merged immediately.
    • If there is no second approval yet, please wait for a day before merging the PR without the second approval.
    • Rationale: This is to allow other developers the chance to review the PR, and delay the merge if there's any significant problems. Not everyone is available all of the time, so please be patient.
    • Note: If the PR is too simple (e.g. correcting a simple typo), one approval is sufficient for merging, and this requirement is relaxed.

Actual Merging

  1. Re-run the Travis build for the current PR's continuous-integration/travis-ci/pr.

    • Rationale: This is because we do not ask PR authors to rebase their PRs, but the master branch may have since been updated. It is possible for tests to pass on their branch, only to fail when integrating the changes with the master (Note: This is possible even if GitHub doesn't complain about any merge conflict!)
  2. Merge the PR. Depending on the PR:

    • Use "Squash and Merge" if the PR is a simple feature.
    • Use "Create a Merge Commit" if the PR is non-trivial, and the author has tidied up the commit organization so that each commit is a logical change.

    a. Regardless of the option chosen above, ensure that your commit title is of the form <PR_TITLE> (#PR_NUMBER). For example, for PR #745, it is of the form:

    Add built-in support for light themes from bootswatch (#745)

    b. For non-trivial PRs, ensure that there is a sensible commit message accompanied by it. Rationale: So that future developers have an idea of what is going on for this PR without having to go back to the GitHub website.

Please follow the commit message convention. For example, for PR #745, the commit message is as follows:

```
To use any custom Bootstrap themes, authors must manually copy over the
theme's .css files to the website's asset folders, and configure the
layout's head.md to use the .css files.

Let's add built-in support for bootswatch light themes, by providing a
"theme" option in site.json, so that authors can just directly specify
the name of the theme in order to use it. For example:

  {        
    "theme": "bootswatch-cerulean"
  }

Dark themes from Bootswatch are not yet supported because they require
our custom MarkBind components to inherit the Bootstrap styling classes,
to be done in #782.
```
  1. Ensure that a version milestone is tagged to the PR. Reason: We may have missed it during the "Approval" stage, so please add the version milestone if it is missing, so that the drafting of the release notes during the release process will be easier.

Doing a Release

Building Vue-Strap

  1. Ensure that you are on the root directory on vue-strap, then execute:
$ npm run build

You should see changes in vue.min.js, vue-strap.js.map and vue-strap.min.js.

  • Note: Building vue-strap is optional if there's no changes since the last release of MarkBind. If there are no changes to the three files mentioned above, skip to the "Building MarkBind" section.

  • Note: Do take a glance at the diff for vue.min.js to see if there's any strange changes (e.g. the version of jQuery changes even though no one upgraded it).

  1. Commit the new changes.
$ git commit -m 'Update dist'
  1. Tag the new commit with the new version number, whereby XYZ is the incremented number of the previous release.
$ git tag v2.0.1-markbind.XYZ
  • Note: The tag used is a lightweight tag. Don't use an annotated tag.
  1. Push everything to the main vue-strap repository (replace XYZ with version number).
$ git push upstream master
$ git push upstream v2.0.1-markbind.XYZ

Building MarkBind

  1. If we did a new vue-strap release, then:

    a. Copy vue-strap.min.js from the vue-strap repository to the main asset folder, and to each of the test site's expected/ folder.

# copy to main asset folder
$ cp <VUE_STRAP_REPO>/dist/vue-strap.min.js <MARKBIND_REPO>/asset/js/vue-strap.mins.js

# for each test site's expected folder:
$ cp <VUE_STRAP_REPO>/dist/vue-strap.min.js <MARKBIND_REPO>/test/functional/<TEST_SITE_NAME>/expected/markbind/js/vue-strap.min.js`

b. Commit the new vue-strap assets (replace XYZ with version number).

$ git commit -m 'Update vue-strap version to v2.0.1-markbind.XYZ'
  • Note: We uniquely do this for each MarkBind release (rather than spontaneously update the vue-strap files for each affected PR), in order to reduce unnecessary merge conflicts. It also makes it easier for the maintainers to vet the changes.
  1. Rebuild the test files.
$ cd test/functional/

# for each test site
$ cd <TEST_SITE_NAME>
$ markbind build
$ cp _site/* expected/
$ cd ..

When rebuilding the expected test files, ensure that only the version number is updated. For example, this is correct:

diff --git a/test/functional/test_site/expected/bugs/index.html b/test/functional/test_site/expected/bugs/index.html
index 779f279..bb3c602 100644
--- a/test/functional/test_site/expected/bugs/index.html
+++ b/test/functional/test_site/expected/bugs/index.html
@@ -4,7 +4,7 @@
     <meta name="default-head-top">
     <meta charset="utf-8">
     <meta http-equiv="X-UA-Compatible" content="IE=edge">
-    <meta name="generator" content="MarkBind 1.20.0">
+    <meta name="generator" content="MarkBind 1.21.0">
     <meta name="viewport" content="width=device-width, initial-scale=1">
     <title>Open Bugs</title>
     <link rel="stylesheet" href="../markbind/css/bootstrap.min.css">

However, if there are any extra lines changed, that means that someone screwed up the functional tests, and needs to be fixed accordingly!

Only when it is fixed do you proceed with the next step of the release procedure.

  1. Do an npm version to increment the version number. Which to increment (patch, minor or major) depends on what PRs are merged for the new version, which means you must know beforehand about the changes.
  • If there are no significant changes, a patch is sufficient:
$ npm version patch
  • If there are significant changes (e.g. breaking changes, new release), a minor release is needed:

a. Update the version number inside src/lib/markbind/package-lock.json and src/lib/markbind/package.json manually. This is because npm version will not automatically update the numbers from the outside.

b. Do a npm version minor as per normal.

$ npm version minor
  • We rarely do major releases, but if necessary, the steps are the same as the minor release (just change minor to major).
  1. Push the new commit and version tag generated by npm (change vA.B.C to the new version's string accordingly).
$ git push upstream master
$ git push upstream vA.B.C
  1. Do an npm publish. You should receive a notification by npm that the publish is successful.
$ npm publish
  1. If you used npm link for your project, ensure that you try the new release on another platform that doesn't use npm link, so that we can be sure the end-users can install and use the new version.

    a. Just do npm i -g markbind-cli@A.B.C on the different platform and...

    b. ... play around with the new MarkBind version to ensure that it works.

  2. Ensure that the documentation at markbind.org is deployed correctly.

Since #701, the deployment is automated.

However, if it doesn't deploy properly for the release, do the following:

$ cd docs
$ markbind build
$ markbind deploy
  1. Draft a new release on GitHub.

    a. Go to the Markbind release page at https://github.com/MarkBind/markbind/releases.

    b. Click "Draft a new release".

    c. For the tag version, enter vA.B.C. (The newly released version should be recognized by GitHub, with an "Existing Tag" indicator, otherwise, ensure that you have pushed the version commit and tag in step 4).

    d. For the release title, leave it blank.

    e. For the main body, use the following template:

# markbind-cli

<!-- List out each of the PR for this version in the following format: -->
<!-- #ISSUE_NUMBER ISSUE_TITLE (#PR_NUMBER) -->

### Breaking Changes

<!-- Any feature that is made obsolete -->

> Also give a brief explanation note about:
>   - what was the old feature that was made obsolete
>   - any replacement feature (if any), and
>   - how the author should modify his website to migrate from the old feature to the replacement feature (if possible).

### Features

<!-- Features enable users (authors/readers) to do something new. -->

### Enhancements

<!-- Enhances any existing features --> 

### Fixes

<!-- Fixes correct a programming error/assumption. -->

### Documentation

<!-- Pure changes to the documentation, such as typo, restructuring, etc -->

### Code Quality

<!-- DevOps, refactoring, etc. -->

### Dependencies

<!-- Replace `OLD` with the previous version and `NEW` with the current version -->

[MarkBind/vue-strap](https://github.com/MarkBind/vue-strap): v2.0.1-markbind.OLD → v2.0.1-markbind.NEW

Use the list of PRs merged in the milestone to write the release notes. You may omit any sections that do not have a single PR under it.

An example of a release note draft (taken from v1.18.0):

# markbind-cli

### Breaking Changes

#653 Disable decamelize for anchor ID generation (#667, MarkBind/vue-strap#95)

> Headings with PascalCase wordings now generate a different anchor ID
in order to be more compatible with anchor IDs generated by Github
Flavored Markdown.
>
> For example, if we have the following heading:
>
> ```markdown
> # MarkBind docs
> ```
>
> Old anchor id:
>
> ```
> mark-bind-docs
> ```
>
> **New** anchor id:
>
> ```
> markbind-docs
> ```
>

### Features

#457 Add `deploy -t/--travis` to deploy via Travis (#649)
#470 Support custom MarkBind plugins (#474)
#642 Support specifying include variables inline (#681)

### Enhancements

#369 Seamless panels: omit caret if not expandable (MarkBind/vue-strap#96)
#657 Add temporary styles to prevent FOUC (#664)

### Fixes

#651 Exit MarkBind with non-zero exit code on fatal error (#679)

### Documentation

Restructure user docs on MarkBind syntax (#668)
Add documentation for badges (#686)
Fix filename capitalization for syntax documentation (#685)

### Code Quality

test: Add diff printing for easier debugging (#632)

### Dependencies

[MarkBind/vue-strap](https://github.com/MarkBind/vue-strap): v2.0.1-markbind.20 → v2.0.1-markbind.21

f. Click "Publish release".

  1. Finally, announce the new release on our Slack channel (replace A.B.C with the new version). Congrats!
  • Published: npm i -g markbind-cli@A.B.C