はじめに
2020年8月24日にUiPath Platform 20.8 previewがリリースされました。今回のアップデート内容の一つとしてイベント監視系アクティビティの一新があります。アクティビティの表示名は同じですが、中身は別物となっており、従来アクティビティとの互換性はありません。整理を兼ねてこれらの変遷をまとめてみます。
イベント監視系アクティビティとは?
ここでは、イベント監視系アクティビティを、「なんらかの変化を検知し、それをきっかけに特定の動作を行う仕組みを提供するアクティビティ」として説明します。何らかの変化とは例えばキーボード入力やマウス入力、ファイルの変更や削除等が該当します。具体的にはファイル変更トリガーアクティビティやマウストリガーアクティビティ等があります。なお画面要素が対象となる、On~Appear/Disappear系アクティビティはここでは含めていません。
イベント監視系アクティビティ変遷の概要
UiPathにおけるイベント監視系アクティビティは、今回のアップデートを含めて、以下の通り大きく3世代に分類できると考えています。(世代というのは勝手に筆者がつけたもので公式ではありません)順を追ってみていきましょう。
イベントを監視(MonitorEvent)アクティビティ内で動作するトリガーアクティビティ(2020.4未満)(第一世代)
UiAutomation.Activities Package内にあるイベントを監視アクティビティを用い、その中に各種トリガーアクティビティを配置するタイプです。各イベントの情報は、イベントハンドラーの中でイベント情報を取得アクティビティを通じて取得することが可能です。
例:イベントを監視+ファイル変更トリガー(FileChangeTrigger)
単独でイベント監視可能なアクティビティ(2019.10や2020.4での一部アクティビティ)(第二世代)
2019.10ではバックグラウンドプロセスが導入されましたが、イベントを監視アクティビティがUiAutomation.Activities Package内にあるため、このままでは(UIには直接関係のない)ファイル変更の検知がバックグラウンドプロセスで動作させることができない課題が出てきたのではないかと思います。あくまで推測ですが、これの対応として、イベントを監視アクティビティが無くとも単独で動作可能なファイル監視トリガー(FileChangeTriggerV2)アクティビティが用意されたのではないかと思います。下図のように、単独でファイルの変更監視機能を提供します。また同様の形態として、同じく2019.10でリリースされたプロセス開始トリガー、プロセス終了トリガーもあります。(そのためこれらもバックグラウンドプロセスでも動作可能です。)
例:ファイル変更トリガー(FileChangeTriggerV2)
トリガースコープ(TriggerScope)アクティビティ内で動作するトリガーアクティビティ(2020.8以降)(第三世代)
最新の2020.8では、これらが統合された、TriggerScopeの仕組みが提供されました。TriggerScope自身はSystem.Activities Packageに同梱されていますので、バックグラウンドプロセスでも動作可能です。またイベントの情報はargs変数を通じて、内部で参照できるようになっています。
例:TriggerScope+ファイル変更トリガー(FileChangeTriggerV3)
各トリガーアクティビティの整理
このようにActivity Packageのバージョンによって、同梱されているイベント監視系アクティビティのタイプが異なります。表示名はすべて同じなので、アクティビティ名でこれを識別する必要があります。プロパティパネルの最上部を参照するのが良いと思います。
以下の表はイベント監視系アクティビティが上記のどの世代に該当するかをまとめたものです。
Activity Name | Gen1 | Gen2 | Gen3 | Package |
---|---|---|---|---|
FileChangeTrigger | 無印 | V2 | V3 | System |
ProcessStartTrigger | - | 無印 | V2 | System |
ProcessEndTrigger | - | 無印 | V2 | System |
SystemTrigger | 無印 | - | V2 | UiAutomation |
HotkeyTrigger | 無印 | - | V2 | UiAutomation |
MouseTrigger | 無印 | - | V2 | UiAutomation |
ClickImageTrigger | 無印 | - | V2 | UiAutomation |
KeyPressTrigger | 無印 | - | V2 | UiAutomation |
ClickTrigger | 無印 | - | V2 | UiAutomation |
Gen1:MonitorEvent内で動作、Gen2:単独動作、Gen3:TriggerScope内で動作
特に単独動作可能なものを、イベント監視やTriggerScope内で使うと、エラーにならず、想定した挙動と異なる動作となることがありますので、注意が必要です。
下位互換
現在の最新バージョンである2020.8previewに同梱されているアクティビティパッケージでは、上記の古いイベント監視系アクティビティは新たに選択はできません。ただし互換性維持のため、古いアクティビティもパッケージ内に同梱されているようで、古いワークフローがエラーとはなることはありません。
カスタムトリガーアクティビティ
TriggerScopeアクティビティリリースに伴い、これに対応可能なカスタムトリガーアクティビティを作成できるSDKが用意されています。
詳しくは以下参照ください。
まとめ
今回TriggerScopeアクティビティがリリースされ、ほぼ強制的に従来アクティビティと置き換わりましたので、今後は否応なしに、こちらの仕組みに移行していくものと考えられます。
機能の面では色々と強化されており喜ばしい反面、これらのアクティビティはUiAutomationやSystemのアクティビティパッケージのバージョンに依存しているため、特に古いバージョンのパッケージを使用している場合、名前が同じなのに仕様が異なるとのことで、混乱の元になるかもしれません。
もしイベント監視系のアクティビティの動作が想定と異なると思ったら、アクティビティ名(表示名ではなく)をチェックして、想定しているアクティビティかどうかをまずは確認した方が良いかもしれません。