Example #1
0
class SyslogTailTestCase(BaseTestCase):
    def setup_method(self, method):
        super(SyslogTailTestCase, self).setup_method(method)
        self.tail = SyslogTail(address=('localhost', 514), interval=0.1)

        # Set up python logger
        self.logger = logging.getLogger(self.__class__.__name__)
        self.logger.setLevel(logging.DEBUG)
        self.handler = SysLogHandler(address=('localhost', 514))
        self.handler.setFormatter(logging.Formatter(' amplify: %(message)s'))
        self.logger.addHandler(self.handler)

    def teardown_method(self, method):
        # Revert logger stuff
        self.handler.close()
        self.handler = None
        self.logger = None

        # Kill the SyslogTail
        self.tail.stop()
        self.tail = None

    def test_overall(self):
        time.sleep(0.1)  # Release GIL so async listener can "hear" the DGRAMs
        count = 1
        while count <= 5:
            self.logger.debug('This is message #%s' % count)
            count += 1

        time.sleep(0.1)  # Release GIL so async listener can handle DGRAMs

        # Check to see that SyslogListener read 5 messages
        assert_that(self.tail.cache, has_length(count - 1))

        # Check the cache directly to make sure messages were decoded.
        for i in xrange(5):
            assert_that(self.tail.cache[i],
                        equal_to(u'This is message #%s\x00' % (i + 1)))

        # Go through and check the messages via iteration
        count = 1
        for line in self.tail:
            assert_that(line, equal_to(u'This is message #%s\x00' % count))
            count += 1

        # Check that cache was cleared after iteration
        assert_that(self.tail.cache, has_length(0))

    # TODO: test_overall doesn't work if there are other tests run with it...why?
    # The tests below pass, but will cause test_overall to fail if run...so skipped for now.
    @disabled_test
    def test_addresses(self):
        assert_that(('localhost', 514), is_in(SYSLOG_ADDRESSES))

    @disabled_test
    def test_socket_conflict(self):
        assert_that(
            calling(SyslogTail).with_args(address=('localhost', 514)),
            raises(AmplifyAddresssAlreadyInUse))
Example #2
0
    def setup_method(self, method):
        super(SyslogTailTestCase, self).setup_method(method)
        self.tail = SyslogTail(address=('localhost', 514), interval=0.1)

        # Set up python logger
        self.logger = logging.getLogger(self.__class__.__name__)
        self.logger.setLevel(logging.DEBUG)
        self.handler = SysLogHandler(address=('localhost', 514))
        self.handler.setFormatter(logging.Formatter(' amplify: %(message)s'))
        self.logger.addHandler(self.handler)
Example #3
0
    def __setup_pipeline(self, name):
        """
        Sets up a pipeline/tail object for a collector based on "filename".

        :param name: Str
        :return: Pipeline
        """
        tail = None
        try:
            if name.startswith('syslog'):
                address_bucket = name.split(',', 1)[0]
                host, port, address = net.ipv4_address(
                    address=address_bucket.split('=')[1],
                    full_format=True,
                    silent=True)
                # Right now we assume AFNET address/port...e.g. no support for unix sockets

                if address in context.listeners:
                    port = int(port)  # socket requires integer port
                    tail = SyslogTail(address=(host, port))
            else:
                tail = FileTail(name)
        except Exception as e:
            context.log.error(
                'failed to initialize pipeline for "%s" due to %s (maybe has no rights?)'
                % (name, e.__class__.__name__))
            context.log.debug('additional info:', exc_info=True)

        return tail