分享方式:


進度狀態範例報告

Azure DevOps Services |Azure DevOps Server 2022 |Azure DevOps Server 2020

您可以在 Power BI 中報告一或多個測試計畫的執行狀態。 您使用本文中的資訊所建立的報表與下圖和追蹤測試狀態 - 進度報表摘要圖表類似。

Power BI 測試計劃進度環圈報表的螢幕快照。

此報表會顯示兩個環圈圖,摘要說明執行且未執行的測試計劃,以及執行的測試計劃狀態。

  • 執行與未執行
    • 執行:執行的測試案例的總和和百分比。
    • NotExecuted:未執行之測試案例的總和和百分比。
  • 依結果分割
    • 通過:通過的測試案例的總和和百分比。
    • 已封鎖:目前封鎖無法執行的測試案例總和百分比。
    • 失敗:執行時失敗的測試案例總和百分比。
    • NotApplicable:未執行之測試案例的總和和百分比。

報表回答的問題

整體執行狀態報告可藉由回答下列問題,協助您追蹤小組在產品或服務計劃測試方面的進度:

  • 測試完成多少?
  • 測試通過、失敗或遭到封鎖的目前狀態為何?

重要

Azure DevOps Services 和 Azure DevOps Server 2020 和更新版本的 Power BI 整合 和存取 Analytics Service 的 OData 摘要 已正式推出。 本文中提供的範例查詢僅適用於 Azure DevOps Server 2020 和更新版本,且相依於 v3.0-preview 或更新版本。 我們鼓勵您使用這些查詢並提供意見反應。

必要條件

  • 存取:至少是具有基本存取權的項目成員。
  • 許可權: 根據預設,項目成員具有查詢分析及建立檢視的許可權。
  • 如需有關服務與功能啟用和一般數據追蹤活動之其他必要條件的詳細資訊,請參閱 存取分析的許可權和必要條件。

注意

本文假設您已閱讀 使用 OData 查詢 的範例報表概觀,並具備 Power BI 的基本瞭解。

若要讓報表產生有用的數據,小組必須執行下列活動來管理測試計劃:

  • 定義測試計劃、測試套件和測試案例。 指定其狀態。 若要讓 Test Suite 執行,它必須處於 [進行中] 狀態。 若要讓測試案例執行,它必須處於就緒狀態。 如需詳細資訊,請參閱 建立手動測試案例

  • 執行手動測試並驗證結果。 將測試案例中每個驗證步驟的結果標示為通過或失敗。 如需詳細資訊,請參閱 執行手動測試

    注意

    如果測試人員是驗證測試步驟,則必須標示狀態為測試步驟的測試步驟。 測試的整體結果會反映已標記之所有測試步驟的狀態。 因此,如果任何測試步驟標示為失敗或未標示,測試將會有失敗的狀態。

範例查詢

您可以使用實體集的 TestPoints 下列查詢來建立不同的但類似的測試計劃進度報告。

注意

若要判斷篩選或報表用途的可用屬性,請參閱 Test Plans Analytics 的元數據參考。 您可以使用的 或 NavigationPropertyBinding PathEntitySet底下EntityType的任何Property值來篩選查詢或傳回屬性。 每個 EntitySet 對應至 EntityType。 如需每個值之數據類型的詳細資訊,請檢閱針對對應 EntityType提供的元數據。

將下列 Power BI 查詢直接複製並貼到 [取得資料>空白查詢] 視窗中。 如需詳細資訊,請參閱 使用 OData 查詢的範例報表概觀

