はじめに
AWS Step Functionsのワークフロー作成時に知っておくと楽になるTipsの紹介をします。
Step FunctionsはAWSコンソールのワークフロースタジオ上でぽちぽち作成を行うことができますが、
設定値の記法の独特さや(以前のJSONPath
・新しく追加されたJSONata
)、ワークフローをデバックしたい場合の方法などが作成時の悩みです。
ただ、ここ最近このあたりの使い勝手が改善しており、アップデートされて使いやすくなったワークフロースタジオの機能を紹介します。
便利機能
① JSONataのコード補完
既存のJSONPath形式に加えて、新しくクエリ言語のJSONataがサポートされました。
JSONata設定にした場合、ワークフローのエディタ上でコード補完が効くようになっています。
まずはステートマシンを新規作成して、Passステートをフローに追加します。
出力エディタに下記のようにJSONataの必須項目を記載すると、エディタ内でコード補完が効くようになります
"{%%}"
まず、JSONata記法の起点となる$
を入力してみます。
すると、それに続いて書けるコード候補がサジェストされるようになります。
サジェスト通りstatesを選択(enter or クリック)してみましょう。
$statesの後は、.
つなぎで記載していくため、$states.
まで入力してみます。
すると、input / context のサジェストが現れました。
ちなみに、inputはステートへの入力値を取得する用途で使用します。contextは、起動ステートマシンの情報を取得する用途で使用します。
(参考)inputについて
(参考)contextについて
context.
まで入力し、そのサジェストで出てきたState
を入力、さらに.
でつないで出てきた、EnteredTime
まで入力してみます。
最終的に、コード補完のお陰で、ステート処理の開始時間を参照するところまでスムーズに到達することができました。
"{% $states.context.State.EnteredTime %}"
inputも同様に、コード補完を活かして、$states.input
まで書き進めます。inputの先は任意の入力値となるため、コード補完は出ません。設定したい任意のKey名にします。
"{% $states.input.text %}"
最終的にcontextの情報とinputの情報を出力で渡してみるようにしましょう。
{
"context": "{% $states.context.StateMachine.Name %}",
"text": "{% $states.input.text %}"
}
ここまでが補完機能の説明になります。
② JSONata専用エディタ
JSONata専用のエディターも使用することができます。このエディターはフォームエリア全体の編集エディターではなく、選択したJSONata式1つに対しての専用エディターになっています。
専用エディタを開くにはJSONata式の右側に表示されている「✏️」マークをクリックします。
変更を保存して閉じる
を押すと、専用エディタでの変更内容が反映されます。
③ テスト実行
出力式が完成したので、意図通り動くか確認してみたいです。
一昔前まではワークフローを保存し、ステートマシンを実際に起動してみないと動作確認ができなかったのですが、
2023年11月のTestAPIの新規追加により、ワークフローの作成・編集の更新前に、ステートごとに単体の動作確認ができるようになっています。
テストを行うにはテスト状態
というボタンを押下します。
モーダルが立ち上がります。
状態の入力欄に、下記のJSONを入力して、テストを開始
を実行してみます。
{
"text" : "テストです"
}
すると、Pass 成功しました
の表示とともに、右側には状態の出力欄に出力内容が表示されました。
入力内容を変えてテストすることで、状態の出力内容がどう変わるかをテストすることができます。
また、テストを行った際、エラーの発生や内容の変更で、出力内容のJSONを変更したくなった場合、
エディタ上で修正し、右下の変更を適用して閉じる
を押下すると変更点を実際のステートマシンの内容に反映することができます。
試しに出力内容を変更してみましょう
下記のようにtext部分を書き換えてみます。
"text": "{% $states.input.text & '!!!' %}"
{
"context": "{% $states.context.State.EnteredTime %}",
"text": "{% $states.input.text & '!!!' %}"
}
テスト実行すると、修正が反映されて、出力内容が変化しています。
これで編集を更新したい場合、右下の変更を適用して閉じる
ボタンを押下することにより、テストで試した出力定義をそのままステートマシンの設定に反映することができます。
ボタンを押下してステートマシンのページに戻ると、
反映できていることが確認できました。
おわりに
今回はStep Functions作成時に役立つコード補完やテスト実行についてまとめました。
慣れないJSONataの記法を使う場合にコード補完が効いてくれるととても助かりますし、候補を見ていると「あんなこともできそう?」とアイデアが膨らむきっかけにもなりますね。
ちょっとお試ししたいや、ワークフローの中で部分的にデバックを試したい場合にはテスト実行がとても便利です。ワークフローを作成・保存する手間や、別ステートの実行・結果を待つ手間が短縮できます。
ステートの数が増え、複雑かつ大きなワークフローになると単一ステートにフォーカスしたデバックを行うのが大変だったので、ありがたいですね。
Step Functions初学者にはまずこれらの便利機能を知っておくとその後のStep Functions Lifeが楽になりそうです。
それでは!