Пример #1
0
def test_nested_payload_not_allowed(basic_event):
    basic_event['payload'] = {
        'turtle': {
            'turtle': {
                'turtle': {
                    'turtle': 'turtle'
                }
            }
        }
    }
    with pytest.raises(CosmologgerException):
        CosmologEvent.from_dict(basic_event)
Пример #2
0
def process(line, verbosity, formatter):
    e = CosmologEvent.from_json(line)

    if verbosity < e['level']:
        return

    click.echo(formatter.event_format(e))
Пример #3
0
def test_from_json(basic_event):
    j = '''{
        "version": 0,
        "stream_name": "telemetry",
        "origin": "foobar.example.com",
        "timestamp": "2016-09-02T16:34:12.019105Z",
        "format": "once upon a time {sensor}",
        "level": 400,
        "payload": {
            "sensor": 36.7
        }
    }'''
    e = CosmologEvent.from_json(j)
    assert e == basic_event
Пример #4
0
def test_case_insensitive_stream_name(basic_event):
    basic_event['stream_name'] = 'raven.FooClient'
    kwargs = deepcopy(basic_event)
    e = CosmologEvent(**kwargs)
    assert e == basic_event
Пример #5
0
def test_invalid_stream_name(basic_event):
    basic_event['stream_name'] = '%&^'
    with pytest.raises(CosmologgerException):
        CosmologEvent.from_dict(basic_event)
Пример #6
0
def test_invalid_origin(basic_event):
    basic_event['origin'] = 'spaces are not allowed'
    with pytest.raises(CosmologgerException):
        CosmologEvent.from_dict(basic_event)
Пример #7
0
def test_default_origin(monkeypatch, basic_event):
    monkeypatch.setattr(socket, 'getfqdn', lambda: 'foobar.example.com')
    kwargs = deepcopy(basic_event)
    kwargs.pop('origin')
    e = CosmologEvent(**kwargs)
    assert e == basic_event
Пример #8
0
def test_invalid_json(basic_event):
    j = '{"not": "quite", "json"'
    with pytest.raises(CosmologgerException):
        CosmologEvent.from_json(j)
Пример #9
0
def test_origin_with_underscores(basic_event):
    basic_event['origin'] = 'black_hole'
    e = CosmologEvent(**basic_event)
    assert e == basic_event
Пример #10
0
def test_from_dict(basic_event):
    e = CosmologEvent.from_dict(basic_event)
    assert e == basic_event
Пример #11
0
def test_payload_keys_with_dashes(basic_event):
    basic_event['payload'] = {
        'sun-distance': 146e6,
    }
    e = CosmologEvent(**basic_event)
    assert e == basic_event
Пример #12
0
def test_payload_keys_with_dots(basic_event):
    basic_event['payload'] = {'sun.distance': 146e6, 'moon.distance': 384400}
    e = CosmologEvent(**basic_event)
    assert e == basic_event
Пример #13
0
def test_null_values_in_payload(basic_event):
    kwargs = deepcopy(basic_event)
    kwargs['payload']['sensor'] = None
    e = CosmologEvent(**kwargs)
    assert e == kwargs
Пример #14
0
def test_unix_timestamp_string_allowed(basic_event):
    kwargs = deepcopy(basic_event)
    kwargs['timestamp'] = '1472834052.019105'
    e = CosmologEvent(**kwargs)
    assert e == basic_event
Пример #15
0
def test_datetimes_allowed(basic_event):
    kwargs = deepcopy(basic_event)
    kwargs['timestamp'] = dateparse(basic_event['timestamp'])
    e = CosmologEvent(**kwargs)
    assert e == basic_event