找零钱最佳组合,实验报告(请结合等价类划分法和边界值分析法为上述程序设计出相应的测试用例)

实验:找零钱最佳组合,实验报告

一、实验目的:
(1)掌握黑盒测试的等价类划分和边界值划分的基本方法
(2)利用等价类划分和边界值分析的方法,正确的设计测试用例
实验重点及难点:
重点:正确地划分等价类以及利用健壮性分析法找出边界值,并且按照两者正确地设计测试用例
难点:利用等价类划分技术时,容易出现划分的等价类不准确,或者遗留等价类的情况。而在找出边界值时容易划分不当或者遗漏边界值。

二、实验内容:
结合等价类划分法和边界值分析法为《找零钱最佳组合》程序设计出相应的测试用例。
1、程序内容:
假设商店货品价格® 都不大于100元(且为整数),若顾客付款§在100元内,现有一个程序能在每位顾客付款后给出找零钱的最佳组合(找给顾客货币张数最少)。 假定此商店的货币面值只包括:50元(N50)、10元(N10)、 5元(N5)、1元(N1) 四种。
2、为程序准备测试用例
首先,在充分理解《找零钱》程序的基础上,对程序的每一个参数划分出等价类,注意有效等价类和无效等价类都要设计;再根据题意划分出所有存在的边界值,然后根据边界值和等价类准备测试用例,要求写清楚编号,设计出输入数据以及对应的输出数据,最后撰写测试用例报告。

三、实验原理:
等价类划分法是一种典型的,重要的黑盒测试方法,它将程序所有可能的输入数据*(有效的和无效的)划分成若干个等价类。然后从每个部分选取具有代表性的数据作为测试用例。
利用这一方法设计测试用例可以不考虑程序的内部结构,以需求规格说明说为依据,选择适当的典型子集,认真分析和推敲说明书的各项需求,特别是功能需求,以尽可能多地发现程序的错误。
由于等价类是在需求规格说明书的基础上进行划分的,并且等价类划分不仅可以用来确定测试用例中的数据的输入输出的精确取值范围,也可以用来准备中间值、状态和与时间相关的数据以及接口参数等,所以等价类划分方法可以用在系统测试、集成测试和组件测试中,在明确的条件和限制的情况下,利用等价类划分技术可以设计出完备的测试用例。
边界值分析法是 对输入或输出的边界值进行测试的一种黑盒测试方法。通常边界值分析法是作为对等价类划分法的补充,这种情况下,其测试用例来自等价类的边界。
无数的测试实践表明,大量的故障往往发生在输入定义域或输出值域的边界上,而不是在其内部。因此,针对各种边界情况设计测试用例,通常会取得很好的测试效果。
健壮性分析法:对于一个含有n个变量的程序,保留其中一个变量,让其余的变量取正常值,被保留的变量依次取min、min+、min-,nom、max-、max, max+值,对每个变量都重复进行。

四、实验步骤:
(1)确定等价类
a、有效等价类
商店货品价格R都不大于100元,因此得出0 < R <= 100;
顾客付款P在100元以内,因此得出R <= P <= 100;
b、无效等价类
R <= 0 and R > 100
0 < R <= 100, P > 100
0 < R <= 100, P < R
(2)利用健壮性分析法确定输入和输出的界限
a、输入
商品价格R位于0 < R <= 100、R刚大于100、R刚小于或等于0;
付款金额P位于R <= P <= 100、P刚大于100、P刚小于R;
b、输出
商店的货币面值包括:50元(N50)、10元(N10)、 5元(N5)、1元(N1)
可能的输出为:0 <= N50 <= 1
0 <= N10 <= 4
0 <= N5 <= 1
0 <= N1 <= 4
N50、N10、N5、N1都取整数。
(3)找零边界值
设找零的金额为T = P - R
根据健壮性分析法得出K可能的取值有:
0、1、4、5、9、10、49、50、99
具体如下:
T(找零) 面值组合 T(找零) 面值组合
0 N50=0、N10=0
N5=0、N1=0 10 N50=0、N10=1
N5=0、N1=0
1 N50=0、N10=0
N5=0、N1=1 49 N50=0、N10=4
N5=1、N1=4
4 N50=0、N10=0
N5=0、N1=4 50 N50=1、N10=0
N5=0、N1=0
5 N50=0、N10=0
N5=1、N1=0 99 N50=1、N10=4
N5=1、N1=4
9 N50=0、N10=0
N5=1、N1=4
结合输入输出,得出两者组合的情况为:
序号 价格(R)、付款(P) 找零(T) 预期结果
1 R>100 无效
2 R<=0 无效
3 0<R<=100,P>100 无效
4 0<R<=100,P<R 无效
5 0<R<=100,R<=P<=100 0 输出0张
6 0<R<=100,R<=P<=100 1 输出1张
7 0<R<=100,R<=P<=100 4 输出4张
8 0<R<=100,R<=P<=100 5 输出1张
9 0<R<=100,R<=P<=100 9 输出5张
10 0<R<=100,R<=P<=100 10 输出1张
11 0<R<=100,R<=P<=100 49 输出9张
12 0<R<=100,R<=P<=100 50 输出1张
13 0<R<=100,R<=P<=100 99 输出10张

