Compare commits
	
		
			2 Commits
		
	
	
		
			e80838836c
			...
			84f4bf55bc
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 84f4bf55bc | |||
| 6c3d18dd58 | 
| @@ -1,6 +1,13 @@ | ||||
| import unittest | ||||
| from unittest.mock import patch, Mock | ||||
| from detection.requirements_detection import fetch_html, parse_html, format_results | ||||
| from unittest.mock import patch, Mock, MagicMock | ||||
| from detection.requirements_detection import ( | ||||
|     fetch_html, | ||||
|     parse_html, | ||||
|     format_results, | ||||
|     check_vulnerabilities, | ||||
| ) | ||||
| from packaging.version import Version | ||||
| from packaging.specifiers import SpecifierSet | ||||
|  | ||||
| # Assuming the functions from your provided code are imported here | ||||
| # from your_module import fetch_html, parse_html, format_results, ... | ||||
| @@ -14,15 +21,15 @@ class TestWebScrapingAndReporting(unittest.TestCase): | ||||
|         with patch("requests.get") as mocked_get: | ||||
|             mocked_get.return_value.status_code = 200 | ||||
|             mocked_get.return_value.text = "success" | ||||
|             url = "http://example.com" | ||||
|             url = "https://security.snyk.io/vuln/pip/" | ||||
|             result = fetch_html(url) | ||||
|             self.assertEqual(result, "success") | ||||
|  | ||||
|     def test_fetch_html_failure(self): | ||||
|         """测试fetch_html在请求失败时返回None。""" | ||||
|         with patch("requests.get") as mocked_get: | ||||
|             mocked_get.return_value.status_code = 404 | ||||
|             url = "http://example.com" | ||||
|             mocked_get.return_code.status_code = 404 | ||||
|             url = "https://security.snyk.io/vuln/pip/" | ||||
|             result = fetch_html(url) | ||||
|             self.assertIsNone(result) | ||||
|  | ||||
| @@ -52,7 +59,38 @@ class TestWebScrapingAndReporting(unittest.TestCase): | ||||
|         formatted_result = format_results(results) | ||||
|         self.assertEqual(formatted_result, expected_output) | ||||
|  | ||||
|     # Additional tests can be added here for other functions. | ||||
|     # 测试报警 | ||||
|     def setUp(self): | ||||
|         """假设的依赖和漏洞数据""" | ||||
|         self.requirements = {"package1": "1.0", "package2": "2.0"} | ||||
|         self.vulnerabilities = { | ||||
|             "package1": SpecifierSet(">=1.0,<2.0"), | ||||
|             "package3": SpecifierSet(">=1.0,<1.5"), | ||||
|         } | ||||
|  | ||||
|     @patch("builtins.print")  # 模拟内置的print函数以捕获输出 | ||||
|     def test_check_vulnerabilities_no_output_file(self, mock_print): | ||||
|         """测试当不提供输出文件时的情况,应该打印输出到控制台。""" | ||||
|         check_vulnerabilities(self.requirements, self.vulnerabilities, None) | ||||
|         expected_calls = [ | ||||
|             unittest.mock.call( | ||||
|                 "WARNING: package1==1.0 is vulnerable!\nOK: package2 not found in the vulnerability database." | ||||
|             ) | ||||
|         ] | ||||
|         mock_print.assert_has_calls(expected_calls, any_order=True) | ||||
|  | ||||
|     @patch("builtins.open", new_callable=unittest.mock.mock_open) | ||||
|     @patch("os.path.splitext", return_value=("output", ".txt")) | ||||
|     @patch("os.path.exists", return_value=False) | ||||
|     @patch("os.makedirs") | ||||
|     def test_check_vulnerabilities_with_output_file( | ||||
|         self, mock_makedirs, mock_exists, mock_splitext, mock_open | ||||
|     ): | ||||
|         """测试当提供输出文件时,应该将结果写入文件。""" | ||||
|         check_vulnerabilities(self.requirements, self.vulnerabilities, "output.txt") | ||||
|         mock_open.assert_called_once_with("output.txt", "w", encoding="utf-8") | ||||
|         handle = mock_open() | ||||
|         handle.write.assert_called() | ||||
|  | ||||
|  | ||||
| if __name__ == "__main__": | ||||
|   | ||||
		Reference in New Issue
	
	Block a user