Hirdetés

Új hozzászólás Aktív témák

  • joysefke

    veterán

    xUnit Dispose vs Async hogyan?

    Sziasztok!

    Nagyon új nekem ez az xUnit, tegnap kezdtem :B és nem hiszem, hogy jól használom az Async metódusomatot a Dispose()-ban: működik, de nem teljesen azt csinálja a kód amit szeretnék/elvárnék...

    Az adott xUnit test class egy külső API interfészről történő lekérdezést tesztel.

    Az xUnit osztály konstruktorában van a setup kódom, itt többek között kreálok egy
    friss sessionId-t amitől a teszt végén mindenképpen meg kell szabadulnom.
    A "megszabadulás" egy Async DeleteSession(string sessionId) hívás formájában kell megtörténjen, ezért ezt beraktam a teszt osztály public async void Dispose() metódusába.

    A problémám az, hogy a Dispose() metódusban a végrehajtás látszólag túljut az await DeleteSession()-ön, ezt onnan látom, hogy a SessionId törlődik a külső rendszerből.
    De a DeleteSession() utáni szinkron utasítások már nem hajtódnak végre.

    Itt a kód!

    Osztály deklaráció, konstruktor és Dispose:
    public class GetAccountDetailsTests : IDisposable
    {
    // Setup
    public GetAccountDetailsTests(ITestOutputHelper output)
    {
    // csak a lényeg:
    _getSession = hot task indul
    }

    public async void Dispose()
    {
    // nem annak látszik, de ez SZINKRON, a Task már elkészült
    var sessionId = (await await _getSession).SessionId;
    _output.WriteLine($"Teardown: DeleteSession({sessionId}) called...");

    // ez biztosan most indul és a külső szervizből látszólag
    // törlődik a session tehát a lényegi dolgát elvégzi,
    // NEM tud exceptiont dobni
    // (elnyeli őket) kóddal jelzi ha hiba volt
    var result = await _client.DeleteSession(sessionId);

    // Ide nem jut el a végrehajtás, nem ír semmit az outputba
    var code = result.HttpStatusCode.ToString();
    _output.WriteLine($"Teardown: DeleteSession(...) returned with {code}");
    }

    Teszt metódus belseje, try-catch-ben, hogy biztosan eljusson a Dispose-ig:
    public async void WhenValidArguments_ReturnsAccountDetails()
    {
    // Arrange
    var sessionId = (await await _getSession).SessionId;

    // Act
    var result = await _client.GetAccountDetails(sessionId);
    AccountDetailsModel account = JsonConvert.DeserializeObject<AccountDetailsModel>(result.Json);

    // Assert
    Assert.True(result.HttpStatusCode == System.Net.HttpStatusCode.OK);
    Assert.True(account.AccountName == _settings.AccountName);
    }

    Nem tudom hogyan kéne értelmesen debuggolni a tesztet, hiába rakok a Dispose-ba breakpointot átugrik rajta amikor a VS "Debug selected test" opciójával indítom. :F

Új hozzászólás Aktív témák