dir.by  
  Поиск  
Программирование, разработка, тестирование
WPF. Windows Presentation Foundation (отдельное приложение exe файл)
Пишем автоматический тест для WPF C# приложения (используем Nuget.Appium и свойство AutomationProperties.AutomationId)
  Посмотрели 1904 раз(а)    
 Пишем автоматический тест для WPF C# приложения 
Введение. У меня есть WPF приложение
Скачать пример:
WpfAppAnimal.zip (40 kb) ...

Мое WPF приложение работает так:
• вводим название животного
• нажимаем на кнопку
• увидим количество лет сколько животное живет
Код WPF приложения:
Важно:
Чтобы автоматический тест нашел элемент в WPF приложении
используется AutomationProperties.AutomationId
  Xaml  
<Window x:Class="WpfAppAnimal.MainWindow"
          xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
          xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
          xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
          xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
          xmlns:local="clr-namespace:WpfAppAnimal"
          mc:Ignorable="d"
          Title="MainWindow" Height="450" Width="800">
     <Grid>
          <TextBlock
               HorizontalAlignment="Left"
               Margin="147,78,0,0"
               TextWrapping="Wrap"
               Text="Enter animal name:"
               VerticalAlignment="Top"/>
         
          <TextBox
               HorizontalAlignment="Left"
               Height="23"
               Margin="256,77,0,0"
               TextWrapping="Wrap"
               AutomationProperties.AutomationId="AnimalNameTextId"
               Text="{Binding MyModel.AnimalName}"
               VerticalAlignment="Top"
               Width="120"/>
         
          <Button
               Content="Calculate lifetime"
               HorizontalAlignment="Left"
               Margin="147,129,0,0"
               AutomationProperties.AutomationId="CalculateButtonId"
               Command="{Binding MyModel.ClickMyButton1, RelativeSource={RelativeSource FindAncestor, AncestorType={x:Type Window}}}"
               VerticalAlignment="Top" Width="142"/>
         
          <TextBlock
               HorizontalAlignment="Left"
               Margin="147,185,0,0"
               TextWrapping="Wrap"
               AutomationProperties.AutomationId="LifeTimeTextId"
               Text="{Binding MyModel.LifeTime, UpdateSourceTrigger=PropertyChanged}"
               VerticalAlignment="Top"
               Height="21"
               Width="109"/>

     </Grid>
</Window>
Пишем Автоматический тест для этого WPF приложения
Скачать пример:
AutoTestForWpfApp.zip (115 kb) ...
Шаг 1. Открываем Visual Studio
Если у вас не установлена Visual Studio нужно установить Visual Studio...
Открываем Visual Studio 2022
или
Открываем Visual Studio 2019
Шаг 2. Создаем новый проект с типом NUnit тест
 
Создался вот такой проект:
 
Шаг 3. Добавляем NuGet package с Gravity.Drivers.Appium
Шаг 4. Добавим код
  C#     Файл UnitTest1.cs
using OpenQA.Selenium.Appium;
using OpenQA.Selenium.Appium.Windows;

namespace AutoTestForWpfApp
{
     public class Tests
     {
          public const string DriverUrl = "http://127.0.0.1:4723/";

          [SetUp]
          public void Setup()
          {
          }

          [Test]
          public void Test_CheckDog_LifeTime()
          {
               // run WPF exe
               string appWPF = @"D:\WpfAppAnimal\bin\Debug\WpfAppAnimal.exe";
               var options = new AppiumOptions();
               options.AddAdditionalCapability("app", appWPF);
               var session = new WindowsDriver<WindowsElement>(new Uri(DriverUrl), options);

               // wait running WPF (3 seconds)
               Thread.Sleep(3000);

               WindowsElement element = null;

               // autotest write in wpf application text "dog"
               element = session.FindElementByAccessibilityId("AnimalNameTextId");
               element.SendKeys("dog");

               // autotest click button in wpf application
               element = session.FindElementByAccessibilityId("CalculateButtonId");
               element.Click();

               // autotest get text from wpf application
               element = session.FindElementByAccessibilityId("LifeTimeTextId");

               // result
               Assert.AreEqual("16 years", element.Text);

               // close wpf application
               session.Quit();
          }
     }
}
Шаг 5. Запускаем автоматический тест
На заметку! Перед запуском теста надо убедится что приложение WinAppDriver запущено ...
 
