Skip to content

Commit

Permalink
Mocked telemetry in modularinput tests
Browse files Browse the repository at this point in the history
  • Loading branch information
amysutedja committed Jun 23, 2020
1 parent a8ba77e commit e70ae01
Show file tree
Hide file tree
Showing 5 changed files with 42 additions and 18 deletions.
15 changes: 15 additions & 0 deletions splunklib/modularinput/script.py
Original file line number Diff line number Diff line change
Expand Up @@ -21,6 +21,7 @@
from .event_writer import EventWriter
from .input_definition import InputDefinition
from .validation_definition import ValidationDefinition
from ..wire._internal import Telemetry, TelemetryMetric
from splunklib import six

try:
Expand Down Expand Up @@ -70,6 +71,20 @@ def run_script(self, args, event_writer, input_stream):
# passed on stdin as XML, and the script will write events on
# stdout and log entries on stderr.
self._input_definition = InputDefinition.parse(input_stream)

# create a telemetry metric
metric = TelemetryMetric(**{
'metric_type': 'event',
'component': 'telemetry_test_case',
'data': {
'testValue': 32
}
})

# call out to telemetry
telemetry = Telemetry(self.service)
telemetry.submit(metric.to_wire())

self.stream_events(self._input_definition, event_writer)
event_writer.close()
return 0
Expand Down
1 change: 1 addition & 0 deletions splunklib/wire/_internal/json_sink.py
Original file line number Diff line number Diff line change
Expand Up @@ -44,6 +44,7 @@ def submit(self, data):
"""

response = self._post('', headers=self.__class__.JSON_HEADER, body=json.dumps(data))

body = json.loads(response.body.read().decode('utf-8'))

return response, body
25 changes: 22 additions & 3 deletions tests/modularinput/test_script.py
Original file line number Diff line number Diff line change
@@ -1,8 +1,12 @@
import io
import json
import sys

from mock import Mock, patch

from splunklib import six
from splunklib.client import Service
from splunklib.modularinput import Script, EventWriter, Scheme, Argument, Event
import io

from splunklib.modularinput.utils import xml_compare
from tests.modularinput.modularinput_testlib import data_open
Expand Down Expand Up @@ -184,9 +188,24 @@ def stream_events(self, inputs, ew):
script = NewScript()
input_configuration = data_open("data/conf_with_2_inputs.xml")

ew = EventWriter(sys.stdout, sys.stderr)
event_writer = EventWriter(sys.stdout, sys.stderr)

patched_telemetry_response = {
'status': 201,
'reason': 'Created',
'body.read.return_value': six.ensure_binary(json.dumps({
'message': 'Data submitted successfully',
'metricValueID': '26844DB9-7806-40E0-96C0-1BD554930BA8'
})),
'headers': [
('content-type', 'application/json; charset=UTF-8')
]
}

with patch.object(Service, 'post') as patched_telemetry_post:
patched_telemetry_post.return_value = Mock(**patched_telemetry_response)

return_value = script.run_script([TEST_SCRIPT_PATH], ew, input_configuration)
return_value = script.run_script([TEST_SCRIPT_PATH], event_writer, input_configuration)

output = capsys.readouterr()
assert output.err == ""
Expand Down
16 changes: 2 additions & 14 deletions tests/test_telemetry.py
Original file line number Diff line number Diff line change
Expand Up @@ -21,15 +21,10 @@
from splunklib.wire._internal.telemetry import Telemetry
from splunklib.wire._internal.telemetry_metric import TelemetryMetric

try:
import unittest
except ImportError:
import unittest2 as unittest

@pytest.mark.app
class TelemetryTestCase(testlib.SDKTestCase):
class TestTelemetry(testlib.SDKTestCase):
def setUp(self):
super(TelemetryTestCase, self).setUp()
super(TestTelemetry, self).setUp()

self.service.namespace['owner'] = 'nobody'
self.service.namespace['app'] = 'sdk-app-collection'
Expand All @@ -51,10 +46,3 @@ def test_submit(self):

# it should return a 201
self.assertEqual(response.status, 201)

if __name__ == "__main__":
try:
import unittest2 as unittest
except ImportError:
import unittest
unittest.main()
3 changes: 2 additions & 1 deletion tox.ini
Original file line number Diff line number Diff line change
Expand Up @@ -27,7 +27,8 @@ passenv = LANG
setenv = SPLUNK_HOME=/opt/splunk
INPUT_EXAMPLE_UPLOAD=/opt/splunk/var/log/splunk/splunkd_ui_access.log
whitelist_externals = true
deps = pytest
deps = mock
pytest
pytest-cov
xmlrunner
unittest2
Expand Down

0 comments on commit e70ae01

Please sign in to comment.