HEX
Server: LiteSpeed
System: Linux br-asc-web1845.main-hosting.eu 5.14.0-611.42.1.el9_7.x86_64 #1 SMP PREEMPT_DYNAMIC Tue Mar 24 05:30:20 EDT 2026 x86_64
User: u790421558 (790421558)
PHP: 8.2.30
Disabled: system, exec, shell_exec, passthru, mysql_list_dbs, ini_alter, dl, symlink, link, chgrp, leak, popen, apache_child_terminate, virtual, mb_send_mail
Upload Files
File: //opt/alt/python311/lib/python3.11/site-packages/tests/unit/test_ExcludeFilter.py
#!/usr/bin/env python
# -*- coding: utf-8 -*-

"""pytests for :class:`graypy.rabbitmq.ExcludeFilter`"""

import pytest

from graypy import ExcludeFilter

from tests.unit.helper import MOCK_LOG_RECORD_NAME, MOCK_LOG_RECORD


@pytest.mark.parametrize("name", [None, ""])
def test_invalid_name(name):
    """Test constructing:class:`graypy.rabbitmq.ExcludeFilter` with a
    invalid ``name`` argument"""
    with pytest.raises(ValueError):
        ExcludeFilter(name)


@pytest.mark.parametrize("name", ["foobar", ".", " "])
def test_valid_name(name):
    """Test constructing :class:`graypy.rabbitmq.ExcludeFilter` with a
    valid ``name`` argument"""
    exclude_filter = ExcludeFilter(name)
    assert exclude_filter
    assert name == exclude_filter.name
    assert len(name) == exclude_filter.nlen


def test_non_filtering_record():
    exclude_filter = ExcludeFilter("NOT" + MOCK_LOG_RECORD_NAME)
    assert exclude_filter.filter(MOCK_LOG_RECORD)
    assert MOCK_LOG_RECORD.name != exclude_filter.name


def test_filtering_record():
    exclude_filter = ExcludeFilter(MOCK_LOG_RECORD_NAME)
    assert not exclude_filter.filter(MOCK_LOG_RECORD)
    assert MOCK_LOG_RECORD.name == exclude_filter.name