2012-09-05 13 views
5

Uso l'approccio MsTests e Data Driven per il test. (Excel è l'archiviazione dei dati per i test)Nome Mstest invece Riga dati con test basati sui dati

risultato dei test non fornire alcuna informazione sui dati di test. Ad esempio:

Risultato come: testname (riga di dati 5). E non è chiaro per me.

Come posso personalizzare il risultato del test di uscita? Per esempio nometest (dati di test (parola, il numero, o una riga di nome))

risposta

4

ho trovato una sola soluzione:

ho il file MyData.xlsx con 1000 righe. Logica semplice: colonna "A" = 1, colonna "B" = A * 2 + 2.

Righe 5,6,7 e 11,12,13 conteine ​​zero per ottenere risultati non riusciti.

SourceCode della mia prova:

public TestContext TestContext { get; set; } 

    [TestMethod] 
    [DataSource("System.Data.Odbc", "Dsn=Excel Files;dbq=|DataDirectory|\\TestData\\MyData.xlsx;", "TestDataSheet$", DataAccessMethod.Sequential)] 
    public void ExcelDataSource1000Items() 
    { 
     var errorMessage = "Passed"; 

     int valueA = Convert.ToInt32(TestContext.DataRow["valueA"]); 
     int valueB = Convert.ToInt32(TestContext.DataRow["valueB"]); 
     try 
     { 
      Assert.AreEqual(valueA * 2 + 2, valueB); 
     } 
     catch (Exception exception) 
     { 
      errorMessage = exception.Message; 
     } 
     TestContext.WriteLine(string.Format("valueA: {0}, valueB: {1}, AssertResult: {2}", valueA, valueB, errorMessage)); 
    } 

Dopo la prova di esecuzione da MSTest riga di comando (per la generazione di file * .trx) con i parametri:/testcontainer,/testsettings,/resultsfile si generano file * .trx con la prova risultati.

E se apriamo il file * .trx, possiamo vedere textmessages:

<Results> 
<UnitTestResult executionId="cfc325a7-647f-4ef3-bb08-777f7bb3ca37" testId="1dbff80d-1f74-5ea7-35fa-f2ecd1f9b9e4" testName="ExcelDataSource1000Items" computerName="AMDX6" duration="00:00:00.5764248" startTime="2012-09-06T03:21:45.2070571+04:00" endTime="2012-09-06T03:21:46.1251096+04:00" testType="13cdc9d9-ddb5-4fa4-a97d-d965ccfc6d4b" outcome="Passed" testListId="8c84fa94-04c1-424b-9868-57a2d4851a1d" relativeResultsDirectory="cfc325a7-647f-4ef3-bb08-777f7bb3ca37" resultType="DataDrivenTest"> 
    <Output> 
    <TextMessages> 
     <Message>valueA: 1, valueB: 4, AssertResult: Passed</Message> 
     <Message>valueA: 2, valueB: 6, AssertResult: Passed</Message> 
     <Message>valueA: 3, valueB: 8, AssertResult: Passed</Message> 
     <Message>valueA: 4, valueB: 0, AssertResult: Assert.AreEqual failed. Expected:&lt;10&gt;. Actual:&lt;0&gt;. </Message> 
     <Message>valueA: 5, valueB: 0, AssertResult: Assert.AreEqual failed. Expected:&lt;12&gt;. Actual:&lt;0&gt;. </Message> 
     <Message>valueA: 6, valueB: 0, AssertResult: Assert.AreEqual failed. Expected:&lt;14&gt;. Actual:&lt;0&gt;. </Message> 
     <Message>valueA: 7, valueB: 16, AssertResult: Passed</Message> 
     <Message>valueA: 8, valueB: 18, AssertResult: Passed</Message> 
     <Message>valueA: 9, valueB: 20, AssertResult: Passed</Message> 
     <Message>valueA: 10, valueB: 0, AssertResult: Assert.AreEqual failed. Expected:&lt;22&gt;. Actual:&lt;0&gt;. </Message> 
     <Message>valueA: 11, valueB: 0, AssertResult: Assert.AreEqual failed. Expected:&lt;24&gt;. Actual:&lt;0&gt;. </Message> 
     <Message>valueA: 12, valueB: 0, AssertResult: Assert.AreEqual failed. Expected:&lt;26&gt;. Actual:&lt;0&gt;. </Message> 
     <Message>valueA: 13, valueB: 28, AssertResult: Passed</Message> 
     <Message>valueA: 14, valueB: 30, AssertResult: Passed</Message> 
     <Message>valueA: 15, valueB: 32, AssertResult: Passed</Message> 
     <Message>valueA: 16, valueB: 34, AssertResult: Passed</Message> 
     <Message>valueA: 17, valueB: 36, AssertResult: Passed</Message> 
     <Message>valueA: 18, valueB: 38, AssertResult: Passed</Message> 
     <Message>valueA: 19, valueB: 40, AssertResult: Passed</Message> 
     <Message>valueA: 20, valueB: 42, AssertResult: Passed</Message> 

Questi textmessages può essere analizzato per generare il rapporto di prova. (per esempio)

P.S. Spiacente, non posso aggiungere screenshot, perché non ho 10 o più reputazione = \

+0

Sì, sono d'accordo. Ma per i primi dati di test TestContext.CurrentTestOutcome Property return "In Progress". È corretto utilizzare la proprietà TestContext.CurrentTestOutcome nel metodo di prova. Se contengo "TestContext.WriteLine (TestContext.CurrentTestOutcome.ToString());" nel metodo TestCleanup, non ottengo nulla. –

Problemi correlati