五、编写测试用例
测试用例 商品价格 付款金额 预期输出(N50、N10、N5、N1)
1 101 — 无效
2 0 无效
3 100 101 无效
4 100 99 无效
5 100 100 T=0,N50=0,N10=0,N5= 0,N1=0
6 99 100 T=1,N50=0,N10=0,N5= 0,N1=1
7 96 100 T=4,N50=0,N10=0,N5= 0,N1=4
8 95 100 T=5,N50=0,N10=0,N5=1 ,N1=0
9 91 100 T=9,N50=0,N10=0,N5=1 ,N1=4
10 90 100 T=10,N50=0,N10=1,N5= 0,N1=0
11 51 100 T=49,N50=0,N10=4,N5=1 ,N1=4
12 50 100 T=50,N50=1,N10=0,N5= 0,N1=0
13 1 100 T=99,N50=1,N10=1,N5= 1,N1=4

  • 9
    点赞
  • 106
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
#include "stdio.h" /*输入,输头文件*/ #include "stdlib.h" /*申空间头文件*/ #include "string.h" /*对字符串加工头文件*/ #include "conio.h" /*清屏头文件*/ FILE *fp; int n=0; /*定义文件指针类型*/ int i,j,a[4],m; /*定义整数类型*/ float aver[4],sum[4],g[4],h; /*定义浮点类型*/ char c[5]="elec"; /*定义字符数组类型*/ char d[5]="comm"; /*定义字符数组类型*/ char e[5]="food"; /*定义字符数组类型*/ char f[5]="offi"; /*定义字符数组类型*/ struct good /*定义结构体*/ { int num; /*商品编号*/ char name[20]; /*商品名称*/ char kind[40]; /*商品类型*/ float price; /*商品价格*/ char unit[10]; /*商品单位*/ int quantity; /*商品数量*/ struct good *next; /*定义结构体指针类型*/ }*head,*p1,*p2; struct good *createlist() /*创建链表函数*/ { struct good *head1,*p1,*p2; /*定义结构体指针类型*/ if((fp=fopen("goods message.txt","w"))==NULL) /*判断能否打开文件*/ { printf("can not open the file"); exit(0); /*结束程序*/ } head1=(struct good *)malloc(sizeof(struct good)); /*申头结点空间*/ p1=head1; p2=head1; printf("*********************************************\n"); printf("输入信息:编号,名称,类型,价格,单位,数目\n"); printf(" (以输入“-1”表示结束输入)\n"); printf("*********************************************\n"); printf("____________________\n"); scanf("%d %s %s %f %s %d",&p1;->num,p1->name,p1->kind,&p1;->price,p1->unit,&p1;->quantity); /*输入商品信息*/ printf("____________________\n"); p1->next=NULL; fprintf(fp,"%d %s %s %f %s %d ",p1->num,p1->name,p1->kind,p1->price,p1->unit,p1->quantity); /*将商品信息写入文件*/ while(1) { p1=(struct good *)malloc(sizeof(struct good)); /*申新空间*/ printf("*********************************************\n"); printf("输入信息:编号,名称,类型,价格,单位,数目\n"); printf(" (以输入“-1”表示结束输入)\n"); printf("*********************************************\n"); printf("____________________\n"); scanf("%d",&p1;->num); if(p1->num==-1) /*申空间结束条件*/ { printf("____________________\n\n"); fprintf(fp,"%d",-1); fclose(fp); return head1; /*返回头指针*/ } scanf("%s %s %f %s %d",p1->name,p1->kind,&p1;->price,p1->unit,&p1;->quantity); /*输入商品信息*/ printf("________________\n"); fprintf(fp,"%d %s %s %f %s %d ",p1->num,p1->name,p1->kind,p1->price,p1->unit,p1->quantity); /*将商品信息写入文件*/ p1->next=NULL; p2->next=p1; p2=p1; } } struct good *paixu(struct good*head2) /*链表排序函数*/ { struct good *p6,*p7,*r,*s; /*定义结构体指针类型*/ for(i=0;i<=3;i++) /*赋初值值*/ { a[i]=0; sum[i]=0; aver[i]=0; } p6=(struct good *)malloc(sizeof(struct good)); /*申新空间*/ p6->next=head2; head2=p6; while(p6->next!=NULL) /*判断循环结束条件*/ { p7=p6->next; r=p6; while(p7->next!=NULL) /*判断循环结束条件*/ { if((p7->next->price)>(r->next->price)) /*判断是否调换*/ r=p7; p7=p7->next; } if(p6!=r) /*判断循环结束条件*/ { s=r->next; /*指针调换*/ r->next=s->next; s->next=p6->next; p6->next=s; } p6=p6->next; } p6=head2; head2=head2->next; free(p6); /*释放第一个无效空间*/ return head2; } void jisuan() { p1=head; do { if(strcmp(p1->kind,c)==0) /*判断是否为电器类型*/ { sum[0]=sum[0]+(p1->price)*(p1->quantity); /*求电器总价*/ a[0]=a[0]+p1->quantity; /*求电器总件数*/ } if(strcmp(p1->kind,d)==0) /*判断是否为日用品类型*/ { sum[1]=sum[1]+(p1->price)*(p1->quantity); /*求日用品总价*/ a[1]=a[1]+p1->quantity; /*求日用品总件数*/ } if(strcmp(p1->kind,e)==0) /*判断是否为办公用品类型*/ { sum[2]=sum[2]+(p1->price)*(p1->quantity); /*求办公用品总价*/ a[2]=a[2]+p1->quantity; /*求办公用品总件数*/ } if(strcmp(p1->kind,f)==0) /*判断是否为食品类型*/ { sum[3]=sum[3]+(p1->price)*(p1->quantity); /*求食品总价*/ a[3]=a[3]+p1->quantity; /*求食品总件数*/ } p1=p1->next; }while (p1!=NULL); /*遍历链表结束条件*/ for(i=0;i<4;i++) aver[i]=sum[i]/a[i]; /*求每类商品平均价*/ printf("****************************************************\n"); printf("商品类型 \t 平均价\t 总库存量\n"); printf("****************************************************\n"); printf("____________________________________________________\n"); printf("电器总价值:%0.1f\t平均价:%0.1f\t总库存量:%d\n",sum[0],aver[0],a[0]); printf("____________________________________________________\n"); printf("日用品总价值:%0.1f\t平均价:%0.1f\t总库存量:%d\n",sum[1],aver[1],a[1]); printf("____________________________________________________\n"); printf("食品总价值:%0.1f\t平均价:%0.1f\t总库存量:%d\n",sum[2],aver[2],a[2]); printf("____________________________________________________\n"); printf("办公用品总价值:%0.1f\t平均价:%0.1f\t总库存量:%d\n",sum[3],aver[3],a[3]); printf("____________________________________________________\n"); } void shuchu() /*输商品信息函数*/ { do { struct good *p3,*p4,*p5; /*定义结构体指针类型*/ int n=0,p=0,q=0,r=0; printf("所有商品信息:\n"); printf("编号,名称,类型,价格,单位,数目\n"); printf("**********************************\n"); if((fp=fopen("goods message.txt","rb+"))==NULL) /*判断能否打开文件*/ { printf("can not open the file"); exit(0); /*结束程序*/ } head=(struct good *)malloc(sizeof(struct good)); /*申头结点空间*/ p3=head; fscanf(fp,"%d %s %s %f %s %d ",&p3;->num,p3->name,p3->kind,&p3;->price,p3->unit,&p3;->quantity); /*从文件中写到链表*/ while(1) { p4=(struct good *)malloc(sizeof(struct good)); /*申头结点空间*/ fscanf(fp,"%d ",&p4;->num); if(p4->num!=-1) /*判断循环结束条件*/ { fscanf(fp,"%s %s %f %s %d ",p4->name,p4->kind,&p4;->price,p4->unit,&p4;->quantity); /*从文件中写到链表*/ p4->next=NULL; p3->next=p4; p3=p4; } else { p3->next=NULL; break; } } fclose(fp); /*关闭文件*/ p3=head; while(p3!=NULL) { printf(" %d %s %s %0.1f %s %d\n\n",p3->num,p3->name,p3->kind,p3->price,p3->unit,p3->quantity); printf("__________________________________\n"); p3=p3->next; } printf("**********************************\n"); printf("//////////////////////////////////\n"); while(n!=4) { p3=head; printf("**********************************\n"); printf("1 添加商品信息\n"); printf("2 删除某商品信息\n"); printf("3 修改某商品信息\n"); printf("4 返回(当你完成了对某一商品的添加、删除或者修改后按4返回)\n"); printf("**********************************\n"); scanf("%d",&n); if(n==1) /*添加商品信息*/ { printf("输入商品 编号 名称 类型 价格 单位 数目\n"); printf("**********************************\n"); p4=(struct good *)malloc(sizeof(struct good)); /*申空间*/ scanf("%d %s %s %f %s %d",&p4;->num,p4->name,p4->kind,&p4;->price,p4->unit,&p4;->quantity); /*输入商品信息*/ p4->next=NULL; while(p3->next!=NULL) /*判断循环结束条件*/ { p3=p3->next; } p3->next=p4; p3=head; if((fp=fopen("goods message.txt","w"))==NULL) /*判断能否打开文件*/ { printf("can not open the file"); exit(0); /*结束程序*/ } while(p3!=NULL) { fprintf(fp,"%d %s %s %f %s %d ",p3->num,p3->name,p3->kind,p3->price,p3->unit,p3->quantity) /*将商品信息写入文件*/ p3=p3->next; } fprintf(fp,"%d",-1); fclose(fp); /*关闭文件*/ printf("**********************************\n"); printf("__________________________________\n"); printf("------------按4返回-------------\n"); printf("__________________________________\n"); printf("**********************************\n"); } if(n==2) /*删除商品*/ { printf("**********************************\n"); printf("输入需要删除的商品编号\n"); printf("**********************************\n"); scanf("%d",&p); printf("**********\n"); printf("1 确认删除\n2 取消删除\n"); printf("**********\n"); scanf("%d",&r); if(r==1) { if((head->num)==p) { head=head->next; free(p3); /*释放空间*/ } else { p4=head; p3=p4->next; while(p3!=NULL) /*判断循环结束条件*/ { if((p3->num)==p) { p5=p3->next; free(p3); /*释放空间*/ p4->next=p5; break; } p3=p3->next; p4=p4->next; } } if((fp=fopen("goods message.txt","w"))==NULL) /*判断能否打开文件*/ { printf("can not open the file"); exit(0); /*结束程序*/ } p3=head; while(p3!=NULL) /*判断循环结束条件*/ { fprintf(fp,"%d %s %s %f %s %d ",p3->num,p3->name,p3->kind,p3->price,p3->unit,p3->quantity); /*将商品信息写入文件*/ p3=p3->next; } fprintf(fp,"%d",-1); fclose(fp); /*关闭文件*/ } if(r==2) continue; /*继续循环*/ printf("**********************************\n"); printf("__________________________________\n"); printf("------------按4返回-------------\n"); printf("__________________________________\n"); printf("**********************************\n"); } if(n==3) /*修改某商品信息*/ { printf("输入需要修改的商品编号\n"); scanf("%d",&q); while(p3!=NULL) /*判断循环结束条件*/ { if((p3->num)==q) /*判断是否为所需要修改的商品*/ { printf("输入商品单价与库存量(如果单价不变输入原来的单价)\n"); scanf("%f %d",&p3;->price,&p3;->quantity); /*输入商品价格与库存量*/ } p3=p3->next; } if((fp=fopen("goods message.txt","w"))==NULL) /*判断能否打开文件*/ { printf("can not open the file"); exit(0); /*结束程序*/ } p3=head; while(p3!=NULL) /*判断循环结束条件*/ { fprintf(fp,"%d %s %s %f %s %d ",p3->num,p3->name,p3->kind,p3->price,p3->unit,p3->quantity); /*将商品信息写入文件*/ p3=p3->next; } fprintf(fp,"%d",-1); fclose(fp); /*关闭文件*/ printf("**********************************\n"); printf("__________________________________\n"); printf("------------按4返回-------------\n"); printf("__________________________________\n"); printf("**********************************\n"); } if(n==4) /*退*/ break; } printf("**********\n"); printf("1 继续修改\n---------\n2 返回\n"); printf("**********\n"); scanf("%d",&p); if(p==1) continue; /*继续循环*/ if(p==2) break; /*跳循环*/ }while(n!=2); fclose(fp); /*关闭文件*/ } void printf0(struct good *p) /*遍历链表并打印电器类商品函数*/ { struct good *p3; /*定义结构体指针类型*/ p3=p; while (p3!=NULL) /*判断遍历链表循环结束条件*/ { if(strcmp(p3->kind,c)==0) /*判断商品类型是否为电器类型*/ { printf("%d\t%s\t%s\t%0.1f\t%s\t%d\n",p3->num,p3->name,p3->kind,p3->price,p3->unit,p3->quantity); /*输电器类商品信息*/ printf("________________________________________________\n"); } p3=p3->next; } return; } void printf1(struct good *p) /*遍历链表并打印日用品类商品函数*/ { struct good *p3; /*定义结构体指针类型*/ p3=p; while (p3!=NULL) /*判断遍历链表循环结束条件*/ { if(strcmp(p3->kind,d)==0) /*判断商品类型是否为日用品类型*/ { printf("%d\t%s\t%s\t%0.1f\t%s\t%d\n",p3->num,p3->name,p3->kind,p3->price,p3->unit,p3->quantity); /*输日用品类商品信息*/ printf("________________________________________________\n"); } p3=p3->next; } return; } void printf2(struct good *p) /*遍历链表并打印办公用品类商品函数*/ { struct good *p3; /*定义结构体指针类型*/ p3=p; while (p3!=NULL) /*判断遍历链表循环结束条件*/ { if(strcmp(p3->kind,e)==0) /*判断商品类型是否为办公用品类型*/ { printf("%d\t%s\t%s\t%0.1f\t%s\t%d\n",p3->num,p3->name,p3->kind,p3->price,p3->unit,p3->quantity); /*输办公用品类商品信息*/ printf("________________________________________________\n"); } p3=p3->next; } return; } void printf3(struct good *p) /*遍历链表并打印食品类商品函数*/ { struct good *p3; /*定义结构体指针类型*/ p3=p; while (p3!=NULL) /*判断遍历链表循环结束条件*/ { if(strcmp(p3->kind,f)==0) /*判断商品类型是否为食品类型*/ { printf("%d\t%s\t%s\t%0.1f\t%s\t%d\n",p3->num,p3->name,p3->kind,p3->price,p3->unit,p3->quantity); /*输食品类商品信息*/ printf("________________________________________________\n"); } p3=p3->next; } return; } void shunxudayin() { for(i=0;i<4;i++) g[i]=aver[i]; /*将平均价赋给新数组*/ for(j=0;j<3;j++) /*将新数组用冒泡排序法排序*/ for(i=j+1;i<4;i++) { if(g[j]<g[i]) { h=g[j]; g[j]=g[i]; g[i]=h; } } printf("\n****************************\n"); printf("商品平均价格排序表(从高到低)\n"); printf("****************************\n"); printf("________________________________________________\n"); printf("编号\t名称\t类别\t单价\t单位\t数量\n"); printf("________________________________________________\n"); for(j=0;j<4;j++) for(i=0;i<4;i++) { if (aver[i]==g[j]) /*判断每类商品平均价格的先后顺序*/ switch(i) { case 0: printf0(head); /*调用遍历链表并打印电器类商品函数*/ break; case 1: printf1(head); /*调用遍历链表并打印日用品类商品函数*/ break; case 2: printf2(head);/*调用遍历链表并打印办公用品类商品函数*/ break; case 3: printf3(head); /*调用遍历链表并打印食品类商品函数*/ break; } } } void tongji1() { p1=head; printf("\n************************\n"); printf("库存量低于100的货名及类别\n"); printf("************************\n"); printf("________________________\n"); printf("商品名称\t商品类型\n"); printf("________________________\n"); while(p1!=NULL) /*判断遍历链表循环结束条件*/ { if(p1->quantity<100) /*判断库存量是否小于100*/ { printf("%s\t%s\n",p1->name,p1->kind); /*输商品名称及类别*/ printf("________________________\n"); } p1=p1->next; } } void tongji2() { printf("\n**********************************************\n"); printf("商品库存量有2种以上(含2种)低于100的商品类别:\n"); printf("**********************************************\n"); printf("________\n"); if((a[0]<100)&&(a[0]>=2)) /*判断电器类库存量是否为2种以上(含2种)低于100*/ { printf("电器\n"); printf("________\n"); } if((a[1]<100)&&(a[1]>=2)) /*判断日用品类库存量是否为2种以上(含2种)低于100*/ { printf("日用品\n"); printf("________\n"); } if((a[2]<100)&&(a[2]>=2)) /*判断食品类库存量是否为2种以上(含2种)低于100*/ { printf("食品\n"); printf("________\n"); } if((a[3]<100)&&(a[3]>=2)) /*判断办公用品类库存量是否为2种以上(含2种)低于100*/ { printf("办公用品\n"); printf("________\n"); } } int main(int argc, char* argv[]) { struct good *p1,*p2; /*定义结构体指针类型*/ while(1) { printf("***********************************************\n"); printf("1 ----------输查看或者修改已存信息-----------\n"); printf("-----------------------------------------------\n"); printf("2 -----重新输入新信息(并且删除原有信息)------\n"); printf("-----------------------------------------------\n"); printf("3 统计商品信息(如果您还没有查看过信息先按1)\n"); printf("-----------------------------------------------\n"); printf("4 -------------------退---------------------\n"); printf("***********************************************\n"); scanf("%d",&m); if(m==1) shuchu(); /*调用输信息函数*/ if(m==2) { system("cls"); head=createlist(); /*调用建立链表函数*/ } if(m==3) { printf("统计结果如下\n"); head=paixu(head); /*调用链表排序函数*/ jisuan(); /*调用计算函数*/ shunxudayin(); /*调用顺序打印函数*/ tongji1(); /*调用统计1函数*/ tongji2(); /*调用统计2函数*/ } if(m==4) { p1=head; while(p1!=NULL) /*判断遍历链表结束条件*/ { p2=p1->next; free(p1); /*释放空间*/ p1=p2; } break; } } return 0; /*结束程序*/ }
等价类划分法边界值分析法都是软件测试中常用的测试设计技术。 等价类划分法是将输入数据分为若干个等价类,每个等价类的数据具有相同的测试结果。这样,从每个等价类中选择一个代表数据作为测试用例,即可覆盖整个等价类。例如,一个需要输入数字的系统,可以将输入数据划分为正数、负数和零三个等价类。 边界值分析法是特殊的等价类划分法,它将输入数据的边界值作为测试用例,因为边界值通常是导致程序错误的原因。例如,如果一个系统要求输入1到100之间的整数,那么测试用例可以选择1、100、2和99等四个边界值。 下面以一个简单的例子来说明等价类划分法边界值分析法的测试用例设计: 假设有一个登录系统,要求用户名和密码都不能少于6个字符,也不能超过20个字符,且用户名和密码不能相同。使用等价类划分法边界值分析法分别设计测试用例等价类划分法: - 输入用户名和密码都在6-20个字符之间的有效数据 - 输入用户名长度小于6个字符的无效数据 - 输入密码长度小于6个字符的无效数据 - 输入用户名长度大于20个字符的无效数据 - 输入密码长度大于20个字符的无效数据 - 输入用户名和密码相同的无效数据 边界值分析法: - 输入用户名和密码都为6个字符的边界值 - 输入用户名和密码都为20个字符的边界值 - 输入用户名长度为5个字符、密码长度为6个字符的边界值 - 输入用户名长度为6个字符、密码长度为5个字符的边界值 - 输入用户名长度为20个字符、密码长度为19个字符的边界值 - 输入用户名长度为19个字符、密码长度为20个字符的边界值 - 输入用户名和密码相同的无效数据的边界值 以上就是等价类划分法边界值分析法的测试用例设计示例。通过这些测试用例的设计,可以有效地测试登录系统的各种情况,从而提高软件的质量和稳定性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值