WebAPIで簡単にデータを蓄積できるところがGoogle Spreadsheetの超便利なところです。
スクリプトのデバッグをしていると、POSTを他のサーバから発行しないといけなくて面倒と思うことがあります。コード書く毎にデプロイしないといけないためです。
ブレークポイントも有効なので、ゆっくりとデバッグできます。
そこで、単体テスト用に関数を作って、その中でdoPost(e)を呼び出します。
Google Apps Script(GAS)でJOSONデータを受け取る場合は、
function doPost(e) { var params = JSON.parse(e.postData.getDataAsString()); }
ですが、これをローカルでデバッグする際のJSONデータの作成方法です。
ポイント
- GASのPOSTは特殊(parameterにデータは無い)
- データは、parameterのpostDataに入れておく。
- 入れておくデータはBlob形式
参考:https://qiita.com/shirakiya/items/db22de49f00710478cfc
なので、こういった形で作成
// デバッグ用の関数 function doPostTest() { //eの作成 var e = { postData : Utilities.newBlob('この中にJSONデータを入れる') }; //呼び出す。 doPost(e); }
あとは、AppsScriptの上部メニューで作ったDebug関数を指定して、デバッグを押下する。
ブレークポイントも有効なので、ゆっくりとデバッグできます。
SigFox BackendからのCallback呼び出しで、デバッグが面倒だったので、こういった形でデバッグしました。
SigFoxからダイレクトにGoogle Spreadsheetにほぼリアルタイムで受信データが送信できるので安価にシステム構築できるのは便利ですね。ただ、SigFoxの送信メッセージ上限(40回/日)は厳しいなぁ。
5分おきでデータが欲しい場合は採用できないのが難点。
0 件のコメント:
コメントを投稿