Estrutura de teste de automação da interface do usuário da Web

pyse renomeado para raramente

Estrutura de teste de automação WebUI baseada em Selenium e unittest.

Estrutura de teste de automação de IU da Web baseada em Selenium e Unittest.

características

  • Forneça uma API mais simples para escrever testes automatizados.
  • Forneça andaimes para gerar rapidamente projetos de teste automatizados.
  • Gere automaticamente geração de relatório de teste HTML.
  • Método de afirmação independente, título de afirmação, URL e texto.
  • Suporte para parametrização de casos de uso.
  • Suporte a reexecução de falha de caso de uso.
  • Captura de tela de falha/erro do caso de uso.

Instalar

> pip install seldom

Se você deseja acompanhar a versão mais recente, pode instalar com o URL do repositório github:

> pip install -U git+https://github.com/defnngj/seldom.git@master

Começo rápido

1. Veja a ajuda:

> seldom -h
usage: seldom [-h] [-V] [--startproject STARTPROJECT] [-r R]

WebUI automation testing framework based on Selenium.

optional arguments:
  -h, --help            show this help message and exit
  -V, --version         show version
  --startproject STARTPROJECT
                        Specify new project name.
  -r R                  run test case

2. Crie um projeto:

>seldom --startproject mypro

3. Estrutura do diretório:

mypro/
├── test_dir/
│   ├── test_sample.py
├── report/
└── run.py
  • test_dir/O catálogo implementa a escrita de casos de uso.
  • report/ O diretório armazena os relatórios de teste gerados.
  • run.py arquivo para executar os casos de teste.

3. Execute o projeto:

> seldom -r run.py
Python 3.7.1                                                                    

            _      _
           | |    | |
 ___   ___ | |  __| |  ___   _ __ ___
/ __| / _ \| | / _` | / _ \ | '_ ` _ \
\__ \|  __/| || (_| || (_) || | | | | |
|___/ \___||_| \__,_| \___/ |_| |_| |_|
-----------------------------------------
                             @itest.info

generated html file: file:///D:\mypro\reports\2019_11_12_22_28_53_result.html   
.1                                                                              

4. Veja o relatório

Você pode ir para  mypro\reports\ o diretório para visualizar o relatório de teste.

Documentos da API

demonstração simples

Por favor, veja  demo/test_sample.py o arquivo

import seldom


class YouTest(seldom.TestCase):

    def test_case(self):
        """a simple test case """
        self.open("https://www.baidu.com")
        self.type(id_="kw", text="seldom")
        self.click(css="#su")
        self.assertTitle("seldom")


if __name__ == '__main__':
    seldom.main("test_sample.py")

ilustrar:

  • Para criar uma classe de teste deve-se herdar  seldom.TestCase.
  • Os nomes dos arquivos de caso de teste devem  test começar com .
  • Raramente encapsula métodos de asserção como assertTitle, assertUrl e  .assertText

método main()

import seldom

# ...

if __name__ == '__main__':
    
    seldom.main(path="./",
              browser="chrome",
              title="百度测试用例", 
              description="测试环境:chrome", 
              debug=False,
              rerun=0,
              save_last_run=False
    )

ilustrar:

  • path : Especifica o diretório ou arquivo de teste.
  • navegador: Especifique o navegador de teste, o padrão Chrome.
  • title : Especifica o título do relatório de teste.
  • descrição : Especifica a descrição do relatório de teste.
  • debug : modo de depuração, definido como True para não gerar testes HTML de teste, padrão para False.
  • reexecução : Defina o número de reexecuções em caso de falha, o padrão é  0.
  • save_last_run : Defina para salvar apenas o último resultado, o padrão é False.

Execute o teste

import seldom

seldom.main(path="./")  # 当前目录下的所有测试文件
seldom.main(path="./test_dir/")  # 指定目录下的所有测试文件
seldom.main(path="./test_dir/test_sample.py")  # 指定目录下的测试文件
seldom.main(path="test_sample.py")  # 指定当前目录下的测试文件

ilustrar:

  • Se um diretório for especificado, o arquivo de teste deve test começar com .
  • Se você deseja executar os arquivos no subdiretório, deve adicionar os arquivos no subdiretório  __init__.py .

Navegadores e drivers compatíveis

Se você quiser especificar que os casos de teste rodam em navegadores diferentes, é muito simples, você só precisa passar  configurações de parâmetros seldom.main()no método .browser

import seldom

if __name__ == '__main__':
    seldom.main(browser="chrome") # chrome浏览器,默认值
    seldom.main(browser="firefox") # firefox浏览器
    seldom.main(browser="ie")  # IE浏览器
    seldom.main(browser="opera") # opera浏览器
    seldom.main(browser="edge") # edge浏览器
    seldom.main(browser="chrome_headless") # chrome浏览器headless模式
    seldom.main(browser="firefox_headless") # Firefox浏览器headless模式

Diferentes endereços de download do driver do navegador:

geckodriver(Firefox): Lançamentos · mozilla/geckodriver · GitHub

Chromedriver (Chrome): https://sites.google.com/a/chromium.org/chromedriver/home

IEDriverServer(IE): http://selenium-release.storage.googleapis.com/index.html

operadriver(Opera):Releases · operasoftware/operachromiumdriver · GitHub

MicrosoftWebDriver(Edge): Microsoft Edge WebDriver - Microsoft Edge Developer

==================================================== === ==========

posicionamento do elemento

<form id="form" class="fm" action="/s" name="f">
    <span class="bg s_ipt_wr quickdelete-wrap">
        <input id="kw" class="s_ipt" name="wd">

Alvejando:

self.type(id_="kw", text="seldom")
self.type(name="wd", text="seldom")
self.type(class_name="s_ipt", text="seldom")
self.type(tag="input", text="seldom")
self.type(link_text="hao123", text="seldom")
self.type(partial_link_text="hao", text="seldom")
self.type(xpath="//input[@id='kw']", text="seldom")
self.type(css="#kw", text="seldom")

casos de teste parametrizados

raramente suporta casos de teste parametrizados e integra arquivos parametrizados .


import seldom
from seldom import ddt

# ...

class BaiduTest(seldom.TestCase):

    @ddt.data([
        (1, 'seldom'),
        (2, 'selenium'),
        (3, 'unittest'),
    ])
    def test_baidu(self, name, keyword):
        """
         used parameterized test
        :param name: case name
        :param keyword: search keyword
        """
        self.open("https://www.baidu.com")
        self.type(id_="kw", text=keyword)
        self.click(css="#su")
        self.assertTitle(search_key+"_百度搜索")

padrão de design de objetos de página

raramente suporta o padrão de design de objetos Page e pode ser usado com poium  .

import seldom
from poium import Page, PageElement


class BaiduPage(Page):
    """baidu page"""
    search_input = PageElement(id_="kw")
    search_button = PageElement(id_="su")


class BaiduTest(seldom.TestCase):
    """Baidu serach test case"""

    def test_case(self):
        """
        A simple test
        """
        page = BaiduPage(self.driver)
        page.get("https://www.baidu.com")
        page.search_input = "seldom"
        page.search_button.click()
        self.assertTitle("seldom_百度搜索")


if __name__ == '__main__':
    seldom.main("test_po_demo.py")

poium fornece funções mais úteis para facilitar a criação da camada de página.

Acho que você gosta

Origin blog.csdn.net/nhb687095/article/details/129749712
Recomendado
Clasificación