let 
    Source = OData.Feed ("https://analytics.dev.azure.com/{organization}/{project}/_odata/v3.0-preview/TestPoints?" 
        &"$apply=filter(TestSuite/TestPlanTitle eq '{testPlanTitle}')" 
        &"/aggregate(" 
            &"$count as TotalCount," 
            &"cast(LastResultOutcome eq 'Passed', Edm.Int32) with sum as Passed," 
            &"cast(LastResultOutcome eq 'Failed', Edm.Int32) with sum as Failed," 
            &"cast(LastResultOutcome eq 'Blocked', Edm.Int32) with sum as Blocked," 
            &"cast(LastResultOutcome eq 'NotApplicable', Edm.Int32) with sum as NotApplicable," 
            &"cast(LastResultOutcome eq 'None', Edm.Int32) with sum as NotExecuted," 
            &"cast(LastResultOutcome ne 'None', Edm.Int32) with sum as Executed" 
        &")/compute(" 
            &"Executed mul 100 div TotalCount as ExecPct," 
            &"iif(TotalCount gt NotExecuted, Passed mul 100 div Executed,0) as PassedPct" 
        &")", null, [Implementation="2.0"]) 
in 
    Source

替代字串和查詢明細

以您的值取代下列字串。 請勿在替代中包含括號 {} 。 例如,如果您的組織名稱為 「Fabrikam」 ,請將 取代 {organization}Fabrikam,而非 {Fabrikam}

  • {organization} - 您的組織名稱
  • {project} - 針對跨項目查詢,您的小組專案名稱或完全省略 “/{project}”
  • {testPlanTitle} - 您要傳回其資料的測試計劃標題。

查詢明細

下表描述查詢的每個部分。

查詢元件

說明


filter((TestSuite/TestPlanTitle eq '{testPlanTitle}'))

只傳回所選測試計劃的數據。 您可以使用 子句來新增多個方案,例如 filter((TestSuite/TestPlanTitle eq '{testPlanTitle1}' or TestSuite/TestPlanTitle eq '{testPlanTitle2}'))。 您也可以在這裡套用任何其他與測試套件、測試組態相關的篩選。

/aggregate($count as TotalCount,

匯總篩選測試點的數據,其計數為 TotalCount

cast(LastResultOutcome eq 'Passed', Edm.Int32) with sum as Passed

在匯總時,類型轉換測試點具有最新的執行結果 「傳遞」到1,並將其加總為『Passed計量。

/compute(Executed mul 100 div TotalCount as ExecPct.

提供等於 (執行的測試點/ 總計數 * 100) 的計算計量 ExecPct

(選擇性)重新命名查詢

您可以將預設查詢標籤 Query1 重新命名為更有意義的專案。 只要從 [ 查詢設定 ] 窗格輸入新名稱即可。

Power BI 查詢功能表選項、重新命名查詢的螢幕快照。

變更數據行數據類型

從 Power Query 編輯器,選取數據TotalCount行和其他所有數據行,然後從 [轉換] 功能選取 [數據類型],然後選擇 [整數]。 如需變更數據類型的詳細資訊,請參閱 轉換分析數據以產生Power BI報表、轉換資料行數據類型

(選擇性)重新命名數據行欄位

您可以重新命名資料列欄位。 例如,您可以將資料列 NotApplicable 重新命名為 Not Applicable,或 TotalCount 重新命名為 Total Count。 若要瞭解如何,請參閱 重新命名數據行欄位

關閉查詢並套用您的變更

完成所有數據轉換之後,請從 [常用] 功能表選擇 [關閉及套用],以儲存查詢並返回 Power BI 中的 [報表] 索引卷標。

Power Query 編輯器 關閉和套用選項的螢幕快照。

建立環圈圖報表

  1. 在 Power BI 的 [視覺效果],選擇環圈報表。

    測試進度執行報表的視覺效果字段選取項目螢幕快照。

  2. 若要建立 Executed v/s Not executed環圈圖,請依照指示的順序,將下列字段新增至 Values

    • Executed
    • NotExecuted.
  3. 若要依結果建立環圈圖分割,請依照指示的順序,將下列字段新增至 [值]。

    • Passed
    • Failed
    • Blocked
    • NotApplicable
    • 依此類推。

下圖顯示產生的報表。

Power BI 範例測試計劃進度報告的螢幕快照。