软件测试中谓词测试的自动化JAVA实现

题目

这周的软件测试课程,要对布尔表达式(a+b<c)∧﹁p∨(r>s)生成BOR约束集,依据BOR约束集生成测试用例,然后证明测试用例对于BOR测试准则是充分的。

生成约束集合与测试用例

IMG_1616.JPG

谓词自动化测试test set的java实现

注释很清楚了,这里不再啰嗦

public class Bor_test {

    public static void main(String[] args){
        /*测试位数,也即布尔运算符个数
        **用1表示未出错,0表示出错
        * 这样0~30对应的二进制最低五位表示所有的出错情况
         */
        int bit_count=5;
        int count=30;
        /*BOR测试约束
        ** 布尔表达式异常后,测试用例test的输出结果应与其不同
         */
        boolean[]  criterion={true,true,false,false};
        /*
        **基于AST求得的BOR约束的一个test set
         */
        boolean[][] test={{true,false,false},{false,false,true},{true,true,false},{false,false,false}};
        /*
        **存放布尔表达式出错后用test set测试的结果
         */
        boolean ans[][]=new boolean[31][4];

        /*
        **每个不同的i对应一个不同的布尔表达式异常(单或多)
         */
        for(int i=0;i<30;i++){
            //条件判断通过para传入test函数实现解耦
            ans[i]=test(test,i);

        }
        System.out.println("t1\t\tt2\t\tt3\t\tt4\t\t是否可测出错误?");
        for (boolean[] a:ans
             ) {
            boolean flag3=true;
            for(int i=0;i<4;i++){
                System.out.print(a[i]+"\t");
                if(a[i]!=criterion[I])
                    flag3=false;
            }
            System.out.print(flag3);
            System.out.println();
        }

    }
    public static boolean[] test(boolean[][] test,int bit){
        boolean[] ans=new boolean[4];
        boolean flag1=(bit>>3)%2==1;
        boolean flag2=(bit>>1)%2==1;
        if(flag1){
            if(flag2){
                for(int i=0;i<3;i++) {
                    ans[i] = (((i>>4)%2==0)^test[i][0])
                            &!((i>>2)%2==0)^test[i][1]
                            |(i%2==0)^test[i][2];
                }
            }
            else {
                for(int i=0;i<3;i++) {
                    ans[i] = (((i>>4)%2==0)^test[i][0])
                            &!((i>>2)%2==0)^test[i][1]
                            &(i%2==0)^test[i][2];
                }
            }
        }
        else {
            if (flag2){
                for(int i=0;i<3;i++) {
                    ans[i] = (((i>>4)%2==0)^test[i][0])
                            |!((i>>2)%2==0)^test[i][1]
                            |(i%2==0)^test[i][2];
                }
            }
            else {
                for(int i=0;i<3;i++) {
                    ans[i] = (((i>>4)%2==0)^test[i][0])
                            |!((i>>2)%2==0)^test[i][1]
                            &(i%2==0)^test[i][2];
                }
            }
        }
        return  ans;
    }

}

后记

用手算太累,因此用java自己实现了。写这段大概用了半小时,第一次写这种测试,老是想着尽可能解耦、简单化。但其实按照手动算的思路写。。。那还不如用手算(30*4的运算量)

参考

《软件测试基础教程》
http://book.51cto.com/art/201109/291990.htm

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 1.测试与软件模型 软件开发生命周期模型指的是软件开发全过程、活动和任务的结构性框架。软件项目的开发包括:需求、设...
    宇文臭臭阅读 6,759评论 5 100
  • -----转载----- 1、问:你在测试中发现了一个bug,但是开发经理认为这不是一个bug,你应该怎样解决? ...
    花开沉浮阅读 7,474评论 4 88
  • 【文章摘要】 面向对象的软件测试摘 要: 如今,面向对象开发技术正大力地的推动着软件产业的快速发展。在保证软件产品...
    西边人阅读 3,171评论 0 2
  • 1****、问:你在测试中发现了一个bug****,但是开发经理认为这不是一个bug****,你应该怎样解决?首先...
    一箭阅读 9,113评论 1 205
  • 基于 SELENIUM 的自动化测试架构 非常感谢各位查阅本篇文章,笔者在此感谢各位。 目前市面上有分门别类的自动...
    厲铆兄阅读 6,121评论 6 43