]> source.dussan.org Git - sonarqube.git/commitdiff
SONAR-1526 ResourceFilters are not used by Squid
authorsimonbrandhof <simon.brandhof@gmail.com>
Fri, 21 Jan 2011 16:55:47 +0000 (17:55 +0100)
committersimonbrandhof <simon.brandhof@gmail.com>
Fri, 21 Jan 2011 16:55:47 +0000 (17:55 +0100)
plugins/sonar-squid-java-plugin/src/main/java/org/sonar/plugins/squid/bridges/CommentLinesDensityBridge.java [deleted file]
plugins/sonar-squid-java-plugin/src/main/java/org/sonar/plugins/squid/bridges/CopyBasicMeasuresBridge.java [new file with mode: 0644]
plugins/sonar-squid-java-plugin/src/main/java/org/sonar/plugins/squid/bridges/OneToOneBridge.java [deleted file]
plugins/sonar-squid-java-plugin/src/main/java/org/sonar/plugins/squid/bridges/PublicUndocumentedApiBridge.java
plugins/sonar-squid-java-plugin/src/test/java/org/sonar/plugins/squid/bridges/BridgeFactoryTest.java
plugins/sonar-squid-java-plugin/src/test/java/org/sonar/plugins/squid/bridges/CommentLinesDensityBridgeTest.java [deleted file]
plugins/sonar-squid-java-plugin/src/test/java/org/sonar/plugins/squid/bridges/PublicUndocumentedApiBridgeTest.java

