JUnit多线程Test

简介: <div style="font-family:微软雅黑; font-size:14px; line-height:21px"> <p style="margin-top:5px; margin-bottom:5px; background-color:inherit"><span lang="EN-US" style="background-color:inherit; color:r

    今天测试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();

            }

        }

    }


目录
相关文章
|
Java 测试技术 Android开发
Junit - 期望异常测试(Expected Test)
Junit - 期望异常测试(Expected Test)
1213 0
|
11月前
Junit报错java.lang.Exception: No tests found matching [{ExactMatcher:fDisplayName=test]的解决
Junit报错java.lang.Exception: No tests found matching [{ExactMatcher:fDisplayName=test]的解决
77 0
导入了Junit依赖,但@Test注解依然爆红~
导入了Junit依赖,但@Test注解依然爆红~
138 0
|
编解码 Java 测试技术
日期类--JUnit--多线程基础--互斥锁
日期类--JUnit--多线程基础--互斥锁
82 0
|
IDE Java Maven
java: 程序包org.junit不存在,无法通过Test测试
IDEA Error: java: 程序包org.junit不存在,无法通过Test测试
2828 0
java: 程序包org.junit不存在,无法通过Test测试
|
Java Spring
第四篇:SpringBoot如何整合Junit -- @SpringBootTest + @Test
第四篇:SpringBoot如何整合Junit -- @SpringBootTest + @Test
232 0
第四篇:SpringBoot如何整合Junit -- @SpringBootTest + @Test
|
Java 测试技术 数据库
Junit - 优先级测试(FixMethodOrder Test)
Junit - 优先级测试(FixMethodOrder Test)
364 0
Junit - 优先级测试(FixMethodOrder Test)
|
测试技术 Android开发
Junit - 超时测试(Timeout Test)
Junit - 超时测试(Timeout Test)
358 0
Junit - 超时测试(Timeout Test)
|
测试技术 Android开发
Junit - 忽略测试(Ignore Test)
Junit - 忽略测试(Ignore Test)
645 0
Junit - 忽略测试(Ignore Test)
|
测试技术 Android开发
Junit - 套件测试(Suite Test)
Junit - 套件测试(Suite Test)
232 0
Junit - 套件测试(Suite Test)