Help us understand the problem. What is going on with this article?

Node.js Debug and Test Tips

More than 5 years have passed since last update.

概要

Node.jsの開発で、デバッグやテストに役に立つTipsをまとめました。

デバッグ

console.xxx

標準出力にログを出力する。

  • console.log()
  • console.info()
  • console.warn()
  • console.error()
  • console.dir()
  • console.trace() => スタックとレースを出力
  • console.time() => 始めから終わりまでの時間を出力

assert.xxx

値が期待した値と異なる場合は、例外を発生させる。

node debug

コマンドライン上でデバッグする。

  • c: continue 実行
  • n: next 次の行を実行
  • s: step 次の関数内を実行
  • repl: プログラム内の変数や関数にアクセスする
  • watch(): 変数の値をウォッチする。引数はテキストで変数名を指定する
  • unwatch(): 変数の値をウォッチを解除する
  • setBreakPoint / sb: ブレークポイントを設定する
  • clearBreakPoint / cb: ブレークポイントを解除する

node-inspector

GUI(Coogle Chromeのデバッガー)でデバッグする。

# node-inspectorをインストール
npm install -g node-inspector

# node-inspectorでデバッグするプロセスを起動する
node --debug-brk app.js

# node-inspectorを起動
node-inspector

テスト

mocha

ユニットテストのフレームワーク

npm install mocha

supertest

expressのwebテストフレームワーク
mochaと合わせて使う、httpレベルのでテストが可能。

npm install supertest
node_modules/mocha/bin/mocha --reporter spec

supertest-session

supertestにsession管理機能を追加したもの。
ログイン機能などがある場合はこちらを使うと良い。

npm install supertest-session
node_modules/mocha/bin/mocha --reporter spec
bisque33
Rubyをよく使っていましたが、最近はスマホアプリを作るためJavaScriptを勉強中です。 投稿記事については自分の勉強メモで中途半端な内容も多いと思いますので、参考程度と考えてください。
http://bisque.hatenablog.jp/
Why not register and get more from Qiita?
  1. We will deliver articles that match you
    By following users and tags, you can catch up information on technical fields that you are interested in as a whole
  2. you can read useful information later efficiently
    By "stocking" the articles you like, you can search right away
Comments
No comments
Sign up for free and join this conversation.
If you already have a Qiita account
Why do not you register as a user and use Qiita more conveniently?
You need to log in to use this function. Qiita can be used more conveniently after logging in.
You seem to be reading articles frequently this month. Qiita can be used more conveniently after logging in.
  1. We will deliver articles that match you
    By following users and tags, you can catch up information on technical fields that you are interested in as a whole
  2. you can read useful information later efficiently
    By "stocking" the articles you like, you can search right away
ユーザーは見つかりませんでした