diff --git a/plugins/sonar-squid-java-plugin/src/main/java/org/sonar/plugins/squid/bridges/CommentLinesDensityBridge.java b/plugins/sonar-squid-java-plugin/src/main/java/org/sonar/plugins/squid/bridges/CommentLinesDensityBridge.java
deleted file mode 100644 (file)
index 1390403..0000000
+++ /dev/null
@@ -1,43 +0,0 @@
-/*
- * Sonar, open source software quality management tool.
- * Copyright (C) 2009 SonarSource SA
- * mailto:contact AT sonarsource DOT com
- *
- * Sonar 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.
- *
- * Sonar 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 Sonar; if not, write to the Free Software
- * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02
- */
-package org.sonar.plugins.squid.bridges;
-
-import org.sonar.api.measures.CoreMetrics;
-import org.sonar.api.resources.Resource;
-import org.sonar.api.utils.ParsingUtils;
-import org.sonar.squid.api.SourceCode;
-import org.sonar.squid.measures.Metric;
-
-public class CommentLinesDensityBridge extends BasicBridge {
-
-  protected CommentLinesDensityBridge() {
-    super(false);
-  }
-
-  @Override
-  protected final void onResource(SourceCode squidResource, Resource sonarResource) {
-    if (squidResource.getDouble(Metric.LINES) > 0) {
-      context.saveMeasure(
-          sonarResource,
-          CoreMetrics.COMMENT_LINES_DENSITY,
-          ParsingUtils.scaleValue(squidResource.getDouble(Metric.COMMENT_LINES_DENSITY) * 100, 2));
-    }
-  }
-}
diff --git a/plugins/sonar-squid-java-plugin/src/main/java/org/sonar/plugins/squid/bridges/CopyBasicMeasuresBridge.java b/plugins/sonar-squid-java-plugin/src/main/java/org/sonar/plugins/squid/bridges/CopyBasicMeasuresBridge.java
new file mode 100644 (file)
index 0000000..94f7b3b
--- /dev/null
@@ -0,0 +1,72 @@
+/*
+ * Sonar, open source software quality management tool.
+ * Copyright (C) 2009 SonarSource SA
+ * mailto:contact AT sonarsource DOT com
+ *
+ * Sonar 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.
+ *
+ * Sonar 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 Sonar; if not, write to the Free Software
+ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02
+ */
+package org.sonar.plugins.squid.bridges;
+
+import org.sonar.api.measures.CoreMetrics;
+import org.sonar.api.resources.Resource;
+import org.sonar.api.utils.ParsingUtils;
+import org.sonar.java.api.JavaClass;
+import org.sonar.java.api.JavaMethod;
+import org.sonar.squid.api.SourceClass;
+import org.sonar.squid.api.SourceCode;
+import org.sonar.squid.api.SourceFile;
+import org.sonar.squid.api.SourceMethod;
+import org.sonar.squid.measures.Metric;
+
+public final class CopyBasicMeasuresBridge extends Bridge {
+
+  protected CopyBasicMeasuresBridge() {
+    super(false);
+  }
+
+  @Override
+  public void onFile(SourceFile squidFile, Resource sonarResource) {
+    copyStandard(squidFile, sonarResource);
+    copy(squidFile, sonarResource, Metric.CLASSES, CoreMetrics.CLASSES);
+    copy(squidFile, sonarResource, Metric.FILES, CoreMetrics.FILES);
+    context.saveMeasure(sonarResource, CoreMetrics.PUBLIC_DOCUMENTED_API_DENSITY, ParsingUtils.scaleValue(squidFile.getDouble(Metric.PUBLIC_DOCUMENTED_API_DENSITY) * 100, 2));
+  }
+
+  @Override
+  public void onClass(SourceClass squidClass, JavaClass sonarClass) {
+    copyStandard(squidClass, sonarClass);
+  }
+
+  @Override
+  public void onMethod(SourceMethod squidMethod, JavaMethod sonarMethod) {
+    copyStandard(squidMethod, sonarMethod);
+  }
+
+  private void copyStandard(SourceCode squidCode, Resource sonarResource) {
+    copy(squidCode, sonarResource, Metric.LINES_OF_CODE, CoreMetrics.NCLOC);
+    copy(squidCode, sonarResource, Metric.LINES, CoreMetrics.LINES);
+    copy(squidCode, sonarResource, Metric.COMMENT_LINES_WITHOUT_HEADER, CoreMetrics.COMMENT_LINES);
+    copy(squidCode, sonarResource, Metric.METHODS, CoreMetrics.FUNCTIONS);
+    copy(squidCode, sonarResource, Metric.ACCESSORS, CoreMetrics.ACCESSORS);
+    copy(squidCode, sonarResource, Metric.PUBLIC_API, CoreMetrics.PUBLIC_API);
+    copy(squidCode, sonarResource, Metric.COMPLEXITY, CoreMetrics.COMPLEXITY);
+    copy(squidCode, sonarResource, Metric.STATEMENTS, CoreMetrics.STATEMENTS);
+    copy(squidCode, sonarResource, Metric.COMMENTED_OUT_CODE_LINES, CoreMetrics.COMMENTED_OUT_CODE_LINES);
+  }
+
+  private void copy(SourceCode squidResource, Resource sonarResource, Metric squidMetric, org.sonar.api.measures.Metric sonarMetric) {
+    context.saveMeasure(sonarResource, sonarMetric, squidResource.getDouble(squidMetric));
+  }
+}
diff --git a/plugins/sonar-squid-java-plugin/src/main/java/org/sonar/plugins/squid/bridges/OneToOneBridge.java b/plugins/sonar-squid-java-plugin/src/main/java/org/sonar/plugins/squid/bridges/OneToOneBridge.java
deleted file mode 100644 (file)
index 705a70f..0000000
+++ /dev/null
@@ -1,49 +0,0 @@
-/*
- * Sonar, open source software quality management tool.
- * Copyright (C) 2009 SonarSource SA
- * mailto:contact AT sonarsource DOT com
- *
- * Sonar 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.
- *
- * Sonar 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 Sonar; if not, write to the Free Software
- * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02
- */
-package org.sonar.plugins.squid.bridges;
-
-import org.sonar.api.measures.CoreMetrics;
-import org.sonar.api.resources.Resource;
-import org.sonar.api.utils.ParsingUtils;
-import org.sonar.squid.api.SourceCode;
-import org.sonar.squid.measures.Metric;
-
-public class OneToOneBridge extends BasicBridge {
-
-  protected OneToOneBridge() {
-    super(false);
-  }
-
-  @Override
-  protected void onResource(SourceCode squidResource, Resource sonarResource) {
-    context.saveMeasure(sonarResource, CoreMetrics.NCLOC, squidResource.getDouble(Metric.LINES_OF_CODE));
-    context.saveMeasure(sonarResource, CoreMetrics.LINES, squidResource.getDouble(Metric.LINES));
-    context.saveMeasure(sonarResource, CoreMetrics.COMMENT_LINES, squidResource.getDouble(Metric.COMMENT_LINES_WITHOUT_HEADER));
-    context.saveMeasure(sonarResource, CoreMetrics.FUNCTIONS, squidResource.getDouble(Metric.METHODS));
-    context.saveMeasure(sonarResource, CoreMetrics.ACCESSORS, squidResource.getDouble(Metric.ACCESSORS));
-    context.saveMeasure(sonarResource, CoreMetrics.PUBLIC_API, squidResource.getDouble(Metric.PUBLIC_API));
-    context.saveMeasure(sonarResource, CoreMetrics.CLASSES, squidResource.getDouble(Metric.CLASSES));
-    context.saveMeasure(sonarResource, CoreMetrics.COMPLEXITY, squidResource.getDouble(Metric.COMPLEXITY));
-    context.saveMeasure(sonarResource, CoreMetrics.STATEMENTS, squidResource.getDouble(Metric.STATEMENTS));
-    context.saveMeasure(sonarResource, CoreMetrics.FILES, squidResource.getDouble(Metric.FILES));
-    context.saveMeasure(sonarResource, CoreMetrics.COMMENTED_OUT_CODE_LINES, squidResource.getDouble(Metric.COMMENTED_OUT_CODE_LINES));
-    context.saveMeasure(sonarResource, CoreMetrics.PUBLIC_DOCUMENTED_API_DENSITY, ParsingUtils.scaleValue(squidResource.getDouble(Metric.PUBLIC_DOCUMENTED_API_DENSITY) * 100, 2));
-  }
-}
index c0c4ca0af861b417550a55dc11131cd7531c39cc..bd455b4618700103628bf890bb60027f0e3cb810 100644 (file)
@@ -21,17 +21,36 @@ package org.sonar.plugins.squid.bridges;
 
 import org.sonar.api.measures.CoreMetrics;
 import org.sonar.api.resources.Resource;
