fluentd 0.14.4-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.

Potentially problematic release.


This version of fluentd might be problematic. Click here for more details.

Files changed (328) hide show
  1. checksums.yaml +7 -0
  2. data/.github/ISSUE_TEMPLATE.md +6 -0
  3. data/.gitignore +26 -0
  4. data/.travis.yml +45 -0
  5. data/AUTHORS +2 -0
  6. data/CONTRIBUTING.md +35 -0
  7. data/COPYING +14 -0
  8. data/ChangeLog +276 -0
  9. data/Gemfile +9 -0
  10. data/README.md +51 -0
  11. data/Rakefile +53 -0
  12. data/Vagrantfile +17 -0
  13. data/appveyor.yml +41 -0
  14. data/bin/fluent-debug +5 -0
  15. data/example/copy_roundrobin.conf +39 -0
  16. data/example/filter_stdout.conf +22 -0
  17. data/example/in_forward.conf +11 -0
  18. data/example/in_http.conf +14 -0
  19. data/example/in_out_forward.conf +17 -0
  20. data/example/in_syslog.conf +15 -0
  21. data/example/in_tail.conf +14 -0
  22. data/example/in_tcp.conf +13 -0
  23. data/example/in_udp.conf +13 -0
  24. data/example/multi_filters.conf +61 -0
  25. data/example/out_buffered_null.conf +32 -0
  26. data/example/out_copy.conf +20 -0
  27. data/example/out_file.conf +13 -0
  28. data/example/out_forward.conf +35 -0
  29. data/example/out_forward_buf_file.conf +23 -0
  30. data/example/v0_12_filter.conf +78 -0
  31. data/example/v1_literal_example.conf +36 -0
  32. data/fluent.conf +139 -0
  33. data/fluentd.gemspec +51 -0
  34. data/lib/fluent/agent.rb +194 -0
  35. data/lib/fluent/command/bundler_injection.rb +45 -0
  36. data/lib/fluent/command/cat.rb +319 -0
  37. data/lib/fluent/command/debug.rb +102 -0
  38. data/lib/fluent/command/fluentd.rb +273 -0
  39. data/lib/fluent/compat/call_super_mixin.rb +67 -0
  40. data/lib/fluent/compat/exec_util.rb +129 -0
  41. data/lib/fluent/compat/file_util.rb +54 -0
  42. data/lib/fluent/compat/filter.rb +68 -0
  43. data/lib/fluent/compat/formatter.rb +111 -0
  44. data/lib/fluent/compat/formatter_utils.rb +85 -0
  45. data/lib/fluent/compat/handle_tag_and_time_mixin.rb +62 -0
  46. data/lib/fluent/compat/handle_tag_name_mixin.rb +53 -0
  47. data/lib/fluent/compat/input.rb +49 -0
  48. data/lib/fluent/compat/output.rb +677 -0
  49. data/lib/fluent/compat/output_chain.rb +60 -0
  50. data/lib/fluent/compat/parser.rb +180 -0
  51. data/lib/fluent/compat/parser_utils.rb +40 -0
  52. data/lib/fluent/compat/propagate_default.rb +62 -0
  53. data/lib/fluent/compat/record_filter_mixin.rb +34 -0
  54. data/lib/fluent/compat/set_tag_key_mixin.rb +50 -0
  55. data/lib/fluent/compat/set_time_key_mixin.rb +69 -0
  56. data/lib/fluent/compat/socket_util.rb +165 -0
  57. data/lib/fluent/compat/string_util.rb +34 -0
  58. data/lib/fluent/compat/structured_format_mixin.rb +26 -0
  59. data/lib/fluent/compat/type_converter.rb +90 -0
  60. data/lib/fluent/config.rb +56 -0
  61. data/lib/fluent/config/basic_parser.rb +123 -0
  62. data/lib/fluent/config/configure_proxy.rb +366 -0
  63. data/lib/fluent/config/dsl.rb +149 -0
  64. data/lib/fluent/config/element.rb +218 -0
  65. data/lib/fluent/config/error.rb +26 -0
  66. data/lib/fluent/config/literal_parser.rb +251 -0
  67. data/lib/fluent/config/parser.rb +107 -0
  68. data/lib/fluent/config/section.rb +212 -0
  69. data/lib/fluent/config/types.rb +136 -0
  70. data/lib/fluent/config/v1_parser.rb +190 -0
  71. data/lib/fluent/configurable.rb +176 -0
  72. data/lib/fluent/daemon.rb +15 -0
  73. data/lib/fluent/engine.rb +220 -0
  74. data/lib/fluent/env.rb +27 -0
  75. data/lib/fluent/event.rb +287 -0
  76. data/lib/fluent/event_router.rb +259 -0
  77. data/lib/fluent/filter.rb +21 -0
  78. data/lib/fluent/formatter.rb +23 -0
  79. data/lib/fluent/input.rb +21 -0
  80. data/lib/fluent/label.rb +38 -0
  81. data/lib/fluent/load.rb +36 -0
  82. data/lib/fluent/log.rb +445 -0
  83. data/lib/fluent/match.rb +141 -0
  84. data/lib/fluent/mixin.rb +31 -0
  85. data/lib/fluent/msgpack_factory.rb +62 -0
  86. data/lib/fluent/output.rb +26 -0
  87. data/lib/fluent/output_chain.rb +23 -0
  88. data/lib/fluent/parser.rb +23 -0
  89. data/lib/fluent/plugin.rb +161 -0
  90. data/lib/fluent/plugin/bare_output.rb +63 -0
  91. data/lib/fluent/plugin/base.rb +130 -0
  92. data/lib/fluent/plugin/buf_file.rb +154 -0
  93. data/lib/fluent/plugin/buf_memory.rb +34 -0
  94. data/lib/fluent/plugin/buffer.rb +603 -0
  95. data/lib/fluent/plugin/buffer/chunk.rb +160 -0
  96. data/lib/fluent/plugin/buffer/file_chunk.rb +323 -0
  97. data/lib/fluent/plugin/buffer/memory_chunk.rb +90 -0
  98. data/lib/fluent/plugin/exec_util.rb +22 -0
  99. data/lib/fluent/plugin/file_util.rb +22 -0
  100. data/lib/fluent/plugin/file_wrapper.rb +120 -0
  101. data/lib/fluent/plugin/filter.rb +93 -0
  102. data/lib/fluent/plugin/filter_grep.rb +75 -0
  103. data/lib/fluent/plugin/filter_record_transformer.rb +342 -0
  104. data/lib/fluent/plugin/filter_stdout.rb +53 -0
  105. data/lib/fluent/plugin/formatter.rb +45 -0
  106. data/lib/fluent/plugin/formatter_csv.rb +47 -0
  107. data/lib/fluent/plugin/formatter_hash.rb +29 -0
  108. data/lib/fluent/plugin/formatter_json.rb +44 -0
  109. data/lib/fluent/plugin/formatter_ltsv.rb +41 -0
  110. data/lib/fluent/plugin/formatter_msgpack.rb +29 -0
  111. data/lib/fluent/plugin/formatter_out_file.rb +78 -0
  112. data/lib/fluent/plugin/formatter_single_value.rb +34 -0
  113. data/lib/fluent/plugin/formatter_stdout.rb +74 -0
  114. data/lib/fluent/plugin/in_debug_agent.rb +64 -0
  115. data/lib/fluent/plugin/in_dummy.rb +135 -0
  116. data/lib/fluent/plugin/in_exec.rb +149 -0
  117. data/lib/fluent/plugin/in_forward.rb +366 -0
  118. data/lib/fluent/plugin/in_gc_stat.rb +52 -0
  119. data/lib/fluent/plugin/in_http.rb +422 -0
  120. data/lib/fluent/plugin/in_monitor_agent.rb +401 -0
  121. data/lib/fluent/plugin/in_object_space.rb +90 -0
  122. data/lib/fluent/plugin/in_syslog.rb +204 -0
  123. data/lib/fluent/plugin/in_tail.rb +838 -0
  124. data/lib/fluent/plugin/in_tcp.rb +41 -0
  125. data/lib/fluent/plugin/in_udp.rb +37 -0
  126. data/lib/fluent/plugin/in_unix.rb +201 -0
  127. data/lib/fluent/plugin/input.rb +33 -0
  128. data/lib/fluent/plugin/multi_output.rb +95 -0
  129. data/lib/fluent/plugin/out_buffered_null.rb +59 -0
  130. data/lib/fluent/plugin/out_buffered_stdout.rb +70 -0
  131. data/lib/fluent/plugin/out_copy.rb +42 -0
  132. data/lib/fluent/plugin/out_exec.rb +114 -0
  133. data/lib/fluent/plugin/out_exec_filter.rb +393 -0
  134. data/lib/fluent/plugin/out_file.rb +167 -0
  135. data/lib/fluent/plugin/out_forward.rb +646 -0
  136. data/lib/fluent/plugin/out_null.rb +27 -0
  137. data/lib/fluent/plugin/out_relabel.rb +28 -0
  138. data/lib/fluent/plugin/out_roundrobin.rb +80 -0
  139. data/lib/fluent/plugin/out_stdout.rb +48 -0
  140. data/lib/fluent/plugin/out_stream.rb +130 -0
  141. data/lib/fluent/plugin/output.rb +1020 -0
  142. data/lib/fluent/plugin/owned_by_mixin.rb +42 -0
  143. data/lib/fluent/plugin/parser.rb +175 -0
  144. data/lib/fluent/plugin/parser_apache.rb +28 -0
  145. data/lib/fluent/plugin/parser_apache2.rb +84 -0
  146. data/lib/fluent/plugin/parser_apache_error.rb +26 -0
  147. data/lib/fluent/plugin/parser_csv.rb +33 -0
  148. data/lib/fluent/plugin/parser_json.rb +79 -0
  149. data/lib/fluent/plugin/parser_ltsv.rb +50 -0
  150. data/lib/fluent/plugin/parser_multiline.rb +104 -0
  151. data/lib/fluent/plugin/parser_nginx.rb +28 -0
  152. data/lib/fluent/plugin/parser_none.rb +36 -0
  153. data/lib/fluent/plugin/parser_regexp.rb +73 -0
  154. data/lib/fluent/plugin/parser_syslog.rb +82 -0
  155. data/lib/fluent/plugin/parser_tsv.rb +37 -0
  156. data/lib/fluent/plugin/socket_util.rb +22 -0
  157. data/lib/fluent/plugin/storage.rb +84 -0
  158. data/lib/fluent/plugin/storage_local.rb +132 -0
  159. data/lib/fluent/plugin/string_util.rb +22 -0
  160. data/lib/fluent/plugin_helper.rb +42 -0
  161. data/lib/fluent/plugin_helper/child_process.rb +298 -0
  162. data/lib/fluent/plugin_helper/compat_parameters.rb +224 -0
  163. data/lib/fluent/plugin_helper/event_emitter.rb +80 -0
  164. data/lib/fluent/plugin_helper/event_loop.rb +118 -0
  165. data/lib/fluent/plugin_helper/formatter.rb +149 -0
  166. data/lib/fluent/plugin_helper/inject.rb +125 -0
  167. data/lib/fluent/plugin_helper/parser.rb +147 -0
  168. data/lib/fluent/plugin_helper/retry_state.rb +177 -0
  169. data/lib/fluent/plugin_helper/storage.rb +331 -0
  170. data/lib/fluent/plugin_helper/thread.rb +147 -0
  171. data/lib/fluent/plugin_helper/timer.rb +90 -0
  172. data/lib/fluent/plugin_id.rb +63 -0
  173. data/lib/fluent/process.rb +504 -0
  174. data/lib/fluent/registry.rb +99 -0
  175. data/lib/fluent/root_agent.rb +314 -0
  176. data/lib/fluent/rpc.rb +94 -0
  177. data/lib/fluent/supervisor.rb +680 -0
  178. data/lib/fluent/system_config.rb +122 -0
  179. data/lib/fluent/test.rb +56 -0
  180. data/lib/fluent/test/base.rb +85 -0
  181. data/lib/fluent/test/driver/base.rb +179 -0
  182. data/lib/fluent/test/driver/base_owned.rb +70 -0
  183. data/lib/fluent/test/driver/base_owner.rb +125 -0
  184. data/lib/fluent/test/driver/event_feeder.rb +98 -0
  185. data/lib/fluent/test/driver/filter.rb +57 -0
  186. data/lib/fluent/test/driver/formatter.rb +30 -0
  187. data/lib/fluent/test/driver/input.rb +31 -0
  188. data/lib/fluent/test/driver/multi_output.rb +52 -0
  189. data/lib/fluent/test/driver/output.rb +76 -0
  190. data/lib/fluent/test/driver/parser.rb +30 -0
  191. data/lib/fluent/test/driver/test_event_router.rb +45 -0
  192. data/lib/fluent/test/filter_test.rb +77 -0
  193. data/lib/fluent/test/formatter_test.rb +65 -0
  194. data/lib/fluent/test/helpers.rb +79 -0
  195. data/lib/fluent/test/input_test.rb +172 -0
  196. data/lib/fluent/test/log.rb +73 -0
  197. data/lib/fluent/test/output_test.rb +156 -0
  198. data/lib/fluent/test/parser_test.rb +70 -0
  199. data/lib/fluent/time.rb +175 -0
  200. data/lib/fluent/timezone.rb +133 -0
  201. data/lib/fluent/unique_id.rb +39 -0
  202. data/lib/fluent/version.rb +21 -0
  203. data/lib/fluent/winsvc.rb +71 -0
  204. data/test/compat/test_calls_super.rb +166 -0
  205. data/test/compat/test_parser.rb +82 -0
  206. data/test/config/assertions.rb +42 -0
  207. data/test/config/test_config_parser.rb +507 -0
  208. data/test/config/test_configurable.rb +1194 -0
  209. data/test/config/test_configure_proxy.rb +386 -0
  210. data/test/config/test_dsl.rb +415 -0
  211. data/test/config/test_element.rb +403 -0
  212. data/test/config/test_literal_parser.rb +297 -0
  213. data/test/config/test_section.rb +184 -0
  214. data/test/config/test_system_config.rb +120 -0
  215. data/test/config/test_types.rb +171 -0
  216. data/test/helper.rb +119 -0
  217. data/test/plugin/data/2010/01/20100102-030405.log +0 -0
  218. data/test/plugin/data/2010/01/20100102-030406.log +0 -0
  219. data/test/plugin/data/2010/01/20100102.log +0 -0
  220. data/test/plugin/data/log/bar +0 -0
  221. data/test/plugin/data/log/foo/bar.log +0 -0
  222. data/test/plugin/data/log/test.log +0 -0
  223. data/test/plugin/test_bare_output.rb +118 -0
  224. data/test/plugin/test_base.rb +75 -0
  225. data/test/plugin/test_buf_file.rb +571 -0
  226. data/test/plugin/test_buf_memory.rb +42 -0
  227. data/test/plugin/test_buffer.rb +1200 -0
  228. data/test/plugin/test_buffer_chunk.rb +168 -0
  229. data/test/plugin/test_buffer_file_chunk.rb +771 -0
  230. data/test/plugin/test_buffer_memory_chunk.rb +265 -0
  231. data/test/plugin/test_file_util.rb +96 -0
  232. data/test/plugin/test_filter.rb +353 -0
  233. data/test/plugin/test_filter_grep.rb +119 -0
  234. data/test/plugin/test_filter_record_transformer.rb +600 -0
  235. data/test/plugin/test_filter_stdout.rb +211 -0
  236. data/test/plugin/test_formatter_csv.rb +94 -0
  237. data/test/plugin/test_formatter_json.rb +30 -0
  238. data/test/plugin/test_formatter_ltsv.rb +52 -0
  239. data/test/plugin/test_formatter_msgpack.rb +28 -0
  240. data/test/plugin/test_formatter_out_file.rb +95 -0
  241. data/test/plugin/test_formatter_single_value.rb +38 -0
  242. data/test/plugin/test_in_debug_agent.rb +28 -0
  243. data/test/plugin/test_in_dummy.rb +188 -0
  244. data/test/plugin/test_in_exec.rb +133 -0
  245. data/test/plugin/test_in_forward.rb +635 -0
  246. data/test/plugin/test_in_gc_stat.rb +39 -0
  247. data/test/plugin/test_in_http.rb +442 -0
  248. data/test/plugin/test_in_monitor_agent.rb +329 -0
  249. data/test/plugin/test_in_object_space.rb +64 -0
  250. data/test/plugin/test_in_syslog.rb +205 -0
  251. data/test/plugin/test_in_tail.rb +1001 -0
  252. data/test/plugin/test_in_tcp.rb +102 -0
  253. data/test/plugin/test_in_udp.rb +121 -0
  254. data/test/plugin/test_in_unix.rb +126 -0
  255. data/test/plugin/test_input.rb +122 -0
  256. data/test/plugin/test_multi_output.rb +180 -0
  257. data/test/plugin/test_out_buffered_null.rb +79 -0
  258. data/test/plugin/test_out_buffered_stdout.rb +122 -0
  259. data/test/plugin/test_out_copy.rb +160 -0
  260. data/test/plugin/test_out_exec.rb +155 -0
  261. data/test/plugin/test_out_exec_filter.rb +262 -0
  262. data/test/plugin/test_out_file.rb +383 -0
  263. data/test/plugin/test_out_forward.rb +590 -0
  264. data/test/plugin/test_out_null.rb +29 -0
  265. data/test/plugin/test_out_relabel.rb +28 -0
  266. data/test/plugin/test_out_roundrobin.rb +146 -0
  267. data/test/plugin/test_out_stdout.rb +92 -0
  268. data/test/plugin/test_out_stream.rb +93 -0
  269. data/test/plugin/test_output.rb +568 -0
  270. data/test/plugin/test_output_as_buffered.rb +1604 -0
  271. data/test/plugin/test_output_as_buffered_overflow.rb +250 -0
  272. data/test/plugin/test_output_as_buffered_retries.rb +839 -0
  273. data/test/plugin/test_output_as_buffered_secondary.rb +817 -0
  274. data/test/plugin/test_output_as_standard.rb +374 -0
  275. data/test/plugin/test_owned_by.rb +35 -0
  276. data/test/plugin/test_parser_apache.rb +42 -0
  277. data/test/plugin/test_parser_apache2.rb +38 -0
  278. data/test/plugin/test_parser_apache_error.rb +45 -0
  279. data/test/plugin/test_parser_base.rb +32 -0
  280. data/test/plugin/test_parser_csv.rb +104 -0
  281. data/test/plugin/test_parser_json.rb +107 -0
  282. data/test/plugin/test_parser_labeled_tsv.rb +129 -0
  283. data/test/plugin/test_parser_multiline.rb +100 -0
  284. data/test/plugin/test_parser_nginx.rb +48 -0
  285. data/test/plugin/test_parser_none.rb +53 -0
  286. data/test/plugin/test_parser_regexp.rb +277 -0
  287. data/test/plugin/test_parser_syslog.rb +66 -0
  288. data/test/plugin/test_parser_time.rb +46 -0
  289. data/test/plugin/test_parser_tsv.rb +121 -0
  290. data/test/plugin/test_storage.rb +167 -0
  291. data/test/plugin/test_storage_local.rb +8 -0
  292. data/test/plugin/test_string_util.rb +26 -0
  293. data/test/plugin_helper/test_child_process.rb +608 -0
  294. data/test/plugin_helper/test_compat_parameters.rb +242 -0
  295. data/test/plugin_helper/test_event_emitter.rb +51 -0
  296. data/test/plugin_helper/test_event_loop.rb +52 -0
  297. data/test/plugin_helper/test_formatter.rb +252 -0
  298. data/test/plugin_helper/test_inject.rb +487 -0
  299. data/test/plugin_helper/test_parser.rb +263 -0
  300. data/test/plugin_helper/test_retry_state.rb +399 -0
  301. data/test/plugin_helper/test_storage.rb +521 -0
  302. data/test/plugin_helper/test_thread.rb +164 -0
  303. data/test/plugin_helper/test_timer.rb +131 -0
  304. data/test/scripts/exec_script.rb +32 -0
  305. data/test/scripts/fluent/plugin/formatter_known.rb +8 -0
  306. data/test/scripts/fluent/plugin/out_test.rb +81 -0
  307. data/test/scripts/fluent/plugin/out_test2.rb +80 -0
  308. data/test/scripts/fluent/plugin/parser_known.rb +4 -0
  309. data/test/test_config.rb +179 -0
  310. data/test/test_configdsl.rb +148 -0
  311. data/test/test_event.rb +329 -0
  312. data/test/test_event_router.rb +331 -0
  313. data/test/test_event_time.rb +184 -0
  314. data/test/test_filter.rb +121 -0
  315. data/test/test_formatter.rb +319 -0
  316. data/test/test_input.rb +31 -0
  317. data/test/test_log.rb +572 -0
  318. data/test/test_match.rb +137 -0
  319. data/test/test_mixin.rb +351 -0
  320. data/test/test_output.rb +214 -0
  321. data/test/test_plugin_classes.rb +136 -0
  322. data/test/test_plugin_helper.rb +81 -0
  323. data/test/test_process.rb +48 -0
  324. data/test/test_root_agent.rb +278 -0
  325. data/test/test_supervisor.rb +339 -0
  326. data/test/test_time_formatter.rb +186 -0
  327. data/test/test_unique_id.rb +47 -0
  328. metadata +823 -0
