fluent-plugin-parser-logfmt 0.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
checksums.yaml ADDED
@@ -0,0 +1,7 @@
1
+ ---
2
+ SHA1:
3
+ metadata.gz: 2c0baf0352f65a806b9a7396914b42f83933218c
4
+ data.tar.gz: 22f4a608cca37b6661341f63230224d789e8e405
5
+ SHA512:
6
+ metadata.gz: 5a73344d2b4b65aec55fc00efb750624fd4ef5809e527a2607c38b16174e04ed22dfc479fd3e251fcb9b9a0cc3239b71911a472b30e3e3642437581d5bed3bf9
7
+ data.tar.gz: bb2d013fb82d5aca77a70e74a4cf97b107a63c9ea473fa17cdd0505ca4e68fa0f2a72bd21b4b7b1b091ccd6a14348766403944d8e8fffe61732e646e8649cf89
data/Gemfile ADDED
@@ -0,0 +1,3 @@
1
+ source 'https://rubygems.org'
2
+
3
+ gemspec
data/Rakefile ADDED
@@ -0,0 +1,10 @@
1
+ require "bundler/gem_tasks"
2
+
3
+ require 'rake/testtask'
4
+
5
+ task default: [:test]
6
+ Rake::TestTask.new do |test|
7
+ test.libs << 'lib' << 'test'
8
+ test.test_files = FileList['test/**/test_*.rb']
9
+ test.options = '-v'
10
+ end
data/VERSION ADDED
@@ -0,0 +1 @@
1
+ 0.0.0
@@ -0,0 +1,23 @@
1
+ $:.push File.expand_path('../lib', __FILE__)
2
+
3
+ Gem::Specification.new do |spec|
4
+ spec.name = "fluent-plugin-parser-logfmt"
5
+ spec.version = File.read("VERSION").strip
6
+ spec.author = 'Moriyoshi Koizumi <mozo@mozo.jp>'
7
+ spec.summary = "Fluentd parser plugin that parses logfmt-style log entries"
8
+ spec.homepage = "https://github.com/moriyoshi/fluent-plugin-parser-logfmt"
9
+ spec.license = "Apache-2.0"
10
+
11
+ spec.files = `git ls-files`.split("\n").reject{|f| f.start_with?(".")}
12
+ spec.test_files = `git ls-files -- {test,spec,features}/*`.split("\n")
13
+ spec.executables = `git ls-files -- bin/*`.split("\n").map{|f| File.basename(f)}
14
+ spec.require_paths = ["lib"]
15
+ spec.required_ruby_version = '>= 2.1'
16
+
17
+ spec.add_dependency "fluentd", ">= 1", "< 2"
18
+ spec.add_dependency "logfmt", "~> 0.0.8"
19
+
20
+ spec.add_development_dependency "bundler", "~> 1.10"
21
+ spec.add_development_dependency "rake", "~> 10.0"
22
+ spec.add_development_dependency "test-unit", "~> 3.0"
23
+ end
@@ -0,0 +1,34 @@
1
+ #
2
+ # Copyright 2018 Moriyoshi Koizumi. All Rights Reserved.
3
+ #
4
+ # Licensed under the Apache License, Version 2.0 (the "License");
5
+ # you may not use this file except in compliance with the License.
6
+ # You may obtain a copy of the License at
7
+ #
8
+ # http://www.apache.org/licenses/LICENSE-2.0
9
+ #
10
+ # Unless required by applicable law or agreed to in writing, software
11
+ # distributed under the License is distributed on an "AS IS" BASIS,
12
+ # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13
+ # See the License for the specific language governing permissions and
14
+ # limitations under the License.
15
+ #
16
+
17
+ require 'fluent/plugin/parser'
18
+ require 'logfmt'
19
+
20
+ module Fluent
21
+ module Plugin
22
+ class LogfmtParser < Parser
23
+ Plugin.register_parser('logfmt', self)
24
+
25
+ config_set_default :time_key, 'time'
26
+
27
+ def parse(text)
28
+ r = Logfmt.parse(text)
29
+ time, record = convert_values(parse_time(r), r)
30
+ yield time, record
31
+ end
32
+ end
33
+ end
34
+ end
@@ -0,0 +1,36 @@
1
+ require 'fluent/test'
2
+ require 'fluent/test/helpers'
3
+ require 'fluent/test/driver/parser'
4
+ require 'fluent/plugin/parser_logfmt'
5
+
6
+ class LogfmtParserTest < ::Test::Unit::TestCase
7
+ include Fluent::Test::Helpers
8
+
9
+ def setup
10
+ Fluent::Test.setup
11
+ @parser =Fluent::Test::Driver::Parser.new(Fluent::Plugin::LogfmtParser)
12
+ end
13
+
14
+ test 'basic parsing' do
15
+ @parser.configure({})
16
+ @parser.instance.parse('time="2018-01-01 00:00:00" aaa=111 bbb=222') { |time, record|
17
+ assert_equal(event_time('2018-01-01 00:00:00').to_i, time)
18
+ assert_equal({ 'aaa' => 111, 'bbb' => 222 }, record)
19
+ }
20
+ end
21
+
22
+ test 'time format' do
23
+ @parser.configure({ :time_format => '%Y/%m/%d %H:%M:%S' })
24
+ assert_raise Fluent::Plugin::Parser::ParserError do
25
+ @parser.instance.parse('time="2018-01-01 00:00:00" aaa=111 bbb=222') { |time, record|
26
+ assert_equal(event_time('2018-01-01 00:00:00').to_i, time)
27
+ assert_equal({ 'aaa' => 111, 'bbb' => 222 }, record)
28
+ }
29
+ end
30
+
31
+ @parser.instance.parse('time="2018/01/02 01:23:45" aaa=111 bbb=222') { |time, record|
32
+ assert_equal(event_time('2018-01-02 01:23:45').to_i, time)
33
+ assert_equal({ 'aaa' => 111, 'bbb' => 222 }, record)
34
+ }
35
+ end
36
+ end
metadata ADDED
@@ -0,0 +1,125 @@
1
+ --- !ruby/object:Gem::Specification
2
+ name: fluent-plugin-parser-logfmt
3
+ version: !ruby/object:Gem::Version
4
+ version: 0.0.0
5
+ platform: ruby
6
+ authors:
7
+ - Moriyoshi Koizumi <mozo@mozo.jp>
8
+ autorequire:
9
+ bindir: bin
10
+ cert_chain: []
11
+ date: 2018-05-29 00:00:00.000000000 Z
12
+ dependencies:
13
+ - !ruby/object:Gem::Dependency
14
+ name: fluentd
15
+ requirement: !ruby/object:Gem::Requirement
16
+ requirements:
17
+ - - ">="
18
+ - !ruby/object:Gem::Version
19
+ version: '1'
20
+ - - "<"
21
+ - !ruby/object:Gem::Version
22
+ version: '2'
23
+ type: :runtime
24
+ prerelease: false
25
+ version_requirements: !ruby/object:Gem::Requirement
26
+ requirements:
27
+ - - ">="
28
+ - !ruby/object:Gem::Version
29
+ version: '1'
30
+ - - "<"
31
+ - !ruby/object:Gem::Version
32
+ version: '2'
33
+ - !ruby/object:Gem::Dependency
34
+ name: logfmt
35
+ requirement: !ruby/object:Gem::Requirement
36
+ requirements:
37
+ - - "~>"
38
+ - !ruby/object:Gem::Version
39
+ version: 0.0.8
40
+ type: :runtime
41
+ prerelease: false
42
+ version_requirements: !ruby/object:Gem::Requirement
43
+ requirements:
44
+ - - "~>"
45
+ - !ruby/object:Gem::Version
46
+ version: 0.0.8
47
+ - !ruby/object:Gem::Dependency
48
+ name: bundler
49
+ requirement: !ruby/object:Gem::Requirement
50
+ requirements:
51
+ - - "~>"
52
+ - !ruby/object:Gem::Version
53
+ version: '1.10'
54
+ type: :development
55
+ prerelease: false
56
+ version_requirements: !ruby/object:Gem::Requirement
57
+ requirements:
58
+ - - "~>"
59
+ - !ruby/object:Gem::Version
60
+ version: '1.10'
61
+ - !ruby/object:Gem::Dependency
62
+ name: rake
63
+ requirement: !ruby/object:Gem::Requirement
64
+ requirements:
65
+ - - "~>"
66
+ - !ruby/object:Gem::Version
67
+ version: '10.0'
68
+ type: :development
69
+ prerelease: false
70
+ version_requirements: !ruby/object:Gem::Requirement
71
+ requirements:
72
+ - - "~>"
73
+ - !ruby/object:Gem::Version
74
+ version: '10.0'
75
+ - !ruby/object:Gem::Dependency
76
+ name: test-unit
77
+ requirement: !ruby/object:Gem::Requirement
78
+ requirements:
79
+ - - "~>"
80
+ - !ruby/object:Gem::Version
81
+ version: '3.0'
82
+ type: :development
83
+ prerelease: false
84
+ version_requirements: !ruby/object:Gem::Requirement
85
+ requirements:
86
+ - - "~>"
87
+ - !ruby/object:Gem::Version
88
+ version: '3.0'
89
+ description:
90
+ email:
91
+ executables: []
92
+ extensions: []
93
+ extra_rdoc_files: []
94
+ files:
95
+ - Gemfile
96
+ - Rakefile
97
+ - VERSION
98
+ - fluent-plugin-parser-logfmt.gemspec
99
+ - lib/fluent/plugin/parser_logfmt.rb
100
+ - test/test_parser_logfmt.rb
101
+ homepage: https://github.com/moriyoshi/fluent-plugin-parser-logfmt
102
+ licenses:
103
+ - Apache-2.0
104
+ metadata: {}
105
+ post_install_message:
106
+ rdoc_options: []
107
+ require_paths:
108
+ - lib
109
+ required_ruby_version: !ruby/object:Gem::Requirement
110
+ requirements:
111
+ - - ">="
112
+ - !ruby/object:Gem::Version
113
+ version: '2.1'
114
+ required_rubygems_version: !ruby/object:Gem::Requirement
115
+ requirements:
116
+ - - ">="
117
+ - !ruby/object:Gem::Version
118
+ version: '0'
119
+ requirements: []
120
+ rubyforge_project:
121
+ rubygems_version: 2.5.2.1
122
+ signing_key:
123
+ specification_version: 4
124
+ summary: Fluentd parser plugin that parses logfmt-style log entries
125
+ test_files: []