forked from elastic/logstash
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathjson_spec.rb
83 lines (75 loc) · 2.56 KB
/
json_spec.rb
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
require "logstash/codecs/json"
require "logstash/event"
require "logstash/json"
require "insist"
describe LogStash::Codecs::JSON do
subject do
next LogStash::Codecs::JSON.new
end
context "#decode" do
it "should return an event from json data" do
data = {"foo" => "bar", "baz" => {"bah" => ["a","b","c"]}}
subject.decode(LogStash::Json.dump(data)) do |event|
insist { event.is_a? LogStash::Event }
insist { event["foo"] } == data["foo"]
insist { event["baz"] } == data["baz"]
insist { event["bah"] } == data["bah"]
end
end
it "should be fast", :performance => true do
json = '{"message":"Hello world!","@timestamp":"2013-12-21T07:01:25.616Z","@version":"1","host":"Macintosh.local","sequence":1572456}'
iterations = 500000
count = 0
# Warmup
10000.times { subject.decode(json) { } }
start = Time.now
iterations.times do
subject.decode(json) do |event|
count += 1
end
end
duration = Time.now - start
insist { count } == iterations
puts "codecs/json rate: #{"%02.0f/sec" % (iterations / duration)}, elapsed: #{duration}s"
end
context "processing plain text" do
it "falls back to plain text" do
decoded = false
subject.decode("something that isn't json") do |event|
decoded = true
insist { event.is_a?(LogStash::Event) }
insist { event["message"] } == "something that isn't json"
end
insist { decoded } == true
end
end
context "processing weird binary blobs" do
it "falls back to plain text and doesn't crash (LOGSTASH-1595)" do
decoded = false
blob = (128..255).to_a.pack("C*").force_encoding("ASCII-8BIT")
subject.decode(blob) do |event|
decoded = true
insist { event.is_a?(LogStash::Event) }
insist { event["message"].encoding.to_s } == "UTF-8"
end
insist { decoded } == true
end
end
end
context "#encode" do
it "should return json data" do
data = {"foo" => "bar", "baz" => {"bah" => ["a","b","c"]}}
event = LogStash::Event.new(data)
got_event = false
subject.on_event do |d|
insist { d.chomp } == LogStash::Event.new(data).to_json
insist { LogStash::Json.load(d)["foo"] } == data["foo"]
insist { LogStash::Json.load(d)["baz"] } == data["baz"]
insist { LogStash::Json.load(d)["bah"] } == data["bah"]
got_event = true
end
subject.encode(event)
insist { got_event }
end
end
end