学习内容:

1.Junit

2.maven安装配置环境


一、Junit实例演示步骤

1.引入jar包

junit包需要引入hamcrest-core包,否则会报错

2.测试如下代码

 package com.junit.test;

 public class Calculator {
private static int result; //静态变量,用于存储运行结果
public void add(int n){
result=result+n;
}
public void substract(int n){
result=result-1; //Bug:正确的应该是result=result-n
}
public void multiply(int n){ }//此方法尚未写好
public void divide(int n)throws Exception{
if(n==0)
throw new Exception("除数不能为0");
result=result/n;
}
public void square(int n){
result=n*n;
}
public void squareRoot(int n){
for(;;); //Bug:死循环
}
public void clear(){ //将结果清零
result=0;
}
}

3.进行单元测试

点击测试项目,点击新建JUnit Test Case

选择测试方法

演示代码

package com.junit.test;

import static org.junit.Assert.*;

import org.junit.Before;
import org.junit.Ignore;
import org.junit.Test; public class CalculatorTest { public static Calculator c = new Calculator();
@Before
public void setUp() throws Exception {
} @Test
public void testAdd() {
c.add(2);
c.add(2);
assertEquals(4,c.getResult());
} @Test
public void testSubstract() {
c.substract(2);
assertEquals(2,c.getResult());
} @Ignore
public void testMultiply() {
c.multiply(10);
} @Test(expected = Exception.class)
public void testDivide() throws Exception {
c.divide(0);
} @Test(timeout = 1000)
public void testSquareRoot() {
c.squareRoot(9);
} }

演示结果

其中将multiply方式用ignore注解忽略到了


另外一个测试代码演示带有数据库

待测试的项目:

 package com.junit.test;

 import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.HashMap;
import java.util.Map; public class Demo {
Connection conn=null;
public static void main(String[] args){
//运行之前需要创建数据库和表格,参考test1.sql文件
Demo d=new Demo();
Map param=new HashMap();
param.put("id",5);
param.put("name","amy");
param.put("password","123456");
d.insert(param);
d.getAll();
d.close();
}
public void createDb(){
String url="jdbc:mysql://localhost:3306/test1";
String name="com.mysql.jdbc.Driver";
String user="root";
String password="root";
try {
Class.forName(name);//指定连接类型
conn = DriverManager.getConnection(url, user,password);
System.out.println("连接成功");
//pst=conn.prepareStatement(sql);//准备执行语句
} catch (ClassNotFoundException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch(SQLException e){
e.printStackTrace();
}
} public int insert(Map param){
this.createDb();
int i=0;
String sql="INSERT INTO user(id,username,password) VALUES(?,?,?)";
PreparedStatement pstmt;
try{
pstmt=this.conn.prepareStatement(sql);
pstmt.setString(1,(String)param.get("id"));
pstmt.setString(2,(String)param.get("name"));
pstmt.setString(3,(String)param.get("password"));
i=pstmt.executeUpdate();
pstmt.close();
}catch(SQLException e){
e.printStackTrace();
} return i;
}
public void getAll(){
String sql="select * from user";
PreparedStatement pstmt=null;
try{
pstmt=this.conn.prepareStatement(sql);
ResultSet rs=pstmt.executeQuery();
int col=rs.getMetaData().getColumnCount();
System.out.println("=========================");
while(rs.next()){
for(int i=1;i<=col;i++){
System.out.print(rs.getString(i)+"\t");
if((i==2)&&(rs.getString(i).length()<8)){
System.out.print("\t");
}
}
System.out.println("");
}
System.out.println("========================="); }catch(Exception e){
e.printStackTrace();
}
}
public void close(){
}
}

测试代码

package com.junit.test;

import static org.junit.Assert.*;

import java.util.HashMap;
import java.util.Map; import org.junit.After;
import org.junit.Before;
import org.junit.Test; public class DemoTest { public static Demo d = new Demo(); @Before
public void setUp() throws Exception {
} @Before
public void testCreateDb() {
d.createDb();
} @Test
public void testInsert() {
Map param=new HashMap();
param.put("id","2");
param.put("name","amy");
param.put("password","123456");
d.insert(param);
} @Test
public void testGetAll() {
d.getAll();
} @After
public void testClose() {
d.close();
} }

测试结果

打包所有要测试的类

package com.junit.test;

import org.junit.runner.RunWith;
import org.junit.runners.Suite; @RunWith(Suite.class)
@Suite.SuiteClasses({
CalculatorTest.class,
DemoTest.class
}) public class TestAllForJunit { }

 maven

之前已经安装配置过maven,今天算是重温一下。

maven的几个命令

mvn compile   编译

mvn install       编译,运行和发布

mvn package   编译,运行不负责发布,也就是package命令不会将target内容发布到本地仓库

mvn test   编译,如果你test包下面有相关Java也编译和运行,但是也一样不会发布到本地仓库中

mvn clean 清除

明天就是2.1了,年也过了,不管考研结果怎么样,也要好好准备了。

从明天起,每天6小时学习时间(其实也不多~)一点点加吧

还有背单词!奥利给~

最新文章

  1. mysql 语法
  2. MySQL数据库
  3. Linux学习 :移植U-boot_2016.09到JZ2440开发板
  4. hdu 2014鞍山赛区 5073 Galaxy
  5. [转]ldconfig几个需要注意的地方
  6. 在IT网站上少花些时间
  7. [C#]Linq To Xml 实例操作- 转
  8. POJ_3176_Cow_Bowling_(数字三角形)_(动态规划)
  9. hdu1992(递推)
  10. 14.TCP的坚持定时器和保活定时器
  11. 如何关闭浏览器的HSTS功能
  12. Java多线程Future模式
  13. map标签
  14. python安装提示错误Could not find a version that satisfies the requirement dateutil
  15. 部署openresty遇到的一些坑
  16. nginx ipv4 ipv6 chrome /firefox remote-address/chrome://net-internals/dns
  17. kNN分类算法实例1:用kNN改进约会网站的配对效果
  18. 配置iOS项目的设备系统目标设置:Base SDK和Deployment Target
  19. spring mvc集成freemarker使用
  20. 培训补坑(day4:网络流建模与二分图匹配)

热门文章

  1. maven项目打包和运行
  2. STL语句表跳转指令学习
  3. 2.9 学习总结 之 【Android】体温统计APP
  4. C++Socket通信(客户端和服务器)
  5. Jenkins实现自动打包,MAVEN打包,Shell脚本启动
  6. MongoDB 常用查询语法
  7. 123-PHP类构造函数
  8. 4. Linux 集群安装
  9. php观察者模式。
  10. OLAP(On-Line Analytical Processing)