日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

surefire 拉起 junit 单元测试类 源码阅读(一)

發布時間:2023/12/19 编程问答 44 豆豆
生活随笔 收集整理的這篇文章主要介紹了 surefire 拉起 junit 单元测试类 源码阅读(一) 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

根據surefire 拉起Junit單元測試類 輸出的報錯日志 跟蹤執行過程:

日志1:

java.lang.reflect.InvocationTargetExceptionat sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)at java.lang.reflect.Method.invoke(Method.java:606)at ut.com.suning.common.UnitTestHelper.invokPrivate(UnitTestHelper.java:36)at ut.com.suning.scus.web.controller.OverSeaPlantStoreControllerTest.testImportData(OverSeaPlantStoreControllerTest.java:224)at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)at java.lang.reflect.Method.invoke(Method.java:606)at org.junit.runners.model.FrameworkMethod$1.runReflectiveCall(FrameworkMethod.java:45)at org.junit.internal.runners.model.ReflectiveCallable.run(ReflectiveCallable.java:15)at org.junit.runners.model.FrameworkMethod.invokeExplosively(FrameworkMethod.java:42)at org.junit.internal.runners.statements.InvokeMethod.evaluate(InvokeMethod.java:20)at org.junit.internal.runners.statements.RunBefores.evaluate(RunBefores.java:28)at org.powermock.modules.junit4.rule.PowerMockStatement.evaluate(PowerMockRule.java:63)at org.junit.rules.ExpectedException$ExpectedExceptionStatement.evaluate(ExpectedException.java:110)at org.junit.rules.RunRules.evaluate(RunRules.java:18)at org.junit.runners.ParentRunner.runLeaf(ParentRunner.java:263)at org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:68)at org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:47)at org.junit.runners.ParentRunner$3.run(ParentRunner.java:231)at org.junit.runners.ParentRunner$1.schedule(ParentRunner.java:60)at org.junit.runners.ParentRunner.runChildren(ParentRunner.java:229)at org.junit.runners.ParentRunner.access$000(ParentRunner.java:50)at org.junit.runners.ParentRunner$2.evaluate(ParentRunner.java:222)at org.junit.runners.ParentRunner.run(ParentRunner.java:300)at org.apache.maven.surefire.junit4.JUnit4Provider.execute(JUnit4Provider.java:283)at org.apache.maven.surefire.junit4.JUnit4Provider.executeWithRerun(JUnit4Provider.java:173)at org.apache.maven.surefire.junit4.JUnit4Provider.executeTestSet(JUnit4Provider.java:153)at org.apache.maven.surefire.junit4.JUnit4Provider.invoke(JUnit4Provider.java:128)at org.apache.maven.surefire.booter.ForkedBooter.invokeProviderInSameClassLoader(ForkedBooter.java:203)at org.apache.maven.surefire.booter.ForkedBooter.runSuitesInProcess(ForkedBooter.java:155)at org.apache.maven.surefire.booter.ForkedBooter.main(ForkedBooter.java:103) Caused by: com.suning.framework.exception.BaseException: java.lang.IllegalArgumentException: [Assertion failed] - this argument is required; it must not be nullat com.suning.scus.web.controller.OverSeaPlantStoreController.importData(OverSeaPlantStoreController.java:239)... 34 more Caused by: java.lang.IllegalArgumentException: [Assertion failed] - this argument is required; it must not be nullat org.springframework.util.Assert.notNull(Assert.java:112)at org.springframework.util.Assert.notNull(Assert.java:123)at com.suning.scus.admin.util.ReadExcelUtils.readTitle(ReadExcelUtils.java:71)at com.suning.scus.web.controller.OverSeaPlantStoreController.importData(OverSeaPlantStoreController.java:221)... 34 more

它的主pom的依賴和日志3一樣,但是這個module中沒有使用testng:

<dependency><groupId>org.testng</groupId><artifactId>testng</artifactId><version>${testng.version}</version><scope>test</scope></dependency><dependency><groupId>org.powermock</groupId><artifactId>powermock-api-mockito</artifactId><version>${powermock.version}</version><scope>test</scope></dependency><dependency><groupId>org.powermock</groupId><artifactId>powermock-core</artifactId><version>${powermock.version}</version><scope>test</scope></dependency><dependency><groupId>org.powermock</groupId><artifactId>powermock-module-testng</artifactId><version>${powermock.version}</version><scope>test</scope></dependency><dependency><groupId>org.powermock</groupId><artifactId>powermock-module-junit4-rule-agent</artifactId><version>${powermock.version}</version><scope>test</scope></dependency><dependency><groupId>org.powermock</groupId><artifactId>powermock-module-junit4</artifactId><version>${powermock.version}</version><scope>test</scope></dependency><dependency><groupId>org.hamcrest</groupId><artifactId>hamcrest-all</artifactId><version>1.3</version></dependency><dependency><groupId>org.springframework</groupId><artifactId>spring-test</artifactId><version>${spring-version}</version><scope>test</scope></dependency><dependency><groupId>org.testng</groupId><artifactId>testng</artifactId><version>${testng.version}</version><scope>test</scope></dependency>

日志2:

java.lang.instrument.IllegalClassFormatException: Error while instrumenting class com/suning/epp/sws/fundrecharge/esb/impl/FundResultCallbackBizImpl$1.at org.jacoco.agent.rt.internal_6da5971.CoverageTransformer.transform(CoverageTransformer.java:93)at sun.instrument.TransformerManager.transform(TransformerManager.java:169)at sun.instrument.InstrumentationImpl.transform(InstrumentationImpl.java:365)at java.lang.ClassLoader.defineClass1(Native Method)at java.lang.ClassLoader.defineClassCond(ClassLoader.java:631)at java.lang.ClassLoader.defineClass(ClassLoader.java:615)at java.security.SecureClassLoader.defineClass(SecureClassLoader.java:141)at java.net.URLClassLoader.defineClass(URLClassLoader.java:283)at java.net.URLClassLoader.access$000(URLClassLoader.java:58)at java.net.URLClassLoader$1.run(URLClassLoader.java:197)at java.security.AccessController.doPrivileged(Native Method)at java.net.URLClassLoader.findClass(URLClassLoader.java:190)at java.lang.ClassLoader.loadClass(ClassLoader.java:306)at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:301)at java.lang.ClassLoader.loadClass(ClassLoader.java:247)at com.suning.epp.sws.fundrecharge.esb.impl.FundResultCallbackBizImpl.callback(FundResultCallbackBizImpl.java:47)at com.suning.epp.sws.fundwithdraw.FundWithdrawResultListenersTest.testFundHandleTest(FundWithdrawResultListenersTest.java:66)at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)at java.lang.reflect.Method.invoke(Method.java:597)at org.junit.runners.model.FrameworkMethod$1.runReflectiveCall(FrameworkMethod.java:44)at org.junit.internal.runners.model.ReflectiveCallable.run(ReflectiveCallable.java:15)at org.junit.runners.model.FrameworkMethod.invokeExplosively(FrameworkMethod.java:41)at org.junit.internal.runners.statements.InvokeMethod.evaluate(InvokeMethod.java:20)at org.springframework.test.context.junit4.statements.RunBeforeTestMethodCallbacks.evaluate(RunBeforeTestMethodCallbacks.java:74)at org.springframework.test.context.junit4.statements.RunAfterTestMethodCallbacks.evaluate(RunAfterTestMethodCallbacks.java:83)at org.springframework.test.context.junit4.statements.SpringRepeat.evaluate(SpringRepeat.java:72)at org.springframework.test.context.junit4.SpringJUnit4ClassRunner.runChild(SpringJUnit4ClassRunner.java:231)at org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:50)at org.junit.runners.ParentRunner$3.run(ParentRunner.java:193)at org.junit.runners.ParentRunner$1.schedule(ParentRunner.java:52)at org.junit.runners.ParentRunner.runChildren(ParentRunner.java:191)at org.junit.runners.ParentRunner.access$000(ParentRunner.java:42)at org.junit.runners.ParentRunner$2.evaluate(ParentRunner.java:184)at org.springframework.test.context.junit4.statements.RunBeforeTestClassCallbacks.evaluate(RunBeforeTestClassCallbacks.java:61)at org.springframework.test.context.junit4.statements.RunAfterTestClassCallbacks.evaluate(RunAfterTestClassCallbacks.java:71)at org.junit.runners.ParentRunner.run(ParentRunner.java:236)at org.springframework.test.context.junit4.SpringJUnit4ClassRunner.run(SpringJUnit4ClassRunner.java:174)at org.apache.maven.surefire.junit4.JUnit4Provider.execute(JUnit4Provider.java:367)at org.apache.maven.surefire.junit4.JUnit4Provider.executeWithRerun(JUnit4Provider.java:274)at org.apache.maven.surefire.junit4.JUnit4Provider.executeTestSet(JUnit4Provider.java:238)at org.apache.maven.surefire.junit4.JUnit4Provider.invoke(JUnit4Provider.java:161)at org.apache.maven.surefire.booter.ForkedBooter.invokeProviderInSameClassLoader(ForkedBooter.java:290)at org.apache.maven.surefire.booter.ForkedBooter.runSuitesInProcess(ForkedBooter.java:242)at org.apache.maven.surefire.booter.ForkedBooter.main(ForkedBooter.java:121) Caused by: java.io.IOException: Error while instrumenting class com/suning/epp/sws/fundrecharge/esb/impl/FundResultCallbackBizImpl$1.at org.jacoco.agent.rt.internal_6da5971.core.instr.Instrumenter.instrumentError(Instrumenter.java:160)at org.jacoco.agent.rt.internal_6da5971.core.instr.Instrumenter.instrument(Instrumenter.java:111)at org.jacoco.agent.rt.internal_6da5971.CoverageTransformer.transform(CoverageTransformer.java:91)... 45 more Caused by: java.lang.IllegalStateException: Class com/suning/epp/sws/fundrecharge/esb/impl/FundResultCallbackBizImpl$1 is already instrumented.at org.jacoco.agent.rt.internal_6da5971.core.internal.instr.InstrSupport.assertNotInstrumented(InstrSupport.java:89)at org.jacoco.agent.rt.internal_6da5971.core.internal.instr.ClassInstrumenter.visitField(ClassInstrumenter.java:55)at org.jacoco.agent.rt.internal_6da5971.asm.ClassVisitor.visitField(ClassVisitor.java:272)at org.jacoco.agent.rt.internal_6da5971.asm.ClassReader.readField(ClassReader.java:768)at org.jacoco.agent.rt.internal_6da5971.asm.ClassReader.accept(ClassReader.java:689)at org.jacoco.agent.rt.internal_6da5971.asm.ClassReader.accept(ClassReader.java:506)at org.jacoco.agent.rt.internal_6da5971.core.instr.Instrumenter.instrument(Instrumenter.java:84)at org.jacoco.agent.rt.internal_6da5971.core.instr.Instrumenter.instrument(Instrumenter.java:108)... 46 more

