文章のtypoの修正程度なら、直接GitHub上で編集してPull Requestを送ってください。
ローカルで編集して送りたい場合は次の手順を試してください。
- Forkする
- Branchを作る:
git checkout -b my-new-feature
- テストする:
npm test
- 変更をコミットする:
git commit -am 'Add some feature'
- Pushする:
git push origin my-new-feature
- Pull Requestを送る :D
npm start
を実行後、http://localhost:4000/へアクセスすることでプレビューを見られます。
npm run start
# open http://localhost:4000/
また、Pull Requestを出した際にGitBook.com上でプレビュー用のビルドが公開されます。 Pull Request下部に表示されるCI Statusからそれぞれプレビュービルドを見ることができます。
- プレビュー用 #jsprimer - GitBook
- プレビュー以外には利用しないでください
$ npm test
を実行するとコードや文章に対するテストを実行できます。
npm test
$ npm run textlint
の文章表現のエラーで疑問がある場合は、とりあえずそのままPull Requestを送ってください。
IssueやPull Requestでやりとりしそのエラーを直すか無視するかを決定します。
このプロジェクトでは次のようなテストが npm test
で実行されています。
特定のSuffixを持つファイル名を対象にしているテストも存在しています。
- GitBookのビルドテスト
- textlintによる文章のLint
- ESLintによるコードのLint
- textlint + ESLintによるMarkdown中のインラインコードブロックのLint
- Markdown中のインラインコードブロックへのDoctest
- Mochaによる
*-test.js
ファイルのユニットテスト *-example.js
がJavaScriptとして実行できるかのテスト*-invalid.js
がJavaScriptとして実行できないかのテスト
Markdown中のインラインコードブロックとは次のようなjs
言語指定がされたCodeBlockを示しています。
```js
var foo = "string";
```
*-example.js
のJavaScriptファイルとMarkdownのインラインコードブロックを対象にDoctestが実行されます。
次のように// => 値
というコメントを書いた部分に対してDoctestが実行されます。
const a = 42;
console.log(42); // => 42
これにより、サンプルコードのコメントに書いた評価結果と実際の出力が一致するかをテストしています。
評価したい式; // => 期待する評価結果
or
console.log(評価したい式); // => 期待する評価結果
基本的には、console.log(式); // => 期待する評価結果
を利用し、
console.log
が冗長な場合は 式; // => 期待する評価結果
と書いても良い。
Doctestの正常系は実行結果と期待結果が一致することです。
一方、そのコードの実行結果がエラーになることを期待する場合もあります。
エラーを期待する場合は、doctest: 期待するエラー名
をHTMLコメントに書きます。
例) 実行結果がReferenceError
となることを期待するテスト
条件式
という変数が定義されていないためエラーとなる。
<!-- doctest: ReferenceError -->
```js
if (条件式)
実行する文;
```
個別の行がエラーとなることを期待する場合は、正常系のDoctestでも書けるためそちらを推奨します。
```js
NO_DEFINE++; // => ReferenceError
```
CodeBlockの手前に<!-- doctest:disable -->
というHTMLコメントがある場合はDoctestをしません。
Node.jsで実行できないビルドインオブジェクトを使うパターンや例外的なケースに利用できます。
例) 無視するケース
次の例はAPIの説明のための擬似コードであるため無視しています。
<!-- doctest:disable -->
```js
array.map(コールバック関数);
```
別の手法:
ファイル名が*-invalid.js
のコードは実行できないことを検証できます。(エラーになるとテストが通る)
これを[include]
することでより正確に表現できます。
*-invalid.js
がJavaScriptとして実行できないかのテスト
関連
- console.logと// => の使い分け · Issue #195 · asciidwango/js-primer
- power-assertを使ったDoctestツール power-doctestを書き直した | Web Scratch
- JavaScriptでdoctestを行う power-doctest を作った | Web Scratch
- 25.2. doctest — 対話的な実行例をテストする — Python 2.7.x ドキュメント
source
下に章や節ごとにディレクトリを切り、
その下にコード(src/
)、テスト(test/
)、リソース(img/
)などを配置して扱います。
└── source
└── ch1
├── basic
│ └── README.md
├── comments
│ ├── README.md
│ └── src
│ └── html-like-comments-example.js
└── hello
├── README.md
├── img
├── src
│ └── hello-world.js
└── test
└── hello-world-test.js
AngularJSのGit Commit Guidelinesをベースとしています。
以下のような形で
- 1行目に概要
- 2行目はから改行
- 3行目から本文
最後に関連するIssue(任意)を書きます。
feat(ngInclude): add template url parameter to events
The `src` (i.e. the url of the template to load) is now provided to the
`$includeContentRequested`, `$includeContentLoaded` and `$includeContentError`
events.
Closes #8453
Closes #8454
scope commit title
commit type / /
\ | |
feat(ngInclude): add template url parameter to events
body -> The 'src` (i.e. the url of the template to load) is now provided to the
`$includeContentRequested`, `$includeContentLoaded` and `$includeContentError`
events.
referenced -> Closes #8453
issues Closes #8454
commit type
としては次のようなものがあります。
- feat
- 新しい機能、章、節の追加など
- 更新履歴に載るような新しいページを追加
- fix
- 意味が変わる修正
- 更新履歴に載るような修正
- docs
- 基本的には使わない
- README.mdやCONTRIBUTING.mdや本体のプロジェクト全体のドキュメントについて
- refactor
- 意味が変わらない修正
- 更新履歴に載らないような修正
- style
- スペースやインデントの調整
- Lintエラーの修正など
- perf
- パフォーマンス改善
- test
- テストに関して
- chore
- その他
- typoの修正など
commit type
は、迷ったらとりあえずchore
と書きます。
scope
も省略して問題ないので以下のような形でも問題ありません。
chore: コミットメッセージ
書き方に関するルールや表記統一について
文章に対する相対的な位置の指し示す場合は、 できるかぎり「次のコード」というように事前に説明する。
読んでいる人がサンプルコードのどこに注目すればいいかが事前にわかるように書く。
次のコードは xxx について説明しています。
code
事前に説明した特定のコードを参照したい場合は、 サンプルコードのファイル名を参照に利用する。
[import, example.js](src/example.js)
色々文章...
[example.js](#example.js)では、 ....
次の変数をコードブロックの前に書くことで、コードがインタラクティブに実行できるコンソールモードとして表示されます。 (ウェブのみ)
{{book.console}}
```js
var interactive = "code";
```
importしたコードにも対応しています。
{{book.console}}
[import, example.js](src/example.js)
ES2015は正式な名称ですが、ES6も一般によく使われている名称です。 どちらの表記をメインに利用するかは以下のIssueで議論した結果、ES2015という表記をメインとしています。 これから出てくる仕様はES2016、ES2017と年号形式であるためそちらに揃えていこうという形です。
基本的にコードではlet
またはconst
を利用します。
var
の機能を説明する場合においてはvar
を利用します。