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.assertions; 017 018import io.github.ascopes.jct.compilers.JctCompilation; 019import io.github.ascopes.jct.containers.ModuleContainerGroup; 020import io.github.ascopes.jct.containers.OutputContainerGroup; 021import io.github.ascopes.jct.containers.PackageContainerGroup; 022import io.github.ascopes.jct.diagnostics.TraceDiagnostic; 023import io.github.ascopes.jct.filemanagers.PathFileObject; 024import io.github.ascopes.jct.utils.UtilityClass; 025import java.util.List; 026import javax.tools.Diagnostic; 027import javax.tools.JavaFileManager.Location; 028import javax.tools.JavaFileObject; 029import org.jspecify.annotations.Nullable; 030 031/** 032 * Helper class to provide fluent creation of assertions for compilations. 033 * 034 * @author Ashley Scopes 035 * @since 0.0.1 036 */ 037@SuppressWarnings("unused") 038public final class JctAssertions extends UtilityClass { 039 040 private JctAssertions() { 041 // Disallow initialisation. 042 } 043 044 /** 045 * Perform an assertion on a compilation. 046 * 047 * <p>This is a shorthand alias for {@link #assertThatCompilation(JctCompilation)}. If you are 048 * using AssertJ assertions in your tests with static imports, you may wish to use that instead to 049 * prevent name conflicts. 050 * 051 * @param compilation the compilation to assert on. 052 * @return the assertion. 053 */ 054 public static JctCompilationAssert assertThat(@Nullable JctCompilation compilation) { 055 return assertThatCompilation(compilation); 056 } 057 058 /** 059 * Perform an assertion on a module container group. 060 * 061 * <p>This is a shorthand alias for {@link #assertThatContainerGroup(ModuleContainerGroup)}. If 062 * you are using AssertJ assertions in your tests with static imports, you may wish to use that 063 * instead to prevent name conflicts. 064 * 065 * @param moduleContainerGroup the module container group to assert on. 066 * @return the assertion. 067 */ 068 public static ModuleContainerGroupAssert assertThat( 069 @Nullable ModuleContainerGroup moduleContainerGroup 070 ) { 071 return assertThatContainerGroup(moduleContainerGroup); 072 } 073 074 /** 075 * Perform an assertion on an output container group. 076 * 077 * <p>This is a shorthand alias for {@link #assertThatContainerGroup(OutputContainerGroup)}. If 078 * you are using AssertJ assertions in your tests with static imports, you may wish to use that 079 * instead to prevent name conflicts. 080 * 081 * @param outputContainerGroup the output container group to assert on. 082 * @return the assertion. 083 */ 084 public static OutputContainerGroupAssert assertThat( 085 @Nullable OutputContainerGroup outputContainerGroup 086 ) { 087 return assertThatContainerGroup(outputContainerGroup); 088 } 089 090 /** 091 * Perform an assertion on a package container group. 092 * 093 * <p>This is a shorthand alias for {@link #assertThatContainerGroup(PackageContainerGroup)}. If 094 * you are using AssertJ assertions in your tests with static imports, you may wish to use that 095 * instead to prevent name conflicts. 096 * 097 * @param packageContainerGroup the package container group to assert on. 098 * @return the assertion. 099 */ 100 public static PackageContainerGroupAssert assertThat( 101 @Nullable PackageContainerGroup packageContainerGroup 102 ) { 103 return assertThatContainerGroup(packageContainerGroup); 104 } 105 106 /** 107 * Perform an assertion on a diagnostic. 108 * 109 * <p>This is a shorthand alias for {@link #assertThatDiagnostic(TraceDiagnostic)}. If 110 * you are using AssertJ assertions in your tests with static imports, you may wish to use that 111 * instead to prevent name conflicts. 112 * 113 * @param diagnostic the diagnostic to assert on. 114 * @return the assertion. 115 */ 116 public static TraceDiagnosticAssert assertThat( 117 @Nullable TraceDiagnostic<? extends JavaFileObject> diagnostic 118 ) { 119 return assertThatDiagnostic(diagnostic); 120 } 121 122 /** 123 * Perform an assertion on a Java file object. 124 * 125 * <p>This is a shorthand alias for {@link #assertThatFileObject(JavaFileObject)}. If you are 126 * using AssertJ assertions in your tests with static imports, you may wish to use that instead to 127 * prevent name conflicts. 128 * 129 * @param fileObject the file object to assert on. 130 * @return the assertion. 131 */ 132 public static JavaFileObjectAssert assertThat(@Nullable JavaFileObject fileObject) { 133 return assertThatFileObject(fileObject); 134 } 135 136 /** 137 * Perform an assertion on a Path-based Java file object. 138 * 139 * <p>This is a shorthand alias for {@link #assertThatFileObject(PathFileObject)}. If you are 140 * using AssertJ assertions in your tests with static imports, you may wish to use that instead to 141 * prevent name conflicts. 142 * 143 * @param fileObject the file object to assert on. 144 * @return the assertion. 145 */ 146 public static PathFileObjectAssert assertThat(@Nullable PathFileObject fileObject) { 147 return assertThatFileObject(fileObject); 148 } 149 150 /** 151 * Perform an assertion on a diagnostic kind. 152 * 153 * <p>This is a shorthand alias for {@link #assertThatKind(Diagnostic.Kind)}. If you are using 154 * AssertJ assertions in your tests with static imports, you may wish to use that instead to 155 * prevent name conflicts. 156 * 157 * @param kind the diagnostic kind to assert on. 158 * @return the assertion. 159 */ 160 public static DiagnosticKindAssert assertThat(Diagnostic.@Nullable Kind kind) { 161 return assertThatKind(kind); 162 } 163 164 /** 165 * Perform an assertion on a Java file object kind. 166 * 167 * <p>This is a shorthand alias for {@link #assertThatKind(JavaFileObject.Kind)}. If you are 168 * using AssertJ assertions in your tests with static imports, you may wish to use that instead to 169 * prevent name conflicts. 170 * 171 * @param kind the Java file object kind to assert on. 172 * @return the assertion. 173 */ 174 public static JavaFileObjectKindAssert assertThat(JavaFileObject.@Nullable Kind kind) { 175 return assertThatKind(kind); 176 } 177 178 /** 179 * Perform an assertion on a location. 180 * 181 * <p>This is a shorthand alias for {@link #assertThatLocation(Location)}. If you are using 182 * AssertJ assertions in your tests with static imports, you may wish to use that instead to 183 * prevent name conflicts. 184 * 185 * @param location the location to assert on. 186 * @return the assertion. 187 */ 188 public static LocationAssert assertThat(@Nullable Location location) { 189 return assertThatLocation(location); 190 } 191 192 /** 193 * Perform an assertion on a compilation. 194 * 195 * @param compilation the compilation to assert on. 196 * @return the assertion. 197 */ 198 public static JctCompilationAssert assertThatCompilation(@Nullable JctCompilation compilation) { 199 return new JctCompilationAssert(compilation); 200 } 201 202 /** 203 * Perform an assertion on a module container group. 204 * 205 * @param moduleContainerGroup the module container group to assert on. 206 * @return the assertion. 207 */ 208 public static ModuleContainerGroupAssert assertThatContainerGroup( 209 @Nullable ModuleContainerGroup moduleContainerGroup 210 ) { 211 return new ModuleContainerGroupAssert(moduleContainerGroup); 212 } 213 214 /** 215 * Perform an assertion on an output container group. 216 * 217 * @param outputContainerGroup the output container group to assert on. 218 * @return the assertion. 219 */ 220 public static OutputContainerGroupAssert assertThatContainerGroup( 221 @Nullable OutputContainerGroup outputContainerGroup 222 ) { 223 return new OutputContainerGroupAssert(outputContainerGroup); 224 } 225 226 /** 227 * Perform an assertion on a package container group. 228 * 229 * @param packageContainerGroup the package container group to assert on. 230 * @return the assertion. 231 */ 232 public static PackageContainerGroupAssert assertThatContainerGroup( 233 @Nullable PackageContainerGroup packageContainerGroup 234 ) { 235 return new PackageContainerGroupAssert(packageContainerGroup); 236 } 237 238 /** 239 * Perform an assertion on a diagnostic. 240 * 241 * @param diagnostic the diagnostic to assert on. 242 * @return the assertion. 243 */ 244 public static TraceDiagnosticAssert assertThatDiagnostic( 245 @Nullable TraceDiagnostic<? extends JavaFileObject> diagnostic 246 ) { 247 return new TraceDiagnosticAssert(diagnostic); 248 } 249 250 /** 251 * Perform an assertion on a list of diagnostics. 252 * 253 * @param diagnostics the diagnostics to assert on. 254 * @return the assertion. 255 */ 256 public static TraceDiagnosticListAssert assertThatDiagnostics( 257 @Nullable List<? extends TraceDiagnostic<? extends JavaFileObject>> diagnostics 258 ) { 259 return new TraceDiagnosticListAssert(diagnostics); 260 } 261 262 /** 263 * Perform an assertion on a Java file object. 264 * 265 * @param fileObject the file object to assert on. 266 * @return the assertion. 267 */ 268 public static JavaFileObjectAssert assertThatFileObject(@Nullable JavaFileObject fileObject) { 269 return new JavaFileObjectAssert(fileObject); 270 } 271 272 /** 273 * Perform an assertion on a Path-based Java file object. 274 * 275 * @param fileObject the file object to assert on. 276 * @return the assertion. 277 */ 278 public static PathFileObjectAssert assertThatFileObject(@Nullable PathFileObject fileObject) { 279 return new PathFileObjectAssert(fileObject); 280 } 281 282 /** 283 * Perform an assertion on a diagnostic kind. 284 * 285 * @param kind the diagnostic kind to assert on. 286 * @return the assertion. 287 */ 288 public static DiagnosticKindAssert assertThatKind(Diagnostic.@Nullable Kind kind) { 289 return new DiagnosticKindAssert(kind); 290 } 291 292 /** 293 * Perform an assertion on a Java file object kind. 294 * 295 * @param kind the Java file object kind to assert on. 296 * @return the assertion. 297 */ 298 public static JavaFileObjectKindAssert assertThatKind(JavaFileObject.@Nullable Kind kind) { 299 return new JavaFileObjectKindAssert(kind); 300 } 301 302 /** 303 * Perform an assertion on a location. 304 * 305 * @param location the location to assert on. 306 * @return the assertion. 307 */ 308 public static LocationAssert assertThatLocation(@Nullable Location location) { 309 return new LocationAssert(location); 310 } 311} 312