================================================================================
VIOLATION REPORT FOR TASK 7_withhs_drift_alert_1_412225437_new
================================================================================

Total Violations: 3
================================================================================


================================================================================
VIOLATION #1
================================================================================

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:
----------------------------------------
Current Event:
  Role: KustoAgent
  Content:
    **Kusto Query:**
    let driftedSettingName = 'VncEndpointCandidates';
    cluster('azurecm').database('AzureCM').NetworkServiceManagerEvents
    | where PreciseTimeStamp > ago(6h)
    | where TaskName == 'ChangedSetting' and Message has driftedSettingName
    | parse Message with 'name="' SettingName '" value="' SettingValue '" buildVersion="' BuildVersion '"'
    | project nsmTime = PreciseTimeStamp, SettingName, ActualValue = SettingValue, BuildVersion, Tenant, Region
    | summarize arg_max(nsmTime, *) by Region, Tenant, SettingName
    | extend _key = tolower(Tenant)
    | join kind = leftouter (
    cluster('aznwsdn').database('aznwmds').NSMGoalState
    | where DataIngestionTime > ago(1d)
    | where not(InFlight)
    | where SettingName =~ driftedSettingName
    | summarize arg_max(DataIngestionTime, *) by ClusterName
    | project ClusterName, SettingName, ExpectedValue = SettingValue, _key = tolower(ClusterName)
    ) on _key
    | where ClusterName != ""
    | where ActualValue !~ ExpectedValue
    | project Region, ClusterName, ExpectedValue
    
     semantic_query_matcher: True 
    
    stub match:False 
    
    **Kusto result:**
    Error running Kusto Query:
    Failed to process network request for the endpoint: https://.kusto.windows.net/v1/rest/auth/metadata

Matched Substeps:
  Sub-index: 5
  Role: KustoAgent
  Sub-index: 10
  Role: KustoAgent
  Sub-index: 19
  Role: KustoAgent
----------------------------------------

Taxonomy Targets:
  - InvalidInvocation
  - Instruction/PlanAdherenceFailure
  - IntentPlanMisalignment

================================================================================
VIOLATION #2
================================================================================

Step Index: 2
Assertion Name: kusto_endpoint_url_must_include_cluster_hostname
Invariant Type: CAPABILITY
Check Type: python_check
Severity: medium

Check Hint:
----------------------------------------
When KustoAgent reports an error, verify the Kusto endpoint URL includes a non-empty cluster hostname before '.kusto.windows.net'. If the URL is 'https://.kusto.windows.net/...' or otherwise lacks a hostname, flag it as a configuration/connectivity failure indicative of an invalid or missing endpoint configuration.
----------------------------------------

Evidence:
----------------------------------------
Current Event:
  Role: KustoAgent
  Content:
    **Kusto Query:**
    let driftedSettingName = 'VncEndpointCandidates';
    cluster('azurecm').database('AzureCM').NetworkServiceManagerEvents
    | where PreciseTimeStamp > ago(6h)
    | where TaskName == 'ChangedSetting' and Message has driftedSettingName
    | parse Message with 'name="' SettingName '" value="' SettingValue '" buildVersion="' BuildVersion '"'
    | project nsmTime = PreciseTimeStamp, SettingName, ActualValue = SettingValue, BuildVersion, Tenant, Region
    | summarize arg_max(nsmTime, *) by Region, Tenant, SettingName
    | extend _key = tolower(Tenant)
    | join kind = leftouter (
    cluster('aznwsdn').database('aznwmds').NSMGoalState
    | where DataIngestionTime > ago(1d)
    | where not(InFlight)
    | where SettingName =~ driftedSettingName
    | summarize arg_max(DataIngestionTime, *) by ClusterName
    | project ClusterName, SettingName, ExpectedValue = SettingValue, _key = tolower(ClusterName)
    ) on _key
    | where ClusterName != ""
    | where ActualValue !~ ExpectedValue
    | project Region, ClusterName, ExpectedValue
    
     semantic_query_matcher: True 
    
    stub match:False 
    
    **Kusto result:**
    Error running Kusto Query:
    Failed to process network request for the endpoint: https://.kusto.windows.net/v1/rest/auth/metadata

Matched Substeps:
  Sub-index: 5
  Role: KustoAgent
  Sub-index: 10
  Role: KustoAgent
  Sub-index: 19
  Role: KustoAgent
----------------------------------------

Taxonomy Targets:
  - SystemFailure
  - InvalidInvocation

================================================================================
VIOLATION #3
================================================================================

Step Index: 2
Assertion Name: user_escalation_requires_outgoing_message_to_user
Invariant Type: PROTOCOL
Check Type: python_check
Severity: medium

Check Hint:
----------------------------------------
When the Orchestrator sets next_speaker to 'user' and provides an instruction for manual execution, there must be an actual outbound message addressed to the user in the same step before termination. If next_speaker 'user' is set but no 'Orchestrator -> user' message is emitted and a termination occurs, flag a protocol violation.
----------------------------------------

Evidence:
----------------------------------------
Current Event:
  Role: Orchestrator (Step-2)
  Content:
    
    Step-2

Matched Substeps:
  Sub-index: 1
  Role: Orchestrator (Step-2)
  Sub-index: 2
  Role: Orchestrator (thought)
  Sub-index: 3
  Role: Orchestrator (-> KustoAgent)
  Sub-index: 4
  Role: Orchestrator (thought)
  Sub-index: 6
  Role: Orchestrator (Step-2)
  Sub-index: 7
  Role: Orchestrator (thought)
  Sub-index: 8
  Role: Orchestrator (-> KustoAgent)
  Sub-index: 9
  Role: Orchestrator (thought)
  Sub-index: 11
  Role: Orchestrator (Step-2)
  Sub-index: 12
  Role: Orchestrator (thought)
  Sub-index: 13
  Role: Orchestrator (thought)
  Sub-index: 14
  Role: Orchestrator (thought)
  Sub-index: 15
  Role: Orchestrator (Step-2)
  Sub-index: 16
  Role: Orchestrator (thought)
  Sub-index: 17
  Role: Orchestrator (-> KustoAgent)
  Sub-index: 18
  Role: Orchestrator (thought)
  Sub-index: 20
  Role: Orchestrator (Step-2)
  Sub-index: 21
  Role: Orchestrator (thought)
  Sub-index: 22
  Role: Orchestrator (termination condition)
----------------------------------------

Taxonomy Targets:
  - Instruction/PlanAdherenceFailure

================================================================================
END OF VIOLATION REPORT
================================================================================