All Downloads are FREE. Search and download functionalities are using the official Maven repository.

mockit.internal.startup.JMockitInitialization Maven / Gradle / Ivy

Go to download

JMockit is a Java toolkit for automated developer testing. It contains mocking/faking APIs and a code coverage tool, supporting both JUnit and TestNG. The mocking APIs allow all kinds of Java code, without testability restrictions, to be tested in isolation from selected dependencies.

There is a newer version: 1.49
Show newest version
/*
 * Copyright (c) 2006 Rogério Liesenfeld
 * This file is subject to the terms of the MIT license (see LICENSE.txt).
 */
package mockit.internal.startup;

import java.io.*;
import java.lang.instrument.*;
import javax.annotation.*;

import mockit.*;
import mockit.coverage.*;
import mockit.integration.junit4.internal.*;
import mockit.internal.util.*;

final class JMockitInitialization
{
   @Nonnull private final StartupConfiguration config;

   JMockitInitialization() throws IOException
   {
      config = new StartupConfiguration();
   }

   void initialize(@Nonnull Instrumentation inst)
   {
      applyInternalStartupMocksAsNeeded();

      if (CodeCoverage.active()) {
         inst.addTransformer(new CodeCoverage());
      }

      applyUserSpecifiedStartupMocksIfAny();
   }

   private void applyInternalStartupMocksAsNeeded()
   {
      if (MockFrameworkMethod.hasDependenciesInClasspath()) {
         new RunNotifierDecorator();
         new BlockJUnit4ClassRunnerDecorator();
         new MockFrameworkMethod();
      }
   }

   private void applyUserSpecifiedStartupMocksIfAny()
   {
      for (String mockClassName : config.mockClasses) {
         applyStartupMock(mockClassName);
      }
   }

   private static void applyStartupMock(@Nonnull String mockClassName)
   {
      String argument = null;
      int p = mockClassName.indexOf('=');

      if (p > 0) {
         argument = mockClassName.substring(p + 1);
         mockClassName = mockClassName.substring(0, p);
      }

      try {
         Class mockClass = ClassLoad.loadClassAtStartup(mockClassName);

         if (MockUp.class.isAssignableFrom(mockClass)) {
            if (argument == null) {
               ConstructorReflection.newInstanceUsingDefaultConstructor(mockClass);
            }
            else {
               ConstructorReflection.newInstance(mockClass, argument);
            }
         }
      }
      catch (UnsupportedOperationException ignored) {}
      catch (Throwable unexpectedFailure) {
         StackTrace.filterStackTrace(unexpectedFailure);
         unexpectedFailure.printStackTrace();
      }
   }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy