`

junit单元测试的意义

    博客分类:
  • j2ee
阅读更多
为什么要进行单测试.
1.     单元测试的目的

一个单元测试从整个系统中单独检验产品程序代码的『一个单元』并检查其得到的结果是否是预期的。要测试的『一个单元』其大小是依据一组连贯的功能的大小及介于一个类别及一个包(package)之间实际上的变化 (varies)。其目的是在整合程序代码到系统的其余部分之前先测试以便找出程序代码中的臭虫(bugs)。Junit等支持在Java程序代码中撰写单元测试。

在整合之前于系统其它部分隔离起来抓虫的理由是因为那是比较容易的找到臭虫(亦即比较快且便宜)及比较容易修正问题(并显示其解决方式是可行的)。

单元测试对于在初始整合一小部分程序代码以及整合其余的改变之前提供了一些利益。如果有人需要变动现有的程序代码,事实上单元测试仍然可以让他对于其最后的程序代码更有信心;即他的改变不会破坏任何东西。愈好的单元测试让人愈有信心--理想上测试必须在加入的新功能前也随之更新。

2.     谁来撰写单元测试及何时撰写单元测试

程序代码测试可能是非常乏味的,尤其是测试别人的程序,而当你是一个程序设计师的时候尤甚。但程序设计师喜欢撰写程序,因此为什么不让程序设计师撰写一些程序可以作为测试之用呢?

当单元测试正确的实作可以帮助程序设计师变的更有生产力,而同时提升开发程序代码的品质。有一点你必须了解的是单元测试应该是开发程序的一部份是很重要的;而且程序代码的设计必须是可以测试的。目前的趋势是在撰写程序代码之前要先撰写单元测试,并且把焦点放在Java类别的接口及行为上。

先写测试,再写代码的好处:

从技术上强制设计师先考虑一个类的功能,也就是这个类提供给外部的接口,而不至于太早陷入它的细节。这是面向对象提倡的一种设计原则。

好的测试其实就是一个好的文档,这个类使用者往往可以通过查看这个类的测试代码了解它的功能。特别的,如果你拿到别人的一个程序,对他写测试是最好的了解这个程序的功能的方法。 xp的原则是 make it simple,不是很推荐另外写文档,因为项目在开发过程中往往处于变动中,如果在早期写文档,以后代码变动后还得同步文档,多了一个工作,而且由于项目时间紧往往文档写的不全或与代码不一致,与其这样,不如不写。而如果在项目结束后再写文档,开发人员往往已经忘记当时写代码时的种种考虑,况且有下一个项目的压力,管理人员也不愿意再为旧的项目写文档。导致以后维护的问题

没有人能保证需求不变动,以往项目往往对需求的变动大为头疼,害怕这个改动会带来其它地方的错误。为此,除了设计好的结构以分割项目外(松耦合),但如果有了测试,并已经建立了一个好的测试框架,对于需求的变动,修改完代码后,只要重新运行测试代码,如果测试通过,也就保证了修改的成功,如果测试中出现错误,也会马上发现错在哪里。修改相应的部分,再运行测试,直至测试完全通过。

软件公司里往往存在开发部门和测试部门之间的矛盾:由于开发和测试分为两个部门,多了一层沟通的成本和时间,沟通往往会产生错误的发生。而且极易形成一个怪圈:开发人员为了赶任务,写了烂烂的代码,就把它扔给测试人员,然后写其它的任务,测试当然是失败的,又把代码拿回去重写,测试就成了一个很头疼的问题。这种怪圈的根源是责任不清,根据 xp 中的规定:写这个代码的人必须为自己的代码写测试,而且只有测试通过,才算完成这个任务(这里的测试包括所有的测试,如果测试时发现由于你的程序导致别的组的测试失败,你有责任通知相关人员修改直至集成测试通过),这样就可以避免这类问题的发生。

简而言之,如果程序设计师要写一段代码:

先用 junit 写测试,然后再写代码;

写完代码,运行测试,如果测试失败,

修改代码,运行测试,直到测试成功。

如果以后对程序进行修改,优化 ( refactoring ),只要再运行测试代码。如果所有的测试都成功,则代码修改完成。

3.     单元测试与Java Team开发的结合

Java下的team开发,一般采用cvs(版本控制) + ant(项目管理) + junit(单元测试、集成测试)的模式:

每天早上上班,每个开发人员从 cvs server 获取一个整个项目的工作拷贝。

拿到自己的任务,先用 junit 写今天的任务的测试代码。

然后写今天任务的代码,运行测试(单元测试),直到测试通过。

任务完成在下班前一两个小时,各个开发人员把任务提交到cvs server。

然后由主管对整个项目运行自动测试(集成测试),哪个测试出错,就找相关人员修改,直到所有测试通过。下班。。。

4.     测试控制工具中要有甚么?

无论谁来撰写单元测试或何时撰写单元测试,我们的焦点应该放在检验程序代码;主要是在于产生错误的风险。如果设计文件包含被测试对象的使用情节;便可成为好的测试来源。不管如何,这些情节写得不是很明确;因为这些情节实际上是以设计观点所写的--因此适当的测试应该有对等的情节,换句话说,也就是测试设计应该尽可能的包含用户实际使用程序时可能产生的动作或者过程。

另一个测试案例好的来源是在整合后从产品程序代码当中找到的问题,维修问题的处理方式往往值得封装成为测试案例。

5.     为什么要使用Junit等工具呢?

前面的论述说明为什么我们需要测试控制工具,但为什么我们使用Junit这些工具呢?

首先,它们是完全Free的啦!。

第二点,使用方便。

l          在你提升程序代码的品质时JUnit测试仍允许你更快速的撰写程序

那听起来似乎不是很直觉,但那是事实。当你使用JUnit撰写测试,你将花更少的时间除虫,同时对你程序代码的改变更 俱有信心。这个信心让你更积极重整程序代码并增加新的功能。没有测试,对于重整及增加新功能你会变得没有信心;因为你不知道有甚么东西会破坏产出的结果。采用一个综合的测试系列,你可以在改变程序代码之后快速的执行多个测试并对于你的变动并未破坏任何东西感到有信心。在执行测试时如果发现臭虫,原始码仍然清楚的在你脑中,因此很容易找到臭虫。在JUnit中撰写的测试帮助你以一种极 大(extreme)的步伐撰写程序及快速的找出缺点。

l          JUnit非常简单

撰写测试应该很简单--这是重点!如果撰写测试太复杂或太耗时间,便无法要求程序设计师撰写测试。使用JUnit你可以快速的撰写测试并检测你的程序代码并逐 步随着程序代码的成长增加测试。只要你写了一些测试,你想要快速并频繁的执行测试而不至于中断建立设计及开发程序。使用JUnit执行测试就像编译你的程序代码那么容易。事实上,你应该执行编译时也执行测试。编译是检测程序代码的语法而测试是检查程序代码的完整性(integrity)。

l          JUnit测试检验其结果并提供立即的回馈。

如果你是以人工比对测试的期望与实际结果那么测试是很不好玩的,而且让你的速度慢下来。JUnit测试可以自动执行并且检查他们自己的结果。当你执行测试,你获得简单且立即的回馈; 比如测试是通过或失败。而不再需要人工检查测试结果的报告。

l          JUnit测试可以合成一个测试系列的层级架构。

JUnit可以把测试组织成测试系列;这个测试系列可以包含其它的测试或测试系列。JUnit测试的合成行为允许你组合多个测试并自动的回归(regression)从头到尾测试整个测试系列。你也可以执行测试系列层级架构中任何一层的测试。

l          撰写JUnit测试所费不多。

使用Junit测试框架,你可以很便宜的撰写测试并享受由测试框架所提供的信心。撰写一个测试就像写一个方法一样简单;测试是检验要测试的程序代码并定义期望的结果。这个测试框架提供自动执行测试的背景;这个背景并成为其它测试集合的一部份。在测试少量的投资将持续让你从时间及品质中获得回收。

l          JUnit测试提升软件的稳定性。

你写的测试愈少;你的程序代码变的愈不稳定。测试使得软件稳定并逐步累积信心;因为任何变动不会造成涟漪效应而漫及整个软件。测试可以形成软件的完整结构的胶结。

l          JUnit测试是开发者测试。

JUnit 测试是高度区域性(localized)测试;用以改善开发者的生产力及程序代码品质。不像功能测试(function test)视系统为一个黑箱以确认软件整体的工作性为主,单元测试是由内而外测试系统基础的建构区块。开发者撰写并拥有JUnit测试。每当一个开发反复(iteration)完成,这个测试便包裹成为交付软件的一部份 提供一种沟通的方式,「这是我交付的软件并且是通过测试的。」

l          JUnit测试是以Java写成的。

使用Java测试Java软件形成一个介于测试及程序代码间的无缝(seamless)边界。在测试的控制下测试变成整个软件的扩充同时程序代码可以被重整。Java编译器的单元测试静态语法检查可已帮助测试程序并且确认遵守软件接口的约定。
一段测试的程序代码无法单独的执行,它需要是执行环境的一部份。同时,它需要自动执行的单元测试--譬如在系统中周期性的执行所有的测试以证明没有任何东西被破坏。由于单元测试需要符合特定的准则:一个成功的测试不应该是人工检查的(那可要到天荒地老了啊),一个未通过测试的失败应可以产出文件以供诊断修改。而Junit可以提供给我们这些便利.。这样所有测试开发者所需撰写的只是测试码本身了。跟optimizeit、Jtest那些昂贵而又超级麻烦的 tool比较起来,其利昭然可见!


我用的eclipse 3.1.2,其中就包含了Junit,可以直接使用了.

给出一个简单的测试实例
HelloWorld.java

public class HelloWorld {

    public HelloWorld() {
        super();
        // TODO Auto-generated constructor stub
    }
    public String say()
    {
        return "Hello World!";
    }
    /**
     * @param args
     */
    public static void main(String[] args) {
        // TODO Auto-generated method stub

    }

}


TestHelloWorld.java

import junit.framework.TestCase;

public class TestHelloWorld extends TestCase {
   
    public TestHelloWorld(String name)
    {
            super(name);
        }

        public void testSay() {
           HelloWorld hi = new HelloWorld();
            assertEquals("Hello World!", hi.say());

        }

        public static void main(String[] args) {

            junit.textui.TestRunner.run(TestHelloWorld.class);

        }

    }
分享到:
评论

相关推荐

    junit单元测试jar包集

    这里提到的四个文件是Java开发中常用的单元测试框架和库,分别是JUnit、DBUnit、Unitils和Mockito。让我们逐一深入探讨它们的功能和使用方法。 **JUnit** 是Java领域中最广泛使用的单元测试框架,这里的`junit-4.11...

    junit单元测试使用方法(实例)

    ### JUnit单元测试使用方法详解 #### 一、JUnit简介及意义 JUnit 是一个流行的 Java 编程语言的单元测试框架。它最初由 Erich Gamma 和 Kent Beck 创建,旨在简化软件开发过程中的测试工作。单元测试是软件开发...

    JUnit单元测试原则 单元测试工具

    ### JUnit单元测试原则与工具详解 #### 一、单元测试概述 单元测试(Unit Testing)是一种软件测试方法,主要用于验证程序中的最小可测试单元(通常是单个函数或方法)是否按预期工作。对于Java这样的面向对象语言来...

    JUnit单元测试技术

    JUnit是Java编程语言中最常用的单元测试框架之一,它允许开发者编写可重复运行的测试用例,以确保代码的正确性和稳定性。本节将深入探讨JUnit的核心概念、使用方法以及其在实际开发中的重要性。 首先,我们要理解...

    junit单元测试相关jar包.zip

    《深入理解Junit单元测试与相关工具包》 在软件开发过程中,单元测试是不可或缺的一环,它能够帮助我们确保代码的质量,及时发现并修复问题。Junit作为Java领域最常用的单元测试框架,极大地简化了测试工作。本资源...

    什么是 junit单元测试,及其作用.md

    JUnit单元测试是Java编程语言的一个开源测试框架,它为开发人员提供了一种编写和执行可重复的自动化测试的方法,目的是验证代码中各个可测试单元(通常是一个类或方法)的正确性。单元测试在软件开发中起着至关重要...

    junit 单元测试

    下面将详细介绍JUnit单元测试的相关知识点。 1. **JUnit框架基础** - JUnit是Java编程语言中最常用的单元测试框架,它提供了编写和运行可重复测试的结构。 - JUnit的核心概念包括测试类、测试方法、注解和断言。...

    JUnit单元测试原则和步骤1

    本文将详细探讨JUnit单元测试的原则和步骤,以及如何利用JUnit进行有效的单元测试。 首先,我们要理解单元测试的核心原则。在Java开发中,一个单元通常指的是一个独立的类或方法。以下是一些重要的单元测试原则: ...

    Ant+Junit+Svn实现自动单元测试

    【Ant+JUnit+Svn实现自动单元测试】 Ant是一种流行的Java构建工具,它使用XML格式的构建文件(build.xml)来定义一系列的任务,如编译、打包、测试等,以自动化软件开发过程。Ant的主要优点是它的灵活性和可扩展性...

    单元测试之道Java版-使用JUnit

    《单元测试之道Java版-使用JUnit》是一本深入讲解如何在Java开发中运用JUnit进行单元测试的专业指南。单元测试是软件开发过程中的重要环节,它能够确保代码的正确性、可维护性和稳定性。JUnit作为Java领域最流行的...

    Junit 测试简单代码

    JUnit是Java编程语言中最常用的单元测试框架之一,它允许开发者编写可执行的测试用例来验证代码的功能。单元测试是对程序中的最小可测试单元进行检查和验证,通常是单个方法。JUnit提供了一套断言库,可以判断预期...

    基于Feed4JUnit架构的单元测试技术研究与应用.docx

    3. Junit单元测试框架 JUnit是由Erich Gamma和Kent Beck创建的,它是一个用于编写和执行自动化测试的框架,特别适用于白盒测试。JUnit的测试基于TestCase类,通过继承这个类并覆盖特定的方法来创建测试用例。测试...

    eclipse下利用ant、junit进行自动化测试例子源码

    本示例主要展示了如何在Eclipse集成开发环境中利用ANT构建工具和JUnit单元测试框架进行自动化测试。以下是关于这些知识点的详细说明: 1. **Eclipse IDE**:Eclipse是一款流行的开源Java开发环境,支持多种语言的...

    Struts2SpringUnitDemo单元测试

    JUnit是Java中最常用的单元测试框架,可以用于编写和运行测试用例。在Struts2SpringUnitDemo中,可能使用了JUnit来测试Action和Service类,确保它们的功能正确无误。 4. **Action和Service的测试**:在Struts2中,...

    Junit5.zip

    JUnit5是Java编程语言中最流行的单元测试框架之一,它的最新版本带来了许多改进和新特性,使得测试更加高效和灵活。本资源包含的`junit5.jar`是JUnit5的运行库,可以用于运行使用JUnit5编写的测试用例。而`junit5-...

    软件测试winrunner loadrunner junit

    这三款工具在软件测试领域中各有所长,WinRunner适用于功能测试,LoadRunner擅长性能测试,而JUnit则是单元测试的首选。它们的结合使用,能够覆盖从代码质量验证到系统整体性能评估的全方位测试需求。在实际工作中,...

    对基于Junit的测试代码自动化生成的研究

    Junit是Java编程语言中最常用的单元测试框架,它为开发者提供了编写和运行可重复的测试用例的工具。自动化测试代码生成是提高开发效率和确保软件质量的关键步骤,通过这种方式,可以减少手动编写测试代码的工作量,...

    Java单元测试Java单元测试Java单元测试Java单元测试

    Java单元测试是软件开发过程中的...理解并熟练运用这些Java单元测试的知识点,对于提升软件质量和开发效率具有重要意义。在实际工作中,根据项目需求选择合适的测试策略和工具,可以有效地保证代码的质量和可维护性。

    JUnit in Action中文版.

    JUnit是Java领域最广泛使用的单元测试框架,它简化了编写、运行和分析测试用例的过程,对于保证代码质量、提升开发效率具有重要意义。 本书首先介绍了单元测试的概念和重要性,解释了为何要在软件开发中引入测试...

Global site tag (gtag.js) - Google Analytics