日志3:testng和junit混合使用,junit編寫測試類,testng xml聲明測試參數,但是testng是在主pom中聲明的:

java.lang.reflect.InvocationTargetExceptionat sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)at java.lang.reflect.Method.invoke(Method.java:606)at ut.com.suning.common.UnitTestHelper.invokPrivate(UnitTestHelper.java:36)at ut.com.suning.scus.common.rule.PublicRuleUtilsTest.testTransToMdmCityCode(PublicRuleUtilsTest.java:632)at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)at java.lang.reflect.Method.invoke(Method.java:606)at org.junit.runners.model.FrameworkMethod$1.runReflectiveCall(FrameworkMethod.java:45)at org.junit.internal.runners.model.ReflectiveCallable.run(ReflectiveCallable.java:15)at org.junit.runners.model.FrameworkMethod.invokeExplosively(FrameworkMethod.java:42)at org.junit.internal.runners.statements.InvokeMethod.evaluate(InvokeMethod.java:20)at org.junit.internal.runners.statements.RunBefores.evaluate(RunBefores.java:28)at org.powermock.modules.junit4.rule.PowerMockStatement.evaluate(PowerMockRule.java:63)at org.junit.rules.ExpectedException$ExpectedExceptionStatement.evaluate(ExpectedException.java:110)at org.junit.rules.RunRules.evaluate(RunRules.java:18)at org.junit.runners.ParentRunner.runLeaf(ParentRunner.java:263)at org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:68)at org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:47)at org.junit.runners.ParentRunner$3.run(ParentRunner.java:231)at org.junit.runners.ParentRunner$1.schedule(ParentRunner.java:60)at org.junit.runners.ParentRunner.runChildren(ParentRunner.java:229)at org.junit.runners.ParentRunner.access$000(ParentRunner.java:50)at org.junit.runners.ParentRunner$2.evaluate(ParentRunner.java:222)at org.junit.runners.ParentRunner.run(ParentRunner.java:300)at org.junit.runner.JUnitCore.run(JUnitCore.java:157)at org.junit.runner.JUnitCore.run(JUnitCore.java:136)at org.testng.junit.JUnit4TestRunner.start(JUnit4TestRunner.java:81)at org.testng.junit.JUnit4TestRunner.run(JUnit4TestRunner.java:69)at org.testng.TestRunner$1.run(TestRunner.java:682)at org.testng.TestRunner.runWorkers(TestRunner.java:1005)at org.testng.TestRunner.privateRunJUnit(TestRunner.java:713)at org.testng.TestRunner.run(TestRunner.java:614)at org.testng.SuiteRunner.runTest(SuiteRunner.java:348)at org.testng.SuiteRunner.runSequentially(SuiteRunner.java:343)at org.testng.SuiteRunner.privateRun(SuiteRunner.java:305)at org.testng.SuiteRunner.run(SuiteRunner.java:254)at org.testng.SuiteRunnerWorker.runSuite(SuiteRunnerWorker.java:52)at org.testng.SuiteRunnerWorker.run(SuiteRunnerWorker.java:86)at org.testng.TestNG.runSuitesSequentially(TestNG.java:1224)at org.testng.TestNG.runSuitesLocally(TestNG.java:1149)at org.testng.TestNG.run(TestNG.java:1057)at org.apache.maven.surefire.testng.TestNGExecutor.run(TestNGExecutor.java:115)at org.apache.maven.surefire.testng.TestNGDirectoryTestSuite.executeMulti(TestNGDirectoryTestSuite.java:212)at org.apache.maven.surefire.testng.TestNGDirectoryTestSuite.execute(TestNGDirectoryTestSuite.java:108)at org.apache.maven.surefire.testng.TestNGProvider.invoke(TestNGProvider.java:111)at org.apache.maven.surefire.booter.ForkedBooter.invokeProviderInSameClassLoader(ForkedBooter.java:203)at org.apache.maven.surefire.booter.ForkedBooter.runSuitesInProcess(ForkedBooter.java:155)at org.apache.maven.surefire.booter.ForkedBooter.main(ForkedBooter.java:103) Caused by: java.lang.NullPointerExceptionat com.suning.scus.common.rule.PublicRuleUtils.transToMdmCityCode(PublicRuleUtils.java:161)at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)at java.lang.reflect.Method.invoke(Method.java:606)at org.powermock.api.mockito.internal.invocation.MockitoMethodInvocationControl$1.invoke(MockitoMethodInvocationControl.java:242)at org.powermock.api.mockito.internal.invocation.MockitoMethodInvocationControl.performIntercept(MockitoMethodInvocationControl.java:260)at org.powermock.api.mockito.internal.invocation.MockitoMethodInvocationControl.invoke(MockitoMethodInvocationControl.java:192)at org.powermock.core.MockGateway.doMethodCall(MockGateway.java:124)at org.powermock.core.MockGateway.methodCall(MockGateway.java:63)at com.suning.scus.common.rule.PublicRuleUtils.transToMdmCityCode(PublicRuleUtils.java)... 51 more

pom文件聲明依賴有testng,junit,springtest,powermock-junit-rule,等

之所以混用,是因為需要使用testng聲明xml,在xml中添加參數:

<!DOCTYPE suite SYSTEM "http://testng.org/testng-1.0.dtd" ><suite name="Suite1" verbose="1"><test name="appMoudle1"><classes></classes></test><!-- <test name="appMoudle2"><parameter name="dataSetFile" value="/dataset/dataset-module2.xml" /><classes><class name="com.framework.test.DbInitializer" /><class name="com.sample.UserTest" /></classes></test> --></suite>

<dependency><groupId>junit</groupId><artifactId>junit</artifactId><version>4.10</version><scope>test</scope></dependency><dependency><groupId>org.testng</groupId><artifactId>testng</artifactId><version>${testng.version}</version><scope>test</scope></dependency><dependency><groupId>org.powermock</groupId><artifactId>powermock-api-mockito</artifactId><version>${powermock.version}</version><scope>test</scope></dependency><dependency><groupId>org.powermock</groupId><artifactId>powermock-core</artifactId><version>${powermock.version}</version><scope>test</scope></dependency><dependency><groupId>org.powermock</groupId><artifactId>powermock-module-testng</artifactId><version>${powermock.version}</version><scope>test</scope></dependency><dependency><groupId>org.powermock</groupId><artifactId>powermock-module-junit4-rule-agent</artifactId><version>${powermock.version}</version><scope>test</scope></dependency><dependency><groupId>org.powermock</groupId><artifactId>powermock-module-junit4</artifactId><version>${powermock.version}</version><scope>test</scope></dependency><dependency><groupId>org.hamcrest</groupId><artifactId>hamcrest-all</artifactId><version>1.3</version></dependency><dependency><groupId>org.springframework</groupId><artifactId>spring-test</artifactId><version>${spring-version}</version><scope>test</scope></dependency>

根據日志1進行源碼閱讀跟蹤:

ForkedBooter代碼:

