史上最全excel导入功能测试用例设计(以项目为例)

web系统关于excel的导入导出功能是很常见的,通常为了提高用户的工作效率,在维护系统中的一些数据的时候,批量导入往往比一个一个添加或者修改快很多。针对导入功能的测试,往往会有很多种情况,现在针对平时项目中遇到的一个导入功能进行测试用例的设计。

需求

下图是产品列表,产品编码具有唯一性,每个产品都有成本价、省级价、市级价、特约价、终端价和车主价,这个列表主要是维护当前产品的价格(成本价在此不能修改),修改价钱的时候,变更原因分为两种:首次定价和价格修改。修改价格之后产品的定价状态会变为:待定价审核。

说明:

(1)产品的状态:待审核、已审核、待上线、待上线审核、已上线、待下线审核、已下线;

(2)产品的定价状态:待定价、待定价审核、定过价

定价导入功能的要求:

    1. 导入的Excel文件中必须包含名为“产品编码”的列,且名称必须相同
    1. “产品编码”必须是列表中已存在的产品
    1. 省级价、市级价、特约价、终端价、车主价均可为空,为空表示不对原有价格做改变

image.png

image.png

导入的模板如下:

image.png

测试

(1)用例1

测试情况:产品存在,产品状态为待定价,变更原因为首次定价

预期结果:正确导入,各价钱显示正确,状态变为待定价审核,变更原因为首次定价

(2)用例2

测试情况:产品存在,产品状态为待定价审核,变更原因为价格修改

预期结果:正确导入,价格修改为当前导入的价格,状态为待定价审核

(3)用例3

测试情况:产品存在,产品状态为定过价,变更原因为价格修改

预期结果:正确导入,价格修改为当前导入的价格,状态为待定价审核

(4)用例4

测试情况:产品存在,其他正确填写,变更原因不填

预期结果:错误数据,提示:变更原因必须为首次定价或者价格修改

(5)用例5

测试情况:产品存在,其他正确填写,变更原因填写但不符合要求

预期结果:错误数据,提示:变更原因必须为首次定价或者价格修改

(6)用例6

测试情况:产品存在,其他正确填写,变更原因填写中间有空格

预期结果:错误数据,提示:变更原因必须为首次定价或者价格修改

(7)用例7

测试情况:产品编码在列表中不存在,其他正确填写

预期结果:错误数据,提示:产品编码不存在

(8)用例8

测试情况:产品编码为空,其他正确填写

预期结果:错误数据,提示:产品编码不存在

(9)用例9

测试情况:产品编码存在,正常定价,价钱包含小数

预期结果:正确导入,各个价钱对应显示正确,状态变为待定价审核,变更原因为价格修改

(10)用例10

测试情况:产品编码存在,正常定价,价格小数位比较多

预期结果:正确导入,价钱四舍五入(具体是截取还是四舍五入看需求),各个价钱对应显示正确,状态变为待定价审核

(11)用例11---五条

测试情况:五个价钱分别填写“汉字”,分别测试

预期结果:错误数据,提示:xx价不符合要求

(12)用例12---五条

测试情况:五个价钱分别为空,其他内容填写正确,分别测试

预期结果:正确导入,当前为空的价钱不修改,还是原来的,其他价钱正常修改,状态为待定价审核

(13)用例13

测试情况:价格全部为空,其他正常填写(三个定价状态的产品都需要测试)

预期结果:正确导入,该条产品不做任何修改,状态也不变

(14)用例14

测试情况:产品为定过价,原产品价钱和当前导入的价钱一致

预期结果:正确导入,该条产品不做任何修改,状态也不变

(15)用例15---五条

测试情况:产品为定过价,控制某一个价钱与系统的不一致,其他四个价钱都和系统中一致,分别测试

预期结果:正确导入,不一致的价格修改,其他价钱不修改还是原来的,状态为待定价审核

(16)用例16---六条

测试情况:不同的产品状态,测试一条数据,分别测试

预期结果:待审核状态的提示:错误数据,提示产品为待审核;已下线状态的提示:错误数据,产品已下线;其他状态的正常导入和校验

(17)用例17

