feat:对正则匹配出的文件再过一次llm检测
This commit is contained in:
		| @@ -11,23 +11,41 @@ from detection.GPTdetection import detectGPT | ||||
| class TestFinalTests(unittest.TestCase): | ||||
|     def setUp(self) -> None: | ||||
|         shutil.rmtree("./tmp/repo", ignore_errors=True) | ||||
|         clone_repo("https://github.com/TheAlgorithms/Python.git", "./tmp/repo") | ||||
|         clone_repo("https://github.com/injetlee/Python.git", "./tmp/repo") | ||||
|         sampleRate = 0.1 | ||||
|         self.injectedNum = inject_random_backdoor("./tmp/repo", sample_rate=sampleRate) | ||||
|         print(self.injectedNum) | ||||
|         project_path = Path("./tmp/repo") | ||||
|         self.all_python_files = list(project_path.rglob("*.py")) | ||||
|         self.filesNum = len(self.all_python_files) | ||||
|         self.trueRate = self.injectedNum / self.filesNum | ||||
|         print(self.trueRate) | ||||
|  | ||||
|     def test_final_tests(self): | ||||
|         detectedNum = 0 | ||||
|         possibly_dangerous_file = [] | ||||
|         for file in self.all_python_files: | ||||
|             content = read_file_content(str(file)) | ||||
|             results = find_dangerous_functions(content, ".py") | ||||
|             if len(results["high"]) > 0 or len(results["medium"]) > 0 or len(results["low"]) > 0: | ||||
|                 detectedNum += 1 | ||||
|                 possibly_dangerous_file.append(file) | ||||
|         print(detectedNum / self.filesNum) | ||||
|         self.assertAlmostEqual(detectedNum / self.filesNum, self.trueRate, places=1) | ||||
|         GPTdetectedNum = 0 | ||||
|  | ||||
|         for i in possibly_dangerous_file: | ||||
|             content = read_file_content(str(i)) | ||||
|             results = {} | ||||
|             try: | ||||
|                 results = detectGPT(content) | ||||
|             except Exception as e: | ||||
|                 print(e) | ||||
|             if len(results["high"]) > 0 or len(results["medium"]) > 0 or len(results["low"]) > 0: | ||||
|                 GPTdetectedNum += 1 | ||||
|         print(GPTdetectedNum) | ||||
|         self.assertGreaterEqual(GPTdetectedNum, detectedNum) | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
|   | ||||
		Reference in New Issue
	
	Block a user