fluentd 0.12.40 → 1.6.2

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 (428) hide show
  1. checksums.yaml +5 -5
  2. data/.github/ISSUE_TEMPLATE/bug_report.md +39 -0
  3. data/.github/ISSUE_TEMPLATE/feature_request.md +23 -0
  4. data/.github/ISSUE_TEMPLATE.md +17 -0
  5. data/.github/PULL_REQUEST_TEMPLATE.md +13 -0
  6. data/.gitignore +5 -0
  7. data/.gitlab/cicd-template.yaml +10 -0
  8. data/.gitlab-ci.yml +147 -0
  9. data/.travis.yml +56 -20
  10. data/ADOPTERS.md +5 -0
  11. data/CHANGELOG.md +1369 -0
  12. data/CONTRIBUTING.md +16 -5
  13. data/GOVERNANCE.md +55 -0
  14. data/Gemfile +5 -0
  15. data/GithubWorkflow.md +78 -0
  16. data/LICENSE +202 -0
  17. data/MAINTAINERS.md +7 -0
  18. data/README.md +23 -11
  19. data/Rakefile +48 -2
  20. data/Vagrantfile +17 -0
  21. data/appveyor.yml +37 -0
  22. data/bin/fluent-binlog-reader +7 -0
  23. data/bin/fluent-ca-generate +6 -0
  24. data/bin/fluent-plugin-config-format +5 -0
  25. data/bin/fluent-plugin-generate +5 -0
  26. data/bin/fluentd +3 -0
  27. data/code-of-conduct.md +3 -0
  28. data/example/copy_roundrobin.conf +39 -0
  29. data/example/counter.conf +18 -0
  30. data/example/in_dummy_blocks.conf +17 -0
  31. data/example/in_dummy_with_compression.conf +23 -0
  32. data/example/in_forward.conf +7 -0
  33. data/example/in_forward_client.conf +37 -0
  34. data/example/in_forward_shared_key.conf +15 -0
  35. data/example/in_forward_tls.conf +14 -0
  36. data/example/in_forward_users.conf +24 -0
  37. data/example/in_forward_workers.conf +21 -0
  38. data/example/in_http.conf +3 -1
  39. data/example/in_out_forward.conf +17 -0
  40. data/example/logevents.conf +25 -0
  41. data/example/multi_filters.conf +61 -0
  42. data/example/out_exec_filter.conf +42 -0
  43. data/example/out_forward.conf +13 -13
  44. data/example/out_forward_buf_file.conf +23 -0
  45. data/example/out_forward_client.conf +109 -0
  46. data/example/out_forward_heartbeat_none.conf +16 -0
  47. data/example/out_forward_shared_key.conf +36 -0
  48. data/example/out_forward_tls.conf +18 -0
  49. data/example/out_forward_users.conf +65 -0
  50. data/example/out_null.conf +36 -0
  51. data/example/secondary_file.conf +42 -0
  52. data/example/suppress_config_dump.conf +7 -0
  53. data/example/worker_section.conf +36 -0
  54. data/fluent.conf +29 -0
  55. data/fluentd.gemspec +21 -11
  56. data/lib/fluent/agent.rb +67 -90
  57. data/lib/fluent/clock.rb +62 -0
  58. data/lib/fluent/command/binlog_reader.rb +244 -0
  59. data/lib/fluent/command/ca_generate.rb +181 -0
  60. data/lib/fluent/command/cat.rb +42 -18
  61. data/lib/fluent/command/debug.rb +12 -10
  62. data/lib/fluent/command/fluentd.rb +153 -5
  63. data/lib/fluent/command/plugin_config_formatter.rb +292 -0
  64. data/lib/fluent/command/plugin_generator.rb +324 -0
  65. data/lib/fluent/compat/call_super_mixin.rb +67 -0
  66. data/lib/fluent/compat/detach_process_mixin.rb +33 -0
  67. data/lib/fluent/compat/exec_util.rb +129 -0
  68. data/lib/fluent/compat/file_util.rb +54 -0
  69. data/lib/fluent/compat/filter.rb +68 -0
  70. data/lib/fluent/compat/formatter.rb +111 -0
  71. data/lib/fluent/compat/formatter_utils.rb +85 -0
  72. data/lib/fluent/compat/handle_tag_and_time_mixin.rb +62 -0
  73. data/lib/fluent/compat/handle_tag_name_mixin.rb +53 -0
  74. data/lib/fluent/compat/input.rb +49 -0
  75. data/lib/fluent/compat/output.rb +718 -0
  76. data/lib/fluent/compat/output_chain.rb +60 -0
  77. data/lib/fluent/compat/parser.rb +310 -0
  78. data/lib/fluent/compat/parser_utils.rb +40 -0
  79. data/lib/fluent/compat/propagate_default.rb +62 -0
  80. data/lib/fluent/compat/record_filter_mixin.rb +34 -0
  81. data/lib/fluent/compat/set_tag_key_mixin.rb +50 -0
  82. data/lib/fluent/compat/set_time_key_mixin.rb +69 -0
  83. data/lib/fluent/compat/socket_util.rb +165 -0
  84. data/lib/fluent/compat/string_util.rb +34 -0
  85. data/lib/fluent/compat/structured_format_mixin.rb +26 -0
  86. data/lib/fluent/compat/type_converter.rb +90 -0
  87. data/lib/fluent/config/configure_proxy.rb +210 -62
  88. data/lib/fluent/config/dsl.rb +12 -5
  89. data/lib/fluent/config/element.rb +107 -9
  90. data/lib/fluent/config/literal_parser.rb +9 -3
  91. data/lib/fluent/config/parser.rb +4 -4
  92. data/lib/fluent/config/section.rb +51 -14
  93. data/lib/fluent/config/types.rb +28 -13
  94. data/lib/fluent/config/v1_parser.rb +3 -5
  95. data/lib/fluent/config.rb +23 -20
  96. data/lib/fluent/configurable.rb +79 -21
  97. data/lib/fluent/counter/base_socket.rb +46 -0
  98. data/lib/fluent/counter/client.rb +297 -0
  99. data/lib/fluent/counter/error.rb +86 -0
  100. data/lib/fluent/counter/mutex_hash.rb +163 -0
  101. data/lib/fluent/counter/server.rb +273 -0
  102. data/lib/fluent/counter/store.rb +205 -0
  103. data/lib/fluent/counter/validator.rb +145 -0
  104. data/lib/fluent/counter.rb +23 -0
  105. data/lib/fluent/daemon.rb +15 -0
  106. data/lib/fluent/engine.rb +102 -65
  107. data/lib/fluent/env.rb +7 -3
  108. data/lib/fluent/error.rb +30 -0
  109. data/lib/fluent/event.rb +197 -21
  110. data/lib/fluent/event_router.rb +93 -10
  111. data/lib/fluent/filter.rb +2 -50
  112. data/lib/fluent/formatter.rb +4 -293
  113. data/lib/fluent/input.rb +2 -32
  114. data/lib/fluent/label.rb +10 -2
  115. data/lib/fluent/load.rb +3 -3
  116. data/lib/fluent/log.rb +348 -81
  117. data/lib/fluent/match.rb +37 -36
  118. data/lib/fluent/mixin.rb +12 -176
  119. data/lib/fluent/msgpack_factory.rb +62 -0
  120. data/lib/fluent/output.rb +10 -612
  121. data/lib/fluent/output_chain.rb +23 -0
  122. data/lib/fluent/parser.rb +4 -800
  123. data/lib/fluent/plugin/bare_output.rb +63 -0
  124. data/lib/fluent/plugin/base.rb +192 -0
  125. data/lib/fluent/plugin/buf_file.rb +128 -174
  126. data/lib/fluent/plugin/buf_memory.rb +9 -92
  127. data/lib/fluent/plugin/buffer/chunk.rb +221 -0
  128. data/lib/fluent/plugin/buffer/file_chunk.rb +383 -0
  129. data/lib/fluent/plugin/buffer/memory_chunk.rb +90 -0
  130. data/lib/fluent/plugin/buffer.rb +779 -0
  131. data/lib/fluent/plugin/compressable.rb +92 -0
  132. data/lib/fluent/plugin/exec_util.rb +3 -108
  133. data/lib/fluent/plugin/file_util.rb +4 -34
  134. data/lib/fluent/plugin/file_wrapper.rb +120 -0
  135. data/lib/fluent/plugin/filter.rb +93 -0
  136. data/lib/fluent/plugin/filter_grep.rb +117 -34
  137. data/lib/fluent/plugin/filter_parser.rb +85 -62
  138. data/lib/fluent/plugin/filter_record_transformer.rb +27 -39
  139. data/lib/fluent/plugin/filter_stdout.rb +15 -12
  140. data/lib/fluent/plugin/formatter.rb +50 -0
  141. data/lib/fluent/plugin/formatter_csv.rb +52 -0
  142. data/lib/fluent/plugin/formatter_hash.rb +33 -0
  143. data/lib/fluent/plugin/formatter_json.rb +55 -0
  144. data/lib/fluent/plugin/formatter_ltsv.rb +42 -0
  145. data/lib/fluent/plugin/formatter_msgpack.rb +33 -0
  146. data/lib/fluent/plugin/formatter_out_file.rb +51 -0
  147. data/lib/fluent/plugin/formatter_single_value.rb +34 -0
  148. data/lib/fluent/plugin/formatter_stdout.rb +76 -0
  149. data/lib/fluent/plugin/formatter_tsv.rb +38 -0
  150. data/lib/fluent/plugin/in_debug_agent.rb +17 -6
  151. data/lib/fluent/plugin/in_dummy.rb +47 -20
  152. data/lib/fluent/plugin/in_exec.rb +55 -123
  153. data/lib/fluent/plugin/in_forward.rb +299 -216
  154. data/lib/fluent/plugin/in_gc_stat.rb +14 -36
  155. data/lib/fluent/plugin/in_http.rb +204 -91
  156. data/lib/fluent/plugin/in_monitor_agent.rb +186 -258
  157. data/lib/fluent/plugin/in_object_space.rb +13 -41
  158. data/lib/fluent/plugin/in_syslog.rb +112 -134
  159. data/lib/fluent/plugin/in_tail.rb +408 -745
  160. data/lib/fluent/plugin/in_tcp.rb +66 -9
  161. data/lib/fluent/plugin/in_udp.rb +60 -11
  162. data/lib/fluent/plugin/{in_stream.rb → in_unix.rb} +8 -4
  163. data/lib/fluent/plugin/input.rb +37 -0
  164. data/lib/fluent/plugin/multi_output.rb +158 -0
  165. data/lib/fluent/plugin/out_copy.rb +23 -35
  166. data/lib/fluent/plugin/out_exec.rb +67 -70
  167. data/lib/fluent/plugin/out_exec_filter.rb +204 -271
  168. data/lib/fluent/plugin/out_file.rb +267 -73
  169. data/lib/fluent/plugin/out_forward.rb +854 -325
  170. data/lib/fluent/plugin/out_null.rb +42 -9
  171. data/lib/fluent/plugin/out_relabel.rb +9 -5
  172. data/lib/fluent/plugin/out_roundrobin.rb +18 -37
  173. data/lib/fluent/plugin/out_secondary_file.rb +133 -0
  174. data/lib/fluent/plugin/out_stdout.rb +43 -10
  175. data/lib/fluent/plugin/out_stream.rb +7 -2
  176. data/lib/fluent/plugin/output.rb +1498 -0
  177. data/lib/fluent/plugin/owned_by_mixin.rb +42 -0
  178. data/lib/fluent/plugin/parser.rb +191 -0
  179. data/lib/fluent/plugin/parser_apache.rb +28 -0
  180. data/lib/fluent/plugin/parser_apache2.rb +88 -0
  181. data/lib/fluent/plugin/parser_apache_error.rb +26 -0
  182. data/lib/fluent/plugin/parser_csv.rb +39 -0
  183. data/lib/fluent/plugin/parser_json.rb +94 -0
  184. data/lib/fluent/plugin/parser_ltsv.rb +49 -0
  185. data/lib/fluent/plugin/parser_msgpack.rb +50 -0
  186. data/lib/fluent/plugin/parser_multiline.rb +106 -0
  187. data/lib/fluent/plugin/parser_nginx.rb +28 -0
  188. data/lib/fluent/plugin/parser_none.rb +36 -0
  189. data/lib/fluent/plugin/parser_regexp.rb +68 -0
  190. data/lib/fluent/plugin/parser_syslog.rb +142 -0
  191. data/lib/fluent/plugin/parser_tsv.rb +42 -0
  192. data/lib/fluent/plugin/socket_util.rb +3 -143
  193. data/lib/fluent/plugin/storage.rb +84 -0
  194. data/lib/fluent/plugin/storage_local.rb +164 -0
  195. data/lib/fluent/plugin/string_util.rb +3 -15
  196. data/lib/fluent/plugin.rb +122 -121
  197. data/lib/fluent/plugin_helper/cert_option.rb +178 -0
  198. data/lib/fluent/plugin_helper/child_process.rb +364 -0
  199. data/lib/fluent/plugin_helper/compat_parameters.rb +333 -0
  200. data/lib/fluent/plugin_helper/counter.rb +51 -0
  201. data/lib/fluent/plugin_helper/event_emitter.rb +93 -0
  202. data/lib/fluent/plugin_helper/event_loop.rb +170 -0
  203. data/lib/fluent/plugin_helper/extract.rb +104 -0
  204. data/lib/fluent/plugin_helper/formatter.rb +147 -0
  205. data/lib/fluent/plugin_helper/http_server/app.rb +79 -0
  206. data/lib/fluent/plugin_helper/http_server/compat/server.rb +81 -0
  207. data/lib/fluent/plugin_helper/http_server/compat/webrick_handler.rb +58 -0
  208. data/lib/fluent/plugin_helper/http_server/methods.rb +35 -0
  209. data/lib/fluent/plugin_helper/http_server/request.rb +42 -0
  210. data/lib/fluent/plugin_helper/http_server/router.rb +54 -0
  211. data/lib/fluent/plugin_helper/http_server/server.rb +87 -0
  212. data/lib/fluent/plugin_helper/http_server.rb +76 -0
  213. data/lib/fluent/plugin_helper/inject.rb +151 -0
  214. data/lib/fluent/plugin_helper/parser.rb +147 -0
  215. data/lib/fluent/plugin_helper/record_accessor.rb +210 -0
  216. data/lib/fluent/plugin_helper/retry_state.rb +205 -0
  217. data/lib/fluent/plugin_helper/server.rb +807 -0
  218. data/lib/fluent/plugin_helper/socket.rb +250 -0
  219. data/lib/fluent/plugin_helper/socket_option.rb +80 -0
  220. data/lib/fluent/plugin_helper/storage.rb +349 -0
  221. data/lib/fluent/plugin_helper/thread.rb +179 -0
  222. data/lib/fluent/plugin_helper/timer.rb +92 -0
  223. data/lib/fluent/plugin_helper.rb +73 -0
  224. data/lib/fluent/plugin_id.rb +80 -0
  225. data/lib/fluent/process.rb +3 -489
  226. data/lib/fluent/registry.rb +52 -10
  227. data/lib/fluent/root_agent.rb +204 -42
  228. data/lib/fluent/supervisor.rb +597 -359
  229. data/lib/fluent/system_config.rb +131 -42
  230. data/lib/fluent/test/base.rb +6 -54
  231. data/lib/fluent/test/driver/base.rb +224 -0
  232. data/lib/fluent/test/driver/base_owned.rb +70 -0
  233. data/lib/fluent/test/driver/base_owner.rb +135 -0
  234. data/lib/fluent/test/driver/event_feeder.rb +98 -0
  235. data/lib/fluent/test/driver/filter.rb +57 -0
  236. data/lib/fluent/test/driver/formatter.rb +30 -0
  237. data/lib/fluent/test/driver/input.rb +31 -0
  238. data/lib/fluent/test/driver/multi_output.rb +53 -0
  239. data/lib/fluent/test/driver/output.rb +102 -0
  240. data/lib/fluent/test/driver/parser.rb +30 -0
  241. data/lib/fluent/test/driver/test_event_router.rb +45 -0
  242. data/lib/fluent/test/filter_test.rb +0 -1
  243. data/lib/fluent/test/formatter_test.rb +4 -1
  244. data/lib/fluent/test/helpers.rb +58 -10
  245. data/lib/fluent/test/input_test.rb +27 -19
  246. data/lib/fluent/test/log.rb +79 -0
  247. data/lib/fluent/test/output_test.rb +28 -39
  248. data/lib/fluent/test/parser_test.rb +3 -1
  249. data/lib/fluent/test/startup_shutdown.rb +46 -0
  250. data/lib/fluent/test.rb +33 -1
  251. data/lib/fluent/time.rb +450 -1
  252. data/lib/fluent/timezone.rb +27 -3
  253. data/lib/fluent/{status.rb → unique_id.rb} +15 -24
  254. data/lib/fluent/version.rb +1 -1
  255. data/lib/fluent/winsvc.rb +85 -0
  256. data/templates/new_gem/Gemfile +3 -0
  257. data/templates/new_gem/README.md.erb +43 -0
  258. data/templates/new_gem/Rakefile +13 -0
  259. data/templates/new_gem/fluent-plugin.gemspec.erb +27 -0
  260. data/templates/new_gem/lib/fluent/plugin/filter.rb.erb +14 -0
  261. data/templates/new_gem/lib/fluent/plugin/formatter.rb.erb +14 -0
  262. data/templates/new_gem/lib/fluent/plugin/input.rb.erb +11 -0
  263. data/templates/new_gem/lib/fluent/plugin/output.rb.erb +11 -0
  264. data/templates/new_gem/lib/fluent/plugin/parser.rb.erb +15 -0
  265. data/templates/new_gem/test/helper.rb.erb +8 -0
  266. data/templates/new_gem/test/plugin/test_filter.rb.erb +18 -0
  267. data/templates/new_gem/test/plugin/test_formatter.rb.erb +18 -0
  268. data/templates/new_gem/test/plugin/test_input.rb.erb +18 -0
  269. data/templates/new_gem/test/plugin/test_output.rb.erb +18 -0
  270. data/templates/new_gem/test/plugin/test_parser.rb.erb +18 -0
  271. data/templates/plugin_config_formatter/param.md-compact.erb +25 -0
  272. data/templates/plugin_config_formatter/param.md.erb +34 -0
  273. data/templates/plugin_config_formatter/section.md.erb +12 -0
  274. data/test/command/test_binlog_reader.rb +346 -0
  275. data/test/command/test_ca_generate.rb +70 -0
  276. data/test/command/test_fluentd.rb +901 -0
  277. data/test/command/test_plugin_config_formatter.rb +276 -0
  278. data/test/command/test_plugin_generator.rb +92 -0
  279. data/test/compat/test_calls_super.rb +166 -0
  280. data/test/compat/test_parser.rb +92 -0
  281. data/test/config/test_config_parser.rb +126 -2
  282. data/test/config/test_configurable.rb +946 -187
  283. data/test/config/test_configure_proxy.rb +424 -74
  284. data/test/config/test_dsl.rb +11 -11
  285. data/test/config/test_element.rb +500 -0
  286. data/test/config/test_literal_parser.rb +8 -0
  287. data/test/config/test_plugin_configuration.rb +56 -0
  288. data/test/config/test_section.rb +79 -7
  289. data/test/config/test_system_config.rb +122 -35
  290. data/test/config/test_types.rb +38 -0
  291. data/test/counter/test_client.rb +559 -0
  292. data/test/counter/test_error.rb +44 -0
  293. data/test/counter/test_mutex_hash.rb +179 -0
  294. data/test/counter/test_server.rb +589 -0
  295. data/test/counter/test_store.rb +258 -0
  296. data/test/counter/test_validator.rb +137 -0
  297. data/test/helper.rb +89 -6
  298. data/test/helpers/fuzzy_assert.rb +89 -0
  299. data/test/plugin/test_bare_output.rb +118 -0
  300. data/test/plugin/test_base.rb +115 -0
  301. data/test/plugin/test_buf_file.rb +823 -460
  302. data/test/plugin/test_buf_memory.rb +32 -194
  303. data/test/plugin/test_buffer.rb +1233 -0
  304. data/test/plugin/test_buffer_chunk.rb +198 -0
  305. data/test/plugin/test_buffer_file_chunk.rb +844 -0
  306. data/test/plugin/test_buffer_memory_chunk.rb +338 -0
  307. data/test/plugin/test_compressable.rb +84 -0
  308. data/test/plugin/test_filter.rb +357 -0
  309. data/test/plugin/test_filter_grep.rb +540 -29
  310. data/test/plugin/test_filter_parser.rb +439 -452
  311. data/test/plugin/test_filter_record_transformer.rb +123 -166
  312. data/test/plugin/test_filter_stdout.rb +160 -72
  313. data/test/plugin/test_formatter_csv.rb +111 -0
  314. data/test/plugin/test_formatter_hash.rb +35 -0
  315. data/test/plugin/test_formatter_json.rb +51 -0
  316. data/test/plugin/test_formatter_ltsv.rb +62 -0
  317. data/test/plugin/test_formatter_msgpack.rb +28 -0
  318. data/test/plugin/test_formatter_out_file.rb +95 -0
  319. data/test/plugin/test_formatter_single_value.rb +38 -0
  320. data/test/plugin/test_formatter_tsv.rb +68 -0
  321. data/test/plugin/test_in_debug_agent.rb +24 -1
  322. data/test/plugin/test_in_dummy.rb +111 -18
  323. data/test/plugin/test_in_exec.rb +200 -113
  324. data/test/plugin/test_in_forward.rb +990 -387
  325. data/test/plugin/test_in_gc_stat.rb +10 -8
  326. data/test/plugin/test_in_http.rb +600 -224
  327. data/test/plugin/test_in_monitor_agent.rb +690 -0
  328. data/test/plugin/test_in_object_space.rb +24 -8
  329. data/test/plugin/test_in_syslog.rb +154 -215
  330. data/test/plugin/test_in_tail.rb +1006 -707
  331. data/test/plugin/test_in_tcp.rb +125 -48
  332. data/test/plugin/test_in_udp.rb +204 -63
  333. data/test/plugin/{test_in_stream.rb → test_in_unix.rb} +14 -13
  334. data/test/plugin/test_input.rb +126 -0
  335. data/test/plugin/test_metadata.rb +89 -0
  336. data/test/plugin/test_multi_output.rb +180 -0
  337. data/test/plugin/test_out_copy.rb +117 -112
  338. data/test/plugin/test_out_exec.rb +258 -53
  339. data/test/plugin/test_out_exec_filter.rb +538 -115
  340. data/test/plugin/test_out_file.rb +865 -178
  341. data/test/plugin/test_out_forward.rb +998 -210
  342. data/test/plugin/test_out_null.rb +105 -0
  343. data/test/plugin/test_out_relabel.rb +28 -0
  344. data/test/plugin/test_out_roundrobin.rb +36 -29
  345. data/test/plugin/test_out_secondary_file.rb +458 -0
  346. data/test/plugin/test_out_stdout.rb +135 -37
  347. data/test/plugin/test_out_stream.rb +18 -0
  348. data/test/plugin/test_output.rb +984 -0
  349. data/test/plugin/test_output_as_buffered.rb +2021 -0
  350. data/test/plugin/test_output_as_buffered_backup.rb +312 -0
  351. data/test/plugin/test_output_as_buffered_compress.rb +165 -0
  352. data/test/plugin/test_output_as_buffered_overflow.rb +250 -0
  353. data/test/plugin/test_output_as_buffered_retries.rb +911 -0
  354. data/test/plugin/test_output_as_buffered_secondary.rb +874 -0
  355. data/test/plugin/test_output_as_standard.rb +374 -0
  356. data/test/plugin/test_owned_by.rb +35 -0
  357. data/test/plugin/test_parser.rb +359 -0
  358. data/test/plugin/test_parser_apache.rb +42 -0
  359. data/test/plugin/test_parser_apache2.rb +47 -0
  360. data/test/plugin/test_parser_apache_error.rb +45 -0
  361. data/test/plugin/test_parser_csv.rb +103 -0
  362. data/test/plugin/test_parser_json.rb +138 -0
  363. data/test/plugin/test_parser_labeled_tsv.rb +145 -0
  364. data/test/plugin/test_parser_multiline.rb +100 -0
  365. data/test/plugin/test_parser_nginx.rb +88 -0
  366. data/test/plugin/test_parser_none.rb +52 -0
  367. data/test/plugin/test_parser_regexp.rb +289 -0
  368. data/test/plugin/test_parser_syslog.rb +441 -0
  369. data/test/plugin/test_parser_tsv.rb +122 -0
  370. data/test/plugin/test_storage.rb +167 -0
  371. data/test/plugin/test_storage_local.rb +335 -0
  372. data/test/plugin_helper/data/cert/cert-key.pem +27 -0
  373. data/test/plugin_helper/data/cert/cert-with-no-newline.pem +19 -0
  374. data/test/plugin_helper/data/cert/cert.pem +19 -0
  375. data/test/plugin_helper/http_server/test_app.rb +65 -0
  376. data/test/plugin_helper/http_server/test_route.rb +32 -0
  377. data/test/plugin_helper/test_cert_option.rb +16 -0
  378. data/test/plugin_helper/test_child_process.rb +794 -0
  379. data/test/plugin_helper/test_compat_parameters.rb +353 -0
  380. data/test/plugin_helper/test_event_emitter.rb +51 -0
  381. data/test/plugin_helper/test_event_loop.rb +52 -0
  382. data/test/plugin_helper/test_extract.rb +194 -0
  383. data/test/plugin_helper/test_formatter.rb +255 -0
  384. data/test/plugin_helper/test_http_server_helper.rb +205 -0
  385. data/test/plugin_helper/test_inject.rb +519 -0
  386. data/test/plugin_helper/test_parser.rb +264 -0
  387. data/test/plugin_helper/test_record_accessor.rb +197 -0
  388. data/test/plugin_helper/test_retry_state.rb +442 -0
  389. data/test/plugin_helper/test_server.rb +1714 -0
  390. data/test/plugin_helper/test_storage.rb +542 -0
  391. data/test/plugin_helper/test_thread.rb +164 -0
  392. data/test/plugin_helper/test_timer.rb +132 -0
  393. data/test/scripts/exec_script.rb +0 -6
  394. data/test/scripts/fluent/plugin/formatter1/formatter_test1.rb +7 -0
  395. data/test/scripts/fluent/plugin/formatter2/formatter_test2.rb +7 -0
  396. data/test/scripts/fluent/plugin/out_test.rb +23 -15
  397. data/test/scripts/fluent/plugin/out_test2.rb +80 -0
  398. data/test/test_clock.rb +164 -0
  399. data/test/test_config.rb +16 -7
  400. data/test/test_configdsl.rb +2 -2
  401. data/test/test_event.rb +360 -13
  402. data/test/test_event_router.rb +108 -11
  403. data/test/test_event_time.rb +199 -0
  404. data/test/test_filter.rb +48 -6
  405. data/test/test_formatter.rb +11 -391
  406. data/test/test_input.rb +1 -1
  407. data/test/test_log.rb +591 -31
  408. data/test/test_mixin.rb +1 -1
  409. data/test/test_output.rb +121 -185
  410. data/test/test_plugin.rb +251 -0
  411. data/test/test_plugin_classes.rb +177 -10
  412. data/test/test_plugin_helper.rb +81 -0
  413. data/test/test_plugin_id.rb +101 -0
  414. data/test/test_process.rb +8 -42
  415. data/test/test_root_agent.rb +766 -21
  416. data/test/test_supervisor.rb +481 -0
  417. data/test/test_test_drivers.rb +135 -0
  418. data/test/test_time_formatter.rb +282 -0
  419. data/test/test_time_parser.rb +231 -0
  420. data/test/test_unique_id.rb +47 -0
  421. metadata +454 -60
  422. data/COPYING +0 -14
  423. data/ChangeLog +0 -666
  424. data/lib/fluent/buffer.rb +0 -365
  425. data/lib/fluent/plugin/in_status.rb +0 -76
  426. data/test/plugin/test_in_status.rb +0 -38
  427. data/test/test_buffer.rb +0 -624
  428. data/test/test_parser.rb +0 -1305
