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

io.codemodder.testutils.Metadata Maven / Gradle / Ivy

package io.codemodder.testutils;

import io.codemodder.CodeChanger;
import io.codemodder.ProjectProvider;
import java.lang.annotation.ElementType;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;

@Retention(RetentionPolicy.RUNTIME)
@Target(ElementType.TYPE)
public @interface Metadata {

  /** The codemod being tested. */
  Class codemodType();

  /** The classpath-based test directory containing the test case artifacts. */
  String testResourceDir();

  /**
   * The GAV coordinates of any dependencies that should be added to the project after the codemod's
   * execution.
   */
  String[] dependencies();

  /**
   * Test files should always be renamed to this before execution. Helps test codemods that only
   * target certain file names. Also supports directories in the path.
   */
  String renameTestFile() default "";

  /**
   * Whether to re-run the transformed code through a second transformation with the same inputs,
   * but with the transformed code, to see if another transformation is erroneously made.
   */
  boolean doRetransformTest() default true;

  /**
   * Some codemods change their behavior based on the context of the app -- like which versions of
   * libraries are present. If you want to simulate specific contextual conditions related to
   * dependencies, you can add a customized provider here A usage example can be found at {@code
   * HardenXStreamCodemodTestProjectProvider}
   */
  Class[] projectProviders() default {};

  /** The expected fix metadata that the codemod should report. */
  int[] expectingFixesAtLines() default {};

  /** The expected failed fix metadata that the codemod should report. */
  int[] expectingFailedFixesAtLines() default {};

  /** Sonar issues file names for testing multiple json files */
  String[] sonarIssuesJsonFiles() default {};

  /** Sonar hotspots file names for testing multiple json files */
  String[] sonarHotspotsJsonFiles() default {};

  /**
   * Used to filter test execution to only the tests with a display name that matches the given
   * regex. This is a test-driven development tool for iterating on a single, dynamic test case.
   *
   * 
   * @Metadata(
   *   codemodType = LogFailedLoginCodemod.class,
   *   testResourceDir = "log-failed-login",
   *   only = "\\/safe\\/.*",
   *   dependencies = {})
   * public final class LogFailedLoginCodemodTest implements CodemodTestMixin {
   * 
*/ String only() default ""; }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy