Nelze vybrat více než 25 témat Téma musí začínat písmenem nebo číslem, může obsahovat pomlčky („-“) a může být dlouhé až 35 znaků.

ScannerFactoryTest.java 3.5KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105
  1. /*
  2. * SonarScanner CLI
  3. * Copyright (C) 2011-2022 SonarSource SA
  4. * mailto:info AT sonarsource DOT com
  5. *
  6. * This program is free software; you can redistribute it and/or
  7. * modify it under the terms of the GNU Lesser General Public
  8. * License as published by the Free Software Foundation; either
  9. * version 3 of the License, or (at your option) any later version.
  10. *
  11. * This program is distributed in the hope that it will be useful,
  12. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  13. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
  14. * Lesser General Public License for more details.
  15. *
  16. * You should have received a copy of the GNU Lesser General Public License
  17. * along with this program; if not, write to the Free Software Foundation,
  18. * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
  19. */
  20. package org.sonarsource.scanner.cli;
  21. import java.util.Properties;
  22. import org.junit.Test;
  23. import org.sonarsource.scanner.api.EmbeddedScanner;
  24. import org.sonarsource.scanner.api.LogOutput;
  25. import org.sonarsource.scanner.api.LogOutput.Level;
  26. import static org.assertj.core.api.Assertions.assertThat;
  27. import static org.mockito.Mockito.mock;
  28. import static org.mockito.Mockito.reset;
  29. import static org.mockito.Mockito.verify;
  30. import static org.mockito.Mockito.verifyNoMoreInteractions;
  31. public class ScannerFactoryTest {
  32. private final Properties props = new Properties();
  33. private final Logs logs = mock(Logs.class);
  34. @Test
  35. public void should_create_embedded_runner() {
  36. props.setProperty("foo", "bar");
  37. EmbeddedScanner runner = new ScannerFactory(logs).create(props, "");
  38. assertThat(runner).isInstanceOf(EmbeddedScanner.class);
  39. assertThat(runner.globalProperties()).containsEntry("foo", "bar");
  40. assertThat(runner.app()).isEqualTo("ScannerCLI");
  41. assertThat(runner.appVersion()).isNotNull();
  42. }
  43. @Test
  44. public void should_create_embedded_runner_with_scannername_from_argument() {
  45. props.setProperty("foo", "bar");
  46. EmbeddedScanner runner = new ScannerFactory(logs).create(props, "ScannerMSBuild/4.8.0");
  47. assertThat(runner).isInstanceOf(EmbeddedScanner.class);
  48. assertThat(runner.globalProperties()).containsEntry("foo", "bar");
  49. assertThat(runner.app()).isEqualTo("ScannerMSBuild");
  50. assertThat(runner.appVersion()).isEqualTo("4.8.0");
  51. assertThat(runner.appVersion()).isNotNull();
  52. }
  53. @Test
  54. public void should_create_embedded_runner_from_argument_is_not_regex_compliant_revert_to_default_scanner_name() {
  55. props.setProperty("foo", "bar");
  56. EmbeddedScanner runner = new ScannerFactory(logs).create(props, "ScannerMSBuild4.8.0");
  57. assertThat(runner).isInstanceOf(EmbeddedScanner.class);
  58. assertThat(runner.globalProperties()).containsEntry("foo", "bar");
  59. assertThat(runner.app()).isEqualTo("ScannerCLI");
  60. assertThat(runner.appVersion()).isNotNull();
  61. }
  62. @Test
  63. public void should_fwd_logs() {
  64. LogOutput logOutput = new ScannerFactory(logs).new DefaultLogOutput();
  65. String msg = "test";
  66. logOutput.log(msg, Level.DEBUG);
  67. verify(logs).debug(msg);
  68. verifyNoMoreInteractions(logs);
  69. reset(logs);
  70. logOutput.log(msg, Level.INFO);
  71. verify(logs).info(msg);
  72. verifyNoMoreInteractions(logs);
  73. reset(logs);
  74. logOutput.log(msg, Level.ERROR);
  75. verify(logs).error(msg);
  76. verifyNoMoreInteractions(logs);
  77. reset(logs);
  78. logOutput.log(msg, Level.WARN);
  79. verify(logs).warn(msg);
  80. verifyNoMoreInteractions(logs);
  81. reset(logs);
  82. logOutput.log(msg, Level.TRACE);
  83. verify(logs).debug(msg);
  84. verifyNoMoreInteractions(logs);
  85. reset(logs);
  86. }
  87. }