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

org.codenarc.CodeNarcRunner.groovy Maven / Gradle / Ivy

There is a newer version: 3.5.0-groovy-4.0
Show newest version
/*
 * Copyright 2009 the original author or authors.
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *      http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */
package org.codenarc

import org.apache.log4j.Logger
import org.codenarc.analyzer.SourceAnalyzer
import org.codenarc.results.Results
import org.codenarc.ruleregistry.RuleRegistryInitializer
import org.codenarc.ruleset.CompositeRuleSet
import org.codenarc.ruleset.PropertiesFileRuleSetConfigurer
import org.codenarc.ruleset.RuleSet
import org.codenarc.ruleset.RuleSetUtil

/**
 * Helper class to run CodeNarc.
 * 

* The following properties must be configured before invoking the execute() method: *

    *
  • rulesetfiles - The path to the Groovy or XML RuleSet definition files, relative to the classpath. This can be a * single file path, or multiple paths separated by commas.
  • *
  • sourceAnalyzer - An instance of a org.codenarc.analyzer.SourceAnalyzer implementation.
  • *
  • reportWriters - The list of ReportWriter instances. A report is generated * for each element in this list. At least one ReportWriter must be configured.
  • *
* * NOTE: This is an internal class. Its API is subject to change. * * @author Chris Mair */ class CodeNarcRunner { private static final LOG = Logger.getLogger(CodeNarcRunner) String ruleSetFiles SourceAnalyzer sourceAnalyzer List reportWriters = [] /** * The main entry point for this class. Runs CodeNarc and returns the results. Processing steps include: *
    *
  1. Parse the ruleSetFiles property to create a RuleSet.
  2. *
  3. Configure the RuleSet from the "codenarc.properties" file, if that file is found on the classpath.
  4. *
  5. Apply the configured SourceAnalyzer.
  6. *
  7. Generate a report for each configured ReportWriter.
  8. *
  9. Return the Results object representing the analysis results.
  10. *
* @returns the Results object containing the results of the CodeNarc analysis. */ Results execute() { assert ruleSetFiles, 'The ruleSetFiles property must be set' assert sourceAnalyzer, 'The sourceAnalyzer property must be set to a valid SourceAnalayzer' def startTime = System.currentTimeMillis() new RuleRegistryInitializer().initializeRuleRegistry() def ruleSet = createRuleSet() new PropertiesFileRuleSetConfigurer().configure(ruleSet) def results = sourceAnalyzer.analyze(ruleSet) def p1 = results.getNumberOfViolationsWithPriority(1, true) def p2 = results.getNumberOfViolationsWithPriority(2, true) def p3 = results.getNumberOfViolationsWithPriority(3, true) def countsText = "(p1=$p1; p2=$p2; p3=$p3)" def elapsedTime = System.currentTimeMillis() - startTime LOG.debug("results=$results") def analysisContext = new AnalysisContext(ruleSet:ruleSet, sourceDirectories:sourceAnalyzer.sourceDirectories) reportWriters.each { reportWriter -> reportWriter.writeReport(analysisContext, results) } def resultsMessage = 'CodeNarc completed: ' + countsText + " ${elapsedTime}ms" println resultsMessage results } /** * Create and return the RuleSet that provides the source of Rules to be applied. * The returned RuleSet may aggregate multiple underlying RuleSets. * @return a single RuleSet */ protected RuleSet createRuleSet() { def paths = ruleSetFiles.tokenize(',') def newRuleSet = new CompositeRuleSet() paths.each { path -> def ruleSet = RuleSetUtil.loadRuleSetFile(path.trim()) newRuleSet.addRuleSet(ruleSet) } newRuleSet } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy