diff options
Diffstat (limited to 'src')
3 files changed, 38 insertions, 68 deletions
diff --git a/src/main/java/org/sonarsource/scanner/cli/Main.java b/src/main/java/org/sonarsource/scanner/cli/Main.java index d93116b..7144ec8 100644 --- a/src/main/java/org/sonarsource/scanner/cli/Main.java +++ b/src/main/java/org/sonarsource/scanner/cli/Main.java @@ -19,6 +19,7 @@ */ package org.sonarsource.scanner.cli; +import java.util.Map; import java.util.Properties; import org.sonarsource.scanner.api.EmbeddedScanner; import org.sonarsource.scanner.api.ScanProperties; @@ -64,32 +65,20 @@ public class Main { Stats stats = new Stats(logger).start(); int status = Exit.ERROR; - boolean started = false; try { Properties p = conf.properties(); checkSkip(p); configureLogging(p); init(p); runner.start(); - started = true; logger.info("SonarQube server " + runner.serverVersion()); - runAnalysis(stats, p); + execute(stats, p); status = Exit.SUCCESS; } catch (Throwable e) { - status = Exit.ERROR; displayExecutionResult(stats, "FAILURE"); showError("Error during SonarQube Scanner execution", e, cli.isDebugEnabled()); } finally { - try { - if (started) { - runner.stop(); - } - } catch (Throwable e) { - status = Exit.ERROR; - logger.error("Unable to properly stop the scanner", e); - } finally { - exit.exit(status); - } + exit.exit(status); } } @@ -118,8 +107,8 @@ public class Main { } } - private void runAnalysis(Stats stats, Properties p) { - runner.runAnalysis(p); + private void execute(Stats stats, Properties p) { + runner.execute((Map) p); displayExecutionResult(stats, "SUCCESS"); } diff --git a/src/main/java/org/sonarsource/scanner/cli/ScannerFactory.java b/src/main/java/org/sonarsource/scanner/cli/ScannerFactory.java index 04a6684..7fe4d9f 100644 --- a/src/main/java/org/sonarsource/scanner/cli/ScannerFactory.java +++ b/src/main/java/org/sonarsource/scanner/cli/ScannerFactory.java @@ -19,6 +19,7 @@ */ package org.sonarsource.scanner.cli; +import java.util.Map; import java.util.Properties; import org.sonarsource.scanner.api.EmbeddedScanner; import org.sonarsource.scanner.api.LogOutput; @@ -32,9 +33,8 @@ class ScannerFactory { } EmbeddedScanner create(Properties props) { - return EmbeddedScanner.create(new DefaultLogOutput()) - .addGlobalProperties(props) - .setApp("ScannerCli", ScannerVersion.version()); + return EmbeddedScanner.create("ScannerCli", ScannerVersion.version(), new DefaultLogOutput()) + .addGlobalProperties((Map) props); } class DefaultLogOutput implements LogOutput { diff --git a/src/test/java/org/sonarsource/scanner/cli/MainTest.java b/src/test/java/org/sonarsource/scanner/cli/MainTest.java index 26e1a71..869a183 100644 --- a/src/test/java/org/sonarsource/scanner/cli/MainTest.java +++ b/src/test/java/org/sonarsource/scanner/cli/MainTest.java @@ -20,6 +20,7 @@ package org.sonarsource.scanner.cli; import java.io.IOException; +import java.util.Map; import java.util.Properties; import org.junit.Before; import org.junit.Test; @@ -33,7 +34,7 @@ import org.sonarsource.scanner.api.EmbeddedScanner; import org.sonarsource.scanner.api.ScanProperties; import static org.assertj.core.api.Assertions.assertThat; -import static org.mockito.Matchers.any; +import static org.mockito.ArgumentMatchers.any; import static org.mockito.Mockito.doThrow; import static org.mockito.Mockito.mock; import static org.mockito.Mockito.never; @@ -52,83 +53,64 @@ public class MainTest { @Mock private Properties properties; @Mock - private ScannerFactory runnerFactory; + private ScannerFactory scannerFactory; @Mock - private EmbeddedScanner runner; + private EmbeddedScanner scanner; @Mock private Logs logs; @Before public void setUp() throws IOException { MockitoAnnotations.initMocks(this); - when(runnerFactory.create(any(Properties.class))).thenReturn(runner); + when(scannerFactory.create(any(Properties.class))).thenReturn(scanner); when(conf.properties()).thenReturn(properties); } @Test public void should_execute_runner() { - Main main = new Main(exit, cli, conf, runnerFactory, logs); + Main main = new Main(exit, cli, conf, scannerFactory, logs); main.execute(); verify(exit).exit(Exit.SUCCESS); - verify(runnerFactory).create(properties); + verify(scannerFactory).create(properties); - verify(runner, times(1)).start(); - verify(runner, times(1)).runAnalysis(properties); - verify(runner, times(1)).stop(); + verify(scanner, times(1)).start(); + verify(scanner, times(1)).execute((Map) properties); } @Test - public void should_call_stop_on_error_during_analysis() { + public void should_exit_with_error_on_error_during_analysis() { EmbeddedScanner runner = mock(EmbeddedScanner.class); Exception e = new NullPointerException("NPE"); e = new IllegalStateException("Error", e); - doThrow(e).when(runner).runAnalysis(any(Properties.class)); - when(runnerFactory.create(any(Properties.class))).thenReturn(runner); + doThrow(e).when(runner).execute(any(Map.class)); + when(scannerFactory.create(any(Properties.class))).thenReturn(runner); - Main main = new Main(exit, cli, conf, runnerFactory, logs); + Main main = new Main(exit, cli, conf, scannerFactory, logs); main.execute(); - verify(runner).stop(); verify(exit).exit(Exit.ERROR); verify(logs).error("Error during SonarQube Scanner execution", e); } @Test - public void should_not_call_stop_on_error_during_start() { + public void should_exit_with_error_on_error_during_start() { EmbeddedScanner runner = mock(EmbeddedScanner.class); Exception e = new NullPointerException("NPE"); e = new IllegalStateException("Error", e); doThrow(e).when(runner).start(); - when(runnerFactory.create(any(Properties.class))).thenReturn(runner); + when(scannerFactory.create(any(Properties.class))).thenReturn(runner); - Main main = new Main(exit, cli, conf, runnerFactory, logs); + Main main = new Main(exit, cli, conf, scannerFactory, logs); main.execute(); verify(runner).start(); - verify(runner, never()).runAnalysis(any()); - verify(runner, never()).stop(); + verify(runner, never()).execute(any(Map.class)); verify(exit).exit(Exit.ERROR); verify(logs).error("Error during SonarQube Scanner execution", e); } @Test - public void should_exit_on_error() { - EmbeddedScanner runner = mock(EmbeddedScanner.class); - Exception e = new NullPointerException("NPE"); - e = new IllegalStateException("Error", e); - doThrow(e).when(runner).stop(); - when(runnerFactory.create(any(Properties.class))).thenReturn(runner); - - Main main = new Main(exit, cli, conf, runnerFactory, logs); - main.execute(); - - verify(runner).stop(); - verify(exit).exit(Exit.ERROR); - verify(logs).error("Unable to properly stop the scanner", e); - } - - @Test public void show_error_with_stacktrace() { Exception e = createException(false); testException(e, false); @@ -160,13 +142,12 @@ public class MainTest { when(cli.isDebugEnabled()).thenReturn(debugEnabled); EmbeddedScanner runner = mock(EmbeddedScanner.class); - doThrow(e).when(runner).runAnalysis(any(Properties.class)); - when(runnerFactory.create(any(Properties.class))).thenReturn(runner); + doThrow(e).when(runner).execute(any(Map.class)); + when(scannerFactory.create(any(Properties.class))).thenReturn(runner); - Main main = new Main(exit, cli, conf, runnerFactory, logs); + Main main = new Main(exit, cli, conf, scannerFactory, logs); main.execute(); - verify(runner).stop(); verify(exit).exit(Exit.ERROR); } @@ -188,13 +169,13 @@ public class MainTest { when(cli.isDisplayVersionOnly()).thenReturn(true); when(conf.properties()).thenReturn(p); - Main main = new Main(exit, cli, conf, runnerFactory, logs); + Main main = new Main(exit, cli, conf, scannerFactory, logs); main.execute(); - InOrder inOrder = Mockito.inOrder(exit, runnerFactory); + InOrder inOrder = Mockito.inOrder(exit, scannerFactory); inOrder.verify(exit, times(1)).exit(Exit.SUCCESS); - inOrder.verify(runnerFactory, times(1)).create(p); + inOrder.verify(scannerFactory, times(1)).create(p); inOrder.verify(exit, times(1)).exit(Exit.SUCCESS); } @@ -204,25 +185,25 @@ public class MainTest { p.setProperty(ScanProperties.SKIP, "true"); when(conf.properties()).thenReturn(p); - Main main = new Main(exit, cli, conf, runnerFactory, logs); + Main main = new Main(exit, cli, conf, scannerFactory, logs); main.execute(); verify(logs).info("SonarQube Scanner analysis skipped"); - InOrder inOrder = Mockito.inOrder(exit, runnerFactory); + InOrder inOrder = Mockito.inOrder(exit, scannerFactory); inOrder.verify(exit, times(1)).exit(Exit.SUCCESS); - inOrder.verify(runnerFactory, times(1)).create(p); + inOrder.verify(scannerFactory, times(1)).create(p); inOrder.verify(exit, times(1)).exit(Exit.SUCCESS); } @Test public void shouldLogServerVersion() throws IOException { - when(runner.serverVersion()).thenReturn("5.5"); + when(scanner.serverVersion()).thenReturn("5.5"); Properties p = new Properties(); when(cli.isDisplayVersionOnly()).thenReturn(true); when(conf.properties()).thenReturn(p); - Main main = new Main(exit, cli, conf, runnerFactory, logs); + Main main = new Main(exit, cli, conf, scannerFactory, logs); main.execute(); verify(logs).info("SonarQube server 5.5"); } @@ -250,14 +231,14 @@ public class MainTest { p.put(propKey, propValue); when(conf.properties()).thenReturn(p); - Main main = new Main(exit, cli, conf, runnerFactory, logs); + Main main = new Main(exit, cli, conf, scannerFactory, logs); main.execute(); // Logger used for callback should have debug enabled verify(logs).setDebugEnabled(true); ArgumentCaptor<Properties> propertiesCapture = ArgumentCaptor.forClass(Properties.class); - verify(runner).runAnalysis(propertiesCapture.capture()); + verify(scanner).execute((Map) propertiesCapture.capture()); return propertiesCapture.getValue(); } |