+import org.sonar.java.api.JavaClass;
+import org.sonar.java.api.JavaMethod;
+import org.sonar.squid.api.SourceClass;
 import org.sonar.squid.api.SourceCode;
+import org.sonar.squid.api.SourceFile;
+import org.sonar.squid.api.SourceMethod;
 import org.sonar.squid.measures.Metric;
 
-public class PublicUndocumentedApiBridge extends BasicBridge {
+public final class PublicUndocumentedApiBridge extends Bridge {
 
   protected PublicUndocumentedApiBridge() {
     super(false);
   }
 
   @Override
-  protected void onResource(SourceCode squidResource, Resource sonarResource) {
+  public void onFile(SourceFile squidFile, Resource sonarFile) {
+    copyValue(squidFile, sonarFile);
+  }
+
+  @Override
+  public void onClass(SourceClass squidClass, JavaClass sonarClass) {
+    copyValue(squidClass, sonarClass);
+  }
+
+  @Override
+  public void onMethod(SourceMethod squidMethod, JavaMethod sonarMethod) {
+    copyValue(squidMethod, sonarMethod);
+  }
+
+  private void copyValue(SourceCode squidResource, Resource sonarResource) {
     double undocumentedApi = squidResource.getDouble(Metric.PUBLIC_API) - squidResource.getInt(Metric.PUBLIC_DOC_API);
     context.saveMeasure(sonarResource, CoreMetrics.PUBLIC_UNDOCUMENTED_API, undocumentedApi);
   }
index cbf4ed923ad9c8775395aaf2c188b218a2693ec4..9b5e847bfc14311baa38f5ee5f160a317495f656 100644 (file)
@@ -32,14 +32,14 @@ public class BridgeFactoryTest {
   public void createForSourceAnalysis() {
     List<Bridge> astBridges = BridgeFactory.create(false, null, null, null, null, null);
     assertFalse(has(astBridges, DesignBridge.class));
-    assertTrue(has(astBridges, OneToOneBridge.class));
+    assertTrue(has(astBridges, CopyBasicMeasuresBridge.class));
   }
 
   @Test
   public void createForSourceAndBytecodeAnalysis() {
     List<Bridge> allBridges = BridgeFactory.create(true, null, null, null, null, null);
     assertTrue(has(allBridges, DesignBridge.class));
-    assertTrue(has(allBridges, OneToOneBridge.class));
+    assertTrue(has(allBridges, CopyBasicMeasuresBridge.class));
 
   }
 
diff --git a/plugins/sonar-squid-java-plugin/src/test/java/org/sonar/plugins/squid/bridges/CommentLinesDensityBridgeTest.java b/plugins/sonar-squid-java-plugin/src/test/java/org/sonar/plugins/squid/bridges/CommentLinesDensityBridgeTest.java
deleted file mode 100644 (file)
index eac3a50..0000000
+++ /dev/null
@@ -1,42 +0,0 @@
-/*
- * Sonar, open source software quality management tool.
- * Copyright (C) 2009 SonarSource SA
- * mailto:contact AT sonarsource DOT com
- *
- * Sonar 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.
- *
- * Sonar 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 Sonar; if not, write to the Free Software
- * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02
- */
-package org.sonar.plugins.squid.bridges;
-
-import org.junit.Test;
-import org.sonar.api.measures.CoreMetrics;
-import org.sonar.api.resources.JavaFile;
-import org.sonar.api.resources.JavaPackage;
-
-import static org.hamcrest.number.IsCloseTo.closeTo;
-import static org.mockito.Matchers.anyDouble;
-import static org.mockito.Matchers.doubleThat;
-import static org.mockito.Matchers.eq;
-import static org.mockito.Mockito.verify;
-
-public class CommentLinesDensityBridgeTest extends BridgeTestCase {
-
-  @Test
-  public void commentLineDensity() {
-    verify(context).saveMeasure(eq(new JavaFile("org.apache.struts.config.BaseConfig")), eq(CoreMetrics.COMMENT_LINES_DENSITY), doubleThat(closeTo(48.0, 0.1)));
-    verify(context).saveMeasure(eq(new JavaPackage("org.apache.struts.config")), eq(CoreMetrics.COMMENT_LINES_DENSITY), doubleThat(closeTo(35.2, 0.1)));
-    verify(context).saveMeasure(eq(project), eq(CoreMetrics.COMMENT_LINES_DENSITY), anyDouble());
-  }
-
-}
index 193cb8efd28b2a5915272a028f24f330bc3f888a..435af35c52916fa4ddad051c9381bbb530b1f77c 100644 (file)
@@ -22,22 +22,15 @@ package org.sonar.plugins.squid.bridges;
 import org.junit.Test;
 import org.sonar.api.measures.CoreMetrics;
 import org.sonar.api.resources.JavaFile;
-import org.sonar.api.resources.JavaPackage;
 
-import static org.hamcrest.number.OrderingComparisons.greaterThan;
-import static org.mockito.Matchers.doubleThat;
-import static org.mockito.Matchers.eq;
 import static org.mockito.Mockito.verify;
 
 public class PublicUndocumentedApiBridgeTest extends BridgeTestCase {
 
   @Test
-  public void commentLineDensity() {
+  public void publicUndocumentedApi() {
     verify(context).saveMeasure(new JavaFile("org.apache.struts.config.BaseConfig"), CoreMetrics.PUBLIC_UNDOCUMENTED_API, 0.0);
     verify(context).saveMeasure(new JavaFile("org.apache.struts.config.ConfigHelper"), CoreMetrics.PUBLIC_UNDOCUMENTED_API, 4.0);
-
-    verify(context).saveMeasure(eq(new JavaPackage("org.apache.struts.config")), eq(CoreMetrics.PUBLIC_UNDOCUMENTED_API), doubleThat(greaterThan(50.0)));
-    verify(context).saveMeasure(eq(project), eq(CoreMetrics.PUBLIC_UNDOCUMENTED_API), doubleThat(greaterThan(200.0)));
   }
 
 }