测试情况:Excel中间加上空行

预期结果:忽略空行正常导入

(18)用例18---两条

测试情况:删除模板列/增加模板列

预期结果:按照需求校验

(19)用例19

测试情况:excel中重复产品编码(编码系统中已存在)

预期结果:一条成功解析并校验,另外一条报错重复项

(20)用例20

测试情况:excel中重复产品编码(编码系统中不存在)

预期结果:一条成功解析并校验,另外一条报错重复项

(21)用例21

测试情况:价格或者变更原因填写null,分别测试

期望结果:错误数据:提示:xxx不符合要求

(22)用例22

测试情况:模板不匹配,不是从系统中下载的

期望结果:提示:导入模板不匹配,请从系统中下载导入模板!

附录

image.png

image.png

尾声

欢迎各位优秀的小伙伴们补充,但愿这篇文章对你有用!!!加油!!!

行动吧,在路上总比一直观望的要好,未来的你肯定会感 谢现在拼搏的自己!如果想学习提升找不到资料,没人答疑解惑时,请及时加入扣群: 320231853,里面有各种软件测试+开发资料和技术可以一起交流学习哦。

最后感谢每一个认真阅读我文章的人,礼尚往来总是要有的,虽然不是什么很值钱的东西,如果你用得到的话可以直接拿走:

这些资料,对于【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴上万个测试工程师们走过最艰难的路程,希望也能帮助到你!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/310122.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Excel·VBA二维数组S形排列

与之前的文章《ExcelVBA螺旋数组函数》将一维数组转为二维螺旋数组 本文将数组转为S形排列的二维数组,类似考场座位S形顺序 Function S形排列(ByVal arr, ByVal num_rows&, ByVal num_cols&, Optional ByVal mode$ "row")将数组arr转为num_rows…

Home Assistant OS转 Hassio Supervisor(docker 版本)

这是一个失败案例,请忽略。 原因 HAOS缺点:系统不是很好用,无法满足我在上面使用python开发插件的小需求(或许有方法满足,但是我没找到)。 HAOS优点:方便安装,配置非常方便。 数据…

UE5学习日记——实现自定义输入及监听输入,组合出不同的按键输入~

UE5的自定义按键和UE4有所不同,在这里记录一下。 本文主要是记录如何设置UE5的自定义按键,重点是学会原理,实际开发时结合实际情况操作。 输入映射 1. 创建输入操作 输入操作并不是具体的按键映射,而是按键的激活方式&#xff0…

面试官:说一说CyclicBarrier的妙用!我:这个没用过...

写在开头 面试官:同学,AQS的原理知道吗? 我:学过一点,抽象队列同步器,Java中很多同步工具都是基于它的… 面试官:好的,那其中CyclicBarrier学过吗?讲一讲它的妙用吧 我&…

音乐文件逆向破解

背景 网易云等在线音乐文件的加密源码都按照一定的规则加密,通过对音乐文件的源码分析转化,有望实现对加密文件的解密 实现内容 实现对加密音乐文件的解密 实现对无版权的音乐文件的转化 实现环境 010editor 010 Editor是一个专业的文本编辑器和十六…

FFmpeg: 自实现ijkplayer播放器--04消息队列设计

文章目录 播放器状态转换图播放器状态对应的消息: 消息对象消息队列消息队列api插入消息获取消息初始化消息插入消息加锁初始化消息设置消息参数消息队列初始化清空消息销毁消息启动消息队列终止消息队列删除消息 消息队列,用于发送,设置播放…

破译验证码reCAPTCHA 之 打码平台

由于登录需要验证码,除了日常的字符串+数字,此时就需要用第三方插件进行破译。 reCaptcha是Google公司的验证码服务,方便快捷,改变了传统验证码需要输入n位失真字符的特点。 1. reCAPTCHA 初识 reCaptcha是Google公司…

1、IPEX-LLM(原名BigDL-LLM)环境配置

IPEX-LLM 是一个为Intel XPU (包括CPU和GPU) 打造的轻量级大语言模型加速库,在Intel平台上具有广泛的模型支持、最低的延迟和最小的内存占用。 您可以使用 IPEX-LLM 运行任何 PyTorch 模型(例如 HuggingFace transformers 模型)。在运行过程中…

