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 static java.util.Objects.requireNonNull; 019 020import io.github.ascopes.jct.containers.ModuleContainerGroup; 021import io.github.ascopes.jct.filemanagers.ModuleLocation; 022import io.github.ascopes.jct.utils.StringUtils; 023import org.jspecify.annotations.Nullable; 024 025/** 026 * Assertions for module container groups. 027 * 028 * @author Ashley Scopes 029 * @since 0.0.1 030 */ 031public final class ModuleContainerGroupAssert 032 extends AbstractContainerGroupAssert<ModuleContainerGroupAssert, ModuleContainerGroup> { 033 034 /** 035 * Initialize the container group assertions. 036 * 037 * @param containerGroup the container group to assert upon. 038 */ 039 public ModuleContainerGroupAssert(@Nullable ModuleContainerGroup containerGroup) { 040 super(containerGroup, ModuleContainerGroupAssert.class); 041 } 042 043 /** 044 * Assert that the given module exists and then return assertions to perform on that module. 045 * 046 * @param module the module name. 047 * @return the assertions to perform on the package container group. 048 * @throws AssertionError if the container group is null or if the module does not exist. 049 * @throws NullPointerException if the module parameter is null. 050 */ 051 public PackageContainerGroupAssert moduleExists(String module) { 052 requireNonNull(module, "module"); 053 isNotNull(); 054 055 var moduleGroup = actual.getModule(module); 056 057 if (moduleGroup != null) { 058 return new PackageContainerGroupAssert(moduleGroup); 059 } 060 061 throw failure(StringUtils.resultNotFoundWithFuzzySuggestions( 062 module, 063 module, 064 actual.getModules().keySet(), 065 ModuleLocation::getModuleName, 066 ModuleLocation::getModuleName, 067 "module" 068 )); 069 } 070 071 /** 072 * Assert that the given module does not exist. 073 * 074 * @param module the module name. 075 * @return this assertion object for further assertion calls. 076 * @throws AssertionError if the container group is null or if the module exists. 077 * @throws NullPointerException if the module parameter is null. 078 */ 079 public ModuleContainerGroupAssert moduleDoesNotExist(String module) { 080 requireNonNull(module, "module"); 081 isNotNull(); 082 083 var moduleGroup = actual.getModule(module); 084 085 if (moduleGroup == null) { 086 return this; 087 } 088 089 throw failure("Found unexpected module %s", module); 090 } 091}