136 lines
		
	
	
		
			4.2 KiB
		
	
	
	
		
			Python
		
	
	
			
		
		
	
	
			136 lines
		
	
	
		
			4.2 KiB
		
	
	
	
		
			Python
		
	
	
| import datetime as dt
 | |
| 
 | |
| import pytest
 | |
| import pytz
 | |
| 
 | |
| import stix2
 | |
| 
 | |
| from .constants import (
 | |
|     CAMPAIGN_ID, IDENTITY_ID, INDICATOR_ID, INDICATOR_KWARGS, RELATIONSHIP_ID,
 | |
|     REPORT_ID,
 | |
| )
 | |
| 
 | |
| EXPECTED = """{
 | |
|     "type": "report",
 | |
|     "id": "report--84e4d88f-44ea-4bcd-bbf3-b2c1c320bcb3",
 | |
|     "created_by_ref": "identity--311b2d2d-f010-4473-83ec-1edf84858f4c",
 | |
|     "created": "2015-12-21T19:59:11.000Z",
 | |
|     "modified": "2015-12-21T19:59:11.000Z",
 | |
|     "name": "The Black Vine Cyberespionage Group",
 | |
|     "description": "A simple report with an indicator and campaign",
 | |
|     "published": "2016-01-20T17:00:00Z",
 | |
|     "object_refs": [
 | |
|         "indicator--a740531e-63ff-4e49-a9e1-a0a3eed0e3e7",
 | |
|         "campaign--8e2e2d2b-17d4-4cbf-938f-98ee46b3cd3f",
 | |
|         "relationship--df7c87eb-75d2-4948-af81-9d49d246f301"
 | |
|     ],
 | |
|     "labels": [
 | |
|         "campaign"
 | |
|     ]
 | |
| }"""
 | |
| 
 | |
| 
 | |
| def test_report_example():
 | |
|     report = stix2.v20.Report(
 | |
|         id=REPORT_ID,
 | |
|         created_by_ref=IDENTITY_ID,
 | |
|         created="2015-12-21T19:59:11.000Z",
 | |
|         modified="2015-12-21T19:59:11.000Z",
 | |
|         name="The Black Vine Cyberespionage Group",
 | |
|         description="A simple report with an indicator and campaign",
 | |
|         published="2016-01-20T17:00:00Z",
 | |
|         labels=["campaign"],
 | |
|         object_refs=[
 | |
|             INDICATOR_ID,
 | |
|             CAMPAIGN_ID,
 | |
|             RELATIONSHIP_ID,
 | |
|         ],
 | |
|     )
 | |
| 
 | |
|     assert str(report) == EXPECTED
 | |
| 
 | |
| 
 | |
| def test_report_example_objects_in_object_refs():
 | |
|     report = stix2.v20.Report(
 | |
|         id=REPORT_ID,
 | |
|         created_by_ref=IDENTITY_ID,
 | |
|         created="2015-12-21T19:59:11.000Z",
 | |
|         modified="2015-12-21T19:59:11.000Z",
 | |
|         name="The Black Vine Cyberespionage Group",
 | |
|         description="A simple report with an indicator and campaign",
 | |
|         published="2016-01-20T17:00:00Z",
 | |
|         labels=["campaign"],
 | |
|         object_refs=[
 | |
|             stix2.v20.Indicator(id=INDICATOR_ID, **INDICATOR_KWARGS),
 | |
|             CAMPAIGN_ID,
 | |
|             RELATIONSHIP_ID,
 | |
|         ],
 | |
|     )
 | |
| 
 | |
|     assert str(report) == EXPECTED
 | |
| 
 | |
| 
 | |
| def test_report_example_objects_in_object_refs_with_bad_id():
 | |
|     with pytest.raises(stix2.exceptions.InvalidValueError) as excinfo:
 | |
|         stix2.v20.Report(
 | |
|             id=REPORT_ID,
 | |
|             created_by_ref=IDENTITY_ID,
 | |
|             created="2015-12-21T19:59:11.000Z",
 | |
|             modified="2015-12-21T19:59:11.000Z",
 | |
|             name="The Black Vine Cyberespionage Group",
 | |
|             description="A simple report with an indicator and campaign",
 | |
|             published="2016-01-20T17:00:00Z",
 | |
|             labels=["campaign"],
 | |
|             object_refs=[
 | |
|                 stix2.v20.Indicator(id=INDICATOR_ID, **INDICATOR_KWARGS),
 | |
|                 "campaign-83422c77-904c-4dc1-aff5-5c38f3a2c55c",   # the "bad" id, missing a "-"
 | |
|                 RELATIONSHIP_ID,
 | |
|             ],
 | |
|         )
 | |
| 
 | |
|     assert excinfo.value.cls == stix2.v20.Report
 | |
|     assert excinfo.value.prop_name == "object_refs"
 | |
| 
 | |
| 
 | |
| @pytest.mark.parametrize(
 | |
|     "data", [
 | |
|         EXPECTED,
 | |
|         {
 | |
|             "created": "2015-12-21T19:59:11.000Z",
 | |
|             "created_by_ref": IDENTITY_ID,
 | |
|             "description": "A simple report with an indicator and campaign",
 | |
|             "id": REPORT_ID,
 | |
|             "labels": [
 | |
|                 "campaign",
 | |
|             ],
 | |
|             "modified": "2015-12-21T19:59:11.000Z",
 | |
|             "name": "The Black Vine Cyberespionage Group",
 | |
|             "object_refs": [
 | |
|                 INDICATOR_ID,
 | |
|                 CAMPAIGN_ID,
 | |
|                 RELATIONSHIP_ID,
 | |
|             ],
 | |
|             "published": "2016-01-20T17:00:00Z",
 | |
|             "type": "report",
 | |
|         },
 | |
|     ],
 | |
| )
 | |
| def test_parse_report(data):
 | |
|     rept = stix2.parse(data, version="2.0")
 | |
| 
 | |
|     assert rept.type == 'report'
 | |
|     assert rept.id == REPORT_ID
 | |
|     assert rept.created == dt.datetime(2015, 12, 21, 19, 59, 11, tzinfo=pytz.utc)
 | |
|     assert rept.modified == dt.datetime(2015, 12, 21, 19, 59, 11, tzinfo=pytz.utc)
 | |
|     assert rept.created_by_ref == IDENTITY_ID
 | |
|     assert rept.object_refs == [
 | |
|         INDICATOR_ID,
 | |
|         CAMPAIGN_ID,
 | |
|         RELATIONSHIP_ID,
 | |
|     ]
 | |
|     assert rept.description == "A simple report with an indicator and campaign"
 | |
|     assert rept.labels == ["campaign"]
 | |
|     assert rept.name == "The Black Vine Cyberespionage Group"
 | |
| 
 | |
| # TODO: Add other examples
 |