public final class ForkedBooter {private static final long SYSTEM_EXIT_TIMEOUT_IN_SECONDS = 30;private static final long PING_TIMEOUT_IN_SECONDS = 20;private static final ScheduledExecutorService JVM_TERMINATOR = createJvmTerminator();/*** This method is invoked when Surefire is forked - this method parses and organizes the arguments passed to it and* then calls the Surefire class' run method. <p/> The system exit code will be 1 if an exception is thrown.** @param args Commandline arguments*/public static void main( String... args ){final CommandReader reader = startupMasterProcessReader();final ScheduledFuture<?> pingScheduler = listenToShutdownCommands( reader );final PrintStream originalOut = System.out;try{if ( args.length > 1 ){SystemPropertyManager.setSystemProperties( new File( args[1] ) );}File surefirePropertiesFile = new File( args[0] );InputStream stream = surefirePropertiesFile.exists() ? new FileInputStream( surefirePropertiesFile ) : null;BooterDeserializer booterDeserializer = new BooterDeserializer( stream );ProviderConfiguration providerConfiguration = booterDeserializer.deserialize();final StartupConfiguration startupConfiguration = booterDeserializer.getProviderConfiguration();TypeEncodedValue forkedTestSet = providerConfiguration.getTestForFork();boolean readTestsFromInputStream = providerConfiguration.isReadTestsFromInStream();final ClasspathConfiguration classpathConfiguration = startupConfiguration.getClasspathConfiguration();if ( startupConfiguration.isManifestOnlyJarRequestedAndUsable() ){classpathConfiguration.trickClassPathWhenManifestOnlyClasspath();}ClassLoader classLoader = Thread.currentThread().getContextClassLoader();classLoader.setDefaultAssertionStatus( classpathConfiguration.isEnableAssertions() );startupConfiguration.writeSurefireTestClasspathProperty();final Object testSet;if ( forkedTestSet != null ){testSet = forkedTestSet.getDecodedValue( classLoader );}else if ( readTestsFromInputStream ){testSet = new LazyTestsToRun( originalOut );}else{testSet = null;}try{runSuitesInProcess( testSet, startupConfiguration, providerConfiguration, originalOut );}catch ( InvocationTargetException t ){LegacyPojoStackTraceWriter stackTraceWriter =new LegacyPojoStackTraceWriter( "test subystem", "no method", t.getTargetException() );StringBuilder stringBuilder = new StringBuilder();encode( stringBuilder, stackTraceWriter, false );encodeAndWriteToOutput( ( (char) BOOTERCODE_ERROR ) + ",0," + stringBuilder + "\n" , originalOut );}catch ( Throwable t ){StackTraceWriter stackTraceWriter = new LegacyPojoStackTraceWriter( "test subystem", "no method", t );StringBuilder stringBuilder = new StringBuilder();encode( stringBuilder, stackTraceWriter, false );encodeAndWriteToOutput( ( (char) BOOTERCODE_ERROR ) + ",0," + stringBuilder + "\n", originalOut );}// Say bye.encodeAndWriteToOutput( ( (char) BOOTERCODE_BYE ) + ",0,BYE!\n", originalOut );originalOut.flush();// noinspection CallToSystemExitexit( 0, EXIT, reader, false );}catch ( Throwable t ){// Just throwing does getMessage() and a local trace - we want to call printStackTrace for a full trace// noinspection UseOfSystemOutOrSystemErrt.printStackTrace( System.err );// noinspection ProhibitedExceptionThrown,CallToSystemExitexit( 1, EXIT, reader, false );}finally{pingScheduler.cancel( true );}}private static CommandReader startupMasterProcessReader(){return CommandReader.getReader();}private static ScheduledFuture<?> listenToShutdownCommands( CommandReader reader ){reader.addShutdownListener( createExitHandler( reader ) );AtomicBoolean pingDone = new AtomicBoolean( true );reader.addNoopListener( createPingHandler( pingDone ) );return JVM_TERMINATOR.scheduleAtFixedRate( createPingJob( pingDone, reader ),0, PING_TIMEOUT_IN_SECONDS, SECONDS );}private static CommandListener createPingHandler( final AtomicBoolean pingDone ){return new CommandListener(){public void update( Command command ){pingDone.set( true );}};}private static CommandListener createExitHandler( final CommandReader reader ){return new CommandListener(){public void update( Command command ){exit( 1, command.toShutdownData(), reader, true );}};}private static Runnable createPingJob( final AtomicBoolean pingDone, final CommandReader reader ){return new Runnable(){public void run(){boolean hasPing = pingDone.getAndSet( false );if ( !hasPing ){exit( 1, KILL, reader, true );}}};}private static void encodeAndWriteToOutput( String string, PrintStream out ){byte[] encodeBytes = encodeStringForForkCommunication( string );out.write( encodeBytes, 0, encodeBytes.length );}private static void exit( int returnCode, Shutdown shutdownType, CommandReader reader, boolean stopReaderOnExit ){switch ( shutdownType ){case KILL:Runtime.getRuntime().halt( returnCode );case EXIT:if ( stopReaderOnExit ){reader.stop();}launchLastDitchDaemonShutdownThread( returnCode );System.exit( returnCode );case DEFAULT:// refers to shutdown=testset, but not used now, keeping reader opendefault:break;}}private static RunResult runSuitesInProcess( Object testSet, StartupConfiguration startupConfiguration,ProviderConfiguration providerConfiguration,PrintStream originalSystemOut )throws SurefireExecutionException, TestSetFailedException, InvocationTargetException{final ReporterFactory factory = createForkingReporterFactory( providerConfiguration, originalSystemOut );return invokeProviderInSameClassLoader( testSet, factory, providerConfiguration, true, startupConfiguration,false );}private static ReporterFactory createForkingReporterFactory( ProviderConfiguration providerConfiguration,PrintStream originalSystemOut ){final boolean trimStackTrace = providerConfiguration.getReporterConfiguration().isTrimStackTrace();return SurefireReflector.createForkingReporterFactoryInCurrentClassLoader( trimStackTrace, originalSystemOut );}private static ScheduledExecutorService createJvmTerminator(){ThreadFactory threadFactory = newDaemonThreadFactory( "last-ditch-daemon-shutdown-thread-"+ SYSTEM_EXIT_TIMEOUT_IN_SECONDS+ "sec" );ScheduledThreadPoolExecutor executor = new ScheduledThreadPoolExecutor( 1, threadFactory );executor.setMaximumPoolSize( 1 );executor.prestartCoreThread();return executor;}@SuppressWarnings( "checkstyle:emptyblock" )private static void launchLastDitchDaemonShutdownThread( final int returnCode ){JVM_TERMINATOR.schedule( new Runnable(){public void run(){Runtime.getRuntime().halt( returnCode );}}, SYSTEM_EXIT_TIMEOUT_IN_SECONDS, SECONDS );}private static RunResult invokeProviderInSameClassLoader( Object testSet, Object factory,ProviderConfiguration providerConfiguration,boolean insideFork,StartupConfiguration startupConfig,boolean restoreStreams )throws TestSetFailedException, InvocationTargetException{final PrintStream orgSystemOut = System.out;final PrintStream orgSystemErr = System.err;// Note that System.out/System.err are also read in the "ReporterConfiguration" instatiation// in createProvider below. These are the same values as here.try{return createProviderInCurrentClassloader( startupConfig, insideFork, providerConfiguration, factory ).invoke( testSet );}finally{if ( restoreStreams && System.getSecurityManager() == null ){System.setOut( orgSystemOut );System.setErr( orgSystemErr );}}}private static SurefireProvider createProviderInCurrentClassloader( StartupConfiguration startupConfiguration1,boolean isInsideFork,ProviderConfiguration providerConfiguration,Object reporterManagerFactory1 ){BaseProviderFactory bpf = new BaseProviderFactory( (ReporterFactory) reporterManagerFactory1, isInsideFork );bpf.setTestRequest( providerConfiguration.getTestSuiteDefinition() );bpf.setReporterConfiguration( providerConfiguration.getReporterConfiguration() );ClassLoader classLoader = Thread.currentThread().getContextClassLoader();bpf.setClassLoaders( classLoader );bpf.setTestArtifactInfo( providerConfiguration.getTestArtifact() );bpf.setProviderProperties( providerConfiguration.getProviderProperties() );bpf.setRunOrderParameters( providerConfiguration.getRunOrderParameters() );bpf.setDirectoryScannerParameters( providerConfiguration.getDirScannerParams() );bpf.setMainCliOptions( providerConfiguration.getMainCliOptions() );bpf.setSkipAfterFailureCount( providerConfiguration.getSkipAfterFailureCount() );bpf.setShutdown( providerConfiguration.getShutdown() );String providerClass = startupConfiguration1.getActualClassName();return (SurefireProvider) ReflectionUtils.instantiateOneArg( classLoader, providerClass, ProviderParameters.class, bpf );} }

ReflectionUtils代碼:

public final class ReflectionUtils {private static final Class[] NO_ARGS = new Class[0];private static final Object[] NO_ARGS_VALUES = new Object[0];private ReflectionUtils(){throw new IllegalStateException("no instantiable constructor");}public static Method getMethod(Object instance, String methodName, Class<?>... parameters){return getMethod(instance.getClass(), methodName, parameters);}public static Method getMethod(Class<?> clazz, String methodName, Class<?>... parameters){try{return clazz.getMethod(methodName, parameters);}catch (NoSuchMethodException e){throw new RuntimeException("When finding method " + methodName, e);}}public static Method tryGetMethod(Class<?> clazz, String methodName, Class<?>... parameters){try{return clazz.getMethod(methodName, parameters);}catch (NoSuchMethodException e) {}return null;}public static Object invokeGetter(Object instance, String methodName){Method method = getMethod(instance, methodName, NO_ARGS);return invokeMethodWithArray(instance, method, NO_ARGS_VALUES);}public static Constructor getConstructor(Class<?> clazz, Class<?>... arguments){try{return clazz.getConstructor(arguments);}catch (NoSuchMethodException e){throw new SurefireReflectionException(e);}}public static Object newInstance(Constructor constructor, Object... params){try{return constructor.newInstance(params);}catch (InvocationTargetException e){throw new SurefireReflectionException(e);}catch (InstantiationException e){throw new SurefireReflectionException(e);}catch (IllegalAccessException e){throw new SurefireReflectionException(e);}}public static <T> T instantiate(ClassLoader classLoader, String classname, Class<T> returnType){try{Class<?> clazz = loadClass(classLoader, classname);return returnType.cast(clazz.newInstance());}catch (InstantiationException e){throw new SurefireReflectionException(e);}catch (IllegalAccessException e){throw new SurefireReflectionException(e);}}public static Object instantiateOneArg(ClassLoader classLoader, String className, Class<?> param1Class, Object param1){try{Class<?> aClass = loadClass(classLoader, className);Constructor constructor = getConstructor(aClass, new Class[] { param1Class });return constructor.newInstance(new Object[] { param1 });}catch (InvocationTargetException e){throw new SurefireReflectionException(e.getTargetException());}catch (InstantiationException e){throw new SurefireReflectionException(e);}catch (IllegalAccessException e){throw new SurefireReflectionException(e);}}public static Object instantiateTwoArgs(ClassLoader classLoader, String className, Class<?> param1Class, Object param1, Class param2Class, Object param2){try{Class<?> aClass = loadClass(classLoader, className);Constructor constructor = getConstructor(aClass, new Class[] { param1Class, param2Class });return constructor.newInstance(new Object[] { param1, param2 });}catch (InvocationTargetException e){throw new SurefireReflectionException(e.getTargetException());}catch (InstantiationException e){throw new SurefireReflectionException(e);}catch (IllegalAccessException e){throw new SurefireReflectionException(e);}}public static void invokeSetter(Object o, String name, Class<?> value1clazz, Object value){Method setter = getMethod(o, name, new Class[] { value1clazz });invokeSetter(o, setter, value);}public static Object invokeSetter(Object target, Method method, Object value){return invokeMethodWithArray(target, method, new Object[] { value });}public static Object invokeMethodWithArray(Object target, Method method, Object... args){try{return method.invoke(target, args);}catch (IllegalAccessException e){throw new SurefireReflectionException(e);}catch (InvocationTargetException e){throw new SurefireReflectionException(e.getTargetException());}}public static Object invokeMethodWithArray2(Object target, Method method, Object... args)throws InvocationTargetException{try{return method.invoke(target, args);}catch (IllegalAccessException e){throw new SurefireReflectionException(e);}}public static Object instantiateObject(String className, Class[] types, Object[] params, ClassLoader classLoader){Class<?> clazz = loadClass(classLoader, className);Constructor constructor = getConstructor(clazz, types);return newInstance(constructor, params);}public static Class<?> tryLoadClass(ClassLoader classLoader, String className){try{return classLoader.loadClass(className);}catch (NoClassDefFoundError localNoClassDefFoundError) {}catch (ClassNotFoundException localClassNotFoundException) {}return null;}public static Class<?> loadClass(ClassLoader classLoader, String className){try{return classLoader.loadClass(className);}catch (NoClassDefFoundError e){throw new SurefireReflectionException(e);}catch (ClassNotFoundException e){throw new SurefireReflectionException(e);}} }
junit和surefire中間調度很重要的代碼是SurefireProvider
public abstract interface SurefireProvider {public abstract Iterable<Class<?>> getSuites();public abstract RunResult invoke(Object paramObject)throws TestSetFailedException, ReporterException, InvocationTargetException;public abstract void cancel(); }

surefire-api 中有一個abstractProvider,起到中間連接的作用:

public abstract class AbstractProviderimplements SurefireProvider {private final Thread creatingThread = Thread.currentThread();public void cancel(){synchronized (this.creatingThread){if (this.creatingThread.isAlive()) {this.creatingThread.interrupt();}}} }

surefire-junit4.jar中有兩個class,一個是JUnit4Provider,一個是TestResolverFilter

public JUnit4Provider( ProviderParameters bootParams ){// don't start a thread in CommandReader while we are in in-plugin processcommandsReader = bootParams.isInsideFork() ? getReader().setShutdown( bootParams.getShutdown() ) : null;providerParameters = bootParams;testClassLoader = bootParams.getTestClassLoader();scanResult = bootParams.getScanResult();runOrderCalculator = bootParams.getRunOrderCalculator();String listeners = bootParams.getProviderProperties().get( "listener" );customRunListeners = unmodifiableCollection( createCustomListeners( listeners ) );jUnit4TestChecker = new JUnit4TestChecker( testClassLoader );TestRequest testRequest = bootParams.getTestRequest();testResolver = testRequest.getTestListResolver();rerunFailingTestsCount = testRequest.getRerunFailingTestsCount();}public RunResult invoke( Object forkTestSet )throws TestSetFailedException{upgradeCheck();ReporterFactory reporterFactory = providerParameters.getReporterFactory();RunResult runResult;try{RunListener reporter = reporterFactory.createReporter();startCapture( (ConsoleOutputReceiver) reporter );// startCapture() called in prior to setTestsToRun()if ( testsToRun == null ){setTestsToRun( forkTestSet );}Notifier notifier = new Notifier( new JUnit4RunListener( reporter ), getSkipAfterFailureCount() );Result result = new Result();notifier.addListeners( customRunListeners ).addListener( result.createListener() );if ( isFailFast() && commandsReader != null ){registerPleaseStopJUnitListener( notifier );}try{notifier.fireTestRunStarted( testsToRun.allowEagerReading()? createTestsDescription( testsToRun ): createDescription( UNDETERMINED_TESTS_DESCRIPTION ) );if ( commandsReader != null ){registerShutdownListener( testsToRun );commandsReader.awaitStarted();}for ( Class<?> testToRun : testsToRun ){executeTestSet( testToRun, reporter, notifier );}}finally{notifier.fireTestRunFinished( result );notifier.removeListeners();}rethrowAnyTestMechanismFailures( result );}finally{runResult = reporterFactory.close();}return runResult;}private void setTestsToRun( Object forkTestSet )throws TestSetFailedException{if ( forkTestSet instanceof TestsToRun ){testsToRun = (TestsToRun) forkTestSet;}else if ( forkTestSet instanceof Class ){testsToRun = fromClass( (Class<?>) forkTestSet );}else{testsToRun = scanClassPath();}}private boolean isRerunFailingTests(){return rerunFailingTestsCount > 0;}private boolean isFailFast(){return providerParameters.getSkipAfterFailureCount() > 0;}private int getSkipAfterFailureCount(){return isFailFast() ? providerParameters.getSkipAfterFailureCount() : 0;}private void registerShutdownListener( final TestsToRun testsToRun ){commandsReader.addShutdownListener( new CommandListener(){public void update( Command command ){testsToRun.markTestSetFinished();}} );}private void registerPleaseStopJUnitListener( final Notifier notifier ){commandsReader.addSkipNextTestsListener( new CommandListener(){public void update( Command command ){notifier.pleaseStop();}} );}private void executeTestSet( Class<?> clazz, RunListener reporter, Notifier notifier ){final ReportEntry report = new SimpleReportEntry( getClass().getName(), clazz.getName() );reporter.testSetStarting( report );try{executeWithRerun( clazz, notifier );}catch ( Throwable e ){if ( isFailFast() && e instanceof StoppedByUserException ){String reason = e.getClass().getName();Description skippedTest = createDescription( clazz.getName(), createIgnored( reason ) );notifier.fireTestIgnored( skippedTest );}else{String reportName = report.getName();String reportSourceName = report.getSourceName();PojoStackTraceWriter stackWriter = new PojoStackTraceWriter( reportSourceName, reportName, e );reporter.testError( withException( reportSourceName, reportName, stackWriter ) );}}finally{reporter.testSetCompleted( report );}}private void executeWithRerun( Class<?> clazz, Notifier notifier )throws TestSetFailedException{JUnitTestFailureListener failureListener = new JUnitTestFailureListener();notifier.addListener( failureListener );boolean hasMethodFilter = testResolver != null && testResolver.hasMethodPatterns();try{try{notifier.asFailFast( isFailFast() );execute( clazz, notifier, hasMethodFilter ? createMethodFilter() : null );}finally{notifier.asFailFast( false );}// Rerun failing tests if rerunFailingTestsCount is larger than 0if ( isRerunFailingTests() ){Notifier rerunNotifier = pureNotifier();notifier.copyListenersTo( rerunNotifier );for ( int i = 0; i < rerunFailingTestsCount && !failureListener.getAllFailures().isEmpty(); i++ ){Set<ClassMethod> failedTests = generateFailingTests( failureListener.getAllFailures() );failureListener.reset();if ( !failedTests.isEmpty() ){executeFailedMethod( rerunNotifier, failedTests );}}}}finally{notifier.removeListener( failureListener );}}public Iterable<Class<?>> getSuites(){testsToRun = scanClassPath();return testsToRun;}private TestsToRun scanClassPath(){final TestsToRun scannedClasses = scanResult.applyFilter( jUnit4TestChecker, testClassLoader );return runOrderCalculator.orderTestClasses( scannedClasses );}private void upgradeCheck()throws TestSetFailedException{if ( isJUnit4UpgradeCheck() ){Collection<Class<?>> classesSkippedByValidation =scanResult.getClassesSkippedByValidation( jUnit4TestChecker, testClassLoader );if ( !classesSkippedByValidation.isEmpty() ){StringBuilder reason = new StringBuilder();reason.append( "Updated check failed\n" );reason.append( "There are tests that would be run with junit4 / surefire 2.6 but not with [2.7,):\n" );for ( Class testClass : classesSkippedByValidation ){reason.append( " " );reason.append( testClass.getName() );reason.append( "\n" );}throw new TestSetFailedException( reason.toString() );}}}static Description createTestsDescription( Iterable<Class<?>> classes ){// "null" string rather than null; otherwise NPE in junit:4.0Description description = createDescription( "null" );for ( Class<?> clazz : classes ){description.addChild( createDescription( clazz.getName() ) );}return description;}private static boolean isJUnit4UpgradeCheck(){return System.getProperty( "surefire.junit4.upgradecheck" ) != null;}private static void execute( Class<?> testClass, Notifier notifier, Filter filter ){final int classModifiers = testClass.getModifiers();if ( !isAbstract( classModifiers ) && !isInterface( classModifiers ) ){Request request = aClass( testClass );if ( filter != null ){request = request.filterWith( filter );}Runner runner = request.getRunner();if ( countTestsInRunner( runner.getDescription() ) != 0 ){runner.run( notifier );}}}private void executeFailedMethod( RunNotifier notifier, Set<ClassMethod> failedMethods )throws TestSetFailedException{for ( ClassMethod failedMethod : failedMethods ){try{Class<?> methodClass = Class.forName( failedMethod.getClazz(), true, testClassLoader );String methodName = failedMethod.getMethod();method( methodClass, methodName ).getRunner().run( notifier );}catch ( ClassNotFoundException e ){throw new TestSetFailedException( "Unable to create test class '" + failedMethod.getClazz() + "'", e );}}}/*** JUnit error: test count includes one test-class as a suite which has filtered out all children.* Then the child test has a description "initializationError0(org.junit.runner.manipulation.Filter)"* for JUnit 4.0 or "initializationError(org.junit.runner.manipulation.Filter)" for JUnit 4.12* and Description#isTest() returns true, but this description is not a real test* and therefore it should not be included in the entire test count.*/private static int countTestsInRunner( Description description ){if ( description.isSuite() ){int count = 0;for ( Description child : description.getChildren() ){if ( !hasFilteredOutAllChildren( child ) ){count += countTestsInRunner( child );}}return count;}else if ( description.isTest() ){return hasFilteredOutAllChildren( description ) ? 0 : 1;}else{return 0;}}private static boolean hasFilteredOutAllChildren( Description description ){String name = description.getDisplayName();// JUnit 4.0: initializationError0; JUnit 4.12: initializationError.if ( name == null ){return true;}else{name = name.trim();return name.startsWith( "initializationError0(org.junit.runner.manipulation.Filter)" )|| name.startsWith( "initializationError(org.junit.runner.manipulation.Filter)" );}}private Filter createMethodFilter(){TestListResolver methodFilter = optionallyWildcardFilter( testResolver );return methodFilter.isEmpty() || methodFilter.isWildcard() ? null : new TestResolverFilter( methodFilter );} }

上述的類中execute方法直接調用的junit中的類Runner:

private static void execute( Class<?> testClass, Notifier notifier, Filter filter ){final int classModifiers = testClass.getModifiers();if ( !isAbstract( classModifiers ) && !isInterface( classModifiers ) ){Request request = aClass( testClass );if ( filter != null ){request = request.filterWith( filter );}Runner runner = request.getRunner();if ( countTestsInRunner( runner.getDescription() ) != 0 ){runner.run( notifier );}}}

junit4中Runner僅僅是一個抽象的類:

public abstract class Runner implements Describable {/* (non-Javadoc)* @see org.junit.runner.Describable#getDescription()*/public abstract Description getDescription();/*** Run the tests for this runner.* @param notifier will be notified of events while tests are being run--tests being * started, finishing, and failing*/public abstract void run(RunNotifier notifier);/*** @return the number of tests to be run by the receiver*/public int testCount() {return getDescription().testCount();} }

Describable:

abstract Describable{ /*** @return a {@link Description} showing the tests to be run by the receiver*/public abstract Description getDescription(); }

然后是org.junit.runners這個包里面ParentRunner類,這個類極為關鍵:

public abstract class ParentRunner<T> extends Runner implements Filterable,Sortable {private final TestClass fTestClass;private Filter fFilter= null;private Sorter fSorter= Sorter.NULL;/*** Constructs a new {@code ParentRunner} that will run {@code @TestClass}* @throws InitializationError */protected ParentRunner(Class<?> testClass) throws InitializationError {fTestClass= new TestClass(testClass);validate();}//// Must be overridden///*** Returns a list of objects that define the children of this Runner.*/protected abstract List<T> getChildren();/*** Returns a {@link Description} for {@code child}, which can be assumed to* be an element of the list returned by {@link ParentRunner#getChildren()}*/protected abstract Description describeChild(T child);/*** Runs the test corresponding to {@code child}, which can be assumed to be* an element of the list returned by {@link ParentRunner#getChildren()}.* Subclasses are responsible for making sure that relevant test events are* reported through {@code notifier}*/protected abstract void runChild(T child, RunNotifier notifier);//// May be overridden///*** Adds to {@code errors} a throwable for each problem noted with the test class (available from {@link #getTestClass()}).* Default implementation adds an error for each method annotated with* {@code @BeforeClass} or {@code @AfterClass} that is not* {@code public static void} with no arguments.*/protected void collectInitializationErrors(List<Throwable> errors) {validatePublicVoidNoArgMethods(BeforeClass.class, true, errors);validatePublicVoidNoArgMethods(AfterClass.class, true, errors);}/*** Adds to {@code errors} if any method in this class is annotated with* {@code annotation}, but:* <ul>* <li>is not public, or* <li>takes parameters, or* <li>returns something other than void, or* <li>is static (given {@code isStatic is false}), or* <li>is not static (given {@code isStatic is true}).*/protected void validatePublicVoidNoArgMethods(Class<? extends Annotation> annotation,boolean isStatic, List<Throwable> errors) {List<FrameworkMethod> methods= getTestClass().getAnnotatedMethods(annotation);for (FrameworkMethod eachTestMethod : methods)eachTestMethod.validatePublicVoidNoArg(isStatic, errors);}/** * Constructs a {@code Statement} to run all of the tests in the test class. Override to add pre-/post-processing. * Here is an outline of the implementation:* <ul>* <li>Call {@link #runChild(Object, RunNotifier)} on each object returned by {@link #getChildren()} (subject to any imposed filter and sort).</li>* <li>ALWAYS run all non-overridden {@code @BeforeClass} methods on this class* and superclasses before the previous step; if any throws an* Exception, stop execution and pass the exception on.* <li>ALWAYS run all non-overridden {@code @AfterClass} methods on this class* and superclasses before any of the previous steps; all AfterClass methods are* always executed: exceptions thrown by previous steps are combined, if* necessary, with exceptions from AfterClass methods into a* {@link MultipleFailureException}.* </ul>* @param notifier* @return {@code Statement}*/protected Statement classBlock(final RunNotifier notifier) {Statement statement= childrenInvoker(notifier);statement= withBeforeClasses(statement);statement= withAfterClasses(statement);return statement;}/*** Returns a {@link Statement}: run all non-overridden {@code @BeforeClass} methods on this class* and superclasses before executing {@code statement}; if any throws an* Exception, stop execution and pass the exception on.*/protected Statement withBeforeClasses(Statement statement) {List<FrameworkMethod> befores= fTestClass.getAnnotatedMethods(BeforeClass.class);statement= new RunBefores(statement, befores, null);return statement;}/*** Returns a {@link Statement}: run all non-overridden {@code @AfterClass} methods on this class* and superclasses before executing {@code statement}; all AfterClass methods are* always executed: exceptions thrown by previous steps are combined, if* necessary, with exceptions from AfterClass methods into a* {@link MultipleFailureException}.*/protected Statement withAfterClasses(Statement statement) {List<FrameworkMethod> afters= fTestClass.getAnnotatedMethods(AfterClass.class);statement= new RunAfters(statement, afters, null);return statement;}/*** Returns a {@link Statement}: Call {@link #runChild(Object, RunNotifier)}* on each object returned by {@link #getChildren()} (subject to any imposed* filter and sort)*/protected Statement childrenInvoker(final RunNotifier notifier) {return new Statement() {@Overridepublic void evaluate() {runChildren(notifier);}};}private void runChildren(final RunNotifier notifier) {for (T each : getFilteredChildren())runChild(each, notifier);}/*** Returns a name used to describe this Runner*/protected String getName() {return fTestClass.getName();}//// Available for subclasses///*** Returns a {@link TestClass} object wrapping the class to be executed.*/protected final TestClass getTestClass() {return fTestClass;}//// Implementation of Runner// @Overridepublic Description getDescription() {Description description= Description.createSuiteDescription(getName(),fTestClass.getAnnotations());for (T child : getFilteredChildren())description.addChild(describeChild(child));return description;}@Overridepublic void run(final RunNotifier notifier) {EachTestNotifier testNotifier= new EachTestNotifier(notifier,getDescription());try {Statement statement= classBlock(notifier);statement.evaluate();} catch (AssumptionViolatedException e) {testNotifier.fireTestIgnored();} catch (StoppedByUserException e) {throw e;} catch (Throwable e) {testNotifier.addFailure(e);}}//// Implementation of Filterable and Sortable//public void filter(Filter filter) throws NoTestsRemainException {fFilter= filter;for (T each : getChildren())if (shouldRun(each))return;throw new NoTestsRemainException();}public void sort(Sorter sorter) {fSorter= sorter;}//// Private implementation// private void validate() throws InitializationError {List<Throwable> errors= new ArrayList<Throwable>();collectInitializationErrors(errors);if (!errors.isEmpty())throw new InitializationError(errors);}protected List<T> getFilteredChildren() {ArrayList<T> filtered= new ArrayList<T>();for (T each : getChildren())if (shouldRun(each))try {filterChild(each);sortChild(each);filtered.add(each);} catch (NoTestsRemainException e) {// don't add it}Collections.sort(filtered, comparator());return filtered;}private void sortChild(T child) {fSorter.apply(child);}private void filterChild(T child) throws NoTestsRemainException {if (fFilter != null)fFilter.apply(child);}private boolean shouldRun(T each) {return fFilter == null || fFilter.shouldRun(describeChild(each));}private Comparator<? super T> comparator() {return new Comparator<T>() {public int compare(T o1, T o2) {return fSorter.compare(describeChild(o1), describeChild(o2));}};} }

然后是BlockJUnit4ClassRunner 繼承了ParentRunner:

public class BlockJUnit4ClassRunner extends ParentRunner<FrameworkMethod> {/*** Creates a BlockJUnit4ClassRunner to run {@code klass}* * @throws InitializationError* if the test class is malformed.*/public BlockJUnit4ClassRunner(Class<?> klass) throws InitializationError {super(klass);}//// Implementation of ParentRunner// @Overrideprotected void runChild(FrameworkMethod method, RunNotifier notifier) {EachTestNotifier eachNotifier= makeNotifier(method, notifier);if (method.getAnnotation(Ignore.class) != null) {eachNotifier.fireTestIgnored();return;}eachNotifier.fireTestStarted();try {methodBlock(method).evaluate();} catch (AssumptionViolatedException e) {eachNotifier.addFailedAssumption(e);} catch (Throwable e) {eachNotifier.addFailure(e);} finally {eachNotifier.fireTestFinished();}}@Overrideprotected Description describeChild(FrameworkMethod method) {return Description.createTestDescription(getTestClass().getJavaClass(),testName(method), method.getAnnotations());}@Overrideprotected List<FrameworkMethod> getChildren() {return computeTestMethods();}//// Override in subclasses///*** Returns the methods that run tests. Default implementation * returns all methods annotated with {@code @Test} on this * class and superclasses that are not overridden.*/protected List<FrameworkMethod> computeTestMethods() {return getTestClass().getAnnotatedMethods(Test.class);}@Overrideprotected void collectInitializationErrors(List<Throwable> errors) {super.collectInitializationErrors(errors);validateConstructor(errors);validateInstanceMethods(errors);}private void validateConstructor(List<Throwable> errors) {validateOnlyOneConstructor(errors);validateZeroArgConstructor(errors);}private void validateOnlyOneConstructor(List<Throwable> errors) {if (!hasOneConstructor()) {String gripe= "Test class should have exactly one public constructor";errors.add(new Exception(gripe));}}/*** Adds to {@code errors} if the test class's single constructor* takes parameters*/protected void validateZeroArgConstructor(List<Throwable> errors) {if (hasOneConstructor()&& !(getTestClass().getOnlyConstructor().getParameterTypes().length == 0)) {String gripe= "Test class should have exactly one public zero-argument constructor";errors.add(new Exception(gripe));}}private boolean hasOneConstructor() {return getTestClass().getJavaClass().getConstructors().length == 1;}/*** Adds to {@code errors} for each method annotated with {@code @Test},* {@code @Before}, or {@code @After} that is not a public, void instance* method with no arguments.*/protected void validateInstanceMethods(List<Throwable> errors) {validatePublicVoidNoArgMethods(After.class, false, errors);validatePublicVoidNoArgMethods(Before.class, false, errors);validateTestMethods(errors);if (computeTestMethods().size() == 0)errors.add(new Exception("No runnable methods"));}/*** Adds to {@code errors} for each method annotated with {@code @Test}that* is not a public, void instance method with no arguments.*/protected void validateTestMethods(List<Throwable> errors) {validatePublicVoidNoArgMethods(Test.class, false, errors);}/*** Returns a new fixture for running a test. Default implementation executes* the test class's no-argument constructor (validation should have ensured* one exists).*/protected Object createTest() throws Exception {return getTestClass().getOnlyConstructor().newInstance();}/*** Returns the name that describes {@code method} for {@link Description}s.* Default implementation is the method's name*/protected String testName(FrameworkMethod method) {return method.getName();}/*** Returns a Statement that, when executed, either returns normally if* {@code method} passes, or throws an exception if {@code method} fails.* * Here is an outline of the default implementation:* * <ul>* <li>Invoke {@code method} on the result of {@code createTest()}, and* throw any exceptions thrown by either operation.* <li>HOWEVER, if {@code method}'s {@code @Test} annotation has the {@code* expecting} attribute, return normally only if the previous step threw an* exception of the correct type, and throw an exception otherwise.* <li>HOWEVER, if {@code method}'s {@code @Test} annotation has the {@code* timeout} attribute, throw an exception if the previous step takes more* than the specified number of milliseconds.* <li>ALWAYS run all non-overridden {@code @Before} methods on this class* and superclasses before any of the previous steps; if any throws an* Exception, stop execution and pass the exception on.* <li>ALWAYS run all non-overridden {@code @After} methods on this class* and superclasses after any of the previous steps; all After methods are* always executed: exceptions thrown by previous steps are combined, if* necessary, with exceptions from After methods into a* {@link MultipleFailureException}.* </ul>* * This can be overridden in subclasses, either by overriding this method,* or the implementations creating each sub-statement.*/protected Statement methodBlock(FrameworkMethod method) {Object test;try {test= new ReflectiveCallable() {@Overrideprotected Object runReflectiveCall() throws Throwable {return createTest();}}.run();} catch (Throwable e) {return new Fail(e);}Statement statement= methodInvoker(method, test);statement= possiblyExpectingExceptions(method, test, statement);statement= withPotentialTimeout(method, test, statement);statement= withBefores(method, test, statement);statement= withAfters(method, test, statement);return statement;}//// Statement builders///*** Returns a {@link Statement} that invokes {@code method} on {@code test}*/protected Statement methodInvoker(FrameworkMethod method, Object test) {return new InvokeMethod(method, test);}/*** Returns a {@link Statement}: if {@code method}'s {@code @Test} annotation* has the {@code expecting} attribute, return normally only if {@code next}* throws an exception of the correct type, and throw an exception* otherwise.*/protected Statement possiblyExpectingExceptions(FrameworkMethod method,Object test, Statement next) {Test annotation= method.getAnnotation(Test.class);return expectsException(annotation) ? new ExpectException(next,getExpectedException(annotation)) : next;}/*** Returns a {@link Statement}: if {@code method}'s {@code @Test} annotation* has the {@code timeout} attribute, throw an exception if {@code next}* takes more than the specified number of milliseconds.*/protected Statement withPotentialTimeout(FrameworkMethod method,Object test, Statement next) {long timeout= getTimeout(method.getAnnotation(Test.class));return timeout > 0 ? new FailOnTimeout(next, timeout) : next;}/*** Returns a {@link Statement}: run all non-overridden {@code @Before}* methods on this class and superclasses before running {@code next}; if* any throws an Exception, stop execution and pass the exception on.*/protected Statement withBefores(FrameworkMethod method, Object target,Statement statement) {List<FrameworkMethod> befores= getTestClass().getAnnotatedMethods(Before.class);return new RunBefores(statement, befores, target);}/*** Returns a {@link Statement}: run all non-overridden {@code @After}* methods on this class and superclasses before running {@code next}; all* After methods are always executed: exceptions thrown by previous steps* are combined, if necessary, with exceptions from After methods into a* {@link MultipleFailureException}.*/protected Statement withAfters(FrameworkMethod method, Object target,Statement statement) {List<FrameworkMethod> afters= getTestClass().getAnnotatedMethods(After.class);return new RunAfters(statement, afters, target);}protected EachTestNotifier makeNotifier(FrameworkMethod method,RunNotifier notifier) {Description description= describeChild(method);return new EachTestNotifier(notifier, description);}private Class<? extends Throwable> getExpectedException(Test annotation) {if (annotation == null || annotation.expected() == None.class)return null;elsereturn annotation.expected();}private boolean expectsException(Test annotation) {return getExpectedException(annotation) != null;}private long getTimeout(Test annotation) {if (annotation == null)return 0;return annotation.timeout();} }





總結

以上是生活随笔為你收集整理的surefire 拉起 junit 单元测试类 源码阅读(一)的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

亚洲综合色视频在线观看 | 午夜精品久久久久久久99无限制 | 日本成人免费在线观看 | 在线国产高清 | 综合久久一本 | 婷婷丁香社区 | 免费网址在线播放 | 在线不卡a| 亚洲精品1234区 | 中文字幕在线视频免费播放 | 欧美aaa级片| 狠狠色丁香久久婷婷综合_中 | 国产成人免费观看 | 国产精品淫 | 有码视频在线观看 | 久久a级片 | 欧美精品在线观看免费 | 国产精品麻豆视频 | 欧美激情综合网 | 国产精品一区二区免费看 | 日韩精品免费专区 | 亚洲人成人在线 | 久久高清国产视频 | 国产免费一区二区三区最新 | 国产一区二区三区黄 | 欧美精品亚洲精品日韩精品 | 五月天网页 | 亚洲国产手机在线 | 成人免费一区二区三区在线观看 | 亚洲午夜av久久乱码 | 久久久久麻豆 | 久久人人干 | 日韩专区在线播放 | 中文字幕一区二 | 亚洲午夜小视频 | 成人久久18免费网站麻豆 | 成人久久精品视频 | 久久美女视频 | 天天干,天天操 | 免费电影一区二区三区 | 国产成人av | 精品一区二区久久久久久久网站 | 国产高清专区 | 天天操天天是 | 久久久久久草 | 天天操比 | 久久精品免费看 | 欧美精品久久久久久久久老牛影院 | 在线天堂日本 | a亚洲视频 | 亚洲不卡av一区二区三区 | 国产亚洲精品久久久久久大师 | 在线播放你懂 | 国产亚洲在 | 成人a毛片 | 成年人网站免费观看 | 国产精品日韩高清 | 国产成人在线精品 | 日日爱影视 | 三级视频日韩 | 五月激情六月丁香 | 欧美激情视频一区二区三区免费 | 精品国内| 国产精品嫩草影院99网站 | 中国一级片在线观看 | 国产精品美女久久久久久久久久久 | 日韩在线视 | 欧美在线久久 | 国产午夜不卡 | 91视频高清完整版 | 男女男视频 | 国产99久久99热这里精品5 | 天天干天天爽 | 亚洲天堂精品视频在线观看 | 日韩免费视频线观看 | 国产69精品久久99的直播节目 | 日韩av一区在线观看 | 日本精品二区 | 日本久久电影网 | 最近字幕在线观看第一季 | 国产尤物在线观看 | 国产精品美女久久久网av | 国产一区二区精品久久91 | 麻豆小视频在线观看 | 午夜精品一区二区三区在线观看 | 超级碰碰免费视频 | 88av视频| 国产精品a久久 | 欧美极品少妇xxxxⅹ欧美极品少妇xxxx亚洲精品 | 视频在线一区 | 日韩精品中文字幕av | 黄色免费观看网址 | 97在线影视 | 中文字幕国产精品一区二区 | 国产精品国产三级国产aⅴ入口 | 91麻豆免费版 | 欧美性久久久久久 | 免费久久网 | 国产一区二区午夜 | 国产精品一区二区在线 | 国产小视频福利在线 | 欧美性生活一级片 | a在线观看国产 | 欧美色图88| 久久久一本精品99久久精品66 | 人人爽人人看 | 美女国内精品自产拍在线播放 | 成人免费在线网 | 国产精品一区二区av影院萌芽 | 香蕉在线视频观看 | 国产一级片在线播放 | 涩涩网站在线 | 日韩在线观看电影 | 精品国产乱子伦一区二区 | 97超级碰| 久久女同性恋中文字幕 | 91精品黄色 | 久久人人插 | 国产精品不卡视频 | 日韩久久久久 | 免费又黄又爽的视频 | 中文字幕视频三区 | 中文字幕色站 | 国产精品久久一卡二卡 | 婷婷在线视频观看 | 免费av大全 | 天天操天天艹 | 午夜精品久久久99热福利 | 欧美精品在线观看免费 | 波多野结衣小视频 | 精品久久网| 欧美亚洲国产日韩 | 成 人 黄 色 视频免费播放 | 91成熟丰满女人少妇 | 日韩二区三区在线 | 成年人黄色在线观看 | 欧美日韩不卡一区二区 | 亚洲电影在线看 | 99久久久久成人国产免费 | 日韩免费观看视频 | 色婷婷色 | 久久综合之合合综合久久 | 国产99久久久久 | 久久夜色电影 | 国产一区精品在线观看 | 欧美在线18| av千婊在线免费观看 | 国产色拍 | 日日夜夜草 | 黄色片视频在线观看 | 欧美成人高清 | 深夜激情影院 | 免费看一级特黄a大片 | 国产精品欧美精品 | 日本成人中文字幕在线观看 | 99久久精品免费看国产 | 麻豆精品在线 | 久草在线手机视频 | 亚洲综合欧美精品电影 | 最近2019年日本中文免费字幕 | 丁香九月婷婷综合 | 欧美最猛性xxxxx(亚洲精品) | 亚洲日韩欧美视频 | 91丨九色丨勾搭 | 日狠狠 | 免费在线观看av网站 | 国产精品久久99精品毛片三a | 99在线视频观看 | 国产黑丝袜在线 | 一区二区三区免费在线观看视频 | 久草久 | 在线国产能看的 | 中文字幕视频一区 | 久久久一本精品99久久精品66 | 免费在线观看亚洲视频 | 91人人射 | 一区二区三区日韩视频在线观看 | 国产一区视频导航 | 久久这里只精品 | 天堂在线成人 | 中文视频一区二区 | 国产精品免费麻豆入口 | 在线观看国产区 | 欧美国产不卡 | 天天操天天射天天操 | 久久69精品久久久久久久电影好 | www.天天色.com| 综合伊人久久 | 月下香电影 | 色天天 | 日本中文字幕在线视频 | 国产精品一区二区无线 | 中文字幕资源站 | 狠狠操狠狠插 | 欧美9999| 国产亚洲精品久久久久久 | 亚洲国产美女精品久久久久∴ | 天天干夜夜想 | 午夜av网站| 精品免费国产一区二区三区四区 | 久久综合九色综合97婷婷女人 | 亚洲精品视频偷拍 | 国产黑丝一区二区三区 | 丁香婷婷综合网 | 色中射| 国产一区二区免费在线观看 | 亚洲激情在线 | 国产一区在线视频 | 亚洲国产精品成人va在线观看 | 碰超在线97人人 | 69精品| 天堂中文在线视频 | 欧美男男激情videos | 91麻豆免费版 | 久久久久久久久爱 | 久久香蕉国产精品麻豆粉嫩av | 又粗又长又大又爽又黄少妇毛片 | 天天操 夜夜操 | 国产精品久久久精品 | 美女视频又黄又免费 | 中文伊人| 成年人看片网站 | 日韩性xxx| 99免费精品 | 婷婷伊人五月天 | 日韩国产精品一区 | 亚洲精品国产精品国自产观看浪潮 | 国产一区二区在线播放 | 亚洲女同videos | 亚洲黄色在线播放 | av日韩精品 | 久久草在线视频国产 | 亚洲日本一区二区在线 | 毛片永久新网址首页 | 在线看一区二区 | 欧美日韩综合在线 | 色综合久久久久综合 | 在线视频观看成人 | 激情五月播播久久久精品 | 一级黄网| 亚洲午夜精品久久久久久久久久久久 | 国产在线a免费观看 | 少妇自拍av | 亚洲国产精品电影在线观看 | 婷婷成人亚洲综合国产xv88 | 黄色片网站av | 日本高清免费中文字幕 | 麻豆av电影 | 在线看av网址 | 午夜av日韩| 亚洲aaa级 | 国产精品av一区二区 | 在线观看91网站 | 九九九九精品九九九九 | 91黄色视屏 | 狠狠操电影网 | 在线观看一级片 | 人人爽人人爽人人爽 | 国产精品99久久久久久久久久久久 | 久草在线观看视频免费 | 涩涩成人在线 | 国产中文字幕三区 | 黄色av免费看 | 亚洲精品视频大全 | 日韩精品在线观看视频 | 91亚洲国产成人久久精品网站 | 成人一级在线观看 | 国产天天综合 | 免费在线观看一级片 | 亚洲视频 视频在线 | 天天做夜夜做 | 亚洲视频电影在线 | 亚欧日韩av | 日韩精品在线视频 | 国产黄色大片免费看 | 中文字幕日本在线 | 激情视频在线高清看 | 欧美日韩高清免费 | 天天色视频 | 激情偷乱人伦小说视频在线观看 | 人人爱人人射 | 成人精品在线 | 国产精品一区二区在线看 | 一区二区视频网站 | 国产成人免费在线 | 亚洲成人免费观看 | 久久99国产精品久久99 | 欧洲精品视频一区二区 | 亚洲女人天堂成人av在线 | 成年人看片网站 | jizz欧美性9| 粉嫩av一区二区三区免费 | 欧美男女爱爱视频 | 天天曰 | 夜夜狠狠 | 999电影免费在线观看2020 | 精品国产1区 | 最新超碰在线 | 日批视频在线 | 亚洲精选视频在线 | 手机av在线网站 | 欧美色图视频一区 | 久久久在线免费观看 | 香蕉影视 | 91尤物国产尤物福利在线播放 | 国产福利a | 福利网址在线观看 | 在线 高清 中文字幕 | 国产成人三级在线观看 | 成人性生爱a∨ | 久草在线欧美 | 天天色天天上天天操 | 黄色小说免费观看 | 日韩视频中文字幕在线观看 | 免费高清在线观看成人 | 精品国产精品久久一区免费式 | 亚洲欧美日本一区二区三区 | 国产特级毛片aaaaaa毛片 | 日韩在线第一区 | 亚洲精选久久 | 国产亚洲精品美女久久 | 97碰碰精品嫩模在线播放 | av福利电影| 亚洲视频在线免费看 | 99精品国产99久久久久久97 | 日韩中文字幕免费电影 | 2019精品手机国产品在线 | 91av原创| 色综合久久久久综合体 | 成人免费网站视频 | 欧美亚洲国产一卡 | av黄色免费在线观看 | 91超国产| av在线一 | 久久99国产视频 | 国产精选视频 | 亚洲资源在线 | 免费成人在线视频网站 | 成人动漫一区二区三区 | av一本久道久久波多野结衣 | 国产精品av免费在线观看 | 91免费版在线观看 | 永久免费精品视频网站 | 最新日韩在线观看 | 亚洲自拍自偷 | 亚洲欧美一区二区三区孕妇写真 | 日日爱av | 色综合久久99 | 狠狠88综合久久久久综合网 | 丁香五月网久久综合 | 综合激情网 | 伊人天天操| 最近最新mv字幕免费观看 | 夜色资源站国产www在线视频 | 天天曰天天射 | 国产免费又黄又爽 | 国内成人精品视频 | 免费又黄又爽视频 | 一区二区中文字幕在线播放 | 国产精品久久久久久久久久了 | 午夜视频在线观看一区二区三区 | 成人a视频| 69久久夜色精品国产69 | 婷婷丁香在线观看 | 亚洲一级片av | 欧美 国产 视频 | 成人久久久久 | 国产第一页福利影院 | 天天干夜夜爽 | 国模精品一区二区三区 | 国产精品videoxxxx | 色婷婷中文 | 伊人影院在线观看 | 国产一区二区在线观看免费 | 亚洲国产理论片 | 99综合影院在线 | 五月天婷婷免费视频 | 久久夜夜夜 | 免费日韩高清 | 97综合在线 | 在线免费黄色毛片 | 婷婷福利影院 | 亚洲欧美日韩一二三区 | 国产婷婷一区二区 | 最近乱久中文字幕 | 亚洲爱视频 | 亚洲男男gaygay无套同网址 | 久久五月情影视 | 国产一区二区久久久 | 国产精品 国产精品 | 色综合天天综合网国产成人网 | 91在线视频免费91 | 黄色网大全 | 国产视频每日更新 | 久久久久国产精品一区二区 | 九九免费在线视频 | 欧美了一区在线观看 | 激情丁香5月 | 久草视频在线新免费 | 欧美日韩一区二区在线 | 中文字幕精品一区二区精品 | 极品美女被弄高潮视频网站 | 97精品超碰一区二区三区 | 亚洲激情中文 | 日日操日日 | 久久成人人人人精品欧 | 97av视频| 免费看成年人 | 99在线视频网站 | 欧美一区二区在线 | 亚洲尺码电影av久久 | 免费网站在线观看成人 | 日本精品视频在线 | 黄色免费在线看 | 国产成人免费观看久久久 | 日日夜夜人人精品 | 国产尤物在线观看 | 在线日韩精品视频 | 日韩精品欧美精品 | 国产色婷婷精品综合在线手机播放 | 成人永久在线 | 成人在线免费小视频 | 久久久精品国产一区二区三区 | 99免费在线播放99久久免费 | www免费看 | 日本在线观看视频一区 | 国产日韩欧美在线观看 | 免费能看的av | 午夜在线资源 | 91精品在线视频观看 | 在线成人一区 | 麻花传媒mv免费观看 | 亚洲aⅴ一区二区三区 | 成 人 免费 黄 色 视频 | 亚洲不卡av一区二区三区 | 色播五月激情五月 | 欧美日韩成人一区 | 精品一区二区综合 | 成人国产一区二区 | 欧美色图亚洲图片 | 美女久久久久久久久久 | 欧美日韩国产精品久久 | 日韩中文字幕免费在线播放 | 91在线视频网址 | 国产在线播放不卡 | 3d黄动漫免费看 | 精品久久久久久久 | 国产尤物在线 | 中文字幕高清有码 | 亚洲黄在线观看 | 日韩精品专区 | 久久精彩视频 | 久草视频在线免费看 | 国产精久久久久久久 | 欧美91片 | 五月婷婷丁香六月 | 欧美激情精品一区 | 伊人狠狠干 | 欧美超碰在线 | 毛片无卡免费无播放器 | 狠狠狠狠干 | 欧美在线视频二区 | 色婷婷五 | 国产特级毛片aaaaaa高清 | 岛国一区在线 | 国产日产精品一区二区三区四区的观看方式 | 久久久久亚洲精品 | 久久天堂精品视频 | 国精产品999国精产品岳 | 黄色一级在线免费观看 | 免费日韩三级 | 欧美日韩破处 | 青草草在线视频 | 国产国产人免费人成免费视频 | 欧美性生活免费看 | www.com久久久 | 欧美日韩1区| 国产自产高清不卡 | 中文不卡视频 | 玖玖国产精品视频 | 色综合久久久久久久久五月 | adn—256中文在线观看 | 国产黄免费在线观看 | 激情五月婷婷激情 | 成年人免费电影在线观看 | 在线a人片免费观看视频 | 久久久久国产成人精品亚洲午夜 | 黄色小网站在线 | 九九视频在线播放 | 在线播放亚洲激情 | 日韩欧美99| 婷婷六月综合网 | 黄色a级片在线观看 | 亚洲国产成人av网 | 日韩激情在线视频 | 亚洲精品一区二区久 | 国产视| 一区二区三区日韩在线 | 激情在线五月天 | 精品播放| 色操插 | 日韩精品免费一区 | 在线视频1卡二卡三卡 | 日韩素人在线观看 | 9在线观看免费高清完整版 玖玖爱免费视频 | 日韩免费在线观看视频 | 亚洲电影影音先锋 | 日本中文字幕视频 | 韩日精品在线观看 | 色视频网站免费观看 | 国产精品久久久久久电影 | 国产视频综合在线 | 911久久香蕉国产线看观看 | 最新精品视频在线 | 国产亚洲视频在线免费观看 | 超级碰碰免费视频 | 亚洲视频1| 免费在线激情电影 | 中文字幕av最新 | 亚洲综合射 | 国产精品久久久久久久久久久久午夜 | 日本高清dvd | 午夜性生活 | 六月天综合网 | 久久情网 | 91av短视频 | 中文字幕av免费在线观看 | av福利免费| 在线视频app | 91精品网站 | 日韩av不卡在线播放 | 国产一级免费电影 | 夜夜操综合网 | 在线观看视频你懂的 | 高清国产午夜精品久久久久久 | 国产精品毛片一区二区 | 国产精久久 | 久久成人一区二区 | 日三级在线| 婷婷伊人五月天 | 91精品国产麻豆 | 中国一级片免费看 | 日韩啪视频 | 激情婷婷六月 | 国产成人精品一区二区三区在线观看 | 国产精品国产三级国产aⅴ入口 | 日韩在线免费高清视频 | 久久精品国亚洲 | 国产高清日韩欧美 | 色综合狠狠干 | 在线播放第一页 | 亚洲欧洲中文日韩久久av乱码 | 久久夜色电影 | 国产在线黄 | 久久久久国产一区二区三区 | 热久久免费视频精品 | 天天久久夜夜 | 成人一区二区三区中文字幕 | 一区二区高清在线 | 国产精品一区在线播放 | 欧美性超爽 | 色a4yy| 国产一区在线免费观看视频 | 久久久婷| 日韩高清三区 | 欧美激情视频免费看 | 免费男女羞羞的视频网站中文字幕 | 亚洲国产成人在线观看 | 99精品视频在线观看播放 | 区一区二在线 | 97热久久免费频精品99 | 91精品国产自产在线观看 | 免费在线成人av电影 | 99精品视频免费观看视频 | 亚洲一级二级 | 九九视频免费在线观看 | 超碰97国产精品人人cao | 久久久久久看片 | 99久久久国产免费 | 国产中文字幕视频在线观看 | 久久99热这里只有精品国产 | 操操综合网 | 欧美激情第十页 | 国产中文字幕网 | 99精品系列 | 人人干人人草 | 欧美污在线观看 | 成人影片在线免费观看 | 亚洲aⅴ免费在线观看 | 久久国产欧美日韩精品 | 色视频网站在线观看一=区 a视频免费在线观看 | 久久久久免费精品国产小说色大师 | 在线观看日韩av | 在线免费视频一区 | 99免费看片 | 午夜久久影视 | 久青草影院 | 狠狠干狠狠插 | 99热精品久久 | 久久超级碰 | 精品久久一区二区 | av在线直接看 | 国产精品一区久久久久 | 日本大片免费观看在线 | 99精品免费久久久久久日本 | 激情电影影院 | 中文在线字幕免费观看 | 九九热免费在线观看 | 国产成人精品aaa | 人人爽久久久噜噜噜电影 | 天天操天天操天天爽 | 91一区啪爱嗯打偷拍欧美 | 国产极品尤物在线 | 在线天堂中文www视软件 | 国产黑丝一区二区三区 | 久精品视频在线 | 国产精品成人aaaaa网站 | 日本久久久久久久久久 | 91九色porny蝌蚪视频 | 在线观看深夜福利 | 香蕉在线视频观看 | 亚洲 精品在线视频 | 免费日韩高清 | 亚洲人人av | 天天综合成人网 | av高清不卡 | 日韩网站在线播放 | 久久草网 | 99久热在线精品 | 久久国产精品久久精品 | 欧美少妇的秘密 | 中文字幕观看在线 | www黄| 色视频在线免费 | 色网免费观看 | 亚洲欧洲精品一区 | 国产高清网站 | 欧美成人h版在线观看 | 亚洲欧美日韩国产精品一区午夜 | 综合激情网... | 国产精品入口66mio女同 | 亚洲一区 影院 | 日韩视频一区二区三区在线播放免费观看 | 久久福利国产 | 久久毛片高清国产 | 午夜av日韩| 最新国产在线观看 | 99精品观看| 亚洲在线精品视频 | 黄色大片av | 99久高清在线观看视频99精品热在线观看视频 | 91精选| 久草在线久草在线2 | 久久爱资源网 | 成年人在线看视频 | www.色国产 | 久青草国产在线 | 特级毛片在线观看 | 欧美久久久 | 国产精品igao视频网网址 | 欧美日韩视频免费看 | 成人av电影免费 | 久久草在线视频国产 | 免费视频一区 | 欧美一区二区三区在线视频观看 | 激情在线免费视频 | 国产精品一区二区av日韩在线 | 九九电影在线 | 91传媒免费在线观看 | 国产精品一区二区三区四区在线观看 | 国产精品久久视频 | 韩国av免费观看 | 99在线播放 | 久久激情视频 久久 | 香蕉视频网站在线观看 | 色婷婷国产在线 | 亚洲免费av片 | 成人在线观看资源 | 日韩在线网址 | 亚洲精品国产拍在线 | 免费观看久久 | 欧美va天堂va视频va在线 | 一区二区欧美日韩 | 国产美女在线精品免费观看 | 午夜精品一区二区三区四区 | 97成人精品区在线播放 | 综合网av| 91亚洲国产 | 综合色中文| 91久久久久久久一区二区 | 欧美日韩国产精品一区二区亚洲 | 天天爱天天操 | a黄色片 | 久久成年人 | 在线亚洲激情 | 国内久久久久久 | 国产98色在线 | 日韩 | 婷婷久久综合九色综合 | 国产成人精品亚洲a | 精品欧美在线视频 | 国产精品美女毛片真酒店 | 日韩av高清在线观看 | 成人a在线观看高清电影 | 日韩电影一区二区在线观看 | 丁香婷婷激情啪啪 | 亚洲欧美视频 | 六月丁香综合网 | 精品999久久久 | 国产福利在线免费观看 | 久久视频在线免费观看 | 欧美精彩视频在线观看 | 婷婷日日| 免费国产在线精品 | 欧美激情视频免费看 | 在线观看视频在线观看 | 久久高清国产视频 | 国产精品区免费视频 | 亚洲女同ⅹxx女同tv | 亚洲黑丝少妇 | 97视频在线观看免费 | 深爱激情婷婷网 | 欧美大片在线观看一区 | 国产精品乱码久久久久 | 2023av| 国产又粗又硬又长又爽的视频 | 毛片二区| 久久成人免费 | 黄色1级毛片 | 成人免费观看大片 | 久久久精品久久日韩一区综合 | 欧美一级激情 | 在线电影 一区 | 四虎免费av | 免费的黄色av | 色999视频 | 国内成人av| 免费开视频| 99精品在线免费在线观看 | 久久在草 | 狠狠色丁香婷婷综合久小说久 | 狠狠干狠狠操 | 日韩在线观看第一页 | 久久精品永久免费 | 一区二区欧美激情 | 日韩在线观看不卡 | 国产高清免费在线观看 | 夜夜躁天天躁很躁波 | 国产精品18久久久久久首页狼 | 一二三四精品 | 天天综合人人 | 3d黄动漫免费看 | 日韩在线观看精品 | 欧美极品久久 | 亚洲专区欧美 | 亚洲电影一级黄 | 精品一区二区免费视频 | 久久精品男人的天堂 | 久99久在线视频 | 97成人超碰 | 日本特黄特色aaa大片免费 | 狠狠躁日日躁狂躁夜夜躁av | 欧美视频日韩 | 亚洲精品久久久蜜桃直播 | 一区二区伦理 | 亚洲在线网址 | 蜜臀av夜夜澡人人爽人人桃色 | 亚州人成在线播放 | 五月天久久激情 | 亚洲欧洲精品久久 | 国产精品一区久久久久 | 丁香婷婷色综合亚洲电影 | 久久精品99国产 | 自拍超碰在线 | 国产一区二区三精品久久久无广告 | 日韩精品中文字幕有码 | 欧美激情综合五月色丁香 | a√天堂资源 | 手机在线欧美 | 免费日韩 | 一级电影免费在线观看 | 四虎亚洲精品 | 国产91影院 | 在线中文字幕播放 | 亚洲国产精品电影 | 久久久久一区二区三区四区 | av色网站 | 日韩av进入| 日韩视频1| 91av观看| 日日干干 | 亚洲综合在线发布 | 久久涩涩网站 | 日本在线观看一区二区 | 日韩精品免费一区二区在线观看 | 精一区二区 | 一区二区三区污 | 香蕉在线播放 | 日韩精品欧美一区 | 日韩一区二区三区在线观看 | 成人黄色免费在线观看 | 成人高清av在线 | 免费人成网| 欧美日韩性视频在线 | 超碰在线人人97 | 婷香五月 | 偷拍区另类综合在线 | 天天综合入口 | 天天爱天天操天天射 | 色婷婷亚洲 | 国产精品欧美久久久久天天影视 | av在线网站免费观看 | 色婷婷综合视频在线观看 | 亚洲精品久久久久久中文传媒 | 超级碰视频 | 亚洲精品免费播放 | 精品国产乱码久久久久久1区2匹 | 麻豆传媒精品 | 国产伦理一区 | 一区二区三区韩国免费中文网站 | 久久激情五月婷婷 | 日日日操| 国产欧美精品在线观看 | 日韩在线第一区 | 又色又爽又黄高潮的免费视频 | 国产涩图 | 99视频这里有精品 | 天天操天天添 | 日韩激情中文字幕 | 国产手机在线观看 | 欧美激情片在线观看 | 亚洲性xxxx| 日韩电影在线观看一区二区三区 | 不卡国产视频 | 中文字幕乱码视频 | 欧美日韩高清一区二区 国产亚洲免费看 | 国产五月| 国产一级大片在线观看 | www.av在线.com| 日韩天天操 | 国产精品麻 | 国产中文| 精品久久久久国产 | 中文字幕人成不卡一区 | 久黄色 | 亚洲精选视频免费看 | 国产精品久久久久久99 | 亚洲三级影院 | 91热在线 | 日韩免费av片 | 国产精品一区二区三区免费视频 | 成人精品视频久久久久 | 欧美日韩激情网 | 国产视频在线播放 | 激情网在线视频 | 国产性天天综合网 | 亚洲欧美日韩精品久久久 | 精品亚洲视频在线 | 五月网婷婷 | 99热手机在线 | 久久久久久久久久久黄色 | 日日干天天插 | 欧美综合国产 | 久久国产精品第一页 | 97热在线观看 | 能在线看的av | 欧美日韩中文字幕综合视频 | 日韩黄色av网站 | 九色琪琪久久综合网天天 | 久久这里只有精品视频首页 | 亚洲精品久久激情国产片 | 久久久免费观看 | 伊人手机在线 | 国产婷婷 | 九九热有精品 | 在线观看麻豆av | 韩国在线视频一区 | 日韩黄色免费在线观看 | 中文在线免费看视频 | 欧美日韩午夜在线 | 欧美色噜噜| 天天干天天玩天天操 | 麻豆va一区二区三区久久浪 | 国产精品毛片久久蜜 | 国产精品正在播放 | 国产精品99免费看 | 久久在线看 | 免费观看成人av | 99热这里只有精品8 久久综合毛片 | 久久亚洲私人国产精品va | 狠狠gao| 最近中文字幕高清字幕在线视频 | 国产69熟 | 国产精品日韩 | 九九视频免费在线观看 | 国产日韩欧美在线影视 | 亚洲日本色 | 久久久久亚洲精品国产 | 超碰免费av | 国偷自产视频一区二区久 | 一区二区av | 亚洲第一成网站 | 国产精品成人品 | 日韩精品一卡 | 三级黄色欧美 | 国产五月天婷婷 | 国产精品黄网站在线观看 | 日韩69视频 | 亚洲少妇激情 | 久久99视频免费观看 | 亚洲电影在线看 | 国产精品一区二区av麻豆 | 成人久久18免费 | 91女神的呻吟细腰翘臀美女 | 一级免费看 | 日韩成人精品在线观看 | 天天综合网在线 | 欧美一级黄色片 | 亚洲高清在线视频 | 久久夜色精品国产欧美乱 | 亚洲精品婷婷 | 日韩草比 | 永久免费观看视频 | 最新av中文字幕 | 国语久久 | 国产精品欧美日韩 | 欧美成年网站 | 激情五月开心 | 久久激情影院 | 在线观看一二三区 | 日韩在线免费视频 | 色婷婷综合视频在线观看 | 亚洲综合在线发布 | 韩日成人av | 久草国产在线观看 | 欧美精品少妇xxxxx喷水 | 国内精品在线观看视频 | 国产精品自产拍在线观看网站 | 欧美极品xxxxx | 69精品视频在线观看 | 亚洲日本一区二区在线 | 日韩av成人在线观看 | 国产精品入口a级 | 麻豆你懂的| 四虎国产精品免费观看视频优播 | 99精品在线免费观看 | 美女网站在线播放 | 国产精品久久久久毛片大屁完整版 | 香蕉在线视频观看 | 香蕉影视在线观看 | 欧美激情综合色综合啪啪五月 | 久久久私人影院 | 手机看片久久 | 69av国产 | 日韩在线一级 | 在线观看免费一级片 | 99视频在线播放 | 久久综合中文字幕 | 在线观看黄色av | 国产亚洲精品中文字幕 | 五月天天色 | 国产日产精品久久久久快鸭 | 免费在线播放视频 | 激情欧美xxxx | 国产一级视频在线观看 | 欧美日韩国产亚洲乱码字幕 | 国内精品久久天天躁人人爽 | 国产精品3 | 欧美一区二视频在线免费观看 | 91色一区二区三区 | 顶级欧美色妇4khd | 一区二区三区动漫 | 色婷婷免费视频 | 精品国产大片 | 久久久这里有精品 | 人人看人人| 婷婷五月在线视频 | 日本一区二区不卡高清 | 九九免费在线视频 | 中文字幕在线观看资源 | 在线观看视频一区二区三区 | 一区二区三区电影 | 美女黄色网在线播放 | 免费色视频在线 | 在线91av| 亚洲国产精品成人综合 | 日韩在线观看a | 香蕉视频4aa| 国产精品久久久久久久久免费 | 国产一区二区精品久久91 | 日韩一区二区三区不卡 | 欧美伦理一区二区 | 五月婷亚洲 | 色视频国产直接看 | 又黄又刺激的网站 | 久久精品高清视频 | 欧美精品中文 | 亚洲综合激情 | 久久不卡电影 |