Como lidar com Configuration Manager erros assíncronos usando código gerenciado

Para lidar com um erro Configuration Manager gerado durante uma consulta assíncrona, teste a RunWorkerCompletedEventArgspropriedade error exception do parâmetro que é passada para o manipulador de eventos SmsBackgroundWorker.QueryProcessorCompleted. Se Erro não nullfor , ocorrerá uma exceção e você usará Erro para descobrir a causa.

Se Error for um SmsQueryException, você poderá usá-lo para chegar ao subjacente __ExtendedException ou SMS_ExtendedException. Como a biblioteca gerenciada do Provedor de SMS não encerra essas exceções, você precisará usar o objeto System.Management namespace ManagementException para acessá-las.

Para lidar com um erro de consulta assíncrono

  1. Crie uma consulta assíncrona.

  2. No manipulador de eventos SmsBackgroundWorker.QueryProcessorCompleted de consulta assíncrona, implemente o código no exemplo a seguir.

  3. Execute a consulta assíncrona. Para testar o manipulador de exceção, passe uma cadeia de caracteres de consulta mal formada, como Select & from &&& para o método QueryProcessorBase.ProcessQuery .

Exemplo

O exemplo a seguir implementa um manipulador de eventos SmsBackgroundWorker.QueryProcessorCompleted .

Para obter informações sobre como chamar o código de exemplo, consulte Chamando Configuration Manager Snippets de Código.

void bw1_QueryProcessorCompleted(object sender, RunWorkerCompletedEventArgs e)  
{  
    if (e.Error != null)  
    {  
        Console.WriteLine("There was an Error");  
        if (e.Error is SmsQueryException)  
        {  
            SmsQueryException queryException = (SmsQueryException)e.Error;  
            Console.WriteLine(queryException.Message);  

            // Get either the __ExtendedStatus or SMS_ExtendedStatus object and display various properties.  
            ManagementException mgmtExcept = queryException.InnerException as ManagementException;  

            if (mgmtExcept != null)  
            {  
                if (string.Equals(mgmtExcept.ErrorInformation.ClassPath.ToString(), "SMS_ExtendedStatus", StringComparison.OrdinalIgnoreCase) == true)  
                {  
                    Console.WriteLine("Configuration Manager provider exception");  
                }  

                else if (string.Equals(mgmtExcept.ErrorInformation.ClassPath.ToString(), "__ExtendedStatus", StringComparison.OrdinalIgnoreCase) == true)  
                {  
                    Console.WriteLine("WMI exception");  
                }  
                Console.WriteLine(mgmtExcept.ErrorCode.ToString());  
                Console.WriteLine(mgmtExcept.ErrorInformation["ParameterInfo"].ToString());  
                Console.WriteLine(mgmtExcept.ErrorInformation["Operation"].ToString());  
                Console.WriteLine(mgmtExcept.ErrorInformation["ProviderName"].ToString());  
            }  

        }  
        if (e.Error is SmsConnectionException)  
        {  
            Console.WriteLine("There was a connection error :" + ((SmsConnectionException)e.Error).Message);  
            Console.WriteLine(((SmsConnectionException)e.Error).ErrorCode);  
        }  
    }  

    Console.WriteLine("Done...");  
}  

O método de exemplo tem os seguintes parâmetros:

Parâmetro Tipo Descrição
sender - Object A origem do evento.
e - RunWorkerCompletedEventArgs Os dados do evento.

Para obter mais informações, consulte Classe RunWorkerCompletedEventArgs.

Compilando o código

Este exemplo de C# requer:

Namespaces

System

System.Collections.Generic

System.Text

Microsoft. ConfigurationManagement.ManagementProvider

Microsoft. ConfigurationManagement.ManagementProvider.WqlQueryEngine

System.Management

System.ComponentModel

Assembly

microsoft.configurationmanagement.managementprovider

adminui.wqlqueryengine

System.Management

Programação robusta

Para obter mais informações sobre o tratamento de erros, consulte Sobre erros de Configuration Manager.

Confira também

Sobre erros