Visual Studio 2010 Feature Packs 2之Silverlight自動化測試

在Visual Studio 2010上市沒多久後,很高興它推出了Coded UI的自動化測試,那時我的專案是跑Silverlight,要錄制時出現不支援的錯誤,只好又乖乖的自己當人工測試機,不過前幾天看到微軟推出Visual Studio 2010 Feature Packs 2套件,其中有一項功能是Create coded UI tests for Silverlight 4 applications,就興高彩烈安裝玩一翻。

在Visual Studio 2010上市沒多久後,很高興它推出了Coded UI的自動化測試,那時我的專案是跑Silverlight,要錄制時出現不支援的錯誤,只好又乖乖的自己當人工測試機,不過前幾天看到微軟推出Visual Studio 2010 Feature Packs 2套件,其中有一項功能是Create coded UI tests for Silverlight 4 applications,就興高彩烈安裝玩一翻。

NOTE:

在2010/11/23日,截筆前Visual Studio 2010 Feature Packs 2必需要MSDN Subscribers才能下載,什麼沒有MSDN Subscribers,這我也辦法,只能期待微軟把這功能加到Visual Studio 2010 SP1中,或看沒有沒人分享吧。

 

Visual Studio 2010 Feature Packs 2的新功能(僅介紹測試)

  • Coded UI與Test Manager的動作錄制與執行支援Silverlight。
  • Coded UI與Test Manager的動作錄制與執行支援Firefox 3.5、3.6。
  • Coded UI編輯器。

 

Silverlight自動化測試

要Silverlight可以自動化測試還有點麻煩,有三個條件。

  • Host只支援IE。
  • 必需要Silverlight 4.0以上。
  • 必需要加入參考Microsoft.VisualStudio.TestTools.UITest.Extension.SilverlightUIAutomationHelper.dll組件。

 

Microsoft.VisualStudio.TestTools.UITest.Extension.SilverlightUIAutomationHelper.dll

安裝好Visual Studio 2010 Feature Packs 2後組件的位址預設在:

C:\Program Files (x86)\Common Files\microsoft shared\VSTT\10.0\UITestExtensionPackages\SilverlightUIAutomationHelper\Microsoft.VisualStudio.TestTools.UITest.Extension.SilverlightUIAutomationHelper.dll

但專案不可以一直都掛載組件,組件的下載的流量與或安全性問題,每次要上線前都要刪除組件,或每次要測試時都加入這個組件,會很煩吧,所以可以從MSBuild下手,打開Project檔如*.csproj,打開後找到


<Reference Include="Microsoft.VisualStudio.TestTools.UITest.Extension.SilverlightUIAutomationHelper, Version=10.0.30319.381, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a, processorArchitecture=MSIL" />

加上Condition=" '$(Configuration)' == 'Debug' ",讓組件只有在Debug的模式下才被參考,Release時不會,加入後的結果如下。


<Reference Condition=" '$(Configuration)' == 'Debug' " Include="Microsoft.VisualStudio.TestTools.UITest.Extension.SilverlightUIAutomationHelper, Version=10.0.30319.381, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a, processorArchitecture=MSIL" />

NOTE:

其實有點不懂為什麼MSDN中的文件How to: Set Up Your Silverlight Application for Testing,MSBuild要寫的那麼麻煩,要自訂Property,每一次切換還要打開專案檔,切換Property。

 

範例

下載


<Grid x:Name="LayoutRoot">
    <RadioButton Content="紅色" Height="16" Margin="12,14,22,270" Name="RBRed" Background="Red" Click="OnColorButtomClick" />
    <RadioButton Content="綠色" Height="16" Margin="12,51,22,233" Name="RBGreen" Background="Green"  Click="OnColorButtomClick" />
    <RadioButton Content="藍色" Height="16" Margin="12,32,22,252" Name="RBBlue" Background="Blue"  Click="OnColorButtomClick" />
</Grid>

public partial class MainPage : UserControl
{
    public MainPage()
    {
        InitializeComponent();
    }

    private void OnColorButtomClick(object sender, RoutedEventArgs e)
    {
        this.LayoutRoot.Background = (sender as Control).Background;
    }       
}

範例很簡單只是三個RadioButton,被Click時切換背景色,錄制RadioButton的切換,選擇Silverlight中綠色的RadioButton,驗證Selected是否為真,工具的可驗證的屬性有點少,不過事實上是工具尚未支援,用Code寫幾乎所有的屬性都可以取得,可參考手工製Coded UI Test(Visual Studio 2010新的UI自動化測試)

image

圖一 選取Silverlight的Control並加入Assertion

 

如果沒有加入組件會出現圖二的錯誤訊息,所以改用Release模式Build,組件是沒加入的。

image

圖二 沒有加入組件的錯誤訊息

 

終於有編輯器了,以前錄好了想改不是改XML(誰會改阿),就是重錄,現在小變動下,可以用編輯器微調。

image

圖三 Coded UI Editor

 

參考

Visual Studio 2010 Feature Packs 2