@@ -0,0 +1,13 @@
1
+ require "bundler"
2
+ Bundler::GemHelper.install_tasks
3
+
4
+ require "rake/testtask"
5
+
6
+ Rake::TestTask.new(:test) do |t|
7
+ t.libs.push("lib", "test")
8
+ t.test_files = FileList["test/**/test_*.rb"]
9
+ t.verbose = true
10
+ t.warning = true
11
+ end
12
+
13
+ task default: [:test]
@@ -0,0 +1,27 @@
1
+ lib = File.expand_path("../lib", __FILE__)
2
+ $LOAD_PATH.unshift(lib) unless $LOAD_PATH.include?(lib)
3
+
4
+ Gem::Specification.new do |spec|
5
+ spec.name = "<%= gem_name %>"
6
+ spec.version = "0.1.0"
7
+ spec.authors = ["<%= user_name %>"]
8
+ spec.email = ["<%= user_email %>"]
9
+
10
+ spec.summary = %q{TODO: Write a short summary, because Rubygems requires one.}
11
+ spec.description = %q{TODO: Write a longer description or delete this line.}
12
+ spec.homepage = "TODO: Put your gem's website or public repo URL here."
13
+ spec.license = "<%= @license.name %>"
14
+
15
+ test_files, files = `git ls-files -z`.split("\x0").partition do |f|
16
+ f.match(%r{^(test|spec|features)/})
17
+ end
18
+ spec.files = files
19
+ spec.executables = files.grep(%r{^bin/}) { |f| File.basename(f) }
20
+ spec.test_files = test_files
21
+ spec.require_paths = ["lib"]
22
+
23
+ spec.add_development_dependency "bundler", "~> 1.14"
24
+ spec.add_development_dependency "rake", "~> 12.0"
25
+ spec.add_development_dependency "test-unit", "~> 3.0"
26
+ spec.add_runtime_dependency "fluentd", [">= 0.14.10", "< 2"]
27
+ end
@@ -0,0 +1,14 @@
1
+ <%= preamble %>
2
+
3
+ require "fluent/plugin/filter"
4
+
5
+ module Fluent
6
+ module Plugin
7
+ class <%= class_name %> < Fluent::Plugin::Filter
8
+ Fluent::Plugin.register_filter("<%= plugin_name %>", self)
9
+
10
+ def filter(tag, time, record)
11
+ end
12
+ end
13
+ end
14
+ end
@@ -0,0 +1,14 @@
1
+ <%= preamble %>
2
+
3
+ require "fluent/plugin/formatter"
4
+
5
+ module Fluent
6
+ module Plugin
7
+ class <%= class_name %> < Fluent::Plugin::Formatter
8
+ Fluent::Plugin.register_formatter("<%= name %>", self)
9
+
10
+ def format(tag, time, record)
11
+ end
12
+ end
13
+ end
14
+ end
@@ -0,0 +1,11 @@
1
+ <%= preamble %>
2
+
3
+ require "fluent/plugin/input"
4
+
5
+ module Fluent
6
+ module Plugin
7
+ class <%= class_name %> < Fluent::Plugin::Input
8
+ Fluent::Plugin.register_input("<%= plugin_name %>", self)
9
+ end
10
+ end
11
+ end
@@ -0,0 +1,11 @@
1
+ <%= preamble %>
2
+
3
+ require "fluent/plugin/output"
4
+
5
+ module Fluent
6
+ module Plugin
7
+ class <%= class_name %> < Fluent::Plugin::Output
8
+ Fluent::Plugin.register_output("<%= plugin_name %>", self)
9
+ end
10
+ end
11
+ end
@@ -0,0 +1,15 @@
1
+ <%= preamble %>
2
+
3
+ require "fluent/plugin/parser"
4
+
5
+ module Fluent
6
+ module Plugin
7
+ class <%= class_name %> < Fluent::Plugin::Parser
8
+ Fluent::Plugin.register_parser("<%= plugin_name %>", self)
9
+
10
+ def parse(text)
11
+ yield time, record
12
+ end
13
+ end
14
+ end
15
+ end
@@ -0,0 +1,8 @@
1
+ $LOAD_PATH.unshift(File.expand_path("../../", __FILE__))
2
+ require "test-unit"
3
+ require "fluent/test"
4
+ require "fluent/test/driver/<%= type %>"
5
+ require "fluent/test/helpers"
6
+
7
+ Test::Unit::TestCase.include(Fluent::Test::Helpers)
8
+ Test::Unit::TestCase.extend(Fluent::Test::Helpers)
@@ -0,0 +1,18 @@
1
+ require "helper"
2
+ require "fluent/plugin/<%= plugin_filename %>"
3
+
4
+ class <%= class_name %>Test < Test::Unit::TestCase
5
+ setup do
6
+ Fluent::Test.setup
7
+ end
8
+
9
+ test "failure" do
10
+ flunk
11
+ end
12
+
13
+ private
14
+
15
+ def create_driver(conf)
16
+ Fluent::Test::Driver::Filter.new(Fluent::Plugin::<%= class_name %>).configure(conf)
17
+ end
18
+ end
@@ -0,0 +1,18 @@
1
+ require "helper"
2
+ require "fluent/plugin/<%= plugin_filename %>"
3
+
4
+ class <%= class_name %>Test < Test::Unit::TestCase
5
+ setup do
6
+ Fluent::Test.setup
7
+ end
8
+
9
+ test "failure" do
10
+ flunk
11
+ end
12
+
13
+ private
14
+
15
+ def create_driver(conf)
16
+ Fluent::Test::Driver::Formatter.new(Fluent::Plugin::<%= class_name %>).configure(conf)
17
+ end
18
+ end
@@ -0,0 +1,18 @@
1
+ require "helper"
2
+ require "fluent/plugin/<%= plugin_filename %>"
3
+
4
+ class <%= class_name %>Test < Test::Unit::TestCase
5
+ setup do
6
+ Fluent::Test.setup
7
+ end
8
+
9
+ test "failure" do
10
+ flunk
11
+ end
12
+
13
+ private
14
+
15
+ def create_driver(conf)
16
+ Fluent::Test::Driver::Input.new(Fluent::Plugin::<%= class_name %>).configure(conf)
17
+ end
18
+ end
@@ -0,0 +1,18 @@
1
+ require "helper"
2
+ require "fluent/plugin/<%= plugin_filename %>"
3
+
4
+ class <%= class_name %>Test < Test::Unit::TestCase
5
+ setup do
6
+ Fluent::Test.setup
7
+ end
8
+
9
+ test "failure" do
10
+ flunk
11
+ end
12
+
13
+ private
14
+
15
+ def create_driver(conf)
16
+ Fluent::Test::Driver::Output.new(Fluent::Plugin::<%= class_name %>).configure(conf)
17
+ end
18
+ end
@@ -0,0 +1,18 @@
1
+ require "helper"
2
+ require "fluent/plugin/<%= plugin_filename %>"
3
+
4
+ class <%= class_name %>Test < Test::Unit::TestCase
5
+ setup do
6
+ Fluent::Test.setup
7
+ end
8
+
9
+ test "failure" do
10
+ flunk
11
+ end
12
+
13
+ private
14
+
15
+ def create_driver(conf)
16
+ Fluent::Test::Driver::Parser.new(Fluent::Plugin::<%= class_name %>).configure(conf)
17
+ end
18
+ end
@@ -0,0 +1,25 @@
1
+ <%-
2
+ type = config[:type]
3
+ required_label = config[:required] ? "required" : "optional"
4
+ default = config[:default]
5
+ alias_name = config[:alias]
6
+ deprecated = config[:deprecated]
7
+ obsoleted = config[:obsoleted]
8
+ description = config[:desc]
9
+ -%>
10
+ * **<%= name %>** (<%= type %>) (<%= required_label %>): <%= description %>
11
+ <%- if type == :enum -%>
12
+ * Available values: <%= config[:list].join(", ") %>
13
+ <%- end -%>
14
+ <%- if default -%>
15
+ * Default value: `<%= default %>`.
16
+ <%- end -%>
17
+ <%- if alias_name -%>
18
+ * Alias: <%= alias_name %>
19
+ <%- end -%>
20
+ <%- if deprecated -%>
21
+ * Deprecated: <%= deprecated %>
22
+ <%- end -%>
23
+ <%- if obsoleted -%>
24
+ * Obsoleted: <%= :obsoleted %>
25
+ <%- end -%>
@@ -0,0 +1,34 @@
1
+ <%-
2
+ type = config[:type]
3
+ required_label = config[:required] ? "required" : "optional"
4
+ default = config[:default]
5
+ alias_name = config[:alias]
6
+ deprecated = config[:deprecated]
7
+ obsoleted = config[:obsoleted]
8
+ description = config[:desc]
9
+ param_header = "#" * (3 + level)
10
+ -%>
11
+ <%= param_header %> <%= name %> (<%= type %>) (<%= required_label %>)
12
+
13
+ <%= description %>
14
+ <%- if type == :enum -%>
15
+
16
+ Available values: <%= config[:list].join(", ") %>
17
+ <%- end -%>
18
+ <%- if default -%>
19
+
20
+ Default value: `<%= default %>`.
21
+ <%- end -%>
22
+ <%- if alias_name -%>
23
+
24
+ Alias: <%= alias_name %>
25
+ <%- end -%>
26
+ <%- if deprecated -%>
27
+
28
+ Deprecated: <%= deprecated %>
29
+ <%- end -%>
30
+ <%- if obsoleted -%>
31
+
32
+ Obsoleted: <%= :obsoleted %>
33
+ <%- end -%>
34
+
@@ -0,0 +1,12 @@
1
+ <%-
2
+ section_header = "#" * (3 + level)
3
+ required_label = required ? "required" : "optional"
4
+ multiple_label = multi ? "multiple" : "single"
5
+ -%>
6
+ <%= section_header %> \<<%= section_name %>\> section (<%= required_label %>) (<%= multiple_label %>)
7
+ <%- if alias_name -%>
8
+
9
+ Alias: <%= alias_name %>
10
+ <%- end -%>
11
+
12
+ <%= dump_section_markdown(sub_section, level + 1) %>
@@ -0,0 +1,346 @@
1
+ require_relative '../helper'
2
+
3
+ require 'yajl'
4
+ require 'flexmock/test_unit'
5
+
6
+ require 'fluent/command/binlog_reader'
7
+ require 'fluent/event'
8
+
9
+ class TestFluentBinlogReader < ::Test::Unit::TestCase
10
+ module ::BinlogReaderCommand
11
+ class Dummy < Base
12
+ def call; end
13
+ end
14
+ end
15
+
16
+ def suppress_stdout
17
+ out = StringIO.new
18
+ $stdout = out
19
+ yield
20
+ ensure
21
+ $stdout = STDOUT
22
+ end
23
+
24
+ sub_test_case 'call' do
25
+ data(
26
+ empty: [],
27
+ invalid: %w(invalid packed.log),
28
+ )
29
+ test 'should fail when invalid command' do |argv|
30
+ fu = FluentBinlogReader.new(argv)
31
+
32
+ assert_raise(SystemExit) do
33
+ suppress_stdout { fu.call }
34
+ end
35
+ end
36
+
37
+ data(
38
+ cat: %w(cat packed.log),
39
+ head: %w(head packed.log),
40
+ formats: %w(formats packed.log)
41
+ )
42
+ test 'should succeed when valid command' do |argv|
43
+ fu = FluentBinlogReader.new(argv)
44
+
45
+ flexstub(::BinlogReaderCommand) do |command|
46
+ command.should_receive(:const_get).once.and_return(::BinlogReaderCommand::Dummy)
47
+ assert_nothing_raised do
48
+ fu.call
49
+ end
50
+ end
51
+ end
52
+ end
53
+ end
54
+
55
+ class TestBaseCommand < ::Test::Unit::TestCase
56
+ TMP_DIR = File.expand_path(File.dirname(__FILE__) + "/../tmp/command/binlog_reader#{ENV['TEST_ENV_NUMBER']}")
57
+
58
+ def create_message_packed_file(path, times = [event_time], records = [{ 'message' => 'dummy' }])
59
+ es = Fluent::MultiEventStream.new(times, records)
60
+ v = es.to_msgpack_stream
61
+ out_path = "#{TMP_DIR}/#{path}"
62
+ File.open(out_path, 'wb') do |f|
63
+ f.print(v)
64
+ end
65
+ waiting(5) do
66
+ sleep 0.5 until File.size(out_path) == v.bytesize
67
+ end
68
+ end
69
+
70
+ def setup
71
+ FileUtils.rm_rf(TMP_DIR)
72
+ FileUtils.mkdir_p(TMP_DIR)
73
+ end
74
+
75
+ def timezone(timezone = 'UTC')
76
+ old = ENV['TZ']
77
+ ENV['TZ'] = timezone
78
+ yield
79
+ ensure
80
+ ENV['TZ'] = old
81
+ end
82
+ end
83
+
84
+ class TestHead < TestBaseCommand
85
+ sub_test_case 'initialize' do
86
+ data(
87
+ 'file is not passed' => %w(),
88
+ 'file is not found' => %w(invalid_path.log)
89
+ )
90
+ test 'should fail if file is invalid' do |argv|
91
+ assert_raise(SystemExit) do
92
+ capture_stdout { BinlogReaderCommand::Head.new(argv) }
93
+ end
94
+ end
95
+
96
+ test 'should succeed if a file is valid' do
97
+ file_name = 'packed.log'
98
+ argv = ["#{TMP_DIR}/#{file_name}"]
99
+ create_message_packed_file(file_name)
100
+
101
+ assert_nothing_raised do
102
+ BinlogReaderCommand::Head.new(argv)
103
+ end
104
+ end
105
+
106
+ test 'should fail when config_params format is invalid' do
107
+ file_name = 'packed.log'
108
+ argv = ["#{TMP_DIR}/#{file_name}", '--format=csv', '-e', 'only_key']
109
+ create_message_packed_file(file_name)
110
+
111
+ assert_raise(SystemExit) do
112
+ capture_stdout { BinlogReaderCommand::Head.new(argv) }
113
+ end
114
+ end
115
+
116
+ test 'should succeed if config_params format is valid' do
117
+ file_name = 'packed.log'
118
+ argv = ["#{TMP_DIR}/#{file_name}", '--format=csv', '-e', 'fields=message']
119
+ create_message_packed_file(file_name)
120
+
121
+ assert_nothing_raised do
122
+ capture_stdout { BinlogReaderCommand::Head.new(argv) }
123
+ end
124
+ end
125
+ end
126
+
127
+ sub_test_case 'call' do
128
+ setup do
129
+ @file_name = 'packed.log'
130
+ @t = '2011-01-02 13:14:15 UTC'
131
+ @record = { 'message' => 'dummy' }
132
+ end
133
+
134
+ test 'should output the beginning of the file with default format (out_file)' do
135
+ argv = ["#{TMP_DIR}/#{@file_name}"]
136
+
137
+ timezone do
138
+ create_message_packed_file(@file_name, [event_time(@t).to_i] * 6, [@record] * 6)
139
+ head = BinlogReaderCommand::Head.new(argv)
140
+ out = capture_stdout { head.call }
141
+ assert_equal "2011-01-02T13:14:15+00:00\t#{TMP_DIR}/#{@file_name}\t#{Yajl.dump(@record)}\n" * 5, out
142
+ end
143
+ end
144
+
145
+ test 'should set the number of lines to display' do
146
+ argv = ["#{TMP_DIR}/#{@file_name}", '-n', '1']
147
+
148
+ timezone do
149
+ create_message_packed_file(@file_name, [event_time(@t).to_i] * 6, [@record] * 6)
150
+ head = BinlogReaderCommand::Head.new(argv)
151
+ out = capture_stdout { head.call }
152
+ assert_equal "2011-01-02T13:14:15+00:00\t#{TMP_DIR}/#{@file_name}\t#{Yajl.dump(@record)}\n", out
153
+ end
154
+ end
155
+
156
+ test 'should fail when the number of lines is invalid' do
157
+ argv = ["#{TMP_DIR}/#{@file_name}", '-n', '0']
158
+
159
+ create_message_packed_file(@file_name)
160
+ assert_raise(SystemExit) do
161
+ capture_stdout { BinlogReaderCommand::Head.new(argv) }
162
+ end
163
+ end
164
+
165
+ test 'should output content of a file with json format' do
166
+ argv = ["#{TMP_DIR}/#{@file_name}", '--format=json']
167
+
168
+ timezone do
169
+ create_message_packed_file(@file_name, [event_time(@t).to_i], [@record])
170
+ head = BinlogReaderCommand::Head.new(argv)
171
+ out = capture_stdout { head.call }
172
+ assert_equal "#{Yajl.dump(@record)}\n", out
173
+ end
174
+ end
175
+
176
+ test 'should fail with an invalid format' do
177
+ argv = ["#{TMP_DIR}/#{@file_name}", '--format=invalid']
178
+
179
+ timezone do
180
+ create_message_packed_file(@file_name, [event_time(@t).to_i], [@record])
181
+ head = BinlogReaderCommand::Head.new(argv)
182
+
183
+ assert_raise(SystemExit) do
184
+ capture_stdout { head.call }
185
+ end
186
+ end
187
+ end
188
+
189
+ test 'should succeed if multiple config_params format' do
190
+ file_name = 'packed.log'
191
+ argv = ["#{TMP_DIR}/#{file_name}", '--format=csv', '-e', 'fields=message,fo', '-e', 'delimiter=|']
192
+ create_message_packed_file(file_name, [event_time], [{ 'message' => 'dummy', 'fo' => 'dummy2' }])
193
+
194
+ head = BinlogReaderCommand::Head.new(argv)
195
+ assert_equal "\"dummy\"|\"dummy2\"\n", capture_stdout { head.call }
196
+ end
197
+ end
198
+ end
199
+
200
+ class TestCat < TestBaseCommand
201
+ sub_test_case 'initialize' do
202
+ data(
203
+ 'file is not passed' => [],
204
+ 'file is not found' => %w(invalid_path.log)
205
+ )
206
+ test 'should fail if a file is invalid' do |argv|
207
+ assert_raise(SystemExit) do
208
+ capture_stdout { BinlogReaderCommand::Head.new(argv) }
209
+ end
210
+ end
211
+
212
+ test 'should succeed if a file is valid' do
213
+ file_name = 'packed.log'
214
+ argv = ["#{TMP_DIR}/#{file_name}"]
215
+ create_message_packed_file(file_name)
216
+
217
+ assert_nothing_raised do
218
+ BinlogReaderCommand::Cat.new(argv)
219
+ end
220
+ end
221
+
222
+ test 'should fail when config_params format is invalid' do
223
+ file_name = 'packed.log'
224
+ argv = ["#{TMP_DIR}/#{file_name}", '--format=json', '-e', 'only_key']
225
+ create_message_packed_file(file_name)
226
+
227
+ assert_raise(SystemExit) do
228
+ capture_stdout { BinlogReaderCommand::Cat.new(argv) }
229
+ end
230
+ end
231
+
232
+ test 'should succeed when config_params format is valid' do
233
+ file_name = 'packed.log'
234
+ argv = ["#{TMP_DIR}/#{file_name}", '--format=csv', '-e', 'fields=message']
235
+ create_message_packed_file(file_name)
236
+
237
+ assert_nothing_raised do
238
+ capture_stdout { BinlogReaderCommand::Cat.new(argv) }
239
+ end
240
+ end
241
+ end
242
+
243
+ sub_test_case 'call' do
244
+ setup do
245
+ @file_name = 'packed.log'
246
+ @t = '2011-01-02 13:14:15 UTC'
247
+ @record = { 'message' => 'dummy' }
248
+ end
249
+
250
+ test 'should output the file with default format(out_file)' do
251
+ argv = ["#{TMP_DIR}/#{@file_name}"]
252
+
253
+ timezone do
254
+ create_message_packed_file(@file_name, [event_time(@t).to_i] * 6, [@record] * 6)
255
+ head = BinlogReaderCommand::Cat.new(argv)
256
+ out = capture_stdout { head.call }
257
+ assert_equal "2011-01-02T13:14:15+00:00\t#{TMP_DIR}/#{@file_name}\t#{Yajl.dump(@record)}\n" * 6, out
258
+ end
259
+ end
260
+
261
+ test 'should set the number of lines to display' do
262
+ argv = ["#{TMP_DIR}/#{@file_name}", '-n', '1']
263
+
264
+ timezone do
265
+ create_message_packed_file(@file_name, [event_time(@t).to_i] * 6, [@record] * 6)
266
+ head = BinlogReaderCommand::Cat.new(argv)
267
+ out = capture_stdout { head.call }
268
+ assert_equal "2011-01-02T13:14:15+00:00\t#{TMP_DIR}/#{@file_name}\t#{Yajl.dump(@record)}\n", out
269
+ end
270
+ end
271
+
272
+ test 'should output content of a file with json format' do
273
+ argv = ["#{TMP_DIR}/#{@file_name}", '--format=json']
274
+
275
+ timezone do
276
+ create_message_packed_file(@file_name, [event_time(@t).to_i], [@record])
277
+ head = BinlogReaderCommand::Cat.new(argv)
278
+ out = capture_stdout { head.call }
279
+ assert_equal "#{Yajl.dump(@record)}\n", out
280
+ end
281
+ end
282
+
283
+ test 'should fail with an invalid format' do
284
+ argv = ["#{TMP_DIR}/#{@file_name}", '--format=invalid']
285
+
286
+ timezone do
287
+ create_message_packed_file(@file_name, [event_time(@t).to_i], [@record])
288
+ head = BinlogReaderCommand::Cat.new(argv)
289
+
290
+ assert_raise(SystemExit) do
291
+ capture_stdout { head.call }
292
+ end
293
+ end
294
+ end
295
+
296
+ test 'should succeed if multiple config_params format' do
297
+ file_name = 'packed.log'
298
+ argv = ["#{TMP_DIR}/#{file_name}", '--format=csv', '-e', 'fields=message,fo', '-e', 'delimiter=|']
299
+ create_message_packed_file(file_name, [event_time], [{ 'message' => 'dummy', 'fo' => 'dummy2' }])
300
+
301
+ head = BinlogReaderCommand::Cat.new(argv)
302
+ assert_equal "\"dummy\"|\"dummy2\"\n", capture_stdout { head.call }
303
+ end
304
+ end
305
+ end
306
+
307
+ class TestFormats < TestBaseCommand
308
+ test 'parse_option!' do
309
+ assert_raise(SystemExit) do
310
+ capture_stdout do
311
+ BinlogReaderCommand::Formats.new(['--plugin=invalid_dir_path'])
312
+ end
313
+ end
314
+ end
315
+
316
+ sub_test_case 'call' do
317
+ test 'display available plugins' do
318
+ f = BinlogReaderCommand::Formats.new
319
+ out = capture_stdout { f.call }
320
+ assert out.include?('json')
321
+ assert out.include?('csv')
322
+ end
323
+
324
+ test 'add new plugins using --plugin option' do
325
+ dir_path = File.expand_path(File.dirname(__FILE__) + '/../scripts/fluent/plugin/formatter1')
326
+
327
+ f = BinlogReaderCommand::Formats.new(["--plugin=#{dir_path}"])
328
+ out = capture_stdout { f.call }
329
+ assert out.include?('json')
330
+ assert out.include?('csv')
331
+ assert out.include?('test1')
332
+ end
333
+
334
+ test 'add multiple plugins using --plugin option' do
335
+ dir_path1 = File.expand_path(File.dirname(__FILE__) + '/../scripts/fluent/plugin/formatter1')
336
+ dir_path2 = File.expand_path(File.dirname(__FILE__) + '/../scripts/fluent/plugin/formatter2')
337
+
338
+ f = BinlogReaderCommand::Formats.new(["--plugin=#{dir_path1}", '-p', dir_path2])
339
+ out = capture_stdout { f.call }
340
+ assert out.include?('json')
341
+ assert out.include?('csv')
342
+ assert out.include?('test1')
343
+ assert out.include?('test2')
344
+ end
345
+ end
346
+ end