From 7b85ebdefdd22560fcfeb22e5c60116690149314 Mon Sep 17 00:00:00 2001 From: Freddy Mallet Date: Mon, 24 Oct 2011 17:25:08 +0200 Subject: [PATCH] SONAR-2741 The method JavaAstScanner.scanDirectory(..) can't be called several times --- .../src/main/java/org/sonar/squid/Squid.java | 23 ++++++++---- .../java/org/sonar/squid/MyCodeScanner.java | 35 +++++++++++++++++++ .../test/java/org/sonar/squid/SquidTest.java | 33 +++++++++++++++++ 3 files changed, 85 insertions(+), 6 deletions(-) create mode 100644 sonar-squid/src/test/java/org/sonar/squid/MyCodeScanner.java create mode 100644 sonar-squid/src/test/java/org/sonar/squid/SquidTest.java diff --git a/sonar-squid/src/main/java/org/sonar/squid/Squid.java b/sonar-squid/src/main/java/org/sonar/squid/Squid.java index b2153e25ef0..760a457d770 100644 --- a/sonar-squid/src/main/java/org/sonar/squid/Squid.java +++ b/sonar-squid/src/main/java/org/sonar/squid/Squid.java @@ -20,20 +20,28 @@ package org.sonar.squid; +import java.util.Collection; +import java.util.HashSet; +import java.util.List; +import java.util.Set; + import org.picocontainer.MutablePicoContainer; import org.picocontainer.containers.TransientPicoContainer; import org.sonar.graph.DirectedGraph; import org.sonar.graph.DirectedGraphAccessor; -import org.sonar.squid.api.*; +import org.sonar.squid.api.CodeScanner; +import org.sonar.squid.api.CodeVisitor; +import org.sonar.squid.api.Query; +import org.sonar.squid.api.SourceCode; +import org.sonar.squid.api.SourceCodeEdge; +import org.sonar.squid.api.SourceCodeSearchEngine; +import org.sonar.squid.api.SourceCodeTreeDecorator; +import org.sonar.squid.api.SourceProject; +import org.sonar.squid.api.SquidConfiguration; import org.sonar.squid.indexer.SquidIndex; import org.sonar.squid.measures.Metric; import org.sonar.squid.measures.MetricDef; -import java.util.Collection; -import java.util.HashSet; -import java.util.List; -import java.util.Set; - public class Squid implements DirectedGraphAccessor, SourceCodeSearchEngine { private MutablePicoContainer pico; @@ -67,6 +75,9 @@ public class Squid implements DirectedGraphAccessor, } public SCANNER register(Class scannerClass) { + if(pico.getComponent(scannerClass) != null){ + throw new IllegalStateException("The Squid SCANNER '" + scannerClass.getName() + "' can't be registered multiple times."); + } addToPicocontainer(scannerClass); SCANNER scanner = pico.getComponent(scannerClass); for (Object clazz : scanner.getVisitorClasses()) { diff --git a/sonar-squid/src/test/java/org/sonar/squid/MyCodeScanner.java b/sonar-squid/src/test/java/org/sonar/squid/MyCodeScanner.java new file mode 100644 index 00000000000..409bef945c4 --- /dev/null +++ b/sonar-squid/src/test/java/org/sonar/squid/MyCodeScanner.java @@ -0,0 +1,35 @@ +/* + * Sonar, open source software quality management tool. + * Copyright (C) 2008-2011 SonarSource + * 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.squid; + +import java.util.ArrayList; +import java.util.Collection; + +import org.sonar.squid.api.CodeScanner; +import org.sonar.squid.api.CodeVisitor; + +public class MyCodeScanner extends CodeScanner { + + @Override + public Collection> getVisitorClasses() { + return new ArrayList>(); + } +} diff --git a/sonar-squid/src/test/java/org/sonar/squid/SquidTest.java b/sonar-squid/src/test/java/org/sonar/squid/SquidTest.java new file mode 100644 index 00000000000..576b7fed6a2 --- /dev/null +++ b/sonar-squid/src/test/java/org/sonar/squid/SquidTest.java @@ -0,0 +1,33 @@ +/* + * Sonar, open source software quality management tool. + * Copyright (C) 2008-2011 SonarSource + * 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.squid; + +import org.junit.Test; + +public class SquidTest { + + @Test(expected = IllegalStateException.class) + public void shouldNotAcceptToRegisterTwiceTheSameScanner() { + Squid squid = new Squid(); + squid.register(MyCodeScanner.class); + squid.register(MyCodeScanner.class); + } +} -- 2.39.5