2018-07-03 13:00:18 +02:00
|
|
|
import pytest
|
|
|
|
|
2018-07-13 17:10:05 +02:00
|
|
|
from stix2.datastore import (
|
|
|
|
CompositeDataSource, DataSink, DataSource, DataStoreMixin,
|
|
|
|
)
|
2018-07-03 13:00:18 +02:00
|
|
|
from stix2.datastore.filters import Filter
|
2018-11-29 19:49:06 +01:00
|
|
|
from .constants import CAMPAIGN_MORE_KWARGS
|
2018-07-03 13:00:18 +02:00
|
|
|
|
|
|
|
|
|
|
|
def test_datasource_abstract_class_raises_error():
|
|
|
|
with pytest.raises(TypeError):
|
|
|
|
DataSource()
|
|
|
|
|
|
|
|
|
|
|
|
def test_datasink_abstract_class_raises_error():
|
|
|
|
with pytest.raises(TypeError):
|
|
|
|
DataSink()
|
|
|
|
|
|
|
|
|
|
|
|
def test_datastore_smoke():
|
|
|
|
assert DataStoreMixin() is not None
|
|
|
|
|
|
|
|
|
|
|
|
def test_datastore_get_raises():
|
|
|
|
with pytest.raises(AttributeError) as excinfo:
|
2018-07-11 15:43:37 +02:00
|
|
|
DataStoreMixin().get("indicator--00000000-0000-4000-8000-000000000001")
|
2018-07-03 13:00:18 +02:00
|
|
|
assert "DataStoreMixin has no data source to query" == str(excinfo.value)
|
|
|
|
|
|
|
|
|
|
|
|
def test_datastore_all_versions_raises():
|
|
|
|
with pytest.raises(AttributeError) as excinfo:
|
2018-07-11 15:43:37 +02:00
|
|
|
DataStoreMixin().all_versions("indicator--00000000-0000-4000-8000-000000000001")
|
2018-07-03 13:00:18 +02:00
|
|
|
assert "DataStoreMixin has no data source to query" == str(excinfo.value)
|
|
|
|
|
|
|
|
|
|
|
|
def test_datastore_query_raises():
|
|
|
|
with pytest.raises(AttributeError) as excinfo:
|
|
|
|
DataStoreMixin().query([Filter("type", "=", "indicator")])
|
|
|
|
assert "DataStoreMixin has no data source to query" == str(excinfo.value)
|
|
|
|
|
|
|
|
|
|
|
|
def test_datastore_creator_of_raises():
|
|
|
|
with pytest.raises(AttributeError) as excinfo:
|
|
|
|
DataStoreMixin().creator_of(CAMPAIGN_MORE_KWARGS)
|
|
|
|
assert "DataStoreMixin has no data source to query" == str(excinfo.value)
|
|
|
|
|
|
|
|
|
|
|
|
def test_datastore_relationships_raises():
|
|
|
|
with pytest.raises(AttributeError) as excinfo:
|
2018-07-13 17:10:05 +02:00
|
|
|
DataStoreMixin().relationships(
|
|
|
|
obj="indicator--00000000-0000-4000-8000-000000000001",
|
|
|
|
target_only=True,
|
|
|
|
)
|
2018-07-03 13:00:18 +02:00
|
|
|
assert "DataStoreMixin has no data source to query" == str(excinfo.value)
|
|
|
|
|
|
|
|
|
|
|
|
def test_datastore_related_to_raises():
|
|
|
|
with pytest.raises(AttributeError) as excinfo:
|
2018-07-13 17:10:05 +02:00
|
|
|
DataStoreMixin().related_to(
|
|
|
|
obj="indicator--00000000-0000-4000-8000-000000000001",
|
|
|
|
target_only=True,
|
|
|
|
)
|
2018-07-03 13:00:18 +02:00
|
|
|
assert "DataStoreMixin has no data source to query" == str(excinfo.value)
|
|
|
|
|
|
|
|
|
|
|
|
def test_datastore_add_raises():
|
|
|
|
with pytest.raises(AttributeError) as excinfo:
|
|
|
|
DataStoreMixin().add(CAMPAIGN_MORE_KWARGS)
|
|
|
|
assert "DataStoreMixin has no data sink to put objects in" == str(excinfo.value)
|
|
|
|
|
|
|
|
|
|
|
|
def test_composite_datastore_get_raises_error():
|
|
|
|
with pytest.raises(AttributeError) as excinfo:
|
2018-07-11 15:43:37 +02:00
|
|
|
CompositeDataSource().get("indicator--00000000-0000-4000-8000-000000000001")
|
2018-07-03 13:00:18 +02:00
|
|
|
assert "CompositeDataSource has no data sources" == str(excinfo.value)
|
|
|
|
|
|
|
|
|
|
|
|
def test_composite_datastore_all_versions_raises_error():
|
|
|
|
with pytest.raises(AttributeError) as excinfo:
|
2018-07-11 15:43:37 +02:00
|
|
|
CompositeDataSource().all_versions("indicator--00000000-0000-4000-8000-000000000001")
|
2018-07-03 13:00:18 +02:00
|
|
|
assert "CompositeDataSource has no data sources" == str(excinfo.value)
|
|
|
|
|
|
|
|
|
|
|
|
def test_composite_datastore_query_raises_error():
|
|
|
|
with pytest.raises(AttributeError) as excinfo:
|
|
|
|
CompositeDataSource().query([Filter("type", "=", "indicator")])
|
|
|
|
assert "CompositeDataSource has no data sources" == str(excinfo.value)
|
|
|
|
|
|
|
|
|
|
|
|
def test_composite_datastore_relationships_raises_error():
|
|
|
|
with pytest.raises(AttributeError) as excinfo:
|
2018-07-13 17:10:05 +02:00
|
|
|
CompositeDataSource().relationships(
|
|
|
|
obj="indicator--00000000-0000-4000-8000-000000000001",
|
|
|
|
target_only=True,
|
|
|
|
)
|
2018-07-03 13:00:18 +02:00
|
|
|
assert "CompositeDataSource has no data sources" == str(excinfo.value)
|
|
|
|
|
|
|
|
|
|
|
|
def test_composite_datastore_related_to_raises_error():
|
|
|
|
with pytest.raises(AttributeError) as excinfo:
|
2018-07-13 17:10:05 +02:00
|
|
|
CompositeDataSource().related_to(
|
|
|
|
obj="indicator--00000000-0000-4000-8000-000000000001",
|
|
|
|
target_only=True,
|
|
|
|
)
|
2018-07-03 13:00:18 +02:00
|
|
|
assert "CompositeDataSource has no data sources" == str(excinfo.value)
|
|
|
|
|
|
|
|
|
|
|
|
def test_composite_datastore_add_data_source_raises_error():
|
|
|
|
with pytest.raises(TypeError) as excinfo:
|
2018-07-11 15:43:37 +02:00
|
|
|
ind = "indicator--00000000-0000-4000-8000-000000000001"
|
2018-07-03 13:00:18 +02:00
|
|
|
CompositeDataSource().add_data_source(ind)
|
|
|
|
assert "DataSource (to be added) is not of type stix2.DataSource. DataSource type is '{}'".format(type(ind)) == str(excinfo.value)
|
|
|
|
|
|
|
|
|
|
|
|
def test_composite_datastore_add_data_sources_raises_error():
|
|
|
|
with pytest.raises(TypeError) as excinfo:
|
2018-07-11 15:43:37 +02:00
|
|
|
ind = "indicator--00000000-0000-4000-8000-000000000001"
|
2018-07-03 13:00:18 +02:00
|
|
|
CompositeDataSource().add_data_sources(ind)
|
|
|
|
assert "DataSource (to be added) is not of type stix2.DataSource. DataSource type is '{}'".format(type(ind)) == str(excinfo.value)
|
|
|
|
|
|
|
|
|
|
|
|
def test_composite_datastore_no_datasource():
|
|
|
|
cds = CompositeDataSource()
|
|
|
|
with pytest.raises(AttributeError) as excinfo:
|
2018-07-11 15:43:37 +02:00
|
|
|
cds.get("indicator--00000000-0000-4000-8000-000000000001")
|
2018-07-03 13:00:18 +02:00
|
|
|
assert 'CompositeDataSource has no data source' in str(excinfo.value)
|