NetconfRestServer._configuration_manager.change_configuration(config_data, module_name)
return NetconfRestServer.__create_http_response(202, "Accepted")
+ @staticmethod
+ @_rest_server.route("/get_config/<path:module_name>", methods=['GET'])
+ def _get_config(module_name):
+ data = NetconfRestServer._configuration_manager.get_configuration(module_name)
+ return NetconfRestServer.__create_http_response(200, data)
+
+
@staticmethod
def __create_http_response(code, message):
return make_response(
# limitations under the License.
# ============LICENSE_END=========================================================
###
-
+import json
import logging
def change_configuration(self, config_data: str, module_name: str):
data = self.__parse_config_data(config_data)
self._session.replace_config_ly(data, module_name)
+
+ def get_configuration(self, module_name: str):
+ data = self._session.get_data("/" + module_name + ":*")
+ return json.dumps(data, indent=4)
+import json
import unittest
from unittest.mock import MagicMock
from netconf_server.sysrepo_configuration.sysrepo_configuration_manager import SysrepoConfigurationManager
# then
ctx.parse_data_mem.assert_called_with(config_data, "xml", config=True, strict=False)
session.replace_config_ly.assert_called_with(expected_parse_data, module_name)
+
+ def test_should_get_configuration(self):
+ # given
+ expected_parse_data = '{"config": {"itemValue1": 42,"itemValue2": 35}}'
+
+ connection = MagicMock()
+ session = MagicMock()
+ session.get_data = MagicMock(return_value=expected_parse_data)
+ module_name = "pnf-simulator"
+
+ # when
+ config_manager = SysrepoConfigurationManager(session=session, connection=connection)
+ data = config_manager.get_configuration(module_name=module_name)
+
+ # then
+ session.get_data.assert_called_with("/" + module_name + ":*")
+ self.assertEqual(data, json.dumps(expected_parse_data))