测试代码类好多工作都是跟io有关系:日志的解析,有的时候我们做UI或者接口自动化测试,工具提供的测试报告不能满足我们的需求,这个时候我们就需要自己写测试报告,原理就是基于IO基础知识。字符流只处理文字,而字节流,处理所有东东包括:图片,音频,视频,文字,之所以把字符流单独提取,就是为了提升对于文件的读写效率。
具体案例:
package com.my.io.demo;
import java.io.File;
import java.io.FileNotFoundException;
import java.io.FileReader;
import java.io.FileWriter;
import java.io.IOException;
import java.text.SimpleDateFormat;
import java.util.Date;
public class FileDemo {
public static void main(String[] args) {
writeFile();
readFile();
}
public static String formatCurrentTime() {
SimpleDateFormat sdf = new SimpleDateFormat("yyyy_MM_dd_HH_mm_ss");
Date date = new Date(System.currentTimeMillis());
return sdf.format(date);
}
public static void writeFile() {
File f = new File("d:"+File.separator+"testm10.txt");
System.out.println(f.getAbsolutePath());
System.out.println(f.canRead());
String base = System.getProperty("user.dir");
System.out.println(base);
File path = new File(base+File.separator+"result");
System.out.println(path);
File logFile = new File(path,formatCurrentTime()+".log");
System.out.println(logFile);
if(!logFile.exists()) {
if(!path.exists()) {
path.mkdir();
}
try {
logFile.createNewFile();
System.out.println("创建文件成功!");
} catch (IOException e) {
e.printStackTrace();
}
}else {
System.out.println("文件存在!");
}
try {
FileWriter fw = new FileWriter(logFile);
fw.write("Info "+formatCurrentTime()+" info test\r\n");
Thread.sleep(1000);
fw.write("Debug "+formatCurrentTime()+" debug test\r\n");
fw.close();
} catch (IOException e) {
e.printStackTrace();
} catch (InterruptedException e) {
e.printStackTrace();
}
}
public static void readFile() {
FileReader fr = null;
try {
fr = new FileReader("D:\\eclipse-workspace\\HelloWorld\\result\\2020_03_12_14_45_30.log");
int ch = 0;
while((ch=fr.read()) != -1) {
// System.out.print(ch); //ch 代表ASCII码表
System.out.print((char)ch);
}
} catch (FileNotFoundException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}finally {
try {
fr.close();
} catch (IOException e) {
e.printStackTrace();
}
}
}
}
运行结果:
在日志中写入html的格式
一般日志的内容包括:
定义head 和tail
找到需要重复写入日志中的内容,并进行参数化
提供写日志接口
注意tail部分数据的统计设计
日志模块入口的设计,根据不同的文件名后缀,调用不同的类
junit4中测试日志的应用
把测试结果写入测试用例中
package com.my.io.demo;
import java.io.FileWriter;
import java.io.IOException;
public class WriteFileDemo {
/**
* @param args
*/
public static void main(String[] args) {
FileWriter fw;
try {
//文件大小的判断
fw = new FileWriter("d:/demo_io.html",true);
//fw = new FileWriter("d:/demo_io.html");
fw.write("<html>");
fw.write("<b>");
fw.write("2222abc55555");
fw.write("</b>");
fw.write("def");
fw.write("</html>");
fw.close();
} catch (IOException e) {
e.printStackTrace();
}
}
}
运行结果: