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

org.sonarsource.analyzer.commons.checks.verifier.MultiFileVerifier Maven / Gradle / Ivy

/*
 * SonarSource Analyzers Test Commons
 * Copyright (C) 2009-2024 SonarSource SA
 * mailto:info AT sonarsource DOT com
 *
 * This program is free software; you can redistribute it and/or
 * modify it under the terms of the GNU Lesser General Public
 * License as published by the Free Software Foundation; either
 * version 3 of the License, or (at your option) any later version.
 *
 * This program 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
 * Lesser General Public License for more details.
 *
 * You should have received a copy of the GNU Lesser General Public License
 * along with this program; if not, write to the Free Software Foundation,
 * Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301, USA.
 */
package org.sonarsource.analyzer.commons.checks.verifier;

import java.nio.charset.Charset;
import java.nio.file.Path;
import javax.annotation.Nullable;
import org.sonarsource.analyzer.commons.checks.verifier.internal.InternalIssueVerifier;
import org.sonarsource.analyzer.commons.checks.verifier.quickfix.QuickFix;

/**
 * Example:
 * 
 *   Path path = Paths.get("main.js");
 *
 *   MultiFileVerifier verifier = MultiFileVerifier.create(path, UTF_8);
 *
 *   // use an AST visitor to add all the comment
 *   verifier.addComment(path, 12, 20, " Noncompliant {{Rule message}}", 2, 0);
 *
 *   // report all issues raised by one rule
 *   verifier.reportIssue(path, "Issue on file").onFile();
 *
 *   verifier.reportIssue(path, "Issue on line").onLine(4);
 *
 *   verifier.reportIssue(path, "Issue on range").onRange(9, 11, 9, 13)
 *     .addSecondary(path, 6, 9, 6, 11, "msg");
 *
 *   verifier.assertOneOrMoreIssues();
 * 
* Example 2: *
 *   // to expect to issue, use:
 *   verifier.assertNoIssues();
 * 
*/ public interface MultiFileVerifier { /** * @param mainSourceFilePath * @param encoding encoding used to load source file */ static MultiFileVerifier create(Path mainSourceFilePath, Charset encoding) { return new InternalIssueVerifier(mainSourceFilePath, encoding); } /** * Should be called for all comment of the analyzed source file. Example: *
   *  void visitComment(CommentToken token) {
   *    verifier.addComment(token.path(), token.line(), token.column(), token.text(), COMMENT_PREFIX_LENGTH, COMMENT_SUFFIX_LENGTH);
   *  }
   * 
* @param path path of the source code * @param line start at 1, beginning of the comment * @param column start at 1, beginning of the comment prefix * @param content content of the comment with prefix and suffix * @param prefixLength for example, if the prefix is '//' then the length is 2 * @param suffixLength for example, if the suffix is '-->' then the length is 3 */ MultiFileVerifier addComment(Path path, int line, int column, String content, int prefixLength, int suffixLength); /** * Each issue raised by a rule should be reported using this method. *
   *   verifier.reportIssue(path, "Issue on file").onFile();
   *
   *   verifier.reportIssue(path, "Issue on line").onLine(line);
   *
   *   verifier.reportIssue(path, "Issue on range with a secondary location").onRange(line, column, endLine, endColumn)
   *     .addSecondary(secondary.line, secondary.column, secondary.endLine, secondary.endColumn, "Secondary message");
   * 
* @param path path of the source code file that has the issue * @param message issue message */ IssueBuilder reportIssue(Path path, String message); /** * Run the comparison and expect to find at least one issue. */ void assertOneOrMoreIssues(); /** * Run the comparison and expect to find no issue. */ void assertNoIssues(); /** * Run the comparison and expect to find no issues. Allows Noncompliant comments to be present in the file. */ void assertNoIssuesRaised(); /** * Sets the verifier to ignore expected quick fixes. */ MultiFileVerifier withoutQuickFixes(); /** * Must always call one and only one of: onFile, onLine, onRange */ interface IssueBuilder { /** * issue is global to the source code file (not at a specific line number) */ Issue onFile(); /** * issue is related to a specific line number * @param line, start at 1 */ Issue onLine(int line); /** * issue is at a precise issue location * @param line, start at 1, line number of the first character * @param column, start at 1, column number of the first character * @param endLine, start at 1, line number of the last character, if the issue is on one line then endLine == line * @param endColumn, start at 1, column number of the last character, if there's only one character then endColumn == column */ Issue onRange(int line, int column, int endLine, int endColumn); } interface Issue { /** * @param gap Gap used for the computation of the effort (previously effortToFix) */ Issue withGap(@Nullable Double gap); /** * Add a secondary location with an optional message * @param path path of the source code file related to this location * @param line, start at 1, line number of the first character * @param column, start at 1, column number of the first character * @param endLine, start at 1, line number of the last character, if the location is on one line then endLine == line * @param endColumn, start at 1, column number of the last character, if there's only one character then endColumn == column * @param message optional message, can be null */ Issue addSecondary(Path path, int line, int column, int endLine, int endColumn, @Nullable String message); Issue addQuickFix(QuickFix quickFix); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy