fluentd 1.16.5-x86-mingw32 → 1.17.1-x86-mingw32

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.
Files changed (268) hide show
  1. checksums.yaml +4 -4
  2. data/CHANGELOG.md +88 -0
  3. data/README.md +2 -1
  4. data/Rakefile +1 -1
  5. data/SECURITY.md +2 -2
  6. data/fluent.conf +14 -14
  7. data/lib/fluent/command/binlog_reader.rb +1 -1
  8. data/lib/fluent/command/cap_ctl.rb +4 -4
  9. data/lib/fluent/compat/call_super_mixin.rb +3 -3
  10. data/lib/fluent/compat/propagate_default.rb +4 -4
  11. data/lib/fluent/config/configure_proxy.rb +2 -2
  12. data/lib/fluent/config/types.rb +1 -1
  13. data/lib/fluent/config/yaml_parser/parser.rb +4 -0
  14. data/lib/fluent/configurable.rb +2 -2
  15. data/lib/fluent/counter/mutex_hash.rb +1 -1
  16. data/lib/fluent/fluent_log_event_router.rb +0 -2
  17. data/lib/fluent/log/console_adapter.rb +4 -2
  18. data/lib/fluent/plugin/buf_file.rb +1 -1
  19. data/lib/fluent/plugin/buffer/file_chunk.rb +1 -1
  20. data/lib/fluent/plugin/buffer/file_single_chunk.rb +2 -3
  21. data/lib/fluent/plugin/filter_parser.rb +26 -8
  22. data/lib/fluent/plugin/in_exec.rb +14 -2
  23. data/lib/fluent/plugin/in_http.rb +19 -54
  24. data/lib/fluent/plugin/in_sample.rb +13 -7
  25. data/lib/fluent/plugin/in_tail.rb +99 -25
  26. data/lib/fluent/plugin/out_copy.rb +1 -1
  27. data/lib/fluent/plugin/out_file.rb +8 -0
  28. data/lib/fluent/plugin/out_http.rb +137 -13
  29. data/lib/fluent/plugin/owned_by_mixin.rb +0 -1
  30. data/lib/fluent/plugin/parser_json.rb +26 -17
  31. data/lib/fluent/plugin/parser_msgpack.rb +24 -3
  32. data/lib/fluent/plugin_helper/http_server/server.rb +1 -1
  33. data/lib/fluent/plugin_helper/metrics.rb +2 -2
  34. data/lib/fluent/registry.rb +6 -6
  35. data/lib/fluent/test/output_test.rb +1 -1
  36. data/lib/fluent/unique_id.rb +1 -1
  37. data/lib/fluent/version.rb +1 -1
  38. data/templates/new_gem/fluent-plugin.gemspec.erb +6 -5
  39. metadata +109 -459
  40. data/.github/ISSUE_TEMPLATE/bug_report.yml +0 -71
  41. data/.github/ISSUE_TEMPLATE/config.yml +0 -5
  42. data/.github/ISSUE_TEMPLATE/feature_request.yml +0 -39
  43. data/.github/ISSUE_TEMPLATE.md +0 -17
  44. data/.github/PULL_REQUEST_TEMPLATE.md +0 -14
  45. data/.github/workflows/stale-actions.yml +0 -24
  46. data/.github/workflows/test.yml +0 -32
  47. data/.gitignore +0 -30
  48. data/Gemfile +0 -9
  49. data/fluentd.gemspec +0 -54
  50. data/test/command/test_binlog_reader.rb +0 -362
  51. data/test/command/test_ca_generate.rb +0 -70
  52. data/test/command/test_cap_ctl.rb +0 -100
  53. data/test/command/test_cat.rb +0 -128
  54. data/test/command/test_ctl.rb +0 -56
  55. data/test/command/test_fluentd.rb +0 -1291
  56. data/test/command/test_plugin_config_formatter.rb +0 -397
  57. data/test/command/test_plugin_generator.rb +0 -109
  58. data/test/compat/test_calls_super.rb +0 -166
  59. data/test/compat/test_parser.rb +0 -92
  60. data/test/config/assertions.rb +0 -42
  61. data/test/config/test_config_parser.rb +0 -551
  62. data/test/config/test_configurable.rb +0 -1784
  63. data/test/config/test_configure_proxy.rb +0 -604
  64. data/test/config/test_dsl.rb +0 -415
  65. data/test/config/test_element.rb +0 -518
  66. data/test/config/test_literal_parser.rb +0 -309
  67. data/test/config/test_plugin_configuration.rb +0 -56
  68. data/test/config/test_section.rb +0 -191
  69. data/test/config/test_system_config.rb +0 -195
  70. data/test/config/test_types.rb +0 -408
  71. data/test/counter/test_client.rb +0 -563
  72. data/test/counter/test_error.rb +0 -44
  73. data/test/counter/test_mutex_hash.rb +0 -179
  74. data/test/counter/test_server.rb +0 -589
  75. data/test/counter/test_store.rb +0 -258
  76. data/test/counter/test_validator.rb +0 -137
  77. data/test/helper.rb +0 -155
  78. data/test/helpers/fuzzy_assert.rb +0 -89
  79. data/test/helpers/process_extenstion.rb +0 -33
  80. data/test/log/test_console_adapter.rb +0 -110
  81. data/test/plugin/data/2010/01/20100102-030405.log +0 -0
  82. data/test/plugin/data/2010/01/20100102-030406.log +0 -0
  83. data/test/plugin/data/2010/01/20100102.log +0 -0
  84. data/test/plugin/data/log/bar +0 -0
  85. data/test/plugin/data/log/foo/bar.log +0 -0
  86. data/test/plugin/data/log/foo/bar2 +0 -0
  87. data/test/plugin/data/log/test.log +0 -0
  88. data/test/plugin/data/sd_file/config +0 -11
  89. data/test/plugin/data/sd_file/config.json +0 -17
  90. data/test/plugin/data/sd_file/config.yaml +0 -11
  91. data/test/plugin/data/sd_file/config.yml +0 -11
  92. data/test/plugin/data/sd_file/invalid_config.yml +0 -7
  93. data/test/plugin/in_tail/test_fifo.rb +0 -121
  94. data/test/plugin/in_tail/test_io_handler.rb +0 -150
  95. data/test/plugin/in_tail/test_position_file.rb +0 -346
  96. data/test/plugin/out_forward/test_ack_handler.rb +0 -140
  97. data/test/plugin/out_forward/test_connection_manager.rb +0 -145
  98. data/test/plugin/out_forward/test_handshake_protocol.rb +0 -112
  99. data/test/plugin/out_forward/test_load_balancer.rb +0 -106
  100. data/test/plugin/out_forward/test_socket_cache.rb +0 -174
  101. data/test/plugin/test_bare_output.rb +0 -131
  102. data/test/plugin/test_base.rb +0 -247
  103. data/test/plugin/test_buf_file.rb +0 -1314
  104. data/test/plugin/test_buf_file_single.rb +0 -898
  105. data/test/plugin/test_buf_memory.rb +0 -42
  106. data/test/plugin/test_buffer.rb +0 -1493
  107. data/test/plugin/test_buffer_chunk.rb +0 -209
  108. data/test/plugin/test_buffer_file_chunk.rb +0 -871
  109. data/test/plugin/test_buffer_file_single_chunk.rb +0 -611
  110. data/test/plugin/test_buffer_memory_chunk.rb +0 -339
  111. data/test/plugin/test_compressable.rb +0 -87
  112. data/test/plugin/test_file_util.rb +0 -96
  113. data/test/plugin/test_filter.rb +0 -368
  114. data/test/plugin/test_filter_grep.rb +0 -697
  115. data/test/plugin/test_filter_parser.rb +0 -731
  116. data/test/plugin/test_filter_record_transformer.rb +0 -577
  117. data/test/plugin/test_filter_stdout.rb +0 -207
  118. data/test/plugin/test_formatter_csv.rb +0 -136
  119. data/test/plugin/test_formatter_hash.rb +0 -38
  120. data/test/plugin/test_formatter_json.rb +0 -61
  121. data/test/plugin/test_formatter_ltsv.rb +0 -70
  122. data/test/plugin/test_formatter_msgpack.rb +0 -28
  123. data/test/plugin/test_formatter_out_file.rb +0 -116
  124. data/test/plugin/test_formatter_single_value.rb +0 -44
  125. data/test/plugin/test_formatter_tsv.rb +0 -76
  126. data/test/plugin/test_in_debug_agent.rb +0 -49
  127. data/test/plugin/test_in_exec.rb +0 -261
  128. data/test/plugin/test_in_forward.rb +0 -1178
  129. data/test/plugin/test_in_gc_stat.rb +0 -62
  130. data/test/plugin/test_in_http.rb +0 -1102
  131. data/test/plugin/test_in_monitor_agent.rb +0 -922
  132. data/test/plugin/test_in_object_space.rb +0 -66
  133. data/test/plugin/test_in_sample.rb +0 -190
  134. data/test/plugin/test_in_syslog.rb +0 -505
  135. data/test/plugin/test_in_tail.rb +0 -3288
  136. data/test/plugin/test_in_tcp.rb +0 -328
  137. data/test/plugin/test_in_udp.rb +0 -296
  138. data/test/plugin/test_in_unix.rb +0 -181
  139. data/test/plugin/test_input.rb +0 -137
  140. data/test/plugin/test_metadata.rb +0 -89
  141. data/test/plugin/test_metrics.rb +0 -294
  142. data/test/plugin/test_metrics_local.rb +0 -96
  143. data/test/plugin/test_multi_output.rb +0 -204
  144. data/test/plugin/test_out_copy.rb +0 -308
  145. data/test/plugin/test_out_exec.rb +0 -312
  146. data/test/plugin/test_out_exec_filter.rb +0 -606
  147. data/test/plugin/test_out_file.rb +0 -1038
  148. data/test/plugin/test_out_forward.rb +0 -1349
  149. data/test/plugin/test_out_http.rb +0 -429
  150. data/test/plugin/test_out_null.rb +0 -105
  151. data/test/plugin/test_out_relabel.rb +0 -28
  152. data/test/plugin/test_out_roundrobin.rb +0 -146
  153. data/test/plugin/test_out_secondary_file.rb +0 -458
  154. data/test/plugin/test_out_stdout.rb +0 -205
  155. data/test/plugin/test_out_stream.rb +0 -103
  156. data/test/plugin/test_output.rb +0 -1334
  157. data/test/plugin/test_output_as_buffered.rb +0 -2024
  158. data/test/plugin/test_output_as_buffered_backup.rb +0 -363
  159. data/test/plugin/test_output_as_buffered_compress.rb +0 -179
  160. data/test/plugin/test_output_as_buffered_overflow.rb +0 -250
  161. data/test/plugin/test_output_as_buffered_retries.rb +0 -966
  162. data/test/plugin/test_output_as_buffered_secondary.rb +0 -882
  163. data/test/plugin/test_output_as_standard.rb +0 -374
  164. data/test/plugin/test_owned_by.rb +0 -35
  165. data/test/plugin/test_parser.rb +0 -399
  166. data/test/plugin/test_parser_apache.rb +0 -42
  167. data/test/plugin/test_parser_apache2.rb +0 -47
  168. data/test/plugin/test_parser_apache_error.rb +0 -45
  169. data/test/plugin/test_parser_csv.rb +0 -200
  170. data/test/plugin/test_parser_json.rb +0 -138
  171. data/test/plugin/test_parser_labeled_tsv.rb +0 -160
  172. data/test/plugin/test_parser_multiline.rb +0 -111
  173. data/test/plugin/test_parser_nginx.rb +0 -88
  174. data/test/plugin/test_parser_none.rb +0 -52
  175. data/test/plugin/test_parser_regexp.rb +0 -284
  176. data/test/plugin/test_parser_syslog.rb +0 -650
  177. data/test/plugin/test_parser_tsv.rb +0 -122
  178. data/test/plugin/test_sd_file.rb +0 -228
  179. data/test/plugin/test_sd_srv.rb +0 -230
  180. data/test/plugin/test_storage.rb +0 -167
  181. data/test/plugin/test_storage_local.rb +0 -335
  182. data/test/plugin/test_string_util.rb +0 -26
  183. data/test/plugin_helper/data/cert/cert-key.pem +0 -27
  184. data/test/plugin_helper/data/cert/cert-with-CRLF.pem +0 -19
  185. data/test/plugin_helper/data/cert/cert-with-no-newline.pem +0 -19
  186. data/test/plugin_helper/data/cert/cert.pem +0 -19
  187. data/test/plugin_helper/data/cert/cert_chains/ca-cert-key.pem +0 -27
  188. data/test/plugin_helper/data/cert/cert_chains/ca-cert.pem +0 -20
  189. data/test/plugin_helper/data/cert/cert_chains/cert-key.pem +0 -27
  190. data/test/plugin_helper/data/cert/cert_chains/cert.pem +0 -40
  191. data/test/plugin_helper/data/cert/empty.pem +0 -0
  192. data/test/plugin_helper/data/cert/generate_cert.rb +0 -125
  193. data/test/plugin_helper/data/cert/with_ca/ca-cert-key-pass.pem +0 -30
  194. data/test/plugin_helper/data/cert/with_ca/ca-cert-key.pem +0 -27
  195. data/test/plugin_helper/data/cert/with_ca/ca-cert-pass.pem +0 -20
  196. data/test/plugin_helper/data/cert/with_ca/ca-cert.pem +0 -20
  197. data/test/plugin_helper/data/cert/with_ca/cert-key-pass.pem +0 -30
  198. data/test/plugin_helper/data/cert/with_ca/cert-key.pem +0 -27
  199. data/test/plugin_helper/data/cert/with_ca/cert-pass.pem +0 -21
  200. data/test/plugin_helper/data/cert/with_ca/cert.pem +0 -21
  201. data/test/plugin_helper/data/cert/without_ca/cert-key-pass.pem +0 -30
  202. data/test/plugin_helper/data/cert/without_ca/cert-key.pem +0 -27
  203. data/test/plugin_helper/data/cert/without_ca/cert-pass.pem +0 -20
  204. data/test/plugin_helper/data/cert/without_ca/cert.pem +0 -20
  205. data/test/plugin_helper/http_server/test_app.rb +0 -65
  206. data/test/plugin_helper/http_server/test_route.rb +0 -32
  207. data/test/plugin_helper/service_discovery/test_manager.rb +0 -93
  208. data/test/plugin_helper/service_discovery/test_round_robin_balancer.rb +0 -21
  209. data/test/plugin_helper/test_cert_option.rb +0 -25
  210. data/test/plugin_helper/test_child_process.rb +0 -862
  211. data/test/plugin_helper/test_compat_parameters.rb +0 -358
  212. data/test/plugin_helper/test_event_emitter.rb +0 -80
  213. data/test/plugin_helper/test_event_loop.rb +0 -52
  214. data/test/plugin_helper/test_extract.rb +0 -194
  215. data/test/plugin_helper/test_formatter.rb +0 -255
  216. data/test/plugin_helper/test_http_server_helper.rb +0 -372
  217. data/test/plugin_helper/test_inject.rb +0 -561
  218. data/test/plugin_helper/test_metrics.rb +0 -137
  219. data/test/plugin_helper/test_parser.rb +0 -264
  220. data/test/plugin_helper/test_record_accessor.rb +0 -238
  221. data/test/plugin_helper/test_retry_state.rb +0 -1006
  222. data/test/plugin_helper/test_server.rb +0 -1895
  223. data/test/plugin_helper/test_service_discovery.rb +0 -165
  224. data/test/plugin_helper/test_socket.rb +0 -146
  225. data/test/plugin_helper/test_storage.rb +0 -542
  226. data/test/plugin_helper/test_thread.rb +0 -164
  227. data/test/plugin_helper/test_timer.rb +0 -130
  228. data/test/scripts/exec_script.rb +0 -32
  229. data/test/scripts/fluent/plugin/formatter1/formatter_test1.rb +0 -7
  230. data/test/scripts/fluent/plugin/formatter2/formatter_test2.rb +0 -7
  231. data/test/scripts/fluent/plugin/formatter_known.rb +0 -8
  232. data/test/scripts/fluent/plugin/out_test.rb +0 -81
  233. data/test/scripts/fluent/plugin/out_test2.rb +0 -80
  234. data/test/scripts/fluent/plugin/parser_known.rb +0 -4
  235. data/test/test_capability.rb +0 -74
  236. data/test/test_clock.rb +0 -164
  237. data/test/test_config.rb +0 -369
  238. data/test/test_configdsl.rb +0 -148
  239. data/test/test_daemonizer.rb +0 -91
  240. data/test/test_engine.rb +0 -203
  241. data/test/test_event.rb +0 -531
  242. data/test/test_event_router.rb +0 -348
  243. data/test/test_event_time.rb +0 -199
  244. data/test/test_file_wrapper.rb +0 -53
  245. data/test/test_filter.rb +0 -121
  246. data/test/test_fluent_log_event_router.rb +0 -99
  247. data/test/test_formatter.rb +0 -369
  248. data/test/test_input.rb +0 -31
  249. data/test/test_log.rb +0 -1076
  250. data/test/test_match.rb +0 -148
  251. data/test/test_mixin.rb +0 -351
  252. data/test/test_msgpack_factory.rb +0 -50
  253. data/test/test_oj_options.rb +0 -55
  254. data/test/test_output.rb +0 -278
  255. data/test/test_plugin.rb +0 -251
  256. data/test/test_plugin_classes.rb +0 -370
  257. data/test/test_plugin_helper.rb +0 -81
  258. data/test/test_plugin_id.rb +0 -119
  259. data/test/test_process.rb +0 -14
  260. data/test/test_root_agent.rb +0 -951
  261. data/test/test_static_config_analysis.rb +0 -177
  262. data/test/test_supervisor.rb +0 -821
  263. data/test/test_test_drivers.rb +0 -136
  264. data/test/test_time_formatter.rb +0 -301
  265. data/test/test_time_parser.rb +0 -362
  266. data/test/test_tls.rb +0 -65
  267. data/test/test_unique_id.rb +0 -47
  268. data/test/test_variable_store.rb +0 -65