@@ -0,0 +1,329 @@
1
+ require_relative '../helper'
2
+ require 'fluent/test/driver/input'
3
+ require 'fluent/plugin/in_monitor_agent'
4
+ require 'fluent/engine'
5
+ require 'fluent/config'
6
+ require 'fluent/event_router'
7
+ require 'fluent/supervisor'
8
+ require 'net/http'
9
+ require 'json'
10
+ require_relative '../test_plugin_classes'
11
+
12
+ class MonitorAgentInputTest < Test::Unit::TestCase
13
+ def setup
14
+ Fluent::Test.setup
15
+ end
16
+
17
+ def create_driver(conf = '')
18
+ Fluent::Test::Driver::Input.new(Fluent::Plugin::MonitorAgentInput).configure(conf)
19
+ end
20
+
21
+ def configure_ra(ra, conf_str)
22
+ conf = Fluent::Config.parse(conf_str, "(test)", "(test_dir)", true)
23
+ ra.configure(conf)
24
+ ra
25
+ end
26
+
27
+ def test_configure
28
+ d = create_driver
29
+ assert_equal("0.0.0.0", d.instance.bind)
30
+ assert_equal(24220, d.instance.port)
31
+ assert_equal(nil, d.instance.tag)
32
+ assert_equal(60, d.instance.emit_interval)
33
+ end
34
+
35
+ sub_test_case "collect plugin information" do
36
+ setup do
37
+ # check @type and type in one configuration
38
+ conf = <<-EOC
39
+ <source>
40
+ @type test_in
41
+ @id test_in
42
+ </source>
43
+ <filter>
44
+ @type test_filter
45
+ @id test_filter
46
+ </filter>
47
+ <match **>
48
+ @type relabel
49
+ @id test_relabel
50
+ @label @test
51
+ </match>
52
+ <label @test>
53
+ <match **>
54
+ @type test_out
55
+ @id test_out
56
+ </match>
57
+ </label>
58
+ <label @ERROR>
59
+ <match>
60
+ @type null
61
+ @id null
62
+ </match>
63
+ </label>
64
+ EOC
65
+ @ra = Fluent::RootAgent.new(log: $log)
66
+ stub(Fluent::Engine).root_agent { @ra }
67
+ @ra = configure_ra(@ra, conf)
68
+ end
69
+
70
+ test "plugin_category" do
71
+ d = create_driver
72
+ test_label = @ra.labels['@test']
73
+ error_label = @ra.labels['@ERROR']
74
+ assert_equal("input", d.instance.plugin_category(@ra.inputs.first))
75
+ assert_equal("filter", d.instance.plugin_category(@ra.filters.first))
76
+ assert_equal("output", d.instance.plugin_category(test_label.outputs.first))
77
+ assert_equal("output", d.instance.plugin_category(error_label.outputs.first))
78
+ end
79
+
80
+ test "get_monitor_info" do
81
+ d = create_driver
82
+ test_label = @ra.labels['@test']
83
+ error_label = @ra.labels['@ERROR']
84
+ input_info = {
85
+ "config" => {
86
+ "@id" => "test_in",
87
+ "@type" => "test_in"
88
+ },
89
+ "output_plugin" => false,
90
+ "plugin_category"=> "input",
91
+ "plugin_id" => "test_in",
92
+ "retry_count" => nil,
93
+ "type" => "test_in"
94
+ }
95
+ filter_info = {
96
+ "config" => {
97
+ "@id" => "test_filter",
98
+ "@type" => "test_filter"
99
+ },
100
+ "output_plugin" => false,
101
+ "plugin_category" => "filter",
102
+ "plugin_id" => "test_filter",
103
+ "retry_count" => nil,
104
+ "type" => "test_filter"
105
+ }
106
+ output_info = {
107
+ "config" => {
108
+ "@id" => "test_out",
109
+ "@type" => "test_out"
110
+ },
111
+ "output_plugin" => true,
112
+ "plugin_category" => "output",
113
+ "plugin_id" => "test_out",
114
+ "retry_count" => 0,
115
+ "type" => "test_out"
116
+ }
117
+ error_label_info = {
118
+ "config" => {
119
+ "@id"=>"null",
120
+ "@type" => "null"
121
+ },
122
+ "output_plugin" => true,
123
+ "plugin_category" => "output",
124
+ "plugin_id" => "null",
125
+ "retry_count" => 0,
126
+ "type" => "null"
127
+ }
128
+ assert_equal(input_info, d.instance.get_monitor_info(@ra.inputs.first))
129
+ assert_equal(filter_info, d.instance.get_monitor_info(@ra.filters.first))
130
+ assert_equal(output_info, d.instance.get_monitor_info(test_label.outputs.first))
131
+ assert_equal(error_label_info, d.instance.get_monitor_info(error_label.outputs.first))
132
+ end
133
+
134
+ test "fluentd opts" do
135
+ d = create_driver
136
+ opts = Fluent::Supervisor.default_options
137
+ Fluent::Supervisor.new(opts)
138
+ expected_opts = {
139
+ "config_path" => "/etc/fluent/fluent.conf",
140
+ "pid_file" => nil,
141
+ "plugin_dirs" => ["/etc/fluent/plugin"],
142
+ "log_path" => nil
143
+ }
144
+ assert_equal(expected_opts, d.instance.fluentd_opts)
145
+ end
146
+
147
+ test "all_plugins" do
148
+ d = create_driver
149
+ plugins = []
150
+ d.instance.all_plugins.each {|plugin| plugins << plugin.class }
151
+ assert_equal([FluentTest::FluentTestInput,
152
+ Fluent::Plugin::RelabelOutput,
153
+ FluentTest::FluentTestFilter,
154
+ FluentTest::FluentTestOutput,
155
+ Fluent::Plugin::NullOutput], plugins)
156
+ end
157
+
158
+ test "emit" do
159
+ port = unused_port
160
+ d = create_driver("
161
+ @type monitor_agent
162
+ bind '127.0.0.1'
163
+ port #{port}
164
+ tag monitor
165
+ emit_interval 1
166
+ ")
167
+ d.instance.start
168
+ d.end_if do
169
+ d.events.size >= 5
170
+ end
171
+ d.run
172
+ expect_relabel_record = {
173
+ "plugin_id" => "test_relabel",
174
+ "plugin_category" => "output",
175
+ "type" => "relabel",
176
+ "output_plugin" => true,
177
+ "retry_count" => 0}
178
+ expect_test_out_record = {
179
+ "plugin_id" => "test_out",
180
+ "plugin_category" => "output",
181
+ "type" => "test_out",
182
+ "output_plugin" => true,
183
+ "retry_count" => 0
184
+ }
185
+ assert_equal(expect_relabel_record, d.events[1][2])
186
+ assert_equal(expect_test_out_record, d.events[3][2])
187
+ end
188
+ end
189
+
190
+ def get(uri, header = {})
191
+ url = URI.parse(uri)
192
+ req = Net::HTTP::Get.new(url.path, header)
193
+ unless header.has_key?('Content-Type')
194
+ header['Content-Type'] = 'application/octet-stream'
195
+ end
196
+ res = Net::HTTP.start(url.host, url.port) {|http|
197
+ http.request(req)
198
+ }
199
+ res.body
200
+ end
201
+
202
+ sub_test_case "servlets" do
203
+ setup do
204
+ @port = unused_port
205
+ # check @type and type in one configuration
206
+ conf = <<-EOC
207
+ <source>
208
+ @type test_in
209
+ @id test_in
210
+ </source>
211
+ <source>
212
+ @type monitor_agent
213
+ bind "127.0.0.1"
214
+ port #{@port}
215
+ tag monitor
216
+ @id monitor_agent
217
+ </source>
218
+ <filter>
219
+ @type test_filter
220
+ @id test_filter
221
+ </filter>
222
+ <match **>
223
+ @type relabel
224
+ @id test_relabel
225
+ @label @test
226
+ </match>
227
+ <label @test>
228
+ <match **>
229
+ @type test_out
230
+ @id test_out
231
+ </match>
232
+ </label>
233
+ <label @ERROR>
234
+ <match>
235
+ @type null
236
+ @id null
237
+ </match>
238
+ </label>
239
+ EOC
240
+ @ra = Fluent::RootAgent.new(log: $log)
241
+ stub(Fluent::Engine).root_agent { @ra }
242
+ @ra = configure_ra(@ra, conf)
243
+ end
244
+
245
+ test "/api/plugins" do
246
+ d = create_driver("
247
+ @type monitor_agent
248
+ bind '127.0.0.1'
249
+ port #{@port}
250
+ tag monitor
251
+ ")
252
+ d.instance.start
253
+ expected_test_in_response = "\
254
+ plugin_id:test_in\tplugin_category:input\ttype:test_in\toutput_plugin:false\tretry_count:"
255
+ expected_test_filter_response = "\
256
+ plugin_id:test_filter\tplugin_category:filter\ttype:test_filter\toutput_plugin:false\tretry_count:"
257
+
258
+ response = get("http://127.0.0.1:#{@port}/api/plugins")
259
+ test_in = response.split("\n")[0]
260
+ test_filter = response.split("\n")[3]
261
+ assert_equal(expected_test_in_response, test_in)
262
+ assert_equal(expected_test_filter_response, test_filter)
263
+ end
264
+
265
+ test "/api/plugins.json" do
266
+ d = create_driver("
267
+ @type monitor_agent
268
+ bind '127.0.0.1'
269
+ port #{@port}
270
+ tag monitor
271
+ ")
272
+ d.instance.start
273
+ expected_test_in_response =
274
+ {"config" => {
275
+ "@id" => "test_in",
276
+ "@type" => "test_in"
277
+ },
278
+ "output_plugin" => false,
279
+ "plugin_category" => "input",
280
+ "plugin_id" => "test_in",
281
+ "retry_count" => nil,
282
+ "type" => "test_in"}
283
+ expected_null_response =
284
+ {"config" => {
285
+ "@id" => "null",
286
+ "@type" => "null"
287
+ },
288
+ "output_plugin" => true,
289
+ "plugin_category" => "output",
290
+ "plugin_id" => "null",
291
+ "retry_count" => 0,
292
+ "type" => "null"}
293
+ response = JSON.parse(get("http://127.0.0.1:#{@port}/api/plugins.json"))
294
+ test_in_response = response["plugins"][0]
295
+ null_response = response["plugins"][5]
296
+ assert_equal(expected_test_in_response, test_in_response)
297
+ assert_equal(expected_null_response, null_response)
298
+ end
299
+
300
+ test "/api/config" do
301
+ d = create_driver("
302
+ @type monitor_agent
303
+ bind '127.0.0.1'
304
+ port #{@port}
305
+ tag monitor
306
+ ")
307
+ d.instance.start
308
+ expected_response_regex = /pid:\d+\tppid:\d+\tconfig_path:\/etc\/fluent\/fluent.conf\tpid_file:\tplugin_dirs:\[\"\/etc\/fluent\/plugin\"\]\tlog_path:/
309
+
310
+ assert_match(expected_response_regex,
311
+ get("http://127.0.0.1:#{@port}/api/config"))
312
+ end
313
+
314
+ test "/api/config.json" do
315
+ d = create_driver("
316
+ @type monitor_agent
317
+ bind '127.0.0.1'
318
+ port #{@port}
319
+ tag monitor
320
+ ")
321
+ d.instance.start
322
+ res = JSON.parse(get("http://127.0.0.1:#{@port}/api/config.json"))
323
+ assert_equal("/etc/fluent/fluent.conf", res["config_path"])
324
+ assert_nil(res["pid_file"])
325
+ assert_equal(["/etc/fluent/plugin"], res["plugin_dirs"])
326
+ assert_nil(res["log_path"])
327
+ end
328
+ end
329
+ end
@@ -0,0 +1,64 @@
1
+ require_relative '../helper'
2
+ require 'fluent/test/driver/input'
3
+ require 'fluent/plugin/in_object_space'
4
+
5
+ require 'timeout'
6
+
7
+ class ObjectSpaceInputTest < Test::Unit::TestCase
8
+ def waiting(seconds, instance)
9
+ begin
10
+ Timeout.timeout(seconds) do
11
+ yield
12
+ end
13
+ rescue Timeout::Error
14
+ STDERR.print(*instance.log.out.logs)
15
+ raise
16
+ end
17
+ end
18
+
19
+ class FailObject
20
+ def self.class
21
+ raise "error"
22
+ end
23
+ end
24
+
25
+ def setup
26
+ Fluent::Test.setup
27
+ end
28
+
29
+ TESTCONFIG = %[
30
+ emit_interval 1
31
+ tag t1
32
+ top 2
33
+ ]
34
+
35
+ def create_driver(conf=TESTCONFIG)
36
+ Fluent::Test::Driver::Input.new(Fluent::Plugin::ObjectSpaceInput).configure(conf)
37
+ end
38
+
39
+ def test_configure
40
+ d = create_driver
41
+ assert_equal 1, d.instance.emit_interval
42
+ assert_equal "t1", d.instance.tag
43
+ assert_equal 2, d.instance.top
44
+ end
45
+
46
+ def test_emit
47
+ d = create_driver
48
+
49
+ d.run do
50
+ waiting(10, d.instance) do
51
+ sleep 0.5 until d.events.size > 3
52
+ end
53
+ end
54
+
55
+ emits = d.events
56
+ assert{ emits.length > 0 }
57
+
58
+ emits.each { |tag, time, record|
59
+ assert_equal d.instance.tag, tag
60
+ assert_equal d.instance.top, record.keys.size
61
+ assert(time.is_a?(Fluent::EventTime))
62
+ }
63
+ end
64
+ end
@@ -0,0 +1,205 @@
1
+ require_relative '../helper'
2
+ require 'fluent/test/driver/input'
3
+ require 'fluent/plugin/in_syslog'
4
+
5
+ class SyslogInputTest < Test::Unit::TestCase
6
+ class << self
7
+ def startup
8
+ socket_manager_path = ServerEngine::SocketManager::Server.generate_path
9
+ @server = ServerEngine::SocketManager::Server.open(socket_manager_path)
10
+ ENV['SERVERENGINE_SOCKETMANAGER_PATH'] = socket_manager_path.to_s
11
+ end
12
+
13
+ def shutdown
14
+ @server.close
15
+ end
16
+ end
17
+
18
+ def setup
19
+ Fluent::Test.setup
20
+ require 'fluent/plugin/socket_util'
21
+ end
22
+
23
+ PORT = unused_port
24
+ CONFIG = %[
25
+ port #{PORT}
26
+ bind 127.0.0.1
27
+ tag syslog
28
+ ]
29
+
30
+ IPv6_CONFIG = %[
31
+ port #{PORT}
32
+ bind ::1
33
+ tag syslog
34
+ ]
35
+
36
+ def create_driver(conf=CONFIG)
37
+ Fluent::Test::Driver::Input.new(Fluent::Plugin::SyslogInput).configure(conf)
38
+ end
39
+
40
+ def test_configure
41
+ configs = {'127.0.0.1' => CONFIG}
42
+ configs.merge!('::1' => IPv6_CONFIG) if ipv6_enabled?
43
+
44
+ configs.each_pair { |k, v|
45
+ d = create_driver(v)
46
+ assert_equal PORT, d.instance.port
47
+ assert_equal k, d.instance.bind
48
+ }
49
+ end
50
+
51
+ def test_time_format
52
+ configs = {'127.0.0.1' => CONFIG}
53
+ configs.merge!('::1' => IPv6_CONFIG) if ipv6_enabled?
54
+
55
+ configs.each_pair { |k, v|
56
+ d = create_driver(v)
57
+
58
+ tests = [
59
+ {'msg' => '<6>Dec 11 00:00:00 localhost logger: foo', 'expected' => Fluent::EventTime.from_time(Time.strptime('Dec 11 00:00:00', '%b %d %H:%M:%S'))},
60
+ {'msg' => '<6>Dec 1 00:00:00 localhost logger: foo', 'expected' => Fluent::EventTime.from_time(Time.strptime('Dec 1 00:00:00', '%b %d %H:%M:%S'))},
61
+ ]
62
+ d.run(expect_emits: 2) do
63
+ u = Fluent::SocketUtil.create_udp_socket(k)
64
+ u.connect(k, PORT)
65
+ tests.each {|test|
66
+ u.send(test['msg'], 0)
67
+ }
68
+ end
69
+
70
+ events = d.events
71
+ assert(events.size > 0)
72
+ events.each_index {|i|
73
+ assert_equal_event_time(tests[i]['expected'], events[i][1])
74
+ }
75
+ }
76
+ end
77
+
78
+ def test_msg_size
79
+ d = create_driver
80
+ tests = create_test_case
81
+
82
+ d.run(expect_emits: 2) do
83
+ u = UDPSocket.new
84
+ u.connect('127.0.0.1', PORT)
85
+ tests.each {|test|
86
+ u.send(test['msg'], 0)
87
+ }
88
+ end
89
+
90
+ assert(d.events.size > 0)
91
+ compare_test_result(d.events, tests)
92
+ end
93
+
94
+ def test_msg_size_udp_for_large_msg
95
+ d = create_driver(CONFIG + %[
96
+ message_length_limit 5k
97
+ ])
98
+ tests = create_test_case(large_message: true)
99
+
100
+ d.run(expect_emits: 3) do
101
+ u = UDPSocket.new
102
+ u.connect('127.0.0.1', PORT)
103
+ tests.each {|test|
104
+ u.send(test['msg'], 0)
105
+ }
106
+ end
107
+
108
+ assert(d.events.size > 0)
109
+ compare_test_result(d.events, tests)
110
+ end
111
+
112
+ def test_msg_size_with_tcp
113
+ d = create_driver([CONFIG, 'protocol_type tcp'].join("\n"))
114
+ tests = create_test_case
115
+
116
+ d.run(expect_emits: 2) do
117
+ tests.each {|test|
118
+ TCPSocket.open('127.0.0.1', PORT) do |s|
119
+ s.send(test['msg'], 0)
120
+ end
121
+ }
122
+ end
123
+
124
+ assert(d.events.size > 0)
125
+ compare_test_result(d.events, tests)
126
+ end
127
+
128
+ def test_msg_size_with_same_tcp_connection
129
+ d = create_driver([CONFIG, 'protocol_type tcp'].join("\n"))
130
+ tests = create_test_case
131
+
132
+ d.run(expect_emits: 2) do
133
+ TCPSocket.open('127.0.0.1', PORT) do |s|
134
+ tests.each {|test|
135
+ s.send(test['msg'], 0)
136
+ }
137
+ end
138
+ end
139
+
140
+ assert(d.events.size > 0)
141
+ compare_test_result(d.events, tests)
142
+ end
143
+
144
+ def test_msg_size_with_json_format
145
+ d = create_driver([CONFIG, 'format json'].join("\n"))
146
+ time = Time.parse('2013-09-18 12:00:00 +0900').to_i
147
+ tests = ['Hello!', 'Syslog!'].map { |msg|
148
+ event = {'time' => time, 'message' => msg}
149
+ {'msg' => '<6>' + event.to_json + "\n", 'expected' => msg}
150
+ }
151
+
152
+ d.run(expect_emits: 2) do
153
+ u = UDPSocket.new
154
+ u.connect('127.0.0.1', PORT)
155
+ tests.each {|test|
156
+ u.send(test['msg'], 0)
157
+ }
158
+ end
159
+
160
+ assert(d.events.size > 0)
161
+ compare_test_result(d.events, tests)
162
+ end
163
+
164
+ def test_msg_size_with_include_source_host
165
+ d = create_driver([CONFIG, 'include_source_host true'].join("\n"))
166
+ tests = create_test_case
167
+
168
+ host = nil
169
+ d.run(expect_emits: 2) do
170
+ u = UDPSocket.new
171
+ u.connect('127.0.0.1', PORT)
172
+ host = u.peeraddr[2]
173
+ tests.each {|test|
174
+ u.send(test['msg'], 0)
175
+ }
176
+ end
177
+
178
+ assert(d.events.size > 0)
179
+ compare_test_result(d.events, tests, host)
180
+ end
181
+
182
+ def create_test_case(large_message: false)
183
+ # actual syslog message has "\n"
184
+ if large_message
185
+ [
186
+ {'msg' => '<6>Sep 10 00:00:00 localhost logger: ' + 'x' * 100 + "\n", 'expected' => 'x' * 100},
187
+ {'msg' => '<6>Sep 10 00:00:00 localhost logger: ' + 'x' * 1024 + "\n", 'expected' => 'x' * 1024},
188
+ {'msg' => '<6>Sep 10 00:00:00 localhost logger: ' + 'x' * 4096 + "\n", 'expected' => 'x' * 4096},
189
+ ]
190
+ else
191
+ [
192
+ {'msg' => '<6>Sep 10 00:00:00 localhost logger: ' + 'x' * 100 + "\n", 'expected' => 'x' * 100},
193
+ {'msg' => '<6>Sep 10 00:00:00 localhost logger: ' + 'x' * 1024 + "\n", 'expected' => 'x' * 1024},
194
+ ]
195
+ end
196
+ end
197
+
198
+ def compare_test_result(events, tests, host = nil)
199
+ events.each_index { |i|
200
+ assert_equal('syslog.kern.info', events[i][0]) # <6> means kern.info
201
+ assert_equal(tests[i]['expected'], events[i][2]['message'])
202
+ assert_equal(host, events[i][2]['source_host']) if host
203
+ }
204
+ end
205
+ end