test_SMBScan.py 3.8 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970
  1. import unittest.mock as mock
  2. import Test.ID2TAttackTest as Test
  3. sha_default = '213e194da7bc952cc093868c7450901b0fb93c7255d694eb37ea0b9b48bca65d'
  4. sha_one_victim_linux = '4928d421caaec8f2c4e5c5bb835b5521b705478779cbc8f343b77143a5a66995'
  5. sha_victim_range_winxp_hosting = '4c6cb5cb4f838e75b41af4feb2fd9a6fe7e1b226a38b3e8759ce3d31e5a2535e'
  6. sha_multiple_victims_macos = '0be79b9ad7346562f392e07a5156de978e02f4f25ae8d409b81cc6e0d726012c'
  7. sha_port_shuffle = '8ef501fa31135b8fea845a2be6a9605e0c3f9c4895b717f9206d485a669c2a73'
  8. sha_dest_mac_only = '0814dadb666e0056ef5b3a572a4971f333376b61e602acb84cb99c851845f016'
  9. sha_ip_src_shuffle = '6c0c9ccbedb631e4965ec36932276a1bd73b8a4aca5a5c46f01fd0a2800a064f'
  10. sha_smb2 = '8755a901295a90362d8041ecf1243a31fff582f5fe64555205625263c253476e'
  11. # TODO: improve coverage
  12. class UnitTestSMBScan(Test.ID2TAttackTest):
  13. def test_smbscan_default(self):
  14. with mock.patch("ID2TLib.Utility.get_rnd_os", return_value="win7"):
  15. self.checksum_test([['SMBScanAttack']], sha_default)
  16. def test_smbscan_one_victim_linux(self):
  17. with mock.patch("ID2TLib.Utility.get_rnd_os", return_value="linux"):
  18. self.checksum_test([['SMBScanAttack', 'ip.src=192.168.178.1', 'ip.dst=192.168.178.10']],
  19. sha_one_victim_linux)
  20. def test_smbscan_victim_range_winxp_hosting(self):
  21. with mock.patch("ID2TLib.Utility.get_rnd_os", return_value="winxp"):
  22. self.checksum_test([['SMBScanAttack', 'ip.src=192.168.178.1', 'ip.dst=192.168.178.5',
  23. 'ip.dst.end=192.168.178.10', 'hosting.ip=192.168.178.5']],
  24. sha_victim_range_winxp_hosting)
  25. def test_smbscan_multiple_victims_macos(self):
  26. with mock.patch("ID2TLib.Utility.get_rnd_os", return_value="macos"):
  27. self.checksum_test([['SMBScanAttack', 'ip.src=192.168.178.1',
  28. 'ip.dst=192.168.178.10,192.168.178.15,192.168.178.20',
  29. 'hosting.ip=192.168.178.15,192.168.178.20']], sha_multiple_victims_macos)
  30. def test_smbscan_invalid_smb_version(self):
  31. with self.assertRaises(SystemExit):
  32. self.checksum_test([['SMBScanAttack', 'protocol.version=42']], 'somehash')
  33. def test_smbscan_invalid_smb_platform(self):
  34. with self.assertRaises(SystemExit):
  35. self.checksum_test([['SMBScanAttack', 'hosting.version=1337']], 'somehash')
  36. def test_smbscan_port_shuffle(self):
  37. with mock.patch("ID2TLib.Utility.get_rnd_os", return_value="win7"):
  38. self.checksum_test([['SMBScanAttack', 'ip.src=192.168.178.1', 'ip.dst=192.168.178.5',
  39. 'ip.dst.end=192.168.178.10', 'hosting.ip=192.168.178.5', 'port.src.shuffle=false']],
  40. sha_port_shuffle)
  41. def test_smbscan_dest_mac_only(self):
  42. with mock.patch("ID2TLib.Utility.get_rnd_os", return_value="win7"):
  43. self.checksum_test([['SMBScanAttack', 'ip.src=192.168.178.1',
  44. 'mac.dst=00:0C:29:9C:70:64']], sha_dest_mac_only)
  45. def test_smbscan_src_ip_shuffle(self):
  46. with mock.patch("ID2TLib.Utility.get_rnd_os", return_value="win7"):
  47. self.checksum_test([['SMBScanAttack', 'ip.src=192.168.178.1', 'ip.dst=192.168.178.5',
  48. 'ip.dst.end=192.168.178.10', 'hosting.ip=192.168.178.5', 'ip.src.shuffle=True']],
  49. sha_ip_src_shuffle)
  50. def test_smbscan_smb2(self):
  51. with mock.patch("ID2TLib.Utility.get_rnd_os", return_value="linux"):
  52. self.checksum_test([['SMBScanAttack', 'ip.src=192.168.178.1', 'ip.dst=192.168.178.5',
  53. 'ip.dst.end=192.168.178.10', 'hosting.ip=192.168.178.5', 'protocol.version=2.1',
  54. 'hosting.version=2.1']], sha_smb2)