@@ -1,88 +0,0 @@
1
- require_relative '../helper'
2
- require 'fluent/test/driver/parser'
3
- require 'fluent/plugin/parser_nginx'
4
-
5
- class NginxParserTest < ::Test::Unit::TestCase
6
- def setup
7
- Fluent::Test.setup
8
- @expected = {
9
- 'remote' => '127.0.0.1',
10
- 'host' => '192.168.0.1',
11
- 'user' => '-',
12
- 'method' => 'GET',
13
- 'path' => '/',
14
- 'code' => '200',
15
- 'size' => '777',
16
- 'referer' => '-',
17
- 'agent' => 'Opera/12.0'
18
- }
19
- @expected_extended = {
20
- 'remote' => '127.0.0.1',
21
- 'host' => '192.168.0.1',
22
- 'user' => '-',
23
- 'method' => 'GET',
24
- 'path' => '/',
25
- 'code' => '200',
26
- 'size' => '777',
27
- 'referer' => '-',
28
- 'agent' => 'Opera/12.0',
29
- 'http_x_forwarded_for' => '-'
30
- }
31
- @expected_extended_multiple_ip = {
32
- 'remote' => '127.0.0.1',
33
- 'host' => '192.168.0.1',
34
- 'user' => '-',
35
- 'method' => 'GET',
36
- 'path' => '/',
37
- 'code' => '200',
38
- 'size' => '777',
39
- 'referer' => '-',
40
- 'agent' => 'Opera/12.0',
41
- 'http_x_forwarded_for' => '127.0.0.1, 192.168.0.1'
42
- }
43
- end
44
-
45
- def create_driver
46
- Fluent::Test::Driver::Parser.new(Fluent::Plugin::NginxParser.new).configure({})
47
- end
48
-
49
- def test_parse
50
- d = create_driver
51
- d.instance.parse('127.0.0.1 192.168.0.1 - [28/Feb/2013:12:00:00 +0900] "GET / HTTP/1.1" 200 777 "-" "Opera/12.0"') { |time, record|
52
- assert_equal(event_time('28/Feb/2013:12:00:00 +0900', format: '%d/%b/%Y:%H:%M:%S %z'), time)
53
- assert_equal(@expected, record)
54
- }
55
- end
56
-
57
- def test_parse_with_empty_included_path
58
- d = create_driver
59
- d.instance.parse('127.0.0.1 192.168.0.1 - [28/Feb/2013:12:00:00 +0900] "GET /a[ ]b HTTP/1.1" 200 777 "-" "Opera/12.0"') { |time, record|
60
- assert_equal(event_time('28/Feb/2013:12:00:00 +0900', format: '%d/%b/%Y:%H:%M:%S %z'), time)
61
- assert_equal(@expected.merge('path' => '/a[ ]b'), record)
62
- }
63
- end
64
-
65
- def test_parse_without_http_version
66
- d = create_driver
67
- d.instance.parse('127.0.0.1 192.168.0.1 - [28/Feb/2013:12:00:00 +0900] "GET /" 200 777 "-" "Opera/12.0"') { |time, record|
68
- assert_equal(event_time('28/Feb/2013:12:00:00 +0900', format: '%d/%b/%Y:%H:%M:%S %z'), time)
69
- assert_equal(@expected, record)
70
- }
71
- end
72
-
73
- def test_parse_with_http_x_forwarded_for
74
- d = create_driver
75
- d.instance.parse('127.0.0.1 192.168.0.1 - [28/Feb/2013:12:00:00 +0900] "GET / HTTP/1.1" 200 777 "-" "Opera/12.0" -') { |time, record|
76
- assert_equal(event_time('28/Feb/2013:12:00:00 +0900', format: '%d/%b/%Y:%H:%M:%S %z'), time)
77
- assert_equal(@expected_extended, record)
78
- }
79
- end
80
-
81
- def test_parse_with_http_x_forwarded_for_multiple_ip
82
- d = create_driver
83
- d.instance.parse('127.0.0.1 192.168.0.1 - [28/Feb/2013:12:00:00 +0900] "GET / HTTP/1.1" 200 777 "-" "Opera/12.0" "127.0.0.1, 192.168.0.1"') { |time, record|
84
- assert_equal(event_time('28/Feb/2013:12:00:00 +0900', format: '%d/%b/%Y:%H:%M:%S %z'), time)
85
- assert_equal(@expected_extended_multiple_ip, record)
86
- }
87
- end
88
- end
@@ -1,52 +0,0 @@
1
- require_relative '../helper'
2
- require 'fluent/test/driver/parser'
3
- require 'fluent/plugin/parser'
4
-
5
- class NoneParserTest < ::Test::Unit::TestCase
6
- def setup
7
- Fluent::Test.setup
8
- end
9
-
10
- def test_config_params
11
- parser = Fluent::Test::Driver::Parser.new(Fluent::TextParser::NoneParser)
12
- parser.configure({})
13
- assert_equal "message", parser.instance.message_key
14
-
15
- parser.configure('message_key' => 'foobar')
16
- assert_equal "foobar", parser.instance.message_key
17
- end
18
-
19
- def test_parse
20
- parser = Fluent::Test::Driver::Parser.new(Fluent::Plugin.new_parser('none'))
21
- parser.configure({})
22
- parser.instance.parse('log message!') { |time, record|
23
- assert_equal({'message' => 'log message!'}, record)
24
- }
25
- end
26
-
27
- def test_parse_with_message_key
28
- parser = Fluent::Test::Driver::Parser.new(Fluent::TextParser::NoneParser)
29
- parser.configure('message_key' => 'foobar')
30
- parser.instance.parse('log message!') { |time, record|
31
- assert_equal({'foobar' => 'log message!'}, record)
32
- }
33
- end
34
-
35
- def test_parse_without_default_time
36
- time_at_start = Time.now.to_i
37
-
38
- parser = Fluent::Test::Driver::Parser.new(Fluent::Plugin.new_parser('none'))
39
- parser.configure({})
40
- parser.instance.parse('log message!') { |time, record|
41
- assert time && time >= time_at_start, "parser puts current time without time input"
42
- assert_equal({'message' => 'log message!'}, record)
43
- }
44
-
45
- parser = Fluent::Test::Driver::Parser.new(Fluent::Plugin.new_parser('none'))
46
- parser.configure({'estimate_current_event' => 'false'})
47
- parser.instance.parse('log message!') { |time, record|
48
- assert_equal({'message' => 'log message!'}, record)
49
- assert_nil time, "parser returns nil w/o time if configured so"
50
- }
51
- end
52
- end
@@ -1,284 +0,0 @@
1
- require_relative '../helper'
2
- require 'fluent/test/driver/parser'
3
- require 'fluent/plugin/parser'
4
-
5
- class RegexpParserTest < ::Test::Unit::TestCase
6
- def setup
7
- Fluent::Test.setup
8
- end
9
-
10
- def internal_test_case(parser)
11
- text = '192.168.0.1 - - [28/Feb/2013:12:00:00 +0900] [14/Feb/2013:12:00:00 +0900] "true /,/user HTTP/1.1" 200 777'
12
- parser.parse(text) { |time, record|
13
- assert_equal(event_time('28/Feb/2013:12:00:00 +0900', format: '%d/%b/%Y:%H:%M:%S %z'), time)
14
- assert_equal({
15
- 'user' => '-',
16
- 'flag' => true,
17
- 'code' => 200.0,
18
- 'size' => 777,
19
- 'date' => event_time('14/Feb/2013:12:00:00 +0900', format: '%d/%b/%Y:%H:%M:%S %z'),
20
- 'host' => '192.168.0.1',
21
- 'path' => ['/', '/user']
22
- }, record)
23
- }
24
- end
25
-
26
- sub_test_case "Fluent::Compat::TextParser::RegexpParser" do
27
- def create_driver(regexp, conf = {}, initialize_conf: false)
28
- if initialize_conf
29
- Fluent::Test::Driver::Parser.new(Fluent::Compat::TextParser::RegexpParser.new(regexp, conf))
30
- else
31
- Fluent::Test::Driver::Parser.new(Fluent::Compat::TextParser::RegexpParser.new(regexp)).configure(conf)
32
- end
33
- end
34
-
35
- def test_parse_with_typed
36
- # Use Regexp.new instead of // literal to avoid different parser behaviour in 1.9 and 2.0
37
- regexp = Regexp.new(%q!^(?<host>[^ ]*) [^ ]* (?<user>[^ ]*) \[(?<time>[^\]]*)\] \[(?<date>[^\]]*)\] "(?<flag>\S+)(?: +(?<path>[^ ]*) +\S*)?" (?<code>[^ ]*) (?<size>[^ ]*)$!)
38
- conf = {
39
- 'time_format' => "%d/%b/%Y:%H:%M:%S %z",
40
- 'types' => 'user:string,date:time:%d/%b/%Y:%H:%M:%S %z,flag:bool,path:array,code:float,size:integer'
41
- }
42
- d = create_driver(regexp, conf, initialize_conf: true)
43
- internal_test_case(d.instance)
44
- end
45
-
46
- def test_parse_with_configure
47
- # Specify conf by configure method instead of initializer
48
- regexp = Regexp.new(%q!^(?<host>[^ ]*) [^ ]* (?<user>[^ ]*) \[(?<time>[^\]]*)\] \[(?<date>[^\]]*)\] "(?<flag>\S+)(?: +(?<path>[^ ]*) +\S*)?" (?<code>[^ ]*) (?<size>[^ ]*)$!)
49
- conf = {
50
- 'time_format' => "%d/%b/%Y:%H:%M:%S %z",
51
- 'types' => 'user:string,date:time:%d/%b/%Y:%H:%M:%S %z,flag:bool,path:array,code:float,size:integer'
52
- }
53
- d = create_driver(regexp, conf)
54
- internal_test_case(d.instance)
55
- assert_equal(regexp, d.instance.patterns['format'])
56
- assert_equal("%d/%b/%Y:%H:%M:%S %z", d.instance.patterns['time_format'])
57
- end
58
-
59
- def test_parse_with_typed_and_name_separator
60
- regexp = Regexp.new(%q!^(?<host>[^ ]*) [^ ]* (?<user>[^ ]*) \[(?<time>[^\]]*)\] \[(?<date>[^\]]*)\] "(?<flag>\S+)(?: +(?<path>[^ ]*) +\S*)?" (?<code>[^ ]*) (?<size>[^ ]*)$!)
61
- conf = {
62
- 'time_format' => "%d/%b/%Y:%H:%M:%S %z",
63
- 'types' => 'user|string,date|time|%d/%b/%Y:%H:%M:%S %z,flag|bool,path|array,code|float,size|integer',
64
- 'types_label_delimiter' => '|'
65
- }
66
- d = create_driver(regexp, conf)
67
- internal_test_case(d.instance)
68
- end
69
-
70
- def test_parse_with_time_key
71
- conf = {
72
- 'time_format' => "%Y-%m-%d %H:%M:%S %z",
73
- 'time_key' => 'logtime'
74
- }
75
- d = create_driver(/(?<logtime>[^\]]*)/, conf)
76
- text = '2013-02-28 12:00:00 +0900'
77
- d.instance.parse(text) do |time, _record|
78
- assert_equal Fluent::EventTime.parse(text), time
79
- end
80
- end
81
-
82
- def test_parse_without_time
83
- time_at_start = Time.now.to_i
84
- text = "tagomori_satoshi tagomoris 34\n"
85
-
86
- regexp = Regexp.new(%q!^(?<name>[^ ]*) (?<user>[^ ]*) (?<age>\d*)$!)
87
- conf = {
88
- 'types' => 'name:string,user:string,age:integer'
89
- }
90
- d = create_driver(regexp, conf)
91
-
92
- d.instance.parse(text) { |time, record|
93
- assert time && time >= time_at_start, "parser puts current time without time input"
94
- assert_equal "tagomori_satoshi", record["name"]
95
- assert_equal "tagomoris", record["user"]
96
- assert_equal 34, record["age"]
97
- }
98
- end
99
-
100
- def test_parse_without_time_estimate_curent_event_false
101
- text = "tagomori_satoshi tagomoris 34\n"
102
- regexp = Regexp.new(%q!^(?<name>[^ ]*) (?<user>[^ ]*) (?<age>\d*)$!)
103
- conf = {
104
- 'types' => 'name:string,user:string,age:integer'
105
- }
106
- d = create_driver(regexp, conf)
107
- d.instance.estimate_current_event = false
108
- d.instance.parse(text) { |time, record|
109
- assert_equal "tagomori_satoshi", record["name"]
110
- assert_equal "tagomoris", record["user"]
111
- assert_equal 34, record["age"]
112
-
113
- assert_nil time, "parser returns nil if configured so"
114
- }
115
- end
116
-
117
- def test_parse_with_keep_time_key
118
- regexp = Regexp.new(%q!(?<time>.*)!)
119
- conf = {
120
- 'time_format' => "%d/%b/%Y:%H:%M:%S %z",
121
- 'keep_time_key' => 'true',
122
- }
123
- d = create_driver(regexp, conf)
124
- text = '28/Feb/2013:12:00:00 +0900'
125
- d.instance.parse(text) do |_time, record|
126
- assert_equal text, record['time']
127
- end
128
- end
129
-
130
- def test_parse_with_keep_time_key_with_typecast
131
- regexp = Regexp.new(%q!(?<time>.*)!)
132
- conf = {
133
- 'time_format' => "%d/%b/%Y:%H:%M:%S %z",
134
- 'keep_time_key' => 'true',
135
- 'types' => 'time:time:%d/%b/%Y:%H:%M:%S %z',
136
- }
137
- d = create_driver(regexp, conf)
138
- text = '28/Feb/2013:12:00:00 +0900'
139
- d.instance.parse(text) do |_time, record|
140
- assert_equal 1362020400, record['time']
141
- end
142
- end
143
- end
144
-
145
- sub_test_case "Fluent::Plugin::RegexpParser" do
146
- def create_driver(conf)
147
- Fluent::Test::Driver::Parser.new(Fluent::Plugin::RegexpParser.new).configure(conf)
148
- end
149
-
150
- sub_test_case "configure" do
151
- def test_bad_expression
152
- conf = {
153
- 'expression' => %q!/.*/!,
154
- }
155
- assert_raise Fluent::ConfigError do
156
- create_driver(conf)
157
- end
158
- end
159
-
160
- def test_default_options
161
- conf = {
162
- 'expression' => %q!/^(?<host>[^ ]*) [^ ]* (?<user>[^ ]*) \[(?<time>[^\]]*)\] \[(?<date>[^\]]*)\] "(?<flag>\S+)(?: +(?<path>[^ ]*) +\S*)?" (?<code>[^ ]*) (?<size>[^ ]*)$/!,
163
- 'time_format' => "%d/%b/%Y:%H:%M:%S %z",
164
- 'types' => 'user:string,date:time:%d/%b/%Y:%H:%M:%S %z,flag:bool,path:array,code:float,size:integer'
165
- }
166
- d = create_driver(conf)
167
- regexp = d.instance.expression
168
- assert_equal(0, regexp.options)
169
- end
170
-
171
- data(
172
- ignorecase: ["i", Regexp::IGNORECASE],
173
- multiline: ["m", Regexp::MULTILINE],
174
- ignorecase_multiline: ["im", Regexp::IGNORECASE | Regexp::MULTILINE],
175
- )
176
- def test_options(data)
177
- regexp_option, expected = data
178
- conf = {
179
- 'expression' => %Q!/^(?<host>[^ ]*) [^ ]* (?<user>[^ ]*) \[(?<time>[^\]]*)\] \[(?<date>[^\]]*)\] "(?<flag>\S+)(?: +(?<path>[^ ]*) +\S*)?" (?<code>[^ ]*) (?<size>[^ ]*)$/#{regexp_option}!,
180
- 'time_format' => "%d/%b/%Y:%H:%M:%S %z",
181
- 'types' => 'user:string,date:time:%d/%b/%Y:%H:%M:%S %z,flag:bool,path:array,code:float,size:integer'
182
- }
183
- d = create_driver(conf)
184
- regexp = d.instance.expression
185
- assert_equal(expected, regexp.options)
186
- end
187
- end
188
-
189
- def test_parse_with_typed
190
- conf = {
191
- 'expression' => %q!/^(?<host>[^ ]*) [^ ]* (?<user>[^ ]*) \[(?<time>[^\]]*)\] \[(?<date>[^\]]*)\] "(?<flag>\S+)(?: +(?<path>[^ ]*) +\S*)?" (?<code>[^ ]*) (?<size>[^ ]*)$/!,
192
- 'time_format' => "%d/%b/%Y:%H:%M:%S %z",
193
- 'types' => 'user:string,date:time:%d/%b/%Y:%H:%M:%S %z,flag:bool,path:array,code:float,size:integer'
194
- }
195
- d = create_driver(conf)
196
- internal_test_case(d.instance)
197
- end
198
-
199
- def test_parse_with_typed_by_json_hash
200
- conf = {
201
- 'expression' => %q!/^(?<host>[^ ]*) [^ ]* (?<user>[^ ]*) \[(?<time>[^\]]*)\] \[(?<date>[^\]]*)\] "(?<flag>\S+)(?: +(?<path>[^ ]*) +\S*)?" (?<code>[^ ]*) (?<size>[^ ]*)$/!,
202
- 'time_format' => "%d/%b/%Y:%H:%M:%S %z",
203
- 'types' => '{"user":"string","date":"time:%d/%b/%Y:%H:%M:%S %z","flag":"bool","path":"array","code":"float","size":"integer"}',
204
- }
205
- d = create_driver(conf)
206
- internal_test_case(d.instance)
207
- end
208
-
209
- def test_parse_with_time_key
210
- conf = {
211
- 'expression' => %q!/(?<logtime>[^\]]*)/!,
212
- 'time_format' => "%Y-%m-%d %H:%M:%S %z",
213
- 'time_key' => 'logtime'
214
- }
215
- d = create_driver(conf)
216
- text = '2013-02-28 12:00:00 +0900'
217
- d.instance.parse(text) do |time, _record|
218
- assert_equal Fluent::EventTime.parse(text), time
219
- end
220
- end
221
-
222
- def test_parse_without_time
223
- time_at_start = Time.now.to_i
224
- text = "tagomori_satoshi tagomoris 34\n"
225
-
226
- conf = {
227
- 'expression' => %q!/^(?<name>[^ ]*) (?<user>[^ ]*) (?<age>\d*)$/!,
228
- 'types' => 'name:string,user:string,age:integer'
229
- }
230
- d = create_driver(conf)
231
-
232
- d.instance.parse(text) { |time, record|
233
- assert time && time >= time_at_start, "parser puts current time without time input"
234
- assert_equal "tagomori_satoshi", record["name"]
235
- assert_equal "tagomoris", record["user"]
236
- assert_equal 34, record["age"]
237
- }
238
- end
239
-
240
- def test_parse_without_time_estimate_curent_event_false
241
- text = "tagomori_satoshi tagomoris 34\n"
242
- conf = {
243
- 'expression' => %q!/^(?<name>[^ ]*) (?<user>[^ ]*) (?<age>\d*)$/!,
244
- 'types' => 'name:string,user:string,age:integer'
245
- }
246
- d = create_driver(conf)
247
- d.instance.estimate_current_event = false
248
- d.instance.parse(text) { |time, record|
249
- assert_equal "tagomori_satoshi", record["name"]
250
- assert_equal "tagomoris", record["user"]
251
- assert_equal 34, record["age"]
252
-
253
- assert_nil time, "parser returns nil if configured so"
254
- }
255
- end
256
-
257
- def test_parse_with_keep_time_key
258
- conf = {
259
- 'expression' => %q!/(?<time>.*)/!,
260
- 'time_format' => "%d/%b/%Y:%H:%M:%S %z",
261
- 'keep_time_key' => 'true',
262
- }
263
- d = create_driver(conf)
264
- text = '28/Feb/2013:12:00:00 +0900'
265
- d.instance.parse(text) do |_time, record|
266
- assert_equal text, record['time']
267
- end
268
- end
269
-
270
- def test_parse_with_keep_time_key_with_typecast
271
- conf = {
272
- 'expression' => %q!/(?<time>.*)/!,
273
- 'time_format' => "%d/%b/%Y:%H:%M:%S %z",
274
- 'keep_time_key' => 'true',
275
- 'types' => 'time:time:%d/%b/%Y:%H:%M:%S %z',
276
- }
277
- d = create_driver(conf)
278
- text = '28/Feb/2013:12:00:00 +0900'
279
- d.instance.parse(text) do |_time, record|
280
- assert_equal 1362020400, record['time']
281
- end
282
- end
283
- end
284
- end