Framework de tests unitaires Python (héritage, paramétrage des tests unitaires, assertions, rapports de test)

1. Héritage

Quels problèmes l'héritage peut-il résoudre ?

Chaque module d'unittest doit utiliser des conditions préalables et un nettoyage. S'il y a des centaines de modules, nous devons changer le nom de domaine et le navigateur, et la charge de travail sera très gênante. À ce stade, nous pouvons utiliser l'idée d'héritage pour ne le change qu'une seule fois

Nous pouvons mettre la prémisse et le nettoyage dans un fichier séparé, le code spécifique est le suivant

from selenium import webdriver
import unittest

class Init(unittest.TestCase):
    @classmethod
    def setUpClass(cls) -> None:
        cls.driver=webdriver.Chrome()
        cls.driver.maximize_window()
        cls.driver.get('http://www.baidu.com')
        cls.driver.implicitly_wait(30)

    @classmethod
    def tearDownClass(cls) -> None:
        cls.driver.quit()

Ensuite, nous pouvons en hériter lorsque nous écrivons des cas de test, le code spécifique est le suivant

from selenium import webdriver
import unittest

from 单元测试框架.test.init import Init
class BaiduTest(Init):
    def test_baidu_title(self):
        '''百度测试:验证百度首页的title'''
        # assert self.driver.title=='百度一下,你就知道'
        self.assertEqual(self.driver.title,'百度一下,你就知道')

    def test_baidu_url(self):
        '''百度测试:验证百度首页的url'''
        assert self.driver.current_url=='https://www.baidu.com/'

    def test_baidu_video(self):
        '''百度测试:验证点击视频后跳转到视频的页面'''
        nowhandler=self.driver.current_window_handle
        self.driver.find_element_by_link_text('视频').click()
        allhandlers=self.driver.window_handles
        for handler in allhandlers:
            if handler!=nowhandler:
                self.driver.switch_to.window(handler)
                self.assertTrue(self.driver.current_url,'https://haokan.baidu.com/?sfrom=baidu-top')
                self.driver.close()
        self.driver.switch_to.window(nowhandler)

    def test_baidu_map(self):
        '''百度测试:验证点击地图后跳转到地图的页面'''
        nowhandler=self.driver.current_window_handle
        self.driver.find_element_by_link_text('地图').click()
        allhandlers=self.driver.window_handles
        for handler in allhandlers:
            if handler!=nowhandler:
                self.driver.switch_to.window(handler)
                self.assertTrue(self.driver.current_url.startswith('https://map.baidu'))
                self.driver.close()
        self.driver.switch_to.window(nowhandler)

if __name__ == '__main__':
    unittest.main()
现在我也找了很多测试的朋友,做了一个分享技术的交流群,共享了很多我们收集的技术文档和视频教程。
如果你不想再体验自学时找不到资源,没人解答问题,坚持几天便放弃的感受
可以加入我们一起交流。而且还有很多在自动化,性能,安全,测试开发等等方面有一定建树的技术大牛
分享他们的经验,还会分享很多直播讲座和技术沙龙
可以免费学习!划重点!开源的!!!
qq群号:110685036

2. Paramétrage

Dans le framework de test unittest, la bibliothèque utilisée pour le paramétrage est : paramétrée La méthode d'installation est : pip3 install paramétrée

à paramétrer :

Nous appliquons les mêmes étapes de test à différents scénarios de test, puis nous pouvons utiliser le paramétrage

Le problème qui peut être résolu est qu'une petite quantité de code de test peut être utilisée pour couvrir plus de scénarios de test

Par exemple : testons le module de connexion de sina mailbox, le code est le suivant :

