/** * Powerunit - A JDK1.8 test framework * Copyright (C) 2014 Mathieu Boretti. * * This file is part of Powerunit * * Powerunit is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * Powerunit is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with Powerunit. If not, see <http://www.gnu.org/licenses/>. */ package ch.powerunit.impl.validator; import java.util.HashSet; import java.util.Set; import javax.annotation.processing.ProcessingEnvironment; import javax.annotation.processing.RoundEnvironment; import javax.lang.model.element.Element; import javax.lang.model.element.ElementKind; import javax.lang.model.element.ExecutableElement; import javax.lang.model.element.Modifier; import javax.lang.model.element.TypeElement; import javax.lang.model.type.DeclaredType; import javax.lang.model.type.TypeKind; import javax.lang.model.type.TypeMirror; import ch.powerunit.Parameters; import ch.powerunit.TestDelegator; public interface ParametersProcessorValidator extends ProcessValidator { default void parametersValidation(ProcessingEnvironment processingEnv, RoundEnvironment roundEnv) { Set<Element> exists = new HashSet<>(); Set<? extends Element> elements = roundEnv .getElementsAnnotatedWith(Parameters.class); TypeElement stream = processingEnv.getElementUtils().getTypeElement( "java.util.stream.Stream"); for (Element element : elements) { if (element.getKind() != ElementKind.METHOD) { error("@Parameters must prefix a method -- " + element + " is not a method"); continue; } Element parent = element.getEnclosingElement(); if (exists.contains(parent)) { warn("Class " + elementAsString(parent) + "\n\t contains more than one @Parameters method\n\tOnly one @Parameters method is allowed for a test class"); } exists.add(parent); ExecutableElement ee = (ExecutableElement) element; if (!ee.getModifiers().contains(Modifier.STATIC)) { warn("Method " + elementAsString(element) + "\n\tis prefixed with @Parameters and is not static\n\tThe parameters method must be static"); } if (!ee.getModifiers().contains(Modifier.PUBLIC)) { warn("Method " + elementAsString(element) + "\n\tis prefixed with @Parameters and is not public\n\tThe parameters method must be public"); } TypeMirror rt = ee.getReturnType(); if (rt.getKind() != TypeKind.DECLARED) { warn("Method " + elementAsString(element) + "\n\tis prefixed with @Parameters and return " + rt + "\n\tThe parameters method must return " + stream); } else { DeclaredType dt = (DeclaredType) rt; if (!processingEnv.getTypeUtils().isSubtype( dt.asElement().asType(), stream.asType())) { warn("Method " + elementAsString(element) + "\n\tis prefixed with @Parameters and return " + dt.asElement().asType() + "\n\tThe parameters method must return " + stream); } } if (!ee.getParameters().isEmpty() && ee.getEnclosingElement().getAnnotation( TestDelegator.class) == null) { warn("Method " + elementAsString(element) + "\n\tis prefixed with @Parameters and is not 0-args\n\tThe parameters method must be 0-args"); } if (ee.getParameters().size() != 1 && ee.getEnclosingElement().getAnnotation( TestDelegator.class) != null) { warn("Method " + elementAsString(element) + "\n\tis prefixed with @Parameters and is not 1-args\n\tThe parameters method must be 1-args when used with TestDelegator."); } } } }