Запускаем автоматический тест:
для этого нажимаем правой клавишей мыши на методе Test_CheckDog_LifeTime
Шаг 6. Автоматический тест выполняется ... смотрим
Шаг 1.
Автоматический тест сам запустит наше WPF приложение
 
  C#  

string appWPF = @"D:\WpfAppAnimal\bin\Debug\WpfAppAnimal.exe";
var options = new AppiumOptions();
options.AddAdditionalCapability("app", appWPF);
var session = new WindowsDriver<WindowsElement>(new Uri(DriverUrl), options);


Что происходит:
Создаем объект new WindowsDriver
При создании WindowsDriver запустится файл D:\WpfAppAnimal\bin\Debug\WpfAppAnimal.exe
и этот объект WindowsDriver я назвал переменной session
Шаг 2.
Автоматический тест введет слово dog в WPF приложение
 
  C#  
element = session.FindElementByAccessibilityId("AnimalNameTextId");
element.SendKeys("dog");


Что происходит:
1) element = session.FindElementByAccessibilityId("AnimalNameTextId"); это значит что:
автоматический тест даст команду WPF приложению найти элемент с названием AnimalNameTextId

2) element.SendKeys("dog"); это значит что:
в элемент WPF приложения написать текст dog

Посмотрим код нашего WPF приложения:
  Xaml     код WPF приложения
     <Grid>
          .....
          <TextBox
               HorizontalAlignment="Left"
               Height="23"
               TextWrapping="Wrap"
               AutomationProperties.AutomationId="AnimalNameTextId"
               Text="{Binding MyModel.AnimalName}"
               Width="120"></TextBox>
          .....
     </Grid>
Шаг 3.
Автоматический тест сам нажмет кнопку Calculate Lifetime
 
  C#  
element = session.FindElementByAccessibilityId("CalculateButtonId");
element.Click();


Что происходит:
1) element = session.FindElementByAccessibilityId("CalculateButtonId"); это значит что:
автоматический тест даст команду WPF приложению найти элемент с названием CalculateButtonId

2) element.Click(); это значит что:
кнопка в WPF приложении нажмется
Шаг 4.
В WPF приложении увидим 16 years
 
  C#  
element = session.FindElementByAccessibilityId("LifeTimeTextId");
Assert.AreEqual("16 years", element.Text);


Что происходит:
1) element = session.FindElementByAccessibilityId("LifeTimeTextId"); это значит что:
автоматический тест даст команду WPF приложению найти элемент с названием LifeTimeTextId

2) Assert.AreEqual("16 years", element.Text); это значит что:
Assert.AreEqual если 2 параметра одинаковые то автоматический тест выполнится успешно
1-ый параметр это "16 years"
2-ой параметр это element.Text то есть текст из элемента WPF приложения
Шаг 5.
Закрываем WPF приложение
  C#  
session.Quit();
Шаг 7. Результат автоматического теста
Результат увидим в Visual Studio в Test Explorer:
 
← Предыдущая тема
Как добавить Dependency Injection, загрузку из appsettings.json в новом WPF приложении ?
 
Следующая тема →
В чем отличие static resource от dynamic resource ? | WPF C#
 
Ваши Отзывы ... комментарии ...
   
Вашe имя
Ваш комментарий (www ссылки может добавлять только залогиненный пользователь)

  Объявления  
  Объявления  
 