from selenium import webdriver
import unittest
import time as t
class BaiduTest(unittest.TestCase):
    def setUp(self) -> None: #前提
        self.driver=webdriver.Chrome()
        self.driver.get('https://mail.sina.com.cn/')
        self.driver.maximize_window()
        self.driver.implicitly_wait(30)

    def tearDown(self) -> None: #清理
        self.driver.quit()
    def test_sina_null(self):
        '''sina邮箱验证:登录账户为空'''
        self.driver.find_element_by_class_name('loginBtn').click()
        divText=self.driver.find_element_by_xpath('/html/body/div[3]/div/div[2]/div/div/div[4]/div[1]/div[1]/div[1]/span[1]')
        self.assertEqual(divText.text,'请输入邮箱名')

    def test_sina_email_format(self):
        '''sina邮箱验证:登录邮箱格式不正确'''
        self.driver.find_element_by_id('freename').send_keys('qwert')
        self.driver.find_element_by_class_name('loginBtn').click()
        divText=self.driver.find_element_by_xpath('/html/body/div[3]/div/div[2]/div/div/div[4]/div[1]/div[1]/div[1]/span[1]')
        self.assertEqual(divText.text,'您输入的邮箱名格式不正确')

    def test_sina_username_error(self):
        '''sina邮箱验证:登录账户不匹配'''
        self.driver.find_element_by_id('freename').send_keys('[email protected]')
        self.driver.find_element_by_id('freepassword').send_keys('asdfg')
        self.driver.find_element_by_class_name('loginBtn').click()
        t.sleep(3)
        divText=self.driver.find_element_by_xpath('/html/body/div[3]/div/div[2]/div/div/div[4]/div[1]/div[1]/div[1]/span[1]')
        self.assertEqual(divText.text,'登录名或密码错误')

if __name__ == '__main__':
    unittest.main()

Étant donné que le module de connexion est principalement destiné à la vérification du formulaire de saisie du nom d'utilisateur et du mot de passe et à la vérification du message d'erreur, nous pouvons paramétrer la vérification du nom d'utilisateur, du mot de passe et du message d'erreur.Le code d'implémentation spécifique est le suivant :

 from selenium import  webdriver
import  unittest
import  time as t
from parameterized import  parameterized,param
class BaiduTest(unittest.TestCase):
    def setUp(self) -> None: #前提
        self.driver=webdriver.Chrome()
        self.driver.get('https://mail.sina.com.cn/')
        self.driver.maximize_window()
        self.driver.implicitly_wait(30)

    def tearDown(self) -> None: #清理
        self.driver.quit()

    @parameterized.expand([
        param('','','请输入邮箱名'),
        param('wertasd', 'asdf', '您输入的邮箱名格式不正确'),
        param('[email protected]', 'asdf', '登录名或密码错误')
    ])
    def test_sina_login(self,username,password,result):
        self.driver.find_element_by_id('freename').send_keys(username)
        t.sleep(3)
        self.driver.find_element_by_id('freepassword').send_keys(password)
        t.sleep(3)
        self.driver.find_element_by_class_name('loginBtn').click()
        t.sleep(3)
        divText=self.driver.find_element_by_xpath('/html/body/div[3]/div/div[2]/div/div/div[4]/div[1]/div[1]/div[1]/span[1]')
        self.assertEqual(divText.text,result)

3. Affirmation

assertEqual

assertEqual() consiste à vérifier que deux valeurs sont égales, et que le type de données et le contenu de la valeur sont également égaux, voir l'exemple de code :

from selenium import webdriver
import unittest
class BaiduTest(unittest.TestCase):
    def setUp(self) -> None:
        self.driver=webdriver.Chrome()
        self.driver.get('http://www.baidu.com')
        self.driver.maximize_window()
        self.driver.implicitly_wait(30)

    def tearDown(self) -> None:
        self.driver.quit()

    def test_baidu_title(self):
        '''百度测试:验证百度首页的title'''
        # assert self.driver.title=='百度一下,你就知道'
        self.assertEqual(self.driver.title,'百度一下,你就知道')

assertTrue

Le type de retour est bool, c'est-à-dire pour vérifier l'objet testé. Si le type de retour est booléen et vrai, alors la vérification du résultat est réussie. Ensuite, la méthode assertFlase() vérifie que le contenu renvoyé par l'objet testé est faux. . Voir l'exemple de code :

from selenium import webdriver
import unittest
import time as t
class BaiduTest(unittest.TestCase):
    def setUp(self) -> None: #前提
        self.driver=webdriver.Chrome()
        self.driver.get('https://mail.sina.com.cn/')
        self.driver.maximize_window()
        self.driver.implicitly_wait(30)

    def tearDown(self) -> None: #清理
        self.driver.quit()

    def test_sina_isLogin(self):
        '''sina邮箱验证,判断自动登录是否勾选'''
        isLogin=self.driver.find_element_by_id('store1')
        self.assertTrue(isLogin.is_selected())

assertIn

