misp-modules/tests/test.py

73 lines
2.4 KiB
Python
Raw Normal View History

2016-11-15 16:47:17 +01:00
#!/usr/bin/env python3
2016-06-18 07:53:26 +02:00
# -*- coding: utf-8 -*-
import unittest
import requests
import base64
import json
2016-08-17 14:01:11 +02:00
import os
2016-06-18 07:53:26 +02:00
class TestModules(unittest.TestCase):
def setUp(self):
self.maxDiff = None
self.headers = {'Content-Type': 'application/json'}
self.url = "http://127.0.0.1:6666/"
2016-06-18 07:53:26 +02:00
def test_introspection(self):
response = requests.get(self.url + "modules")
2016-06-18 07:53:26 +02:00
print(response.json())
def test_cve(self):
with open('tests/bodycve.json', 'r') as f:
response = requests.post(self.url + "query", data=f.read())
2016-06-18 07:53:26 +02:00
print(response.json())
def test_dns(self):
with open('tests/body.json', 'r') as f:
response = requests.post(self.url + "query", data=f.read())
print(response.json())
2016-08-25 17:36:28 +02:00
with open('tests/body_timeout.json', 'r') as f:
response = requests.post(self.url + "query", data=f.read())
print(response.json())
def test_stix(self):
2016-11-15 16:47:17 +01:00
with open("tests/stix.xml", "rb") as f:
content = base64.b64encode(f.read())
data = json.dumps({"module": "stiximport",
"data": content.decode('utf-8'),
})
2016-11-21 11:59:30 +01:00
response = requests.post(self.url + "query", data=data).json()
print("STIX :: {}".format(response))
values = [x["values"][0] for x in response["results"]]
assert("209.239.79.47" in values)
assert("41.213.121.180" in values)
assert("eu-society.com" in values)
2016-08-17 14:01:11 +02:00
def test_virustotal(self):
# This can't actually be tested without disclosing a private
# API key. This will attempt to run with a .gitignored keyfile
# and pass if it can't find one
if not os.path.exists("tests/bodyvirustotal.json"):
2016-11-15 16:47:17 +01:00
return
2016-08-17 14:01:11 +02:00
with open("tests/bodyvirustotal.json", "r") as f:
2016-11-15 16:47:17 +01:00
response = requests.post(self.url + "query", data=f.read()).json()
2016-08-17 14:01:11 +02:00
assert(response)
2016-12-02 16:16:25 +01:00
#def test_domaintools(self):
# query = {'config': {'username': 'test_user', 'api_key': 'test_key'}, 'module': 'domaintools', 'domain': 'domaintools.com'}
# try:
# response = requests.post(self.url + "query", data=json.dumps(query)).json()
# except:
# pass
# response = requests.post(self.url + "query", data=json.dumps(query)).json()
# print(response)
2016-12-02 15:29:44 +01:00
if __name__ == '__main__':
2016-11-15 16:47:17 +01:00
unittest.main()