はじめに
Blue Prismでは、人為的ミスや不具合などで動作が正常に終了しない場合があります。
そのため、Blue Prismで業務を自動化する際は動作の途中でエラーが起こることを想定し、それぞれのエラーに対応した例外処理を作成することが必要になります。
今回はそんな例外処理によく使うステージと作成例を紹介します。
例外ステージ
例外ステージでは例外のタイプや内容を記載し、ステージが例外に到達したとき、実行中の処理を「例外」として終了します。
例外ステージで終了すると、例外のタイプと詳細が画面に表示されます。
復元ステージ
復元ステージは処理中に何かエラーが発生したときに自動で開始するステージです。
このステージの後に例外ステージや再試行用のプロセスを作るのが基本的な例外処理の形になります。
復元から例外につなげる場合、「現在の例外のタイプと詳細を保持」にチェックをつけると、自分で入力しなくともBluePrismで発生したエラー内容をそのまま表示してくれます。
注意点として、復元ステージはエラーが発生すると自動で開始するため、そのままにしておくと意図していないステージからのエラーを復元することがあります。
例えば下記の場合、操作1、2どちらでエラーが発生したとしても復元1が開始してしまいます。
そこで用いるのが「ブロック」です。
ブロックで処理と復元ステージを囲むと同じブロックの範囲でのみ起動するため、処理ごとに別々の復元処理を行うことができます。
下記の場合、操作1で起きたエラーは復元1に、操作2で起きたエラーは復元2が開始するようになります。
再開ステージ
復元ステージからは例外だけでなく、別の処理を始めることができます。
しかし、このとき内部にはまだ例外が保持されており、その状態から更にエラーが発生した場合、復元ステージが開始せず処理が強制的に止まってしまいます。
そこで、再開ステージを経由することで保持している例外をリセットして処理を始めることができます。
再開ステージを用いることで、例外とする前に別の処理(例外内容の取得やアプリの終了など)を行ったり、後で紹介する再試行処理を作成したりできます。
※再開ステージで保持した例外がリセットされるため、その後ろの例外内容は自分で設定しなければなりません。
例外処理の作成
ここからは簡単な例外処理の例を紹介します。
・通常処理の後に待機ステージや判断ステージを用いて、処理結果が正常ではなかった場合に例外とすることができます。
・計算ステージや操作ステージなど、ステージ内でエラーが発生することがあるものは復元ステージを使い作成します。
・復元ステージ、再開ステージを用いて、再試行する処理を作ることができます。
このとき、下記のように計算ステージと判断ステージを活用して試行回数に制限を作ると無限ループを回避できます。
※再試行処理はプロセスで作ることが推奨されているので、なるべくプロセスで作成しましょう。
複数作る場合は、ブロックで分割します。
まとめ
今回は例外についての簡単な説明と例を紹介しました。
このほかにも、例外メッセージを取得したり、キューを例外としてマークしたりなどパターンがありますので、そちらは次の機会に書こうと思います。
この記事が少しでも読んでくれた方の役に立ってくれますと幸いです。