Junit单元测试
Junit单元测试
测试分类:1.黑盒测试 2.白盒测试
黑盒测试
只测试输入、输出
白盒测试
不仅测试输入输出,也要关注程序执行的具体流程
白盒测试是要写测试代码的
Junit是白盒测试的一种
单元测试(英语:Unit Testing)又称为模块测试,是针对程序模块(软件设计的最小单位)来进行正确性检验的测试工作。程序单元是应用的最小可测试部件。在过程化编程中,一个单元就是单个程序、函数、过程等;对于面向对象编程,最小单元就是方法,包括基类(超类)、抽象类、或者派生类(子类)中的方法。
通常来说,程序员每修改一次程序就会进行最少一次单元测试,在编写程序的过程中前后很可能要进行多次单元测试,以证实程序达到软件规格书要求的工作目标,没有程序错误;虽然单元测试不是必须的,但也不坏,这牵涉到项目管理的政策决定。
JUnit 是一个回归测试框架,被开发者用于实施对应用程序的单元测试,加快程序编制速度,同时提高编码的质量。JUnit 测试框架能够轻松完成以下任意两种结合:
- Eclipse 集成开发环境
- Ant 打包工具
- Maven 项目构建管理
原有测试方法的问题:
- 进行多项测试时要注释掉之前的测试代码,很不方便
- 测试代码要和源代码放在一起
@After常用于资源的释放
这两个注释都是标注了每次执行测试代码都需要被执行的方法
反射
反射被称为框架设计的灵魂
- .java文件通过javac编译为.class字节码文件,这些都是存放在硬盘中的,这个阶段称为源代码阶段
- ClassLoader将字节码文件加载到内存
- class是一个用来描述字节码文件的类。其的成员变量、构造方法和成员方法分别被封装为Field[]、Constructor[]、Method[]对象(因为可能有多个,所以用数组进行描述)。--这就是一个反射的过程
例如,当我们在IDE中定义了一个对象后,IDE会将这个对象对应的类的字节码文件加载到内存中,对应的class对象将其所有的成员方法封装为Method[],这样只需要将Method[]中的元素变量显示出来,就达到了代码提示的效果
反射的好处:
获取字节码文件Class对象
第二种:字节码文件已加载到内存中
第三种:已经在运行、有对象了
Demo1.java
import domain.Person;
/*
*@author JiaDing
*/
public class Demo1 {
/*
* 获取Class的三种方式
*/
public static void main(String[]args) throws Exception {
//1.Claa.forName("全类名")
Class cls1=Class.forName("domain.Person");
System.out.println(cls1);
//2.类名.class
Class cls2=Person.class;
System.out.println(cls2);
//3.对象.getClass()
Person p=new Person();
Class cls3=p.getClass();
System.out.println(cls3);
}
}
Person.java
package domain;
/*
*@author JiaDing
*/
public class Person {
private String name;
private int age;
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public int getAge() {
return age;
}
public void setAge(int age) {
this.age = age;
}
public Person() {
}
public Person(String name,int age) {
this.name=name;
this.age=age;
}
@Override
public String toString() {
return "Person [name=" + name + ", age=" + age + "]";
}
}
使用Class对象
- 获取成员变量
getFields()获取的所有public成员变量!,而getDeclaredFields()获取的才是所有的成员变量(输出时会输出权限修饰符)!
getDeclaredFields()可以突破private限制对私有变量进行读写!
对成员变量能做的两个操作:设置值void set(Object obj,Object value)、获取值get(Object obj)
- 获取构造方法
获取时要给出不同参数类型的类
有了构造方法获得的构造器,就可以用来创建对象了
如果构造使用空参数构造方法创建对象,则可以简化为用class对象中专用的newInstance方法
constructor1.setAccessible(true)
- 获取成员方法
Method对象调用对应的方法:invoke(Object obj,Object ··· args)//传入一个对象和执行该参数需要的参数
通过getMethods()获取的方法不仅有该类我们定义的方法,还有继承自Object类的方法
开启暴力反射:method.setAccessible(true);
获取该方法的名称:String getName();
String name=method.getName();
- 获取类名
反射案例
配置文件类型:.properties,在其中使用全类名(换句话说,如果我们看到一个配置文件中使用的是全类名,我们也可以猜测它使用了反射原理)
这样每次只需要修改配置文件就好了。相比于修改代码,修改配置文件不需要重新编译、测试、上线,也提高了程序的拓展性。
注解
@Deprecated过时方法不是不能调用,只是显示出来,便于选择和之后的迭代
示例:
javadoc test1.java//抽取注解到文档中
生成的文件们:
@Target(ElementType.FIELD)//声明这个注解类是给其他类的属性做注解
@Rectention(RetentionPolicy.RUNTIME)//定义注解的生命周期
@Documneted//表示将注解写到文档中
@interface TestAnn{
? public int id() default 0;//default是默认值
public String desc() default "";
}
使用:
示例,依然以之前使用配置文件来调用任意类的任意方法的例子为例: