Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
29 changes: 29 additions & 0 deletions tests/unit/conftest.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,29 @@
import pytest
from unittest.mock import Mock
from pytest_splunk_addon.standard_lib.addon_parser.eventtype_parser import (
EventTypeParser,
)


@pytest.fixture()
def parser():
class FakeConfigurationFile:
def __init__(self):
self.headers = []
self.sects = {
"fake_splunkd": {
"name": "fake_splunkd",
"options": "index=_internal sourcetype=splunkd",
},
"fake_for_tags_positive": {
"name": "fake_for_tags_positive",
"options": "sourcetype=splunkd",
},
}
self.errors = []

FakeApp = Mock()
FakeApp.eventtypes = FakeConfigurationFile()
FakeApp.eventtypes_conf.return_value = FakeConfigurationFile()

return EventTypeParser("fake_path", FakeApp)
26 changes: 26 additions & 0 deletions tests/unit/test_eventtype_parser.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,26 @@
def test_eventtypes_can_be_parsed_and_extracted(parser):
assert hasattr(
parser.eventtypes, "sects"
), "eventypes can not be called or does have sects attribute"


def test_eventtypes_can_be_parsed_and_returned(parser):
expected_outputs = [
{"stanza": x} for x in ["fake_splunkd", "fake_for_tags_positive"]
]
for i, event in enumerate(parser.get_eventtypes()):
assert event == expected_outputs[i], "expeceted event {} not found".format(
expected_outputs[i]
)


def test_get_eventtypes_calls_app_get_config(parser):
for _ in parser.get_eventtypes():
pass
parser.app.eventtypes_conf.assert_called_once()


def test_no_eventtype_config_file(parser):
parser.app.eventtypes_conf.side_effect = OSError
output = [eventtype for eventtype in parser.get_eventtypes() if eventtype]
assert output == [], "eventtypes created when no config file exists"