家ラボの vCenter Orchestrator を 5.5.2.1 (ShellShock 対応) に上げたところ、action:waitAllWorkflowComplete でエラーが発生するようになったので、その対応方法を記します。

発生するエラーメッセージは以下の通り。

    Workflow:Create lab / waitAllWorkflowComplete (item6) : ch.dunes.model.type.ConvertorException: Unable to serialize object of class : ch.dunes.vso.sdk.SDKTypeConvertor_server$1

この問題を起こした Action は、直前の Foreach ノードで複数実行したワークフローの完了を workflow token (wfTokens) の内容を確認しながら待機します。この wfToken は Foreach ノードで実行したワークフローのアウトプット オブジェクトも含まれているので、その辺で Serialize Error が出ているのかもしれません。以下が、問題を発生した実際のワークフローになります。

バグ報告をしても修正を待っていられないので、回避策として action:waitAllWorkflowComplete を Scriptable Task に置き換えます。 まず、action:waitAllWorkflowComplete のスクリプトの内容を確認します。

次に、問題を起こしたワークフローの action:waitAllWorkflowComplete を Scriptable Task に変更します。

そしてその中身のスクリプトとパラメーターバインディングを行います。スクリプトは以下になります。

action:waitAllWorkflowComplete のスクリプトから不要な return 文を削除します。 パラメーターバインディングは以下になります。

ワークフローでは、ワークフロー トークンの配列を wfTokens としていますが、バインディングの際に tokens という名前に変更しています。 実際のスクリプトは、貼り付けるほどでもないですが、以下のようになります。

var result = new Array();
if (tokens != null && tokens.length > 0) {
    result[tokens.length-1] = null; // init the array with the good size but full of null

    var allFinished = false;
    while (! allFinished) {
        System.sleep(500);

        allFinished = true;

        for (var i in tokens) {
            if (tokens[i].state == "completed" || tokens[i].state == "failed" || tokens[i].state == "canceled") {
                allFinished &= true;
                if (result[i] == null) {
                    var prop = tokens[i].getOutputParameters(); // Properties
                    if (prop == null) prop = new Properties();
                    prop.put("__state", tokens[i].state);
                    if (tokens[i].state == "failed")
                        prop.put("__exception", tokens[i].exception);
                    result[i] = prop;
                }
            }
            else {
                allFinished = false;
            }
        }
    }   
}