JUnit多线程Test

    今天测试SimpleDateFormat时用到多线程,但最初Junit并不理想,Mark一下。

     Junit多线程测试如下,直接run会发现程序没有任何异常,但debug时SimpleDateFormatUtil却ParseException异常,说明Junit在多线程下Test是有bug的。【SimpleDateFormatUtil为Date解析工具类】

@Test

public void threadTest() {

        for (int i = 0; i < 3; i++) {

            new SimpleThread().start();

        }

    }

private static class SimpleThread extends Thread {

        @Override

        public void run() {

            try {

                System.out.println(this.getName() + ":" + SimpleDateFormatUtil.parse("2015-12-23 15:00:00"));

            catch (ParseException e) {

                e.printStackTrace();

            }

        }

    }

        在多线程环境下,程序退出的条件是,所有的非Daemon线程都正常结束或者某个线程条用了system.exit方法,导致进程强行退出。
JunitCore类的main函数如下:

public static transient void main(String args[]){

        runMainAndExit(new RealSystem(), args);

    }

private static transient void runMainAndExit(JUnitSystem system, String args[]){

        Result result = (new JUnitCore()).runMain(system, args);

        System.exit(result.wasSuccessful() ? 0 : 1);

    }

很明显,其调用了System.exit函数,将导致线程结束,而多线程甚至都来不及运行。

那么,我们该如何在多线程先进行Junit测试呢?【用main函数测试也是OK的】

@Test

public void threadTest() throws Throwable {

        TestRunnable[] testRunnables = new TestRunnable[NUM_THREAD];

        for (int i = 0; i < testRunnables.lengthi++) {

            testRunnables[i] = new SimpleThread();

        }

        final MultiThreadedTestRunner multiThreadedTestRunner = new MultiThreadedTestRunner(testRunnables);

        multiThreadedTestRunner.runTestRunnables();

    }

 

private static class SimpleThread extends TestRunnable {

        @Override

        public void runTest() {

            try {

                System.out.println(this.toString() + ":" + SimpleDateFormatUtil.parse("2015-12-23 15:00:00"));

          // System.out.println(this.toString()); // 正常输出所有线程名

            catch (ParseException e) {

                e.printStackTrace();

            }

        }

    }

欢迎个人转载,但须在文章页面明显位置给出原文连接;
未经作者同意必须保留此段声明、不得随意修改原文、不得用于商业用途,否则保留追究法律责任的权利。

【 CSDN 】:csdn.zxiaofan.com
【GitHub】:github.zxiaofan.com

如有任何问题,欢迎留言。祝君好运!
Life is all about choices! 
将来的你一定会感激现在拼命的自己!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值