学习内容:

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小时学习时间(其实也不多~)一点点加吧

还有背单词!奥利给~

Java学习十四的更多相关文章

  1. “全栈2019”Java第九十四章:局部内部类详解

    难度 初级 学习时间 10分钟 适合人群 零基础 开发语言 Java 开发环境 JDK v11 IntelliJ IDEA v2018.3 文章原文链接 "全栈2019"Java第 ...

  2. “全栈2019”Java第十四章:二进制、八进制、十六进制

    难度 初级 学习时间 10分钟 适合人群 零基础 开发语言 Java 开发环境 JDK v11 IntelliJ IDEA v2018.3 文章原文链接 "全栈2019"Java第 ...

  3. “全栈2019”Java第二十四章:流程控制语句中决策语句switch下篇

    难度 初级 学习时间 10分钟 适合人群 零基础 开发语言 Java 开发环境 JDK v11 IntelliJ IDEA v2018.3 文章原文链接 "全栈2019"Java第 ...

  4. 从.Net到Java学习第四篇——spring boot+redis

    从.Net到Java学习系列目录 “学习java已经十天,有时也怀念当初.net的经典,让这语言将你我相连,怀念你......”接上一篇,本篇使用到的框架redis.FastJSON. 环境准备 安装 ...

  5. Scala学习十四——模式匹配和样例类

    一.本章要点 match表达式是更好的switch,不会有意外调入下一个分支 如果没有模式能够匹配,会抛出MatchError,可以用case _模式避免 模式可以包含一个随意定义的条件,称做守卫 你 ...

  6. 强化学习(十四) Actor-Critic

    在强化学习(十三) 策略梯度(Policy Gradient)中,我们讲到了基于策略(Policy Based)的强化学习方法的基本思路,并讨论了蒙特卡罗策略梯度reinforce算法.但是由于该算法 ...

  7. java学习(四)

    学号 20189214 <Java程序设计>第四周学习总结 教材学习内容总结 枚举 枚举是JDK1.5版本新增的特性(泛型.For-each等如今被广泛应用的特性也是由JDK1.5时所新增 ...

  8. 系统学习 Java IO (十四)----字符读写缓存和回退 BufferedReader/BufferedWriter & PushbackReader

    目录:系统学习 Java IO---- 目录,概览 BufferedReader BufferedReader 类构造器接收一个 Reader 对象,为 Reader 实例提供缓冲. 缓冲可以加快 I ...

  9. Java开发学习(十四)----Spring整合Mybatis及Junit

    一.Spring整合Mybatis思路分析 1.1 环境准备 步骤1:准备数据库表 Mybatis是来操作数据库表,所以先创建一个数据库及表 create database spring_db cha ...

随机推荐

  1. centos6或7查看端口占用及解除占用

    一.查看端口占用 netstat -lnp|grep 要查看的端口号 例如:查看占用端口7000的进程 netstat -lnp|grep 7000 二.清除占用 (1)一次性的清除占用80端口的程序 ...

  2. 吴裕雄--天生自然java开发常用类库学习笔记:排序及重复元素说明

    import java.util.Set ; import java.util.HashSet ; class Person{ private String name ; private int ag ...

  3. Ubuntu下搭建yocto

    参考自: https://www.jianshu.com/p/f6e0debb5e1f https://blog.csdn.net/qq_31041847/article/details/902114 ...

  4. Idea--使用Idea调试设置

    参考 https://blog.csdn.net/yyjava/article/details/81453748 关闭一些Idea默认设置,否则懵逼到爆炸.. 1.关闭集合类视图 2.关闭watch视 ...

  5. 英语语法 - the + 形容词 的意义

    1,表示一类人  (复数) the young 青年 the old 老年the poor 穷人 the rich 富人the sick 病人 The old need care more than ...

  6. nodeks —— fs模块 —— 从流中 读取和写入数据

    Fs流读取和写入数据 使用文件流来读取大文件不会卡顿 1, 从流中读取数据 var fs = require("fs"); var data = ''; var count = 0 ...

  7. Linux系统下的/etc/nsswitch.conf文件

    一.什么是nsswithch.conf(服务搜索顺序)文件呢? nsswitch.conf(name service switch configuration,名字服务切换配置)文件位于/etc目录下 ...

  8. redis主从遇到的问题

    rendis安装 主从切换 Redis的HA方案 Redis高可用架构(1)—Keepalive+VIP 还是配置的问题   从一直无法连接上主 redis.conf配置 # Examples:# 1 ...

  9. eclipse中svn重新设置账户

    查看svn版本:windows > preference > Team > SVN 1.如果svn插件是svnkit版 只需找到.keyring文件,一般目录是:eclipse安装目 ...

  10. MongoDB 数据建模

    版权所有,未经许可,禁止转载 章节 MongoDB 入门 MongoDB 优势 MongoDB 安装 MongoDB 数据建模 MongoDB 创建数据库 MongoDB 删除数据库 MongoDB ...