fluentd 1.16.5-x64-mingw32 → 1.17.1-x64-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,71 +0,0 @@
1
- name: Bug Report
2
- description: Create a report with a procedure for reproducing the bug
3
- labels: "waiting-for-triage"
4
- body:
5
- - type: markdown
6
- attributes:
7
- value: |
8
- Check [CONTRIBUTING guideline](https://github.com/fluent/fluentd/blob/master/CONTRIBUTING.md) first and here is the list to help us investigate the problem.
9
- - type: textarea
10
- id: description
11
- attributes:
12
- label: Describe the bug
13
- description: A clear and concise description of what the bug is
14
- validations:
15
- required: true
16
- - type: textarea
17
- id: reproduce
18
- attributes:
19
- label: To Reproduce
20
- description: Steps to reproduce the behavior
21
- validations:
22
- required: true
23
- - type: textarea
24
- id: expected
25
- attributes:
26
- label: Expected behavior
27
- description: A clear and concise description of what you expected to happen
28
- validations:
29
- required: true
30
- - type: textarea
31
- id: environment
32
- attributes:
33
- label: Your Environment
34
- description: |
35
- - Fluentd or td-agent version: `fluentd --version` or `td-agent --version`
36
- - Operating system: `cat /etc/os-release`
37
- - Kernel version: `uname -r`
38
-
39
- Tip: If you hit the problem with older fluentd version, try latest version first.
40
- value: |
41
- - Fluentd version:
42
- - TD Agent version:
43
- - Operating system:
44
- - Kernel version:
45
- render: markdown
46
- validations:
47
- required: true
48
- - type: textarea
49
- id: configuration
50
- attributes:
51
- label: Your Configuration
52
- description: |
53
- Write your configuration here. Minimum reproducible fluentd.conf is recommended.
54
- render: apache
55
- validations:
56
- required: true
57
- - type: textarea
58
- id: logs
59
- attributes:
60
- label: Your Error Log
61
- description: Write your ALL error log here
62
- render: shell
63
- validations:
64
- required: true
65
- - type: textarea
66
- id: addtional-context
67
- attributes:
68
- label: Additional context
69
- description: Add any other context about the problem here.
70
- validations:
71
- required: false
@@ -1,5 +0,0 @@
1
- blank_issues_enabled: false
2
- contact_links:
3
- - name: Ask a Question
4
- url: https://github.com/fluent/fluentd/discussions
5
- about: I have questions about Fluentd and plugins. Please ask and answer questions at https://github.com/fluent/fluentd/discussions
@@ -1,39 +0,0 @@
1
- name: Feature request
2
- description: Suggest an idea for this project
3
- labels: "waiting-for-triage"
4
- body:
5
- - type: markdown
6
- attributes:
7
- value: |
8
- Check [CONTRIBUTING guideline](https://github.com/fluent/fluentd/blob/master/CONTRIBUTING.md) first and here is the list to help us investigate the problem.
9
- - type: textarea
10
- id: description
11
- attributes:
12
- label: Is your feature request related to a problem? Please describe.
13
- description: |
14
- A clear and concise description of what the problem is.
15
- Ex. I'm always frustrated when [...]
16
- validations:
17
- required: true
18
- - type: textarea
19
- id: solution
20
- attributes:
21
- label: Describe the solution you'd like
22
- description: A clear and concise description of what you want to happen.
23
- validations:
24
- required: true
25
- - type: textarea
26
- id: alternative
27
- attributes:
28
- label: Describe alternatives you've considered
29
- description: A clear and concise description of any alternative solutions or features you've considered.
30
- validations:
31
- required: true
32
- - type: textarea
33
- id: addtional-context
34
- attributes:
35
- label: Additional context
36
- description: Add any other context or screenshots about the feature request here.
37
- validations:
38
- required: false
39
-
@@ -1,17 +0,0 @@
1
- Check [CONTRIBUTING guideline](https://github.com/fluent/fluentd/blob/master/CONTRIBUTING.md) first and here is the list to help us investigate the problem.
2
-
3
- **Got a question or problem?**
4
-
5
- RESOURCES of [Official site](https://www.fluentd.org/) and [Fluentd documentation](https://docs.fluentd.org/) may help you.
6
-
7
- If you have further questions about Fluentd and plugins, please direct these to [Mailing List](https://groups.google.com/forum/#!forum/fluentd).
8
- Don't use Github issue for asking questions. Here are examples:
9
-
10
- - I installed xxx plugin but it doesn't work. Why?
11
- - Fluentd starts but logs are not sent to xxx. Am I wrong?
12
- - I want to do xxx. How to realize it with plugins?
13
-
14
- We may close such questions to keep clear repository for developers and users.
15
- Github issue is mainly for submitting a bug report or feature request. See below.
16
-
17
- If you can't judge your case is a bug or not, use mailing list or slack first.
@@ -1,14 +0,0 @@
1
- <!--
2
- Thank you for contributing to Fluentd!
3
- Your commits need to follow DCO: https://probot.github.io/apps/dco/
4
- And please provide the following information to help us make the most of your pull request:
5
- -->
6
-
7
- **Which issue(s) this PR fixes**:
8
- Fixes #
9
-
10
- **What this PR does / why we need it**:
11
-
12
- **Docs Changes**:
13
-
14
- **Release Note**:
@@ -1,24 +0,0 @@
1
- name: "Mark or close stale issues and PRs"
2
- on:
3
- schedule:
4
- - cron: "00 10 * * *"
5
-
6
- jobs:
7
- stale:
8
- runs-on: ubuntu-latest
9
- steps:
10
- - uses: actions/stale@v8
11
- with:
12
- repo-token: ${{ secrets.GITHUB_TOKEN }}
13
- days-before-stale: 30
14
- days-before-close: 7
15
- stale-issue-message: "This issue has been automatically marked as stale because it has been open 30 days with no activity. Remove stale label or comment or this issue will be closed in 7 days"
16
- stale-pr-message: "This PR has been automatically marked as stale because it has been open 30 days with no activity. Remove stale label or comment or this PR will be closed in 7 days"
17
- close-issue-message: "This issue was automatically closed because of stale in 7 days"
18
- close-pr-message: "This PR was automatically closed because of stale in 7 days"
19
- stale-pr-label: "stale"
20
- stale-issue-label: "stale"
21
- exempt-issue-labels: "waiting-for-triage,bug,enhancement,feature request,pending,work_in_progress,v1,v2"
22
- exempt-pr-labels: "waiting-for-triage,bug,enhancement,feature request,pending,work_in_progress,v1,v2"
23
- exempt-all-assignees: true
24
- exempt-all-milestones: true
@@ -1,32 +0,0 @@
1
- name: Test
2
-
3
- on:
4
- push:
5
- branches: [v1.16]
6
- pull_request:
7
- branches: [v1.16]
8
-
9
- jobs:
10
- test:
11
- runs-on: ${{ matrix.os }}
12
- continue-on-error: false
13
- strategy:
14
- fail-fast: false
15
- matrix:
16
- os: ['ubuntu-latest', 'macos-latest', 'windows-latest']
17
- ruby-version: ['3.3', '3.2', '3.1', '3.0', '2.7']
18
-
19
- name: Ruby ${{ matrix.ruby-version }} on ${{ matrix.os }}
20
- steps:
21
- - uses: actions/checkout@v3
22
- - name: Set up Ruby
23
- uses: ruby/setup-ruby@v1
24
- with:
25
- ruby-version: ${{ matrix.ruby-version }}
26
- - name: Install addons
27
- if: ${{ matrix.os == 'ubuntu-latest' }}
28
- run: sudo apt-get install libgmp3-dev libcap-ng-dev
29
- - name: Install dependencies
30
- run: bundle install
31
- - name: Run tests
32
- run: bundle exec rake test TESTOPTS=-v
data/.gitignore DELETED
@@ -1,30 +0,0 @@
1
- Gemfile.lock
2
- INSTALL
3
- NEWS
4
- Makefile
5
- Makefile.in
6
- README
7
- ac
8
- aclocal.m4
9
- autom4te.cache
10
- confdefs.h
11
- config.log
12
- config.status
13
- configure
14
- deps/
15
- fluent-cat
16
- fluent-gem
17
- fluentd
18
- pkg/*
19
- test/tmp/*
20
- test/config/tmp/*
21
- make_dist.sh
22
- Gemfile.local
23
- .ruby-version
24
- *.swp
25
- coverage/*
26
- .vagrant/
27
- cov-int/
28
- cov-fluentd.tar.gz
29
- .vscode
30
- .idea/
data/Gemfile DELETED
@@ -1,9 +0,0 @@
1
- source 'https://rubygems.org/'
2
-
3
- gemspec
4
-
5
- local_gemfile = File.join(File.dirname(__FILE__), "Gemfile.local")
6
- if File.exist?(local_gemfile)
7
- puts "Loading Gemfile.local ..." if $DEBUG # `ruby -d` or `bundle -v`
8
- instance_eval File.read(local_gemfile)
9
- end
data/fluentd.gemspec DELETED
@@ -1,54 +0,0 @@
1
- require File.expand_path('../lib/fluent/version', __FILE__)
2
-
3
- Gem::Specification.new do |gem|
4
- gem.name = "fluentd"
5
- gem.version = Fluent::VERSION # see lib/fluent/version.rb
6
-
7
- gem.authors = ["Sadayuki Furuhashi"]
8
- gem.email = ["frsyuki@gmail.com"]
9
- gem.description = %q{Fluentd is an open source data collector designed to scale and simplify log management. It can collect, process and ship many kinds of data in near real-time.}
10
- gem.summary = %q{Fluentd event collector}
11
- gem.homepage = "https://www.fluentd.org/"
12
-
13
- gem.files = `git ls-files`.split($\)
14
- gem.executables = gem.files.grep(%r{^bin/}).map{ |f| File.basename(f) }
15
- gem.test_files = gem.files.grep(%r{^(test|spec|features)/})
16
- gem.require_paths = ["lib"]
17
- gem.license = "Apache-2.0"
18
-
19
- gem.required_ruby_version = '>= 2.4'
20
-
21
- gem.add_runtime_dependency("bundler")
22
- gem.add_runtime_dependency("msgpack", [">= 1.3.1", "< 2.0.0"])
23
- gem.add_runtime_dependency("yajl-ruby", ["~> 1.0"])
24
- gem.add_runtime_dependency("cool.io", [">= 1.4.5", "< 2.0.0"])
25
- gem.add_runtime_dependency("serverengine", [">= 2.3.2", "< 3.0.0"])
26
- gem.add_runtime_dependency("http_parser.rb", [">= 0.5.1", "< 0.9.0"])
27
- gem.add_runtime_dependency("sigdump", ["~> 0.2.5"])
28
- gem.add_runtime_dependency("tzinfo", [">= 1.0", "< 3.0"])
29
- gem.add_runtime_dependency("tzinfo-data", ["~> 1.0"])
30
- gem.add_runtime_dependency("strptime", [">= 0.2.4", "< 1.0.0"])
31
- gem.add_runtime_dependency("webrick", ["~> 1.4"])
32
-
33
- # build gem for a certain platform. see also Rakefile
34
- fake_platform = ENV['GEM_BUILD_FAKE_PLATFORM'].to_s
35
- gem.platform = fake_platform unless fake_platform.empty?
36
- if /mswin|mingw/ =~ fake_platform || (/mswin|mingw/ =~ RUBY_PLATFORM && fake_platform.empty?)
37
- gem.add_runtime_dependency("win32-service", ["~> 2.3.0"])
38
- gem.add_runtime_dependency("win32-ipc", ["~> 0.7.0"])
39
- gem.add_runtime_dependency("win32-event", ["~> 0.6.3"])
40
- gem.add_runtime_dependency("certstore_c", ["~> 0.1.7"])
41
- end
42
-
43
- gem.add_development_dependency("rake", ["~> 13.0"])
44
- gem.add_development_dependency("flexmock", ["~> 2.0"])
45
- gem.add_development_dependency("parallel_tests", ["~> 0.15.3"])
46
- gem.add_development_dependency("simplecov", ["~> 0.7"])
47
- gem.add_development_dependency("rr", ["~> 3.0"])
48
- gem.add_development_dependency("timecop", ["~> 0.9"])
49
- gem.add_development_dependency("test-unit", ["~> 3.3"])
50
- gem.add_development_dependency("test-unit-rr", ["~> 1.0"])
51
- gem.add_development_dependency("oj", [">= 2.14", "< 4"])
52
- gem.add_development_dependency("async", "~> 1.23")
53
- gem.add_development_dependency("async-http", ">= 0.50.0")
54
- end
@@ -1,362 +0,0 @@
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
- setup do
86
- @default_newline = if Fluent.windows?
87
- "\r\n"
88
- else
89
- "\n"
90
- end
91
- end
92
-
93
- sub_test_case 'initialize' do
94
- data(
95
- 'file is not passed' => %w(),
96
- 'file is not found' => %w(invalid_path.log)
97
- )
98
- test 'should fail if file is invalid' do |argv|
99
- assert_raise(SystemExit) do
100
- capture_stdout { BinlogReaderCommand::Head.new(argv) }
101
- end
102
- end
103
-
104
- test 'should succeed if a file is valid' do
105
- file_name = 'packed.log'
106
- argv = ["#{TMP_DIR}/#{file_name}"]
107
- create_message_packed_file(file_name)
108
-
109
- assert_nothing_raised do
110
- BinlogReaderCommand::Head.new(argv)
111
- end
112
- end
113
-
114
- test 'should fail when config_params format is invalid' do
115
- file_name = 'packed.log'
116
- argv = ["#{TMP_DIR}/#{file_name}", '--format=csv', '-e', 'only_key']
117
- create_message_packed_file(file_name)
118
-
119
- assert_raise(SystemExit) do
120
- capture_stdout { BinlogReaderCommand::Head.new(argv) }
121
- end
122
- end
123
-
124
- test 'should succeed if config_params format is valid' do
125
- file_name = 'packed.log'
126
- argv = ["#{TMP_DIR}/#{file_name}", '--format=csv', '-e', 'fields=message']
127
- create_message_packed_file(file_name)
128
-
129
- assert_nothing_raised do
130
- capture_stdout { BinlogReaderCommand::Head.new(argv) }
131
- end
132
- end
133
- end
134
-
135
- sub_test_case 'call' do
136
- setup do
137
- @file_name = 'packed.log'
138
- @t = '2011-01-02 13:14:15 UTC'
139
- @record = { 'message' => 'dummy' }
140
- end
141
-
142
- test 'should output the beginning of the file with default format (out_file)' do
143
- argv = ["#{TMP_DIR}/#{@file_name}"]
144
-
145
- timezone do
146
- create_message_packed_file(@file_name, [event_time(@t).to_i] * 6, [@record] * 6)
147
- head = BinlogReaderCommand::Head.new(argv)
148
- out = capture_stdout { head.call }
149
- assert_equal "2011-01-02T13:14:15+00:00\t#{TMP_DIR}/#{@file_name}\t#{Yajl.dump(@record)}#{@default_newline}" * 5, out
150
- end
151
- end
152
-
153
- test 'should set the number of lines to display' do
154
- argv = ["#{TMP_DIR}/#{@file_name}", '-n', '1']
155
-
156
- timezone do
157
- create_message_packed_file(@file_name, [event_time(@t).to_i] * 6, [@record] * 6)
158
- head = BinlogReaderCommand::Head.new(argv)
159
- out = capture_stdout { head.call }
160
- assert_equal "2011-01-02T13:14:15+00:00\t#{TMP_DIR}/#{@file_name}\t#{Yajl.dump(@record)}#{@default_newline}", out
161
- end
162
- end
163
-
164
- test 'should fail when the number of lines is invalid' do
165
- argv = ["#{TMP_DIR}/#{@file_name}", '-n', '0']
166
-
167
- create_message_packed_file(@file_name)
168
- assert_raise(SystemExit) do
169
- capture_stdout { BinlogReaderCommand::Head.new(argv) }
170
- end
171
- end
172
-
173
- test 'should output content of a file with json format' do
174
- argv = ["#{TMP_DIR}/#{@file_name}", '--format=json']
175
-
176
- timezone do
177
- create_message_packed_file(@file_name, [event_time(@t).to_i], [@record])
178
- head = BinlogReaderCommand::Head.new(argv)
179
- out = capture_stdout { head.call }
180
- assert_equal "#{Yajl.dump(@record)}#{@default_newline}", out
181
- end
182
- end
183
-
184
- test 'should fail with an invalid format' do
185
- argv = ["#{TMP_DIR}/#{@file_name}", '--format=invalid']
186
-
187
- timezone do
188
- create_message_packed_file(@file_name, [event_time(@t).to_i], [@record])
189
- head = BinlogReaderCommand::Head.new(argv)
190
-
191
- assert_raise(SystemExit) do
192
- capture_stdout { head.call }
193
- end
194
- end
195
- end
196
-
197
- test 'should succeed if multiple config_params format' do
198
- file_name = 'packed.log'
199
- argv = ["#{TMP_DIR}/#{file_name}", '--format=csv', '-e', 'fields=message,fo', '-e', 'delimiter=|']
200
- create_message_packed_file(file_name, [event_time], [{ 'message' => 'dummy', 'fo' => 'dummy2' }])
201
-
202
- head = BinlogReaderCommand::Head.new(argv)
203
- assert_equal "\"dummy\"|\"dummy2\"\n", capture_stdout { head.call }
204
- end
205
- end
206
- end
207
-
208
- class TestCat < TestBaseCommand
209
- setup do
210
- @default_newline = if Fluent.windows?
211
- "\r\n"
212
- else
213
- "\n"
214
- end
215
- end
216
-
217
- sub_test_case 'initialize' do
218
- data(
219
- 'file is not passed' => [],
220
- 'file is not found' => %w(invalid_path.log)
221
- )
222
- test 'should fail if a file is invalid' do |argv|
223
- assert_raise(SystemExit) do
224
- capture_stdout { BinlogReaderCommand::Head.new(argv) }
225
- end
226
- end
227
-
228
- test 'should succeed if a file is valid' do
229
- file_name = 'packed.log'
230
- argv = ["#{TMP_DIR}/#{file_name}"]
231
- create_message_packed_file(file_name)
232
-
233
- assert_nothing_raised do
234
- BinlogReaderCommand::Cat.new(argv)
235
- end
236
- end
237
-
238
- test 'should fail when config_params format is invalid' do
239
- file_name = 'packed.log'
240
- argv = ["#{TMP_DIR}/#{file_name}", '--format=json', '-e', 'only_key']
241
- create_message_packed_file(file_name)
242
-
243
- assert_raise(SystemExit) do
244
- capture_stdout { BinlogReaderCommand::Cat.new(argv) }
245
- end
246
- end
247
-
248
- test 'should succeed when config_params format is valid' do
249
- file_name = 'packed.log'
250
- argv = ["#{TMP_DIR}/#{file_name}", '--format=csv', '-e', 'fields=message']
251
- create_message_packed_file(file_name)
252
-
253
- assert_nothing_raised do
254
- capture_stdout { BinlogReaderCommand::Cat.new(argv) }
255
- end
256
- end
257
- end
258
-
259
- sub_test_case 'call' do
260
- setup do
261
- @file_name = 'packed.log'
262
- @t = '2011-01-02 13:14:15 UTC'
263
- @record = { 'message' => 'dummy' }
264
- end
265
-
266
- test 'should output the file with default format(out_file)' do
267
- argv = ["#{TMP_DIR}/#{@file_name}"]
268
-
269
- timezone do
270
- create_message_packed_file(@file_name, [event_time(@t).to_i] * 6, [@record] * 6)
271
- head = BinlogReaderCommand::Cat.new(argv)
272
- out = capture_stdout { head.call }
273
- assert_equal "2011-01-02T13:14:15+00:00\t#{TMP_DIR}/#{@file_name}\t#{Yajl.dump(@record)}#{@default_newline}" * 6, out
274
- end
275
- end
276
-
277
- test 'should set the number of lines to display' do
278
- argv = ["#{TMP_DIR}/#{@file_name}", '-n', '1']
279
-
280
- timezone do
281
- create_message_packed_file(@file_name, [event_time(@t).to_i] * 6, [@record] * 6)
282
- head = BinlogReaderCommand::Cat.new(argv)
283
- out = capture_stdout { head.call }
284
- assert_equal "2011-01-02T13:14:15+00:00\t#{TMP_DIR}/#{@file_name}\t#{Yajl.dump(@record)}#{@default_newline}", out
285
- end
286
- end
287
-
288
- test 'should output content of a file with json format' do
289
- argv = ["#{TMP_DIR}/#{@file_name}", '--format=json']
290
-
291
- timezone do
292
- create_message_packed_file(@file_name, [event_time(@t).to_i], [@record])
293
- head = BinlogReaderCommand::Cat.new(argv)
294
- out = capture_stdout { head.call }
295
- assert_equal "#{Yajl.dump(@record)}#{@default_newline}", out
296
- end
297
- end
298
-
299
- test 'should fail with an invalid format' do
300
- argv = ["#{TMP_DIR}/#{@file_name}", '--format=invalid']
301
-
302
- timezone do
303
- create_message_packed_file(@file_name, [event_time(@t).to_i], [@record])
304
- head = BinlogReaderCommand::Cat.new(argv)
305
-
306
- assert_raise(SystemExit) do
307
- capture_stdout { head.call }
308
- end
309
- end
310
- end
311
-
312
- test 'should succeed if multiple config_params format' do
313
- file_name = 'packed.log'
314
- argv = ["#{TMP_DIR}/#{file_name}", '--format=csv', '-e', 'fields=message,fo', '-e', 'delimiter=|']
315
- create_message_packed_file(file_name, [event_time], [{ 'message' => 'dummy', 'fo' => 'dummy2' }])
316
-
317
- head = BinlogReaderCommand::Cat.new(argv)
318
- assert_equal "\"dummy\"|\"dummy2\"\n", capture_stdout { head.call }
319
- end
320
- end
321
- end
322
-
323
- class TestFormats < TestBaseCommand
324
- test 'parse_option!' do
325
- assert_raise(SystemExit) do
326
- capture_stdout do
327
- BinlogReaderCommand::Formats.new(['--plugin=invalid_dir_path'])
328
- end
329
- end
330
- end
331
-
332
- sub_test_case 'call' do
333
- test 'display available plugins' do
334
- f = BinlogReaderCommand::Formats.new
335
- out = capture_stdout { f.call }
336
- assert out.include?('json')
337
- assert out.include?('csv')
338
- end
339
-
340
- test 'add new plugins using --plugin option' do
341
- dir_path = File.expand_path(File.dirname(__FILE__) + '/../scripts/fluent/plugin/formatter1')
342
-
343
- f = BinlogReaderCommand::Formats.new(["--plugin=#{dir_path}"])
344
- out = capture_stdout { f.call }
345
- assert out.include?('json')
346
- assert out.include?('csv')
347
- assert out.include?('test1')
348
- end
349
-
350
- test 'add multiple plugins using --plugin option' do
351
- dir_path1 = File.expand_path(File.dirname(__FILE__) + '/../scripts/fluent/plugin/formatter1')
352
- dir_path2 = File.expand_path(File.dirname(__FILE__) + '/../scripts/fluent/plugin/formatter2')
353
-
354
- f = BinlogReaderCommand::Formats.new(["--plugin=#{dir_path1}", '-p', dir_path2])
355
- out = capture_stdout { f.call }
356
- assert out.include?('json')
357
- assert out.include?('csv')
358
- assert out.include?('test1')
359
- assert out.include?('test2')
360
- end
361
- end
362
- end