[
  {
    "task_id": "7_withhs_drift_alert_3_448197471",
    "step_index": 2,
    "assertion_name": "kusto_invocation_requires_predefined_query_and_correct_cluster",
    "invariant_type": "CAPABILITY",
    "check_type": "python_check",
    "severity": "medium",
    "check_hint": "When KustoAgent runs a query, it must be a predefined query present in the plan or prior Orchestrator instruction, and the query must be tailored to the incident's cluster (no placeholders like TODO/TBD/<CLUSTER>). Verify that a kusto code block exists earlier and that the current query's clusterName matches the cluster parsed from the incident description.",
    "evidence": {
      "matched_substeps": [
        {
          "sub_index": 5,
          "role": "KustoAgent",
          "content": "**Kusto Query:**\nlet driftedSettingName = 'EnableForceDeleteOnDisconnectVmNetworkMerlin';\ncluster('azurecm').database('AzureCM').NetworkServiceManagerEvents\n| where PreciseTimeStamp > ago(6h)\n| where TaskName == 'ChangedSetting' and Message has driftedSettingName\n| parse Message with 'name=\"' SettingName '\" value=\"' SettingValue '\" buildVersion=\"' BuildVersion '\"'\n| project nsmTime = PreciseTimeStamp, SettingName, ActualValue = SettingValue, BuildVersion, Tenant, Region\n| summarize arg_max(nsmTime, *) by Region, Tenant, SettingName\n| extend _key = tolower(Tenant)\n| join kind = leftouter (\n    cluster('aznwsdn').database('aznwmds').NSMGoalState\n    | where DataIngestionTime > ago(1d)\n    | where not(InFlight)\n    | where SettingName =~ driftedSettingName\n    | summarize arg_max(DataIngestionTime, *) by ClusterName\n    | project ClusterName, SettingName, ExpectedValue = SettingValue, _key = tolower(ClusterName)\n) on _key\n| where ClusterName != \"\"\n| where ActualValue !~ ExpectedValue\n| project Region, ClusterName, ExpectedValue\n\n semantic_query_matcher: True \n\nstub match:False \n\n**Kusto result:**\nError running Kusto Query:\nFailed to process network request for the endpoint: https://.kusto.windows.net/v1/rest/auth/metadata"
        }
      ],
      "current_event": {
        "sub_index": 5,
        "role": "KustoAgent",
        "content": "**Kusto Query:**\nlet driftedSettingName = 'EnableForceDeleteOnDisconnectVmNetworkMerlin';\ncluster('azurecm').database('AzureCM').NetworkServiceManagerEvents\n| where PreciseTimeStamp > ago(6h)\n| where TaskName == 'ChangedSetting' and Message has driftedSettingName\n| parse Message with 'name=\"' SettingName '\" value=\"' SettingValue '\" buildVersion=\"' BuildVersion '\"'\n| project nsmTime = PreciseTimeStamp, SettingName, ActualValue = SettingValue, BuildVersion, Tenant, Region\n| summarize arg_max(nsmTime, *) by Region, Tenant, SettingName\n| extend _key = tolower(Tenant)\n| join kind = leftouter (\n    cluster('aznwsdn').database('aznwmds').NSMGoalState\n    | where DataIngestionTime > ago(1d)\n    | where not(InFlight)\n    | where SettingName =~ driftedSettingName\n    | summarize arg_max(DataIngestionTime, *) by ClusterName\n    | project ClusterName, SettingName, ExpectedValue = SettingValue, _key = tolower(ClusterName)\n) on _key\n| where ClusterName != \"\"\n| where ActualValue !~ ExpectedValue\n| project Region, ClusterName, ExpectedValue\n\n semantic_query_matcher: True \n\nstub match:False \n\n**Kusto result:**\nError running Kusto Query:\nFailed to process network request for the endpoint: https://.kusto.windows.net/v1/rest/auth/metadata"
      }
    },
    "taxonomy_targets": [
      "InvalidInvocation",
      "Instruction/PlanAdherenceFailure",
      "IntentPlanMisalignment"
    ]
  }
]
