|
87 | 87 | SONAR_PYTHON_XUNIT_SKIP_DETAILS, |
88 | 88 | SONAR_MODULES, |
89 | 89 | ) |
| 90 | +from pysonar_scanner.exceptions import UnexpectedCliArgument |
90 | 91 |
|
91 | 92 | EXPECTED_CONFIGURATION = { |
92 | 93 | SONAR_TOKEN: "myToken", |
@@ -439,3 +440,82 @@ def test_both_boolean_args_given(self): |
439 | 440 | with patch("sys.argv", [*patch_template, "-Dsonar.scm.exclusions.disabled=true"]): |
440 | 441 | configuration = CliConfigurationLoader.load() |
441 | 442 | self.assertTrue(configuration.get(SONAR_SCM_EXCLUSIONS_DISABLED)) |
| 443 | + |
| 444 | + @patch( |
| 445 | + "sys.argv", |
| 446 | + [ |
| 447 | + "myscript.py", |
| 448 | + "--token", |
| 449 | + "myToken", |
| 450 | + "--sonar-project-key", |
| 451 | + "myProjectKey", |
| 452 | + "-Dunknown.property=unknownValue", |
| 453 | + "-Danother.unknown.property=anotherValue", |
| 454 | + ], |
| 455 | + ) |
| 456 | + def test_unknown_args_with_D_prefix(self): |
| 457 | + configuration = CliConfigurationLoader.load() |
| 458 | + expected_configuration = { |
| 459 | + SONAR_TOKEN: "myToken", |
| 460 | + SONAR_PROJECT_KEY: "myProjectKey", |
| 461 | + "unknown.property": "unknownValue", |
| 462 | + "another.unknown.property": "anotherValue", |
| 463 | + } |
| 464 | + self.assertDictEqual(configuration, expected_configuration) |
| 465 | + |
| 466 | + @patch( |
| 467 | + "sys.argv", |
| 468 | + [ |
| 469 | + "myscript.py", |
| 470 | + "--token", |
| 471 | + "myToken", |
| 472 | + "--sonar-project-key", |
| 473 | + "myProjectKey", |
| 474 | + "-Dunknown.flag", |
| 475 | + ], |
| 476 | + ) |
| 477 | + def test_unknown_args_no_value(self): |
| 478 | + configuration = CliConfigurationLoader.load() |
| 479 | + expected_configuration = { |
| 480 | + SONAR_TOKEN: "myToken", |
| 481 | + SONAR_PROJECT_KEY: "myProjectKey", |
| 482 | + "unknown.flag": "true", |
| 483 | + } |
| 484 | + self.assertDictEqual(configuration, expected_configuration) |
| 485 | + |
| 486 | + @patch( |
| 487 | + "sys.argv", |
| 488 | + [ |
| 489 | + "myscript.py", |
| 490 | + "--token", |
| 491 | + "myToken", |
| 492 | + "--sonar-project-key", |
| 493 | + "myProjectKey", |
| 494 | + "-unknown.property=some_value", |
| 495 | + ], |
| 496 | + ) |
| 497 | + def test_unknown_args_missing_D_prefix(self): |
| 498 | + with self.assertRaises( |
| 499 | + UnexpectedCliArgument, msg="Unexpected argument format: -unknown.property=some_value=another_value" |
| 500 | + ): |
| 501 | + CliConfigurationLoader.load() |
| 502 | + |
| 503 | + @patch( |
| 504 | + "sys.argv", |
| 505 | + [ |
| 506 | + "myscript.py", |
| 507 | + "--token", |
| 508 | + "myToken", |
| 509 | + "--sonar-project-key", |
| 510 | + "myProjectKey", |
| 511 | + "-Dsonar.unknown.property=some_value=another_value", |
| 512 | + ], |
| 513 | + ) |
| 514 | + def test_unknown_args_unexpected_format(self): |
| 515 | + configuration = CliConfigurationLoader.load() |
| 516 | + expected_configuration = { |
| 517 | + SONAR_TOKEN: "myToken", |
| 518 | + SONAR_PROJECT_KEY: "myProjectKey", |
| 519 | + "sonar.unknown.property": "some_value=another_value", |
| 520 | + } |
| 521 | + self.assertDictEqual(configuration, expected_configuration) |
0 commit comments