结合创新!ResNet+Transformer,高性能低参数,准确率达99.12%

今天给各位介绍一个发表高质量论文的好方向:ResNet结合Transformer。 ResNet因其深层结构和残差连接,能够有效地从图像中提取出丰富的局部特征。同时,Transformer的自注意力机制能够捕捉图像中的长距离依赖关系,为模型提供全局上…

世界需要和平--中介者模式

1.1 世界需要和平 "你想呀,国与国之间的关系,就类似于不同的对象与对象之间的关系,这就要求对象之间需要知道其他所有对象,尽管将一个系统分割成许多对象通常可以增加其可复用性,但是对象间相互连接的激增又会降低…

MySQL中的存储过程详解(上篇)

使用语言 MySQL 使用工具 Navicat Premium 16 代码能力快速提升小方法,看完代码自己敲一遍,十分有用 拖动表名到查询文件中就可以直接把名字拉进来中括号,就代表可写可不写 目录 1.认识存储过程 1.1 存储过程的作用 1.2 存储过程简介…

【word】文档标题如何自动编号

我在写一个word文档的时候,每一级标题的格式都设置好了,包括字体,大小等等,但是如何自动编号呢? 在写中期报告的时候,我对每一级标题的格式都创建了一个单独的样式,像这样: 对于每一…

数据类型知识

1,介绍 根据数据所占的空间不同,把数据分为不同的数据类型 js的变量数据类型是在程序运行中,靠等号右边数值的值来判断的 js动态变量,里面的数据类型是可以变化的 2.数据类型 1.简单数据类型 程序里面,数字前面有…

plotly绘图——热力图

文章目录 介绍热力图基础热力图代码解释 多热力图代码解释 显示数字的热力图代码解释 介绍 plotly是一个易于使用,功能强大的python绘图库,用于构建可交互式的图表(可以自行运行后使用鼠标拖拽图片试试),本系列文章将介…

基于springboot+vue的企业人事管理设计与实现

前言 基于Java的企业人事管理设计与实现,可以让用户在最短的时间里享受到最好的服务;而开发本系统,又能够提高系统整体工作水平,简化工作程序,这对管理员和员工来说都是一件非常乐意的事情。 本系统针对基于Java的企…

(一)Jetpack Compose 从入门到会写

基本概念 Compose 名称由来 众所周知,继承在功能拓展上表现的很脆弱,容易类、函数爆炸,通过代理和包装进行组合会更健壮。 Compose 意为组合,使用上也是把 Compose 函数以 模拟函数调用层级关系的方式 组合到一起,最终…

Vue.js------vue基础

1. 能够了解更新监测, key作用, 虚拟DOM, diff算法2. 能够掌握设置动态样式3. 能够掌握过滤器, 计算属性, 侦听器4. 能够完成品牌管理案例 一.Vue基础_更新监测和key 1.v-for更新监测 目标:目标结构变化, 触发v-for的更新 情况1: 数组翻转情况2: 数组截取情况3…

记录--病理切片图像处理

简介 数字病理切片,也称为全幻灯片成像(Whole Slide Imaging,WSI)或数字切片扫描,是将传统的玻片病理切片通过高分辨率扫描仪转换为数字图像的技术。这种技术对病理学领域具有革命性的意义,因为它允许病理…

C语言文件操作详解

1. 什么是文件: 文件是计算机中存储数据的一种方式,它可以包含文本、图像、音频、视频等各种形式的信息。在计算机系统中,文件被组织成一个个独立的单元,可以通过文件名来标识和访问。文件可以存储在计算机的硬盘、固态硬盘、光盘…

SWM341系列应用(RTC、FreeRTOS\RTTHREAD应用和Chip ID)

SWM341系列RTC应用 22.1、RTC的时钟基准 --liuzc 2023-8-17 现象:客户休眠发现RTC走的不准,睡眠2小时才走了5分钟。 分析与解决:经过排查RTC的时钟源是XTAL_32K,由于睡眠时时设置XTAL->CR0;,会把XTAL_32K给关…