001/*
002 * Copyright (C) 2022 - 2025, the original author or authors.
003 *
004 * Licensed under the Apache License, Version 2.0 (the "License");
005 * you may not use this file except in compliance with the License.
006 * You may obtain a copy of the License at
007 *
008 *    http://www.apache.org/licenses/LICENSE-2.0
009 *
010 * Unless required by applicable law or agreed to in writing, software
011 * distributed under the License is distributed on an "AS IS" BASIS,
012 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
013 * See the License for the specific language governing permissions and
014 * limitations under the License.
015 */
016package io.github.ascopes.jct.junit;
017
018import io.github.ascopes.jct.workspaces.PathStrategy;
019import io.github.ascopes.jct.workspaces.Workspace;
020import java.lang.annotation.Documented;
021import java.lang.annotation.ElementType;
022import java.lang.annotation.Retention;
023import java.lang.annotation.RetentionPolicy;
024import java.lang.annotation.Target;
025
026/**
027 * Annotation for a {@link Workspace} field in a test class. This will ensure it gets initialised
028 * and closed correctly between tests.
029 *
030 * <p>Use static-fields to keep a workspace object alive for the duration of all the tests
031 * (providing the same semantics as initialising and closing resources using the
032 * {@link org.junit.jupiter.api.BeforeAll} and {@link org.junit.jupiter.api.AfterAll} annotations).
033 *
034 * <p>You must extend your test class with the {@link JctExtension} extension for this annotation
035 * to be detected and handled.
036 *
037 * <p>Example usage:
038 *
039 * <pre><code>
040 * {@literal @ExtendWith(JctExtension.class)}
041 * class MyTest {
042 *   {@literal @Managed}
043 *   Workspace workspace;
044 *
045 *   {@literal @JavacCompilerTest}
046 *   void myTest(JctCompiler compiler) {
047 *     ...
048 *     var compilation = compiler.compile(workspace);
049 *     ...
050 *   }
051 * }
052 * </code></pre>
053 *
054 * @author Ashley Scopes
055 * @since 0.4.0
056 */
057@Documented
058@Retention(RetentionPolicy.RUNTIME)
059@Target(ElementType.FIELD)
060public @interface Managed {
061
062  /**
063   * Get the path strategy to use for the workspace.
064   *
065   * @return the path strategy to use.
066   */
067  PathStrategy pathStrategy() default PathStrategy.RAM_DIRECTORIES;
068}