ToB企服应用市场:ToB评测及商务社交产业平台
标题:
主动化测试平台计划与实现(二、主动化测试用例对象计划实现、关键字对象设
[打印本页]
作者:
九天猎人
时间:
2024-8-5 23:58
标题:
主动化测试平台计划与实现(二、主动化测试用例对象计划实现、关键字对象设
1、模型计划
建立主动化用例,关键字模型。此中主动化用例基本内容包含title(目录展示)、name等常见文本信息,关键字则是实现主动化测试提速的关键地点,考虑到业务场景的主动化,就能发现有许多业务步骤是重复的:好比一个管理系统里面的创建对象,我们将该步骤抽象出来,形成一个关键字(keyword),关键字保存url、header等信息,要录入到主动化用例testcase模型中,则使用中间表TestCaseKeyword,它会详细记载某个主动化用例的(关键字-序次),并且关键字会带有详细的params、body等信息,也就是可以被全局变量,或者常量所覆盖。
import functools
import uuid
import random
import string
from django.db import models
from django.core.exceptions import ValidationError
from django.utils import timezone
# Create your models here.
def generate_random_string(except_str, length=10):
characters = string.ascii_letters + string.digits
random_chars = ''.join(random.choice(characters) for _ in range(length))
return f'{except_str}_{random_chars}' if except_str else random_chars
def validate_positive(value):
if value < 0:
raise ValidationError('%(value)s is not a positive integer or 0', params={'value': value})
class Testcase(models.Model):
# title:标题; name:编号; level:等级;前置条件,测试步骤,预期结果
title_default = functools.partial(generate_random_string, "title")
name_default = functools.partial(generate_random_string, "test")
title = models.CharField(max_length=50, unique=True, null=False, blank=False, default=title_default)
name = models.CharField(max_length=50, unique=True, null=False, blank=False, default=name_default)
level = models.IntegerField(default=0, validators=[validate_positive])
precondition = models.CharField(max_length=300, null=True, blank=True, default=None)
test_precondition = models.CharField(max_length=300, null=True, blank=True, default=None)
expected_result = models.CharField(max_length=300, null=True, blank=True, default=None)
TYPE = [
("function_case", "功能用例"),
("performance_case", "性能用例"),
("reliability_case", "可靠性用例"),
]
type = models.CharField(max_length=20, choices=TYPE, default="function_case")
auto_flag = models.BooleanField(default=False, null=True, blank=True)
description = models.TextField(blank=True, null=True)
keywords = models.ManyToManyField("KeyWord", through='TestCaseKeyword')
def __str__(self):
return f"{self.title}_{self.name}"
class KeyWord(models.Model):
BODY_TYPES = [
('application/x-www-form-urlencoded', 'Application/X-WWW-Form-Urlencoded'),
('raw', 'Raw'),
('multipart/form-data', 'Multipart/Form-Data'),
]
name_default = functools.partial(generate_random_string, "kw")
name = models.CharField(max_length=100, unique=True, null=False, blank=False, default=name_default)
url = models.URLField()
params = models.JSONField(blank=True, null=True)
headers = models.JSONField(blank=True, null=True)
body_type = models.CharField(max_length=50, choices=BODY_TYPES)
body = models.TextField(blank=True, null=True)
description = models.TextField(blank=True, null=True)
def __str__(self):
return self.name
class TestCaseKeyword(models.Model):
test_case = models.ForeignKey(Testcase, on_delete=models.CASCADE)
keyword = models.ForeignKey(KeyWord, on_delete=models.CASCADE)
order = models.PositiveIntegerField()
params = models.JSONField(blank=True, null=True)
headers = models.JSONField(blank=True, null=True)
body = models.TextField(blank=True, null=True)
class Meta:
ordering = ['order']
def __str__(self):
return f"{self.test_case.name} - {self.keyword.name} ({self.order})"
复制代码
tips:
1. python有前向引用:假如在一个模型类中引用了另一个尚未界说的模型类,大概会出现 Unresolved reference 错误。
可以在 Testcase 模型中使用前向引用,即在字符串中引用 KeyWord 模型。这样可以解决。但函数可以在代码的任何位置界说和调用。
前向引用:在字段界说中使用字符串形式的类名引用未界说的模型类。
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
欢迎光临 ToB企服应用市场:ToB评测及商务社交产业平台 (https://dis.qidao123.com/)
Powered by Discuz! X3.4