Flaky testleri örnek raporu
Azure DevOps Services | Azure DevOps Server 2022 | Azure DevOps Server 2020
Aşağıdaki görüntüde gösterildiği gibi, test görevlerini içeren işlem hattı çalıştırmalarında oluşan flaky testleri listeleyen bir rapor oluşturabilirsiniz. Flaky test, kaynak kodunda veya yürütme ortamında değişiklik olmasa bile başarılı veya başarısız gibi farklı sonuçlar sağlayan bir testtir. Flaky testlerini etkinleştirme hakkında daha fazla bilgi için bkz . Flaky testlerini yönetme. İşlem hattına test ekleme hakkında bilgi için bu makalenin devamında yer alan Görev kaynaklarını test etme bölümüne bakın.
Aşağıdaki raporları oluşturmak için bu makalede sağlanan sorguları kullanın:
- Derleme iş akışı için flaky testleri
- Yayın iş akışı için flaky testleri
- Belirli bir dal için flaky testleri
- Belirli bir test dosyası için flaky testleri
- Belirli bir test sahibi için gevşek testler.
Önemli
Power BI tümleştirmesi ve Analiz Hizmeti'nin OData akışına erişim genellikle Azure DevOps Services ve Azure DevOps Server 2020 ve sonraki sürümlerde kullanılabilir. Bu makalede sağlanan örnek sorgular yalnızca Azure DevOps Server 2020 ve sonraki sürümlerde geçerlidir ve v3.0 önizleme veya sonraki sürüme bağlıdır. Bu sorguları kullanmanızı ve bize geri bildirim sağlamanızı öneririz.
Önkoşullar
- Erişimi: En az Temel erişimi olanProje üyesi.
- İzinler: Varsayılan olarak, proje üyeleri Analytics'i sorgulama ve görünüm oluşturma iznine sahiptir.
- Hizmet ve özellik etkinleştirme ve genel veri izleme etkinlikleriyle ilgili diğer önkoşullar hakkında daha fazla bilgi için bkz . Analytics'e erişim izinleri ve önkoşulları.
Not
Bu makalede, OData Sorguları kullanarak Örnek Raporlara Genel Bakış makalesini okuduğunuz ve Power BI hakkında temel bilgilere sahip olduğunuz varsayılır.
Örnek sorgular
Farklı ama benzer işlem hattı flaky test raporları oluşturmak için varlık kümesinin aşağıdaki sorgularını TestResultsDaily
kullanabilirsiniz.
TestResultsDaily
Varlık kümesi, teste göre gruplandırılmış yürütmelerin günlük anlık görüntü toplamını TestResult
sağlar.
Not
Filtre veya rapor amacıyla kullanılabilir özellikleri belirlemek için bkz . Test Planları Analizi için meta veri başvurusu ve Azure Pipelines için meta veri başvurusu. sorgularınızı filtreleyebilir veya ile kullanılabilen Property
veya EntityType
değerlerinin NavigationPropertyBinding Path
altındaki EntitySet
değerlerden herhangi birini kullanarak özellikleri döndürebilirsiniz. Her EntitySet
bir EntityType
öğesine karşılık gelir. Her değerin veri türü hakkında daha fazla bilgi için ilgili EntityType
için sağlanan meta verileri gözden geçirin.
Derleme iş akışı için küçük testler
Derleme iş akışı işlem hattı için flaky testlerini görüntülemek için aşağıdaki sorguları kullanın.
Aşağıdaki Power BI sorgusunu kopyalayıp doğrudan Veri> penceresine yapıştırın. Daha fazla bilgi için bkz . OData sorgularını kullanan örnek raporlara genel bakış.
let
Source = OData.Feed ("https://analytics.dev.azure.com/{organization}/{project}/_odata/v4.0-preview/TestResultsDaily?
$apply=filter("
&"Pipeline/PipelineName eq '{pipelineName} "
&"And Date/Date ge {startdate} "
&"And Workflow eq 'Build') "
&"/groupby((TestSK, Test/TestName), "
&"aggregate( "
&"ResultCount with sum as TotalCount, "
&"ResultPassCount with sum as PassedCount, "
&"ResultFailCount with sum as FailedCount, "
&"ResultNotExecutedCount with sum as NotExecutedCount, "
&"ResultNotImpactedCount with sum as NotImpactedCount, "
&"ResultFlakyCount with sum as FlakyCount)) "
&"/filter(FlakyCount gt 0) "
&"/compute( "
&"(FlakyCount div cast(TotalCount, Edm.Decimal)) mul 100 as FlaykRate) "
,null, [Implementation="2.0",OmitValues = ODataOmitValues.Nulls,ODataVersion = 4])
in
Source
Yayın iş akışı için flaky testleri
Yayın iş akışı işlem hattı için flaky testlerini görüntülemek için aşağıdaki sorguları kullanın.
Aşağıdaki Power BI sorgusunu kopyalayıp doğrudan Veri> penceresine yapıştırın. Daha fazla bilgi için bkz . OData sorgularını kullanan örnek raporlara genel bakış.
let
Source = OData.Feed ("https://analytics.dev.azure.com/{organization}/{project}/_odata/v4.0-preview/TestResultsDaily?
$apply=filter("
&"Pipeline/PipelineName eq '{pipelineName}' "
&"And Date/Date ge {startdate}) "
&"/groupby((TestSK, Test/TestName, Workflow), "
&"aggregate( "
&"ResultCount with sum as TotalCount, "
&"ResultPassCount with sum as PassedCount, "
&"ResultFailCount with sum as FailedCount, "
&"ResultNotExecutedCount with sum as NotExecutedCount, "
&"ResultNotImpactedCount with sum as NotImpactedCount, "
&"ResultFlakyCount with sum as FlakyCount)) "
&"/filter(FlakyCount gt 0) "
&"/compute( "
&"(FlakyCount div cast(TotalCount, Edm.Decimal)) mul 100 as FlakyRate) "
,null, [Implementation="2.0",OmitValues = ODataOmitValues.Nulls,ODataVersion = 4])
in
Source
Branch tarafından filtrelenen flaky testleri
Belirli bir dal için işlem hattının başarısız testlerini görüntülemek için aşağıdaki sorguları kullanın. Raporu oluşturmak için, bu makalenin devamında belirtilenlerle birlikte aşağıdaki ek adımları uygulayın.
- genişlet
Branch
Branch.BranchName
- Power BI Görselleştirme Dilimleyicisi'ni seçin ve alanı
Branch.BranchName
dilimleyicinin Alanına ekleyin - Sonuç özetini görmeniz gereken dilimleyiciden dal adını seçin.
Dilimleyicileri kullanma hakkında daha fazla bilgi için bkz . Power BI'da dilimleyiciler.
Aşağıdaki Power BI sorgusunu kopyalayıp doğrudan Veri> penceresine yapıştırın. Daha fazla bilgi için bkz . OData sorgularını kullanan örnek raporlara genel bakış.
let
Source = OData.Feed ("https://analytics.dev.azure.com/{organization}/{project}/_odata/v4.0-preview/TestResultsDaily?
$apply=filter("
&"Pipeline/PipelineName eq '{pipelineName}' "
&"And Date/Date ge {startdate} "
&"And Workflow eq 'Build') "
&"/groupby((TestSK, Test/TestName, Branch/BranchName), "
&"aggregate( "
&"ResultCount with sum as TotalCount, "
&"ResultPassCount with sum as PassedCount, "
&"ResultFailCount with sum as FailedCount, "
&"ResultNotExecutedCount with sum as NotExecutedCount, "
&"ResultNotImpactedCount with sum as NotImpactedCount, "
&"ResultFlakyCount with sum as FlakyCount)) "
&"/filter(FlakyCount gt 0) "
&"/compute( "
&"(FlakyCount div cast(TotalCount, Edm.Decimal)) mul 100 as FlakyRate) "
,null, [Implementation="2.0",OmitValues = ODataOmitValues.Nulls,ODataVersion = 4])
in
Source
Test dosyasına göre filtrelenmiş flaky testleri
İşlem hattının ve belirli bir test dosyasının flaky testlerini görüntülemek için aşağıdaki sorguları kullanın. Raporu oluşturmak için, bu makalenin devamında tanımlananlarla birlikte aşağıdaki ek adımları uygulayın.
- genişlet
Test
Test.ContainerName
- Power BI Görselleştirme Dilimleyicisi'ni seçin ve alanı
Test.ContainerName
dilimleyicinin Alanına ekleyin - Sonuç özetini görmeniz gereken dilimleyiciden kapsayıcı adını seçin.
Aşağıdaki Power BI sorgusunu kopyalayıp doğrudan Veri> penceresine yapıştırın. Daha fazla bilgi için bkz . OData sorgularını kullanan örnek raporlara genel bakış.
let
Source = OData.Feed ("https://analytics.dev.azure.com/{organization}/{project}/_odata/v4.0-preview/TestResultsDaily?
$apply=filter("
&"Pipeline/PipelineName eq '{pipelineName}' "
&"And Date/Date ge {startdate}) "
&"/groupby((TestSK, Test/TestName, Test/ContainerName), "
&"aggregate( "
&"ResultCount with sum as TotalCount, "
&"ResultPassCount with sum as PassedCount, "
&"ResultFailCount with sum as FailedCount, "
&"ResultNotExecutedCount with sum as NotExecutedCount, "
&"ResultNotImpactedCount with sum as NotImpactedCount, "
&"ResultFlakyCount with sum as FlakyCount)) "
&"/filter(FlakyCount gt 0) "
&"/compute( "
&"(FlakyCount div cast(TotalCount, Edm.Decimal)) mul 100 as FlakyRate) "
,null, [Implementation="2.0",OmitValues = ODataOmitValues.Nulls,ODataVersion = 4])
in
Source
Test sahibi tarafından filtrelenen flaky testleri
İşlem hattının Flaky testlerini ve belirli bir test sahibinin sahip olduğu testleri görüntülemek için aşağıdaki sorguları kullanın. Raporu oluşturmak için, bu makalenin devamında tanımlananlarla birlikte aşağıdaki ek adımları uygulayın.
- genişlet
Test
Test.TestOwner
- Power BI Görselleştirme Dilimleyicisi'ni seçin ve alanı
Test.TestOwner
dilimleyicinin Alanına ekleyin - Sonuç özetini görmeniz gereken dilimleyiciden test sahibini seçin.
Aşağıdaki Power BI sorgusunu kopyalayıp doğrudan Veri> penceresine yapıştırın. Daha fazla bilgi için bkz . OData sorgularını kullanan örnek raporlara genel bakış.
let
Source = OData.Feed ("https://analytics.dev.azure.com/{organization}/{project}/_odata/v4.0-preview/TestResultsDaily?
$apply=filter("
&"Pipeline/PipelineName eq '{pipelineName}' "
&"And Date/Date ge {startdate}) "
&"/groupby((TestSK, Test/TestName, Test/TestOwner), "
&"aggregate( "
&"ResultCount with sum as TotalCount, "
&"ResultPassCount with sum as PassedCount, "
&"ResultFailCount with sum as FailedCount, "
&"ResultNotExecutedCount with sum as NotExecutedCount, "
&"ResultNotImpactedCount with sum as NotImpactedCount, "
&"ResultFlakyCount with sum as FlakyCount)) "
&"/filter(FlakyCount gt 0) "
&"/compute( "
&"(FlakyCount div cast(TotalCount, Edm.Decimal)) mul 100 as FlakyRate) "
,null, [Implementation="2.0",OmitValues = ODataOmitValues.Nulls,ODataVersion = 4])
in
Source
Değiştirme dizeleri ve sorgu dökümü
Aşağıdaki dizeleri değerlerinizle kullanın. Değiştirmenize köşeli ayraç {} eklemeyin. Örneğin, kuruluşunuzun adı "Fabrikam" ise yerine {organization}
Fabrikam
yerine değerini {Fabrikam}
yazın.
-
{organization}
- Kuruluşunuzun adı -
{project}
- Ekip projenizin adı -
{pipelinename}
- İşlem hattı adınız. Örnek:Fabrikam hourly build pipeline
-
{startdate}
- Raporunuzu başlatma tarihi. Biçim: YYYY-AA-GGZ. Örnek:2021-09-01Z
1 Eylül 2021'i temsil eder. Tırnak veya köşeli ayraç içine almayın ve ay ve tarih için iki basamak kullanın.
Sorgu dökümü
Aşağıdaki tabloda sorgunun her bölümü açıklanmaktadır.
Sorgu bölümü
Açıklama
$apply=filter(
Start filter()
yan tümcesi.
Pipeline/PipelineName eq '{pipelineName}'
Belirtilen işlem hattı için dönüş testi çalıştırmaları.
and CompletedOn/Date ge {startdate}
Dönüş testi belirtilen tarihte veya sonrasında çalışır.
and Workflow eq 'Build'
bir Build
iş akışı için dönüş testi çalıştırmaları.
)
Close filter()
yan tümcesi.
/groupby(
Start groupby()
yan tümcesi.
(TestSK, Test/TestName),
Test adına göre gruplandırın.
aggregate(
Filtre ölçütleri ile eşleşen test çalıştırmalarını hesaplamak için Start aggregate
yan tümcesi.
ResultCount with sum as TotalCount,
Test çalıştırmalarının toplam sayısını olarak TotalCount
sayar.
ResultPassCount with sum as PassedCount,
Geçirilen test çalıştırmalarının toplam sayısını olarak PassedCount
sayar.
ResultFailCount with sum as FailedCount,
Başarısız test çalıştırmalarının toplam sayısını olarak FailedCount
sayın.
ResultNotExecutedCount with sum as NotExecutedCount
Yürütülmemiş test çalıştırmalarının toplam sayısını olarak NotExecutedCount
sayın.
ResultNotImpactedCount with sum as NotImpactedCount,
Etkilenmeyen test çalıştırmalarının toplam sayısını olarak NotImpactedCount
sayın.
ResultFlakyCount with sum as FlakyCount
Flaky test çalıştırmalarının toplam sayısını olarak FlakyCount
sayar.
))
ve aggregate()
yan tümcelerini kapatıngroupby()
.
/filter(FlakyCount gt 0)
Yalnızca en az bir kez gevşek olan testleri filtreleyin.
/compute(
Start compute()
yan tümcesi.
(FlakyCount div cast(TotalCount, Edm.Decimal)) mul 100 as FlakyRate
Tüm flaky testleri için değerini hesaplayın FlakyRate
.
)
Close compute()
yan tümcesi.
(İsteğe bağlı) Sorguyu yeniden adlandırma
Varsayılan sorgu etiketi olan Query1'i daha anlamlı bir şekilde yeniden adlandırabilirsiniz. Sorgu Ayarları bölmesinden yeni bir ad girmeniz yeterlidir.
Power BI'da Test sütununu genişletme
Test
Genişletilmiş varlığı Test.TestName
göstermek için sütununu genişletin. Sütunu genişletmek kaydı belirli alanlara düzleştirir. Nasıl yapılacağını öğrenmek için bkz . Power BI raporları oluşturmak için Analiz verilerini dönüştürme, Sütunları genişletme.
Sütun veri türünü değiştirme
Power Query Düzenleyicisi , ,
TotalCount
,PassedCount
,FailedCount
,NotExecutedCount
veNotImpactedCount
sütunlarını seçinFlakyCount
; Dönüştür menüsünden Veri Türü'nü seçin ve ardından Tam Sayı'yı seçin.FlakyRate
Sütunu seçin; Dönüştür menüsünden Veri Türü'nüseçin ve ardından Ondalık Sayı'yı seçin.
Veri türünü değiştirme hakkında daha fazla bilgi için bkz . Power BI raporları oluşturmak için Analiz verilerini dönüştürme, Sütun veri türünü dönüştürme.
Sorguyu kapatma ve değişikliklerinizi uygulama
Tüm veri dönüşümlerinizi tamamladıktan sonra, sorguyu kaydetmek ve Power BI'daki Rapor sekmesine dönmek için Giriş menüsünden Kapat ve Uygula'yı seçin.
Tablo raporunu oluşturma
Power BI'da Görselleştirmeler'in altında Tablo'ya tıklayın ve alanları Sütunlar alanına sürükleyip bırakın.
Sütunlar bölümüne listelenen sırayla aşağıdaki alanları ekleyin.
Test.TestName
TotalCount
PassedCount
FailedCount
FlakyCount
FlakyRate
Raporunuz aşağıdaki görüntüye benzer görünmelidir.
Görev kaynaklarını test et
- Visual Studio Test görevini kullanarak testleri paralel çalıştırma
- Herhangi bir test çalıştırıcısı için testleri paralel olarak çalıştırma
- Test Etkisi Analizini (TIA) kullanarak testi hızlandırma
- Flaky testlerini yönetme
- KULLANıCı arabirimi testiyle ilgili dikkat edilmesi gerekenler
- Azure Yük Testi
- Azure Pipelines görev başvurusu, Test görevleri