Domanda

Ho una semplice finestra di messaggio in un'applicazione WPF che viene avviata come di seguito:

private void Button_Click(object sender, RoutedEventArgs e)
{
   MessageBox.Show("Howdy", "Howdy");
}

Posso ottenere bianco per fare clic sul mio pulsante e avviare la finestra di messaggio.

UISpy lo mostra come un bambino della mia finestra Non sono riuscito a capire il metodo per accedervi.

Come posso accedere al mio MessageBox per verificarne il contenuto?

È stato utile?

Soluzione

Trovato! La classe window ha un metodo MessageBox che fa il trucco:

        var app = Application.Launch(@"c:\ApplicationPath.exe");
        var window = app.GetWindow("Window1");
        var helloButton = window.Get<Button>("Hello");
        Assert.IsNotNull(helloButton);
        helloButton.Click();
        var messageBox = window.MessageBox("Howdy");
        Assert.IsNotNull(messageBox);

Altri suggerimenti

Prova questo

       Window messageBox = window.MessageBox("");
       var label = messageBox.Get<Label>(SearchCriteria.Indexed(0));
       Assert.AreEqual("Hello",label.Text);

Nel codice sorgente di White sono contenuti alcuni progetti di test dell'interfaccia utente (per testare White stesso).

Uno dei test include i test MessageBox, che include un modo per ottenere il messaggio visualizzato.

[TestFixture, WinFormCategory, WPFCategory]
public class MessageBoxTest : ControlsActionTest
{
    [Test]
    public void CloseMessageBoxTest()
    {
        window.Get<Button>("buttonLaunchesMessageBox").Click();
        Window messageBox = window.MessageBox("Close Me");
        var label = window.Get<Label>("65535");
        Assert.AreEqual("Close Me", label.Text);
        messageBox.Close();
    }

    [Test]
    public void ClickButtonOnMessageBox()
    {
        window.Get<Button>("buttonLaunchesMessageBox").Click();
        Window messageBox = window.MessageBox("Close Me");
        messageBox.Get<Button>(SearchCriteria.ByText("OK")).Click();
    }
}

Evidentemente, l'etichetta utilizzata per visualizzare il messaggio di testo è di proprietà della finestra che visualizza la finestra di messaggio e la sua identificazione principale è il valore massimo della parola (65535).

window.MessageBox () è una buona soluzione !!

Ma questo metodo rimarrebbe bloccato per lungo tempo se la finestra di messaggio non appare . A volte desidero selezionare " Non aspetto " di una finestra di messaggio ( Avviso, errore, ecc. ). Quindi scrivo un metodo per impostare timeOut tramite threading.

[TestMethod]
public void TestMethod()
{
    // arrange
    var app = Application.Launch(@"c:\ApplicationPath.exe");
    var targetWindow = app.GetWindow("Window1");
    Button button = targetWindow.Get<Button>("Button");

    // act
    button.Click();        

    var actual = GetMessageBox(targetWindow, "Application Error", 1000L);

    // assert
    Assert.IsNotNull(actual); // I want to see the messagebox appears.
    // Assert.IsNull(actual); // I don't want to see the messagebox apears.
}

private void GetMessageBox(Window targetWindow, string title, long timeOutInMillisecond)
{
    Window window = null ;

    Thread t = new Thread(delegate()
    {
        window = targetWindow.MessageBox(title);
    });
    t.Start();

    long l = CurrentTimeMillis();
    while (CurrentTimeMillis() - l <= timeOutInMillsecond) { }

    if (window == null)
        t.Abort();

    return window;
}

public static class DateTimeUtil
{
    private static DateTime Jan1st1970 = new DateTime(1970, 1, 1, 0, 0, 0, DateTimeKind.Utc);
    public static long currentTimeMillis()
    {
        return (long)((DateTime.UtcNow - Jan1st1970).TotalMilliseconds);
    }
}
Autorizzato sotto: CC-BY-SA insieme a attribuzione
Non affiliato a StackOverflow
scroll top