def test_should_return_a_set (self): mock_parser = Mock(YadtConfigParser) mock_parser.get_option_as_list.return_value = ['abc', 'def', 'ghi', 'jkl'] actual_option = YadtConfigParser.get_option_as_set(mock_parser, 'section', 'option', 'default_value') self.assertEqual(set(['abc', 'def', 'ghi', 'jkl']), actual_option) self.assertEqual(call('section', 'option', 'default_value'), mock_parser.get_option_as_list.call_args)
def test_should_return_a_set(self): mock_parser = Mock(YadtConfigParser) mock_parser.get_option_as_list.return_value = [ 'abc', 'def', 'ghi', 'jkl' ] actual_option = YadtConfigParser.get_option_as_set( mock_parser, 'section', 'option', 'default_value') self.assertEqual(set(['abc', 'def', 'ghi', 'jkl']), actual_option) self.assertEqual(call('section', 'option', 'default_value'), mock_parser.get_option_as_list.call_args)
class ReceiverConfigLoader (object): """ uses a YadtConfigParser which offers convenience methods. """ def __init__(self): """ Creates instance of YadtConfigParser which will be used to parse the configuration file. """ self._parser = YadtConfigParser() def get_app_status_port(self): """ @return: the app status port from the configuration file as int, otherwise DEFAULT_APP_STATUS_PORT. """ return self._parser.get_option_as_int(SECTION_RECEIVER, 'app_status_port', DEFAULT_APP_STATUS_PORT) def get_broadcaster_host(self): """ @return: the broadcaster host from the configuration file, otherwise DEFAULT_BROADCASTER_HOST. """ return self._parser.get_option(SECTION_BROADCASTER, 'host', DEFAULT_BROADCASTER_HOST) def get_broadcaster_port(self): """ @return: the broadcaster port from the configuration file as int, otherwise DEFAULT_BROADCASTER_PORT. """ return self._parser.get_option_as_int(SECTION_BROADCASTER, 'port', DEFAULT_BROADCASTER_PORT) def get_hostname(self): """ @return: if a hostname is given in the configuration file it will return it, otherwise it will return the host name as given by socket.gethostname """ return self._parser.get_option(SECTION_RECEIVER, 'hostname', socket.gethostname()) def get_log_filename(self): """ @return: the log filename from the configuration file if given, otherwise DEFAULT_LOG_FILENAME """ return self._parser.get_option(SECTION_RECEIVER, 'log_filename', DEFAULT_LOG_FILENAME) def get_python_command(self): """ @return: the python command from the configuration file if given, otherwise DEFAULT_PYTHON_COMMAND """ return self._parser.get_option(SECTION_RECEIVER, 'python_command', DEFAULT_PYTHON_COMMAND) def get_script_to_execute(self): """ @return: if the configuration file provides a script to execute, otherwise DEFAULT_SCRIPT_TO_EXECUTE. """ return self._parser.get_option(SECTION_RECEIVER, 'script_to_execute', DEFAULT_SCRIPT_TO_EXECUTE) def get_targets(self): """ @return: the set of targets given in the configuration file, otherwise DEFAULT_TARGETS. """ return self._parser.get_option_as_set(SECTION_RECEIVER, 'targets', DEFAULT_TARGETS) def get_targets_directory(self): """ @return: the targets directory from the configuration file, otherwise DEFAULT_TARGETS_DIRECTORY. """ return self._parser.get_option(SECTION_RECEIVER, 'targets_directory', DEFAULT_TARGETS_DIRECTORY) def read_configuration_file(self, filename): """ Reads the given configuration file. Uses the YadtConfigParser. @return: configuration dictionary """ return self._parser.read_configuration_file(filename) def get_metrics_directory(self): """ @return: the metrics_directory from the receiver configuration and None otherwise """ return self._parser.get_option(SECTION_RECEIVER, 'metrics_directory', None) def get_metrics_file(self): """ @return: the derived metrics_file or None """ metrics_directory = self.get_metrics_directory() if metrics_directory is not None: return os.path.join(metrics_directory, 'yrc.metrics')
class ReceiverConfigLoader(object): """ uses a YadtConfigParser which offers convenience methods. """ def __init__(self): """ Creates instance of YadtConfigParser which will be used to parse the configuration file. """ self._parser = YadtConfigParser() def get_app_status_port(self): """ @return: the app status port from the configuration file as int, otherwise DEFAULT_APP_STATUS_PORT. """ return self._parser.get_option_as_int(SECTION_RECEIVER, 'app_status_port', DEFAULT_APP_STATUS_PORT) def get_broadcaster_host(self): """ @return: the broadcaster host from the configuration file, otherwise DEFAULT_BROADCASTER_HOST. """ return self._parser.get_option(SECTION_BROADCASTER, 'host', DEFAULT_BROADCASTER_HOST) def get_broadcaster_port(self): """ @return: the broadcaster port from the configuration file as int, otherwise DEFAULT_BROADCASTER_PORT. """ return self._parser.get_option_as_int(SECTION_BROADCASTER, 'port', DEFAULT_BROADCASTER_PORT) def get_hostname(self): """ @return: if a hostname is given in the configuration file it will return it, otherwise it will return the host name as given by socket.gethostname """ return self._parser.get_option(SECTION_RECEIVER, 'hostname', socket.gethostname()) def get_log_filename(self): """ @return: the log filename from the configuration file if given, otherwise DEFAULT_LOG_FILENAME """ return self._parser.get_option(SECTION_RECEIVER, 'log_filename', DEFAULT_LOG_FILENAME) def get_python_command(self): """ @return: the python command from the configuration file if given, otherwise DEFAULT_PYTHON_COMMAND """ return self._parser.get_option(SECTION_RECEIVER, 'python_command', DEFAULT_PYTHON_COMMAND) def get_script_to_execute(self): """ @return: if the configuration file provides a script to execute, otherwise DEFAULT_SCRIPT_TO_EXECUTE. """ return self._parser.get_option(SECTION_RECEIVER, 'script_to_execute', DEFAULT_SCRIPT_TO_EXECUTE) def get_targets(self): """ @return: the set of targets given in the configuration file, otherwise DEFAULT_TARGETS. """ return self._parser.get_option_as_set(SECTION_RECEIVER, 'targets', DEFAULT_TARGETS) def get_targets_directory(self): """ @return: the targets directory from the configuration file, otherwise DEFAULT_TARGETS_DIRECTORY. """ return self._parser.get_option(SECTION_RECEIVER, 'targets_directory', DEFAULT_TARGETS_DIRECTORY) def read_configuration_file(self, filename): """ Reads the given configuration file. Uses the YadtConfigParser. @return: configuration dictionary """ return self._parser.read_configuration_file(filename) def get_metrics_directory(self): """ @return: the metrics_directory from the receiver configuration and None otherwise """ return self._parser.get_option(SECTION_RECEIVER, 'metrics_directory', None) def get_metrics_file(self): """ @return: the derived metrics_file or None """ metrics_directory = self.get_metrics_directory() if metrics_directory is not None: return os.path.join(metrics_directory, 'yrc.metrics')