WPF простое новое приложение
Создаем новое WPF приложение | C#
WPF layout
Делаем layout с DockPanel и StackPanel в WPF
События
Пример "Получаем координаты мыши при нажатии левой клавишей мыши на TextBlock"| координаты экрана и относительные координаты | C# WPF приложение
Пример "Получаем координаты мыши при нажатии левой клавишей мыши на Button"| координаты экрана и относительные координаты | C# WPF приложение
Пример "Получаем координаты мыши при нажатии левой клавишей мыши на Grid и рисуем линию"| C# WPF приложение
Пример "При двойном нажатии левой клавишей мыши на Grid показываем сообщение"| C# WPF приложение
WPF элементы
Label
Пример "Устанавливаем текст в Label" через c# код | WPF приложение
иконки FontAwesome
Пример "Показываю иконки, для иконки подключаю библиотеку fontawesome5" | C# WPF приложение
Пример "Делаю анимацию для иконки, библиотека fontawesome5" | C# WPF приложение
 
TextBlock
Пример "Устанавливаем текст в TextBlock используя Binding". Еще добавим двойной Bindning используя INotifyPropertyChanged | C# WPF приложение
Пример "Несколько TextBlock (показываем тексты) и делаем так чтобы при mouse move выделялся элемент где мышка (mouse over)" | C# WPF приложение
Пример "Получаем координаты мыши при нажатии левой клавишей мыши на TextBlock"| координаты экрана и относительные координаты | C# WPF приложение
Button
Пример "Получаем координаты мыши при нажатии левой клавишей мыши на Button"| координаты экрана и относительные координаты | C# WPF приложение
TextBox
Пример "Устанавливаем и получаем текст в TextBox используя Binding" | C# WPF приложение
Пример "Устанавливаем текст в TextBox" через c# код | WPF приложение
 
TextBox с Place Holder
Пример "Показываем Place Holder в TextBox" | WPF приложение
Пример "Показываем Place Holder с иконкой в TextBox", для иконки подключаю библиотеку fontawesome5 | WPF приложение
 
TextBox с проверкой текста (валидация)
Пример "Устанавливаем текст в TextBox используя Binding и делаем валидацию (если текст не правильный)" | C# WPF приложение
 
ComboBox
Пример "В ComboBox делаем редактирование текста. Получаем текст используя Binding" | C# WPF приложение
 
ItemsControl
Пример "ItemsControl, кнопка и обработчик нажатия" | WPF приложение
Grid
Что такое Grid в WPF
Как добавить RowDefinition, ColumnDefinition в Grid (мышкой в XAML design editor) | C# WPF приложение
В Grid добавляем vertical scrolling | WPF приложение
DataGrid
Пример "DataGrid делаем bind данных", кнопка и обработчик нажатия в DataGrid, выравнивание текста в DataGrid, scrolling | WPF приложение
Как сделать scrolling для DataGrid ? | C# WPF приложение
Scrolling для DataGrid (чтобы скролинг работал когда мы крутим колесо мышки и мышка находится вне scroll bar) | C# WPF приложение
Как выделить row цветом при нажатии на row мышкой (change background for selected row) в DataGrid ? | C# WPF приложение
Как row DataGrid выделить цветом (сделать background) ? | C# WPF приложение
Пример "DataGrid делаем сортировку колонки по своему алгоритму (Custom Sort)" | WPF приложение
DataGrid внутри DataGrid
Пример портфолио сотрудников с описанием задач: "DataGrid внутри DataGrid используя RowDetailsTemplate" | WPF приложение
 
ListView
Пример "В ListView расширяем колонку при добавлении данных (auto column width)" | WPF приложение
Пример "В ListView используем ItemTemplate DataTemplate" | WPF приложение
 