La valeur de assertIn () est de savoir si une valeur est incluse dans une autre valeur. Ici, je voudrais souligner que dans la méthode assertIn (), il y a deux paramètres, donc l'inclusion d'une valeur est en fait la première Le deuxième paramètre réel contient le premier paramètre réel. La méthode opposée est assertNotIn(), voir l'exemple de code :

import unittest
from selenium import webdriver
class UiTest(unittest.TestCase):
def setUp(self) -> None:
self.driver=webdriver.Chrome()
self.driver.maximize_window()
self.driver.get('http://www.baidu.com')
self.driver.implicitly_wait(30)
def tearDown(self) -> None:
self.driver.quit()
def test_baidu_title_001(self):
self.assertIn('百度',self.driver.title)
def test_baidu_title_002(self):
self.assertIn('百度⼀下,你就知道',self.driver.title)
if __name__ == '__main__':
unittest.main()

4. Rapport d'essai

Dans le cadre d'unittest, HTMLTestRunner est nécessaire pour générer des rapports de test

import unittest
import os
from 单元测试框架.HTMLTestRunner import HTMLTestRunner #从HTMLTestRunner模块调用HTMLTestRunner类

def getTests():
    '''加载所有的测试模块'''
    suite=unittest.TestLoader().discover(
        #找到被执行模块的路径
        start_dir=os.path.dirname(__file__),
        #加载路径下所有以test_开头的测试模块的文件
        pattern='test_*.py' #正则表达式
    )
    return suite

def runSuite():
    unittest.TextTestRunner().run(getTests())

def base_dir():
    return os.path.dirname(os.path.dirname(__file__))#获取当前目录的上级目录

def run():
    fp=open(os.path.join(base_dir(),'report','report.html'),'wb')#拼接report.html的路径 wb 二进制的方式写入
    runner=HTMLTestRunner(
        stream=fp,  #流 执行一个写入一个
        title='UI自动化测试报告',
        description='' 
    )
    runner.run(getTests())

if __name__ == '__main__':
    run()

Comment résoudre le problème que le rapport de test généré à chaque fois ne couvre pas le rapport de test précédent et est conservé en même temps :

Solution : introduire la bibliothèque de temps pour obtenir l'horodatage

code afficher comme ci-dessous:

import time
import unittest
import os
from HTMLTestRunner import HTMLTestRunner

def getTests():
    '''加载所有的测试模块'''
    suite=unittest.TestLoader().discover(
        #找到被执行模块的路径
        start_dir=os.path.dirname(__file__),
        #加载路径下所有以test_开头的测试模块的文件
        pattern='test_*.py' #正则表达式
    )
    return suite

def getNowTime():
    return time.strftime('%y-%m-%d %H-%M-%S',time.localtime(time.time()))

def base_dir():
    return os.path.dirname(os.path.dirname(__file__))

def run():
    fp=open(os.path.join(base_dir(),'report',getNowTime()+'report.html'),'wb')
    runner=HTMLTestRunner(
        stream=fp,
        title='UI自动化测试报告',
        description=''
    )
    runner.run(getTests())

if __name__ == '__main__':
    run()

Ainsi, un rapport de test sera généré à chaque exécution :

Les éléments suivants sont des supports d'apprentissage. Pour les amis qui font des [tests de logiciels], il devrait s'agir de l'entrepôt de préparation le plus complet et le plus complet. Cet entrepôt m'a également accompagné tout au long du voyage le plus difficile. J'espère qu'il pourra vous aider aussi !

Applet d'entretien de test de logiciel

La banque de questions de test de logiciel maximisée par des millions de personnes ! ! ! Qui est qui sait ! ! ! Le mini programme de quiz le plus complet sur tout le réseau, vous pouvez utiliser votre téléphone portable pour faire les quiz, dans le métro ou dans le bus, roulez-le !

Les sections de questions d'entrevue suivantes sont couvertes :

1. Théorie de base des tests de logiciels, 2. Web, application, test de fonction d'interface, 3. réseau, 4. base de données, 5. linux

6. Web, application, automatisation de l'interface, 7. tests de performance, 8. bases de la programmation, 9. questions d'entretien sur les heures, 10. questions de test ouvertes, 11. tests de sécurité, 12. bases de l'informatique

Méthode d'acquisition d'informations :

Je suppose que tu aimes

Origine blog.csdn.net/IT_LanTian/article/details/132286849
conseillé
Classement