ScrollViewer
В Grid добавляем vertical scrolling | WPF приложение
Как сделать scrolling для DataGrid ? | C# WPF приложение
Scrolling для DataGrid (чтобы скролинг работал когда мы крутим колесо мышки и мышка находится вне scroll bar) | C# WPF приложение
Пример "Делаем ScrollBar меньше(больше) в ScrollViewer" | C# WPF приложение
Resource файл
Добавляем картинку (jpg, bmp, png) в проект и помечаем как Resource | C# WPF приложение
Image
В элементе Image показываем картинку (jpg, bmp, png) из Resource | C# WPF приложение
Выбираем картинку (jpg, bmp, png) из компьютера и показываем в элементе Image. Сохраняем картинку в базу данных | C# WPF приложение
Пример "В Image элементе делаем Binding для Source" | C# WPF приложение
Пример "Конвертируем текст base64 в картинку Bitmap и показываем в Image элементе" | C# WPF приложение
Пример "Открываем SVG файл и показываем картинку в Image элементе" | C# WPF приложение
 
Canvas
Пример "Создаем Canvas и рисуем картинку" C# WPF
Пример "Рисуем картинку с движением на Canvas" C# WPF
Пример "Рисуем картинку с движением и анимацией sprite на Canvas" C# WPF
 
Line
Рисуем Line (сплошная и штриховая линии) | C# WPF приложение
Пример "Создаем и рисуем линию при нажатии левой клавишей мыши на Grid"| Grid Line | C# WPF приложение
Конвертируем картинку в XAML Path Geometry
Конвертируем SVG в XAML(используя Adobe Illustrator), заполняем Path Data Geometry, показываем линии на экране | C# WPF приложение
Конвертируем SVG в XAML(используя Dias SVG to UWP XAML Converter), заполняем Path Data Geometry, показываем линии на экране | C# WPF приложение
Конвертируем PNG в SVG в XAML | C# WPF приложение
Converter SVG to XAML | WPF C#
Конвертируем XAML в SVG | C# WPF приложение
ViewBox
Пример "ViewBox делаем Binding для Left, Top, Width, Height, ContetnPresenter binding" | C# WPF приложение
Width by percentage
Разделить экран по вертикали (по ширине) на 2 равные части экран (width1 = 50%, width2 = 50%), используем Grid | C# WPF приложение
Разделить экран по вертикали (по ширине) на 2 части (width1 = 70%, width2 = 30%), используем Grid | C# WPF приложение
Пример "Устанавливаем ширину элемента в процентах от ширины родительского элемента" (width in percentage), пишем свой IValueConverter | C# WPF приложение
База данных (Entity Framework)
Entity Framework в приложении WPF. Используем Code First (пишем c# код, а таблицы в базе данных создаются сами)
Создаем свои WPF элементы
Пример "Создаем свой WPF элемент используя Style и новый xaml файл. Новый элемент это: вверху Title, внизу текст в рамке. Используем Binding | C# WPF приложение
Пример "Создаем свой новый WPF элемент со своими свойсвами в новом cs и xaml файлах. В WPF новом элементе: вверху Title, снизу текст и в рамке | C# WPF приложение
WPF приложение с библиотекой Prism (MVVM шаблон проектирования)
Создаем новое WPF приложение с Prism Unity (разделение проекта на папки Services, Views, ViewModels). Патерн MVVM (Model-View-ViewModel) | C#
WPF приложение с Prism Unity. В приложении Tab и разделения на отдельные xaml используя Region.
WPF приложение с Locator (MVVM шаблон проектирования)
Создаем новое WPF приложение с Locator (разделение проекта на папки Views, ViewModels)
Как добавить Dependency Injection, загрузку из appsettings.json в новом WPF приложении ?
Автоматические тесты
Пишем автоматический тест для WPF C# приложения (используем Nuget.Appium и свойство AutomationProperties.AutomationId)
Вопросы на собеседованиях
В чем отличие static resource от dynamic resource ? | WPF C#
Дополнительные темы, вопросы
Открываем окно свойств (properties) для графического элемента в WPF приложении C#
Ошибки
Ошибка "To run this application, you must install .NET. Would you like to download it now?" | Запускаю WPF приложение на C#
Книги
Книги для изучения WPF

  Ваши вопросы присылайте по почте: info@dir.by  
Яндекс.Метрика