fluentd-ui 0.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Potentially problematic release.
This version of fluentd-ui might be problematic. Click here for more details.
- checksums.yaml +7 -0
- data/.bowerrc +3 -0
- data/.gitignore +31 -0
- data/.rspec +1 -0
- data/ChangeLog +3 -0
- data/Gemfile +21 -0
- data/Gemfile.lock +247 -0
- data/Gemfile.production +3 -0
- data/README.md +53 -0
- data/Rakefile +8 -0
- data/app/assets/images/.keep +0 -0
- data/app/assets/javascripts/alert.js +51 -0
- data/app/assets/javascripts/application.js +22 -0
- data/app/assets/javascripts/nested_setting.js +41 -0
- data/app/assets/javascripts/setting_format.js +15 -0
- data/app/assets/javascripts/tutorial.js +58 -0
- data/app/assets/javascripts/vue/fluent_log.js +64 -0
- data/app/assets/javascripts/vue/in_tail_format.js +153 -0
- data/app/assets/javascripts/vue/treeview.js +97 -0
- data/app/assets/javascripts/vue_common.js +4 -0
- data/app/assets/stylesheets/application.css +18 -0
- data/app/assets/stylesheets/common.css.scss +152 -0
- data/app/controllers/api_controller.rb +37 -0
- data/app/controllers/application_controller.rb +110 -0
- data/app/controllers/concerns/.keep +0 -0
- data/app/controllers/fluentd/agents_controller.rb +35 -0
- data/app/controllers/fluentd/settings/in_syslog_controller.rb +34 -0
- data/app/controllers/fluentd/settings/in_tail_controller.rb +57 -0
- data/app/controllers/fluentd/settings/out_forward_controller.rb +42 -0
- data/app/controllers/fluentd/settings/out_mongo_controller.rb +36 -0
- data/app/controllers/fluentd/settings/out_s3_controller.rb +36 -0
- data/app/controllers/fluentd/settings/out_td_controller.rb +36 -0
- data/app/controllers/fluentd/settings_controller.rb +18 -0
- data/app/controllers/fluentd_controller.rb +62 -0
- data/app/controllers/misc_controller.rb +69 -0
- data/app/controllers/plugins_controller.rb +44 -0
- data/app/controllers/polling_controller.rb +20 -0
- data/app/controllers/sessions_controller.rb +45 -0
- data/app/controllers/tutorials_controller.rb +40 -0
- data/app/controllers/users_controller.rb +28 -0
- data/app/controllers/welcome_controller.rb +5 -0
- data/app/helpers/application_helper.rb +55 -0
- data/app/helpers/fluentd/settings_helper.rb +2 -0
- data/app/helpers/miscs_helper.rb +2 -0
- data/app/helpers/settings_helper.rb +43 -0
- data/app/mailers/.keep +0 -0
- data/app/models/.keep +0 -0
- data/app/models/concerns/.keep +0 -0
- data/app/models/fluentd.rb +178 -0
- data/app/models/fluentd/agent.rb +28 -0
- data/app/models/fluentd/agent/common.rb +76 -0
- data/app/models/fluentd/agent/configuration.rb +35 -0
- data/app/models/fluentd/agent/fluentd_gem.rb +104 -0
- data/app/models/fluentd/agent/local_common.rb +101 -0
- data/app/models/fluentd/agent/remote.rb +7 -0
- data/app/models/fluentd/agent/td_agent.rb +44 -0
- data/app/models/fluentd/api.rb +6 -0
- data/app/models/fluentd/api/http.rb +26 -0
- data/app/models/fluentd/setting.rb +4 -0
- data/app/models/fluentd/setting/common.rb +185 -0
- data/app/models/fluentd/setting/in_syslog.rb +16 -0
- data/app/models/fluentd/setting/in_tail.rb +107 -0
- data/app/models/fluentd/setting/out_forward.rb +70 -0
- data/app/models/fluentd/setting/out_mongo.rb +35 -0
- data/app/models/fluentd/setting/out_s3.rb +29 -0
- data/app/models/fluentd/setting/out_td.rb +26 -0
- data/app/models/plugin.rb +193 -0
- data/app/models/settings.rb +4 -0
- data/app/models/user.rb +52 -0
- data/app/views/fluentd/_form.html.haml +31 -0
- data/app/views/fluentd/edit.html.haml +3 -0
- data/app/views/fluentd/errors.html.haml +19 -0
- data/app/views/fluentd/log.html.haml +9 -0
- data/app/views/fluentd/new.html.haml +3 -0
- data/app/views/fluentd/settings/_form.html.haml +43 -0
- data/app/views/fluentd/settings/edit.html.haml +7 -0
- data/app/views/fluentd/settings/in_syslog/_form.html.haml +9 -0
- data/app/views/fluentd/settings/in_syslog/show.html.haml +6 -0
- data/app/views/fluentd/settings/in_tail/_form.html.haml +42 -0
- data/app/views/fluentd/settings/in_tail/after_file_choose.html.haml +19 -0
- data/app/views/fluentd/settings/in_tail/after_format.html.haml +10 -0
- data/app/views/fluentd/settings/in_tail/confirm.html.haml +13 -0
- data/app/views/fluentd/settings/in_tail/show.html.haml +5 -0
- data/app/views/fluentd/settings/out_forward/_form.html.haml +22 -0
- data/app/views/fluentd/settings/out_forward/show.html.haml +6 -0
- data/app/views/fluentd/settings/out_mongo/_form.html.haml +30 -0
- data/app/views/fluentd/settings/out_mongo/finish.html.haml +4 -0
- data/app/views/fluentd/settings/out_mongo/show.html.haml +6 -0
- data/app/views/fluentd/settings/out_s3/_form.html.haml +39 -0
- data/app/views/fluentd/settings/out_s3/show.html.haml +6 -0
- data/app/views/fluentd/settings/out_td/_form.html.haml +18 -0
- data/app/views/fluentd/settings/out_td/show.html.haml +6 -0
- data/app/views/fluentd/settings/show.html.haml +10 -0
- data/app/views/fluentd/settings/source_and_output.html.haml +45 -0
- data/app/views/fluentd/show.html.haml +60 -0
- data/app/views/layouts/application.html.erb +102 -0
- data/app/views/layouts/sign_in.html.erb +28 -0
- data/app/views/misc/information.html.haml +75 -0
- data/app/views/misc/update_fluentd_ui.html.haml +45 -0
- data/app/views/plugins/installed.html.haml +67 -0
- data/app/views/plugins/recommended.html.haml +59 -0
- data/app/views/plugins/updated.html.haml +29 -0
- data/app/views/sessions/new.html.haml +13 -0
- data/app/views/shared/_error.html.haml +3 -0
- data/app/views/shared/_flash.html.haml +10 -0
- data/app/views/shared/_fluentd_nav.html.haml +12 -0
- data/app/views/shared/_global_nav.html.erb +80 -0
- data/app/views/shared/_initial_setup.html.haml +13 -0
- data/app/views/shared/_modal.html.erb +25 -0
- data/app/views/shared/_setting_errors.html.haml +5 -0
- data/app/views/shared/vue/_fluent_log.html.erb +25 -0
- data/app/views/shared/vue/_in_tail_format.html.erb +53 -0
- data/app/views/shared/vue/_treeview.html.erb +30 -0
- data/app/views/tutorials/chapter1.html.erb +31 -0
- data/app/views/tutorials/chapter2.html.haml +12 -0
- data/app/views/tutorials/chapter3.html.haml +12 -0
- data/app/views/tutorials/chapter4.html.haml +12 -0
- data/app/views/tutorials/chapter5.html.haml +10 -0
- data/app/views/tutorials/index.html.haml +26 -0
- data/app/views/users/show.html.haml +22 -0
- data/app/workers/all_plugin_check_update.rb +14 -0
- data/app/workers/fluentd_ui_restart.rb +41 -0
- data/app/workers/fluentd_ui_update_check.rb +15 -0
- data/app/workers/gem_installer.rb +17 -0
- data/app/workers/gem_uninstaller.rb +15 -0
- data/app/workers/gem_update_check.rb +10 -0
- data/bin/bundle +3 -0
- data/bin/fluentd-ui +13 -0
- data/bin/fluentd-ui-restart +12 -0
- data/bin/rails +8 -0
- data/bin/rake +8 -0
- data/bin/spring +18 -0
- data/bower.json +10 -0
- data/circle.yml +8 -0
- data/config.ru +4 -0
- data/config/application.rb +48 -0
- data/config/application.yml +211 -0
- data/config/boot.rb +4 -0
- data/config/environment.rb +5 -0
- data/config/environments/development.rb +36 -0
- data/config/environments/production.rb +69 -0
- data/config/environments/test.rb +40 -0
- data/config/initializers/backtrace_silencers.rb +7 -0
- data/config/initializers/cookies_serializer.rb +3 -0
- data/config/initializers/filter_parameter_logging.rb +4 -0
- data/config/initializers/inflections.rb +16 -0
- data/config/initializers/mime_types.rb +4 -0
- data/config/initializers/prefetch_gem_updates.rb +1 -0
- data/config/initializers/session_store.rb +3 -0
- data/config/initializers/wrap_parameters.rb +14 -0
- data/config/locales/en.yml +204 -0
- data/config/locales/ja.yml +194 -0
- data/config/locales/translation_en.yml +255 -0
- data/config/locales/translation_ja.yml +255 -0
- data/config/locales/tutorial_en.yml +117 -0
- data/config/locales/tutorial_ja.yml +120 -0
- data/config/routes.rb +93 -0
- data/config/secrets.yml +22 -0
- data/db/schema.rb +0 -0
- data/db/seeds.rb +11 -0
- data/fluentd-ui-ss01.png +0 -0
- data/fluentd-ui-ss02.png +0 -0
- data/fluentd-ui-ss03.png +0 -0
- data/fluentd-ui-ss04.png +0 -0
- data/fluentd-ui-ss05.png +0 -0
- data/fluentd-ui.gemspec +46 -0
- data/lib/assets/.keep +0 -0
- data/lib/file_reverse_reader.rb +56 -0
- data/lib/fluentd-ui.rb +22 -0
- data/lib/fluentd-ui/command.rb +52 -0
- data/lib/fluentd-ui/version.rb +3 -0
- data/lib/grok_converter.rb +39 -0
- data/lib/regexp_preview.rb +48 -0
- data/lib/tasks/.keep +0 -0
- data/lib/treeview.rb +45 -0
- data/log/.keep +0 -0
- data/public/404.html +67 -0
- data/public/422.html +67 -0
- data/public/500.html +66 -0
- data/public/favicon.ico +0 -0
- data/public/fluentd-logo-right-text.png +0 -0
- data/public/fluentd-logo.png +0 -0
- data/public/fluentd.png +0 -0
- data/public/robots.txt +5 -0
- data/spec/controllers/plugins_controller_spec.rb +5 -0
- data/spec/controllers/polling_controller_spec.rb +5 -0
- data/spec/controllers/sessions_controller_spec.rb +5 -0
- data/spec/controllers/tutorials_controller_spec.rb +5 -0
- data/spec/factories/fluentd.rb +11 -0
- data/spec/factories/plugins.rb +8 -0
- data/spec/factories/user.rb +6 -0
- data/spec/features/fluentd/setting/out_forward_spec.rb +45 -0
- data/spec/features/fluentd/setting/out_td_spec.rb +35 -0
- data/spec/features/sessions_spec.rb +55 -0
- data/spec/features/shared_examples/login_required.rb +4 -0
- data/spec/features/users_spec.rb +9 -0
- data/spec/grok_converter_spec.rb +50 -0
- data/spec/lib/file_reverse_reader_spec.rb +73 -0
- data/spec/lib/fluentd-ui_spec.rb +35 -0
- data/spec/models/fluentd/agent_spec.rb +91 -0
- data/spec/models/fluentd/setting/common_spec.rb +178 -0
- data/spec/models/fluentd/setting/in_syslog_spec.rb +35 -0
- data/spec/models/fluentd/setting/out_mongo_spec.rb +40 -0
- data/spec/models/fluentd/setting/out_td_spec.rb +38 -0
- data/spec/models/fluentd_spec.rb +166 -0
- data/spec/models/plugin_spec.rb +191 -0
- data/spec/models/user_spec.rb +15 -0
- data/spec/spec_helper.rb +58 -0
- data/spec/support/fixtures/error0.log +12 -0
- data/spec/support/fixtures/error2.log +130 -0
- data/spec/support/fluentd_agent_common_behavior.rb +114 -0
- data/spec/support/fluentd_agent_restart_strategy.rb +94 -0
- data/tmp/.gitkeep +0 -0
- data/vendor/assets/javascripts/.keep +0 -0
- data/vendor/assets/javascripts/bower/es6-promise/.bower.json +15 -0
- data/vendor/assets/javascripts/bower/es6-promise/bower.json +5 -0
- data/vendor/assets/javascripts/bower/es6-promise/promise.js +684 -0
- data/vendor/assets/javascripts/bower/es6-promise/promise.min.js +1 -0
- data/vendor/assets/javascripts/bower/lodash/.bower.json +33 -0
- data/vendor/assets/javascripts/bower/lodash/LICENSE.txt +22 -0
- data/vendor/assets/javascripts/bower/lodash/bower.json +23 -0
- data/vendor/assets/javascripts/bower/lodash/dist/lodash.compat.js +7157 -0
- data/vendor/assets/javascripts/bower/lodash/dist/lodash.compat.min.js +61 -0
- data/vendor/assets/javascripts/bower/lodash/dist/lodash.js +6785 -0
- data/vendor/assets/javascripts/bower/lodash/dist/lodash.min.js +56 -0
- data/vendor/assets/javascripts/bower/lodash/dist/lodash.underscore.js +4979 -0
- data/vendor/assets/javascripts/bower/lodash/dist/lodash.underscore.min.js +39 -0
- data/vendor/assets/javascripts/bower/vue/.bower.json +29 -0
- data/vendor/assets/javascripts/bower/vue/LICENSE +21 -0
- data/vendor/assets/javascripts/bower/vue/dist/vue.js +4713 -0
- data/vendor/assets/javascripts/bower/vue/dist/vue.min.js +7 -0
- data/vendor/assets/javascripts/bower/vue/src/batcher.js +45 -0
- data/vendor/assets/javascripts/bower/vue/src/binding.js +103 -0
- data/vendor/assets/javascripts/bower/vue/src/compiler.js +1037 -0
- data/vendor/assets/javascripts/bower/vue/src/config.js +19 -0
- data/vendor/assets/javascripts/bower/vue/src/deps-parser.js +65 -0
- data/vendor/assets/javascripts/bower/vue/src/directive.js +258 -0
- data/vendor/assets/javascripts/bower/vue/src/directives/html.js +41 -0
- data/vendor/assets/javascripts/bower/vue/src/directives/if.js +56 -0
- data/vendor/assets/javascripts/bower/vue/src/directives/index.js +129 -0
- data/vendor/assets/javascripts/bower/vue/src/directives/model.js +174 -0
- data/vendor/assets/javascripts/bower/vue/src/directives/on.js +56 -0
- data/vendor/assets/javascripts/bower/vue/src/directives/partial.js +50 -0
- data/vendor/assets/javascripts/bower/vue/src/directives/repeat.js +246 -0
- data/vendor/assets/javascripts/bower/vue/src/directives/style.js +40 -0
- data/vendor/assets/javascripts/bower/vue/src/directives/view.js +56 -0
- data/vendor/assets/javascripts/bower/vue/src/directives/with.js +50 -0
- data/vendor/assets/javascripts/bower/vue/src/emitter.js +97 -0
- data/vendor/assets/javascripts/bower/vue/src/exp-parser.js +190 -0
- data/vendor/assets/javascripts/bower/vue/src/filters.js +190 -0
- data/vendor/assets/javascripts/bower/vue/src/fragment.js +84 -0
- data/vendor/assets/javascripts/bower/vue/src/main.js +186 -0
- data/vendor/assets/javascripts/bower/vue/src/observer.js +446 -0
- data/vendor/assets/javascripts/bower/vue/src/text-parser.js +96 -0
- data/vendor/assets/javascripts/bower/vue/src/transition.js +228 -0
- data/vendor/assets/javascripts/bower/vue/src/utils.js +321 -0
- data/vendor/assets/javascripts/bower/vue/src/viewmodel.js +180 -0
- data/vendor/assets/javascripts/sb-admin-v2/bootstrap.js +1951 -0
- data/vendor/assets/javascripts/sb-admin-v2/bootstrap.min.js +6 -0
- data/vendor/assets/javascripts/sb-admin-v2/demo/dashboard-demo.js +117 -0
- data/vendor/assets/javascripts/sb-admin-v2/demo/flot-demo.js +1242 -0
- data/vendor/assets/javascripts/sb-admin-v2/demo/morris-demo.js +155 -0
- data/vendor/assets/javascripts/sb-admin-v2/jquery-1.10.2.js +6 -0
- data/vendor/assets/javascripts/sb-admin-v2/plugins/dataTables/dataTables.bootstrap.js +245 -0
- data/vendor/assets/javascripts/sb-admin-v2/plugins/dataTables/jquery.dataTables.js +14013 -0
- data/vendor/assets/javascripts/sb-admin-v2/plugins/flot/excanvas.min.js +1 -0
- data/vendor/assets/javascripts/sb-admin-v2/plugins/flot/jquery.flot.js +2599 -0
- data/vendor/assets/javascripts/sb-admin-v2/plugins/flot/jquery.flot.pie.js +750 -0
- data/vendor/assets/javascripts/sb-admin-v2/plugins/flot/jquery.flot.resize.js +60 -0
- data/vendor/assets/javascripts/sb-admin-v2/plugins/flot/jquery.flot.tooltip.min.js +12 -0
- data/vendor/assets/javascripts/sb-admin-v2/plugins/metisMenu/jquery.metisMenu.js +45 -0
- data/vendor/assets/javascripts/sb-admin-v2/plugins/morris/morris.js +1888 -0
- data/vendor/assets/javascripts/sb-admin-v2/plugins/morris/raphael-2.1.0.min.js +10 -0
- data/vendor/assets/javascripts/sb-admin-v2/sb-admin.js +18 -0
- data/vendor/assets/stylesheets/.keep +0 -0
- data/vendor/assets/stylesheets/sb-admin-v2/bootstrap.css +5830 -0
- data/vendor/assets/stylesheets/sb-admin-v2/bootstrap.min.css +7 -0
- data/vendor/assets/stylesheets/sb-admin-v2/font-awesome/css/font-awesome.css +1338 -0
- data/vendor/assets/stylesheets/sb-admin-v2/font-awesome/css/font-awesome.min.css +4 -0
- data/vendor/assets/stylesheets/sb-admin-v2/font-awesome/fonts/FontAwesome.otf +0 -0
- data/vendor/assets/stylesheets/sb-admin-v2/font-awesome/fonts/fontawesome-webfont.eot +0 -0
- data/vendor/assets/stylesheets/sb-admin-v2/font-awesome/fonts/fontawesome-webfont.svg +414 -0
- data/vendor/assets/stylesheets/sb-admin-v2/font-awesome/fonts/fontawesome-webfont.ttf +0 -0
- data/vendor/assets/stylesheets/sb-admin-v2/font-awesome/fonts/fontawesome-webfont.woff +0 -0
- data/vendor/assets/stylesheets/sb-admin-v2/font-awesome/scss/_bordered-pulled.scss +16 -0
- data/vendor/assets/stylesheets/sb-admin-v2/font-awesome/scss/_core.scss +12 -0
- data/vendor/assets/stylesheets/sb-admin-v2/font-awesome/scss/_fixed-width.scss +6 -0
- data/vendor/assets/stylesheets/sb-admin-v2/font-awesome/scss/_icons.scss +412 -0
- data/vendor/assets/stylesheets/sb-admin-v2/font-awesome/scss/_larger.scss +13 -0
- data/vendor/assets/stylesheets/sb-admin-v2/font-awesome/scss/_list.scss +19 -0
- data/vendor/assets/stylesheets/sb-admin-v2/font-awesome/scss/_mixins.scss +20 -0
- data/vendor/assets/stylesheets/sb-admin-v2/font-awesome/scss/_path.scss +14 -0
- data/vendor/assets/stylesheets/sb-admin-v2/font-awesome/scss/_rotated-flipped.scss +9 -0
- data/vendor/assets/stylesheets/sb-admin-v2/font-awesome/scss/_spinning.scss +30 -0
- data/vendor/assets/stylesheets/sb-admin-v2/font-awesome/scss/_stacked.scss +20 -0
- data/vendor/assets/stylesheets/sb-admin-v2/font-awesome/scss/_variables.scss +381 -0
- data/vendor/assets/stylesheets/sb-admin-v2/font-awesome/scss/font-awesome.scss +17 -0
- data/vendor/assets/stylesheets/sb-admin-v2/fonts/glyphicons-halflings-regular.eot +0 -0
- data/vendor/assets/stylesheets/sb-admin-v2/fonts/glyphicons-halflings-regular.svg +229 -0
- data/vendor/assets/stylesheets/sb-admin-v2/fonts/glyphicons-halflings-regular.ttf +0 -0
- data/vendor/assets/stylesheets/sb-admin-v2/fonts/glyphicons-halflings-regular.woff +0 -0
- data/vendor/assets/stylesheets/sb-admin-v2/plugins/dataTables/dataTables.bootstrap.css +233 -0
- data/vendor/assets/stylesheets/sb-admin-v2/plugins/morris/morris-0.4.3.min.css +2 -0
- data/vendor/assets/stylesheets/sb-admin-v2/plugins/social-buttons/social-buttons.css +68 -0
- data/vendor/assets/stylesheets/sb-admin-v2/plugins/timeline/timeline.css +144 -0
- data/vendor/assets/stylesheets/sb-admin-v2/sb-admin.css +329 -0
- data/vendor/patterns/firewalls +60 -0
- data/vendor/patterns/grok-patterns +94 -0
- data/vendor/patterns/haproxy +37 -0
- data/vendor/patterns/java +3 -0
- data/vendor/patterns/junos +9 -0
- data/vendor/patterns/linux-syslog +16 -0
- data/vendor/patterns/mcollective +1 -0
- data/vendor/patterns/mcollective-patterns +4 -0
- data/vendor/patterns/mongodb +4 -0
- data/vendor/patterns/nagios +108 -0
- data/vendor/patterns/postgresql +3 -0
- data/vendor/patterns/redis +3 -0
- data/vendor/patterns/ruby +2 -0
- metadata +659 -0
@@ -0,0 +1,191 @@
|
|
1
|
+
require 'spec_helper'
|
2
|
+
|
3
|
+
describe Plugin do
|
4
|
+
let(:plugin) { build(:plugin) }
|
5
|
+
|
6
|
+
describe ".installed" do
|
7
|
+
before { Plugin.stub(:"`").and_return(gem_list) }
|
8
|
+
|
9
|
+
context "fluent-plugin-foo 0.1.2" do
|
10
|
+
let(:target) { Plugin.new(gem_name: "fluent-plugin-foo", version: "0.1.2") }
|
11
|
+
let(:gem_list) { <<-GEM.strip_heredoc }
|
12
|
+
dummy (3.3.3)
|
13
|
+
fluent-plugin-foo (0.1.2)
|
14
|
+
more_dummy (0.0.1)
|
15
|
+
GEM
|
16
|
+
|
17
|
+
it "detect foo plugin" do
|
18
|
+
Plugin.installed.first.inspect.should == target.inspect
|
19
|
+
end
|
20
|
+
|
21
|
+
it "detected foo plugin is marked as installed" do
|
22
|
+
target.should be_installed
|
23
|
+
end
|
24
|
+
|
25
|
+
it "detected foo plugin version to be installed_version" do
|
26
|
+
target.installed_version.should == target.version
|
27
|
+
end
|
28
|
+
end
|
29
|
+
end
|
30
|
+
|
31
|
+
describe "#valid?" do
|
32
|
+
describe "gem_name" do
|
33
|
+
subject { plugin }
|
34
|
+
before { plugin.gem_name = gem_name }
|
35
|
+
|
36
|
+
context "nil is invalid" do
|
37
|
+
let(:gem_name) { nil }
|
38
|
+
it { should_not be_valid }
|
39
|
+
end
|
40
|
+
|
41
|
+
context "somthing filled is valid" do
|
42
|
+
let(:gem_name) { "foobar" }
|
43
|
+
it { should be_valid }
|
44
|
+
end
|
45
|
+
end
|
46
|
+
|
47
|
+
describe "version" do
|
48
|
+
subject { plugin }
|
49
|
+
before { plugin.version = version }
|
50
|
+
|
51
|
+
context "nil is invalid" do
|
52
|
+
let(:version) { nil }
|
53
|
+
it { should_not be_valid }
|
54
|
+
end
|
55
|
+
|
56
|
+
context "somthing filled is valid" do
|
57
|
+
let(:version) { "0.0.1" }
|
58
|
+
it { should be_valid }
|
59
|
+
end
|
60
|
+
end
|
61
|
+
end
|
62
|
+
|
63
|
+
describe "#install!" do
|
64
|
+
describe "invoke fluent_gem" do
|
65
|
+
after do
|
66
|
+
plugin.stub(:valid?).and_return(valid)
|
67
|
+
plugin.stub(:installed?).and_return(installed)
|
68
|
+
plugin.install!
|
69
|
+
end
|
70
|
+
|
71
|
+
context "valid" do
|
72
|
+
let(:valid) { true }
|
73
|
+
|
74
|
+
context "installed" do
|
75
|
+
let(:installed) { true }
|
76
|
+
it { plugin.should_not_receive(:fluent_gem) }
|
77
|
+
end
|
78
|
+
|
79
|
+
context "not installed" do
|
80
|
+
let(:installed) { false }
|
81
|
+
it { plugin.should_receive(:fluent_gem) }
|
82
|
+
end
|
83
|
+
end
|
84
|
+
|
85
|
+
context "invalid" do
|
86
|
+
let(:valid) { false }
|
87
|
+
|
88
|
+
context "installed" do
|
89
|
+
let(:installed) { true }
|
90
|
+
it { plugin.should_not_receive(:fluent_gem) }
|
91
|
+
end
|
92
|
+
|
93
|
+
context "not installed" do
|
94
|
+
let(:installed) { false }
|
95
|
+
it { plugin.should_not_receive(:fluent_gem) }
|
96
|
+
end
|
97
|
+
end
|
98
|
+
end
|
99
|
+
|
100
|
+
context "system command error" do
|
101
|
+
before { plugin.should_receive(:system).at_least(1).and_return(false) }
|
102
|
+
subject { expect { plugin.install! } }
|
103
|
+
|
104
|
+
it "raise GemError" do
|
105
|
+
subject.to raise_error(Plugin::GemError)
|
106
|
+
end
|
107
|
+
|
108
|
+
it "error message contains gem name" do
|
109
|
+
subject.to raise_error(/#{plugin.gem_name}/)
|
110
|
+
end
|
111
|
+
end
|
112
|
+
end
|
113
|
+
|
114
|
+
describe "#uninstall!" do
|
115
|
+
let(:installed_plugin) { build(:plugin, gem_name: "fluent-plugin-foobar") }
|
116
|
+
|
117
|
+
before do
|
118
|
+
installed_plugin.stub(:installed?).and_return(installed)
|
119
|
+
end
|
120
|
+
|
121
|
+
context "installed" do
|
122
|
+
let(:installed) { true }
|
123
|
+
before { installed_plugin.should_receive(:gem_uninstall) }
|
124
|
+
it { installed_plugin.uninstall! }
|
125
|
+
end
|
126
|
+
|
127
|
+
context "not installed" do
|
128
|
+
let(:installed) { false }
|
129
|
+
before { installed_plugin.should_not_receive(:gem_uninstall) }
|
130
|
+
it { installed_plugin.uninstall! }
|
131
|
+
end
|
132
|
+
end
|
133
|
+
|
134
|
+
describe "#upgrade!" do
|
135
|
+
let(:installed_plugin) { build(:plugin, gem_name: "fluent-plugin-foobar", version: current_version) }
|
136
|
+
let(:current_version) { "1.0.0" }
|
137
|
+
let(:target_version) { "1.2.0" }
|
138
|
+
|
139
|
+
before do
|
140
|
+
# NOTE: not `plugin.stub` because upgrade! creates new Plugin instance internally
|
141
|
+
installed_plugin.stub(:installed?).and_return(true)
|
142
|
+
Plugin.any_instance.stub(:fluent_gem).and_return(true)
|
143
|
+
|
144
|
+
installed_plugin.should_receive(:uninstall!)
|
145
|
+
Plugin.any_instance.should_receive(:install!)
|
146
|
+
end
|
147
|
+
|
148
|
+
it { installed_plugin.upgrade!(target_version) }
|
149
|
+
end
|
150
|
+
|
151
|
+
describe "#to_param" do
|
152
|
+
it { plugin.to_param.should == plugin.gem_name }
|
153
|
+
end
|
154
|
+
|
155
|
+
describe "Gem versions" do
|
156
|
+
let(:plugin) { build(:plugin, version: current_version) }
|
157
|
+
let(:current_version) { "1.0.0" }
|
158
|
+
let(:versions) { %w(1.0.1 0.99.1 1.0.0 0.99.0 0.1.0 0.0.3 0.0.2 0.0.1) }
|
159
|
+
let(:authors) { %w(foo bar) }
|
160
|
+
let(:json) do
|
161
|
+
versions.map do |ver|
|
162
|
+
{
|
163
|
+
number: ver,
|
164
|
+
summary: "summary of #{ver}",
|
165
|
+
authors: authors,
|
166
|
+
}
|
167
|
+
end.to_json
|
168
|
+
end
|
169
|
+
|
170
|
+
before do
|
171
|
+
stub_request(:get, plugin.gem_json_url).to_return(body: json)
|
172
|
+
end
|
173
|
+
|
174
|
+
it "latest version is 1.0.1" do
|
175
|
+
plugin.latest_version.should == "1.0.1"
|
176
|
+
end
|
177
|
+
it "1.0.0 is not latest" do
|
178
|
+
plugin.should_not be_latest_version
|
179
|
+
plugin.latest_version.should_not == plugin.version
|
180
|
+
end
|
181
|
+
it "released version is sorted" do
|
182
|
+
plugin.released_versions.should == versions.sort_by{|ver| Gem::Version.new(ver) }.reverse
|
183
|
+
end
|
184
|
+
it "authors" do
|
185
|
+
plugin.authors.should == authors
|
186
|
+
end
|
187
|
+
it "summary" do
|
188
|
+
plugin.summary.should == "summary of #{plugin.version}"
|
189
|
+
end
|
190
|
+
end
|
191
|
+
end
|
@@ -0,0 +1,15 @@
|
|
1
|
+
require 'spec_helper'
|
2
|
+
|
3
|
+
describe User do
|
4
|
+
let(:user) { build(:user) }
|
5
|
+
|
6
|
+
describe "#valid?" do
|
7
|
+
describe "password" do
|
8
|
+
it "password != password_confirmation is invalid" do
|
9
|
+
user.password = "a"
|
10
|
+
user.password_confirmation = "b"
|
11
|
+
user.should_not be_valid
|
12
|
+
end
|
13
|
+
end
|
14
|
+
end
|
15
|
+
end
|
data/spec/spec_helper.rb
ADDED
@@ -0,0 +1,58 @@
|
|
1
|
+
if ENV['RAILS_ENV'] == 'test'
|
2
|
+
require 'simplecov'
|
3
|
+
SimpleCov.start 'rails'
|
4
|
+
|
5
|
+
if ENV['CIRCLE_ARTIFACTS'] # https://circleci.com/docs/code-coverage
|
6
|
+
dir = File.join("..", "..", "..", ENV['CIRCLE_ARTIFACTS'], "coverage")
|
7
|
+
SimpleCov.coverage_dir(dir)
|
8
|
+
end
|
9
|
+
end
|
10
|
+
|
11
|
+
# This file is copied to spec/ when you run 'rails generate rspec:install'
|
12
|
+
ENV["RAILS_ENV"] ||= 'test'
|
13
|
+
require File.expand_path("../../config/environment", __FILE__)
|
14
|
+
require 'rspec/rails'
|
15
|
+
require 'webmock/rspec'
|
16
|
+
WebMock.disable_net_connect!(allow_localhost: true)
|
17
|
+
require 'capybara/poltergeist'
|
18
|
+
Capybara.javascript_driver = :poltergeist
|
19
|
+
|
20
|
+
# Requires supporting ruby files with custom matchers and macros, etc,
|
21
|
+
# in spec/support/ and its subdirectories.
|
22
|
+
Dir[Rails.root.join("spec/support/**/*.rb")].each { |f| require f }
|
23
|
+
Dir[Rails.root.join("spec/*/shared_examples/**/*.rb")].each { |f| require f }
|
24
|
+
|
25
|
+
RSpec.configure do |config|
|
26
|
+
# ## Mock Framework
|
27
|
+
#
|
28
|
+
# If you prefer to use mocha, flexmock or RR, uncomment the appropriate line:
|
29
|
+
#
|
30
|
+
# config.mock_with :mocha
|
31
|
+
# config.mock_with :flexmock
|
32
|
+
# config.mock_with :rr
|
33
|
+
|
34
|
+
# Syntax sugar to use the FactoryGirl methods directly instead FactoryGirl.create ete.
|
35
|
+
config.include FactoryGirl::Syntax::Methods
|
36
|
+
|
37
|
+
# If true, the base class of anonymous controllers will be inferred
|
38
|
+
# automatically. This will be the default behavior in future versions of
|
39
|
+
# rspec-rails.
|
40
|
+
config.infer_base_class_for_anonymous_controllers = false
|
41
|
+
|
42
|
+
# Run specs in random order to surface order dependencies. If you find an
|
43
|
+
# order dependency and want to debug it, you can fix the order by providing
|
44
|
+
# the seed, which is printed after each run.
|
45
|
+
# --seed 1234
|
46
|
+
config.order = "random"
|
47
|
+
|
48
|
+
# allow `should`
|
49
|
+
config.expect_with :rspec do |c|
|
50
|
+
c.syntax = [:should, :expect]
|
51
|
+
end
|
52
|
+
config.mock_with :rspec do |c|
|
53
|
+
c.syntax = [:should, :expect]
|
54
|
+
end
|
55
|
+
|
56
|
+
# rspec 2.99
|
57
|
+
config.infer_spec_type_from_file_location!
|
58
|
+
end
|
@@ -0,0 +1,130 @@
|
|
1
|
+
2014-05-27 10:54:37 +0900 [info]: starting fluentd-0.10.48
|
2
|
+
2014-05-27 10:54:37 +0900 [info]: reading config file path="/tmp/2.conf"
|
3
|
+
2014-05-27 10:54:37 +0900 [info]: gem 'fluentd' version '0.10.48'
|
4
|
+
2014-05-27 10:54:37 +0900 [info]: using configuration file: <ROOT>
|
5
|
+
<source>
|
6
|
+
type forward
|
7
|
+
port 24224
|
8
|
+
</source>
|
9
|
+
<source>
|
10
|
+
type monitor_agent
|
11
|
+
port 24220
|
12
|
+
</source>
|
13
|
+
<source>
|
14
|
+
type http
|
15
|
+
port 9880
|
16
|
+
</source>
|
17
|
+
<source>
|
18
|
+
type debug_agent
|
19
|
+
port 24230
|
20
|
+
</source>
|
21
|
+
</ROOT>
|
22
|
+
2014-05-27 10:54:37 +0900 [info]: adding source type="forward"
|
23
|
+
2014-05-27 10:54:37 +0900 [info]: adding source type="monitor_agent"
|
24
|
+
2014-05-27 10:54:37 +0900 [info]: adding source type="http"
|
25
|
+
2014-05-27 10:54:37 +0900 [info]: adding source type="debug_agent"
|
26
|
+
2014-05-27 10:54:37 +0900 [info]: listening fluent socket on 0.0.0.0:24224
|
27
|
+
2014-05-27 10:54:37 +0900 [error]: unexpected error error_class=Errno::EADDRINUSE error=#<Errno::EADDRINUSE: Address already in use - bind(2) for "0.0.0.0" port 24224>
|
28
|
+
2014-05-27 10:54:37 +0900 [error]: /Users/uu59/.rbenv/versions/2.1.0/lib/ruby/gems/2.1.0/gems/cool.io-1.2.4/lib/cool.io/server.rb:57:in `initialize'
|
29
|
+
2014-05-27 10:54:37 +0900 [error]: /Users/uu59/.rbenv/versions/2.1.0/lib/ruby/gems/2.1.0/gems/cool.io-1.2.4/lib/cool.io/server.rb:57:in `new'
|
30
|
+
2014-05-27 10:54:37 +0900 [error]: /Users/uu59/.rbenv/versions/2.1.0/lib/ruby/gems/2.1.0/gems/cool.io-1.2.4/lib/cool.io/server.rb:57:in `initialize'
|
31
|
+
2014-05-27 10:54:37 +0900 [error]: /Users/uu59/.rbenv/versions/2.1.0/lib/ruby/gems/2.1.0/gems/fluentd-0.10.48/lib/fluent/plugin/in_forward.rb:76:in `new'
|
32
|
+
2014-05-27 10:54:37 +0900 [error]: /Users/uu59/.rbenv/versions/2.1.0/lib/ruby/gems/2.1.0/gems/fluentd-0.10.48/lib/fluent/plugin/in_forward.rb:76:in `listen'
|
33
|
+
2014-05-27 10:54:37 +0900 [error]: /Users/uu59/.rbenv/versions/2.1.0/lib/ruby/gems/2.1.0/gems/fluentd-0.10.48/lib/fluent/plugin/in_forward.rb:47:in `start'
|
34
|
+
2014-05-27 10:54:37 +0900 [error]: /Users/uu59/.rbenv/versions/2.1.0/lib/ruby/gems/2.1.0/gems/fluentd-0.10.48/lib/fluent/engine.rb:260:in `block in start'
|
35
|
+
2014-05-27 10:54:37 +0900 [error]: /Users/uu59/.rbenv/versions/2.1.0/lib/ruby/gems/2.1.0/gems/fluentd-0.10.48/lib/fluent/engine.rb:259:in `each'
|
36
|
+
2014-05-27 10:54:37 +0900 [error]: /Users/uu59/.rbenv/versions/2.1.0/lib/ruby/gems/2.1.0/gems/fluentd-0.10.48/lib/fluent/engine.rb:259:in `start'
|
37
|
+
2014-05-27 10:54:37 +0900 [error]: /Users/uu59/.rbenv/versions/2.1.0/lib/ruby/gems/2.1.0/gems/fluentd-0.10.48/lib/fluent/engine.rb:206:in `run'
|
38
|
+
2014-05-27 10:54:37 +0900 [error]: /Users/uu59/.rbenv/versions/2.1.0/lib/ruby/gems/2.1.0/gems/fluentd-0.10.48/lib/fluent/supervisor.rb:417:in `run_engine'
|
39
|
+
2014-05-27 10:54:37 +0900 [error]: /Users/uu59/.rbenv/versions/2.1.0/lib/ruby/gems/2.1.0/gems/fluentd-0.10.48/lib/fluent/supervisor.rb:116:in `block in start'
|
40
|
+
2014-05-27 10:54:37 +0900 [error]: /Users/uu59/.rbenv/versions/2.1.0/lib/ruby/gems/2.1.0/gems/fluentd-0.10.48/lib/fluent/supervisor.rb:229:in `call'
|
41
|
+
2014-05-27 10:54:37 +0900 [error]: /Users/uu59/.rbenv/versions/2.1.0/lib/ruby/gems/2.1.0/gems/fluentd-0.10.48/lib/fluent/supervisor.rb:229:in `main_process'
|
42
|
+
2014-05-27 10:54:37 +0900 [error]: /Users/uu59/.rbenv/versions/2.1.0/lib/ruby/gems/2.1.0/gems/fluentd-0.10.48/lib/fluent/supervisor.rb:204:in `block in supervise'
|
43
|
+
2014-05-27 10:54:37 +0900 [error]: /Users/uu59/.rbenv/versions/2.1.0/lib/ruby/gems/2.1.0/gems/fluentd-0.10.48/lib/fluent/supervisor.rb:203:in `fork'
|
44
|
+
2014-05-27 10:54:37 +0900 [error]: /Users/uu59/.rbenv/versions/2.1.0/lib/ruby/gems/2.1.0/gems/fluentd-0.10.48/lib/fluent/supervisor.rb:203:in `supervise'
|
45
|
+
2014-05-27 10:54:37 +0900 [error]: /Users/uu59/.rbenv/versions/2.1.0/lib/ruby/gems/2.1.0/gems/fluentd-0.10.48/lib/fluent/supervisor.rb:109:in `start'
|
46
|
+
2014-05-27 10:54:37 +0900 [error]: /Users/uu59/.rbenv/versions/2.1.0/lib/ruby/gems/2.1.0/gems/fluentd-0.10.48/lib/fluent/command/fluentd.rb:160:in `<top (required)>'
|
47
|
+
2014-05-27 10:54:37 +0900 [error]: /Users/uu59/.rbenv/versions/2.1.0/lib/ruby/gems/2.1.0/gems/fluentd-0.10.48/bin/fluentd:6:in `require'
|
48
|
+
2014-05-27 10:54:37 +0900 [error]: /Users/uu59/.rbenv/versions/2.1.0/lib/ruby/gems/2.1.0/gems/fluentd-0.10.48/bin/fluentd:6:in `<top (required)>'
|
49
|
+
2014-05-27 10:54:37 +0900 [error]: /Users/uu59/.rbenv/versions/2.1.0/lib/ruby/gems/2.1.0/bin/fluentd:23:in `load'
|
50
|
+
2014-05-27 10:54:37 +0900 [error]: /Users/uu59/.rbenv/versions/2.1.0/lib/ruby/gems/2.1.0/bin/fluentd:23:in `<main>'
|
51
|
+
2014-05-27 10:54:37 +0900 [info]: shutting down fluentd
|
52
|
+
2014-05-27 10:54:37 +0900 [info]: process finished code=0
|
53
|
+
2014-05-27 10:54:37 +0900 [warn]: process died within 1 second. exit.
|
54
|
+
2014-05-27 11:28:10 +0900 [info]: reading config file path="/tmp/2.conf"
|
55
|
+
2014-05-27 11:28:10 +0900 [info]: gem 'fluentd' version '0.10.48'
|
56
|
+
2014-05-27 11:28:10 +0900 [info]: using configuration file: <ROOT>
|
57
|
+
<source>
|
58
|
+
type forward
|
59
|
+
port 24224
|
60
|
+
</source>
|
61
|
+
<source>
|
62
|
+
type monitor_agent
|
63
|
+
port 24220
|
64
|
+
</source>
|
65
|
+
<source>
|
66
|
+
type http
|
67
|
+
port 9880
|
68
|
+
</source>
|
69
|
+
<source>
|
70
|
+
type debug_agent
|
71
|
+
port 24230
|
72
|
+
</source>
|
73
|
+
</ROOT>
|
74
|
+
2014-05-27 11:28:10 +0900 [info]: adding source type="forward"
|
75
|
+
2014-05-27 11:28:10 +0900 [info]: adding source type="monitor_agent"
|
76
|
+
2014-05-27 11:28:10 +0900 [info]: adding source type="http"
|
77
|
+
2014-05-27 11:28:10 +0900 [info]: adding source type="debug_agent"
|
78
|
+
2014-05-27 11:28:12 +0900 [info]: starting fluentd-0.10.48
|
79
|
+
2014-05-27 11:28:12 +0900 [info]: reading config file path="/tmp/2.conf"
|
80
|
+
2014-05-27 11:28:12 +0900 [info]: gem 'fluentd' version '0.10.48'
|
81
|
+
2014-05-27 11:28:12 +0900 [info]: using configuration file: <ROOT>
|
82
|
+
<source>
|
83
|
+
type forward
|
84
|
+
port 24224
|
85
|
+
</source>
|
86
|
+
<source>
|
87
|
+
type monitor_agent
|
88
|
+
port 24220
|
89
|
+
</source>
|
90
|
+
<source>
|
91
|
+
type http
|
92
|
+
port 9880
|
93
|
+
</source>
|
94
|
+
<source>
|
95
|
+
type debug_agent
|
96
|
+
port 24230
|
97
|
+
</source>
|
98
|
+
</ROOT>
|
99
|
+
2014-05-27 11:28:12 +0900 [info]: adding source type="forward"
|
100
|
+
2014-05-27 11:28:12 +0900 [info]: adding source type="monitor_agent"
|
101
|
+
2014-05-27 11:28:12 +0900 [info]: adding source type="http"
|
102
|
+
2014-05-27 11:28:12 +0900 [info]: adding source type="debug_agent"
|
103
|
+
2014-05-27 11:28:12 +0900 [info]: listening fluent socket on 0.0.0.0:24224
|
104
|
+
2014-05-27 11:28:12 +0900 [error]: unexpected error error_class=Errno::EADDRINUSE error=#<Errno::EADDRINUSE: Address already in use - bind(2) for "0.0.0.0" port 24224>
|
105
|
+
2014-05-27 11:28:12 +0900 [error]: /Users/uu59/.rbenv/versions/2.1.0/lib/ruby/gems/2.1.0/gems/cool.io-1.2.4/lib/cool.io/server.rb:57:in `initialize'
|
106
|
+
2014-05-27 11:28:12 +0900 [error]: /Users/uu59/.rbenv/versions/2.1.0/lib/ruby/gems/2.1.0/gems/cool.io-1.2.4/lib/cool.io/server.rb:57:in `new'
|
107
|
+
2014-05-27 11:28:12 +0900 [error]: /Users/uu59/.rbenv/versions/2.1.0/lib/ruby/gems/2.1.0/gems/cool.io-1.2.4/lib/cool.io/server.rb:57:in `initialize'
|
108
|
+
2014-05-27 11:28:12 +0900 [error]: /Users/uu59/.rbenv/versions/2.1.0/lib/ruby/gems/2.1.0/gems/fluentd-0.10.48/lib/fluent/plugin/in_forward.rb:76:in `new'
|
109
|
+
2014-05-27 11:28:12 +0900 [error]: /Users/uu59/.rbenv/versions/2.1.0/lib/ruby/gems/2.1.0/gems/fluentd-0.10.48/lib/fluent/plugin/in_forward.rb:76:in `listen'
|
110
|
+
2014-05-27 11:28:12 +0900 [error]: /Users/uu59/.rbenv/versions/2.1.0/lib/ruby/gems/2.1.0/gems/fluentd-0.10.48/lib/fluent/plugin/in_forward.rb:47:in `start'
|
111
|
+
2014-05-27 11:28:12 +0900 [error]: /Users/uu59/.rbenv/versions/2.1.0/lib/ruby/gems/2.1.0/gems/fluentd-0.10.48/lib/fluent/engine.rb:260:in `block in start'
|
112
|
+
2014-05-27 11:28:12 +0900 [error]: /Users/uu59/.rbenv/versions/2.1.0/lib/ruby/gems/2.1.0/gems/fluentd-0.10.48/lib/fluent/engine.rb:259:in `each'
|
113
|
+
2014-05-27 11:28:12 +0900 [error]: /Users/uu59/.rbenv/versions/2.1.0/lib/ruby/gems/2.1.0/gems/fluentd-0.10.48/lib/fluent/engine.rb:259:in `start'
|
114
|
+
2014-05-27 11:28:12 +0900 [error]: /Users/uu59/.rbenv/versions/2.1.0/lib/ruby/gems/2.1.0/gems/fluentd-0.10.48/lib/fluent/engine.rb:206:in `run'
|
115
|
+
2014-05-27 11:28:12 +0900 [error]: /Users/uu59/.rbenv/versions/2.1.0/lib/ruby/gems/2.1.0/gems/fluentd-0.10.48/lib/fluent/supervisor.rb:417:in `run_engine'
|
116
|
+
2014-05-27 11:28:12 +0900 [error]: /Users/uu59/.rbenv/versions/2.1.0/lib/ruby/gems/2.1.0/gems/fluentd-0.10.48/lib/fluent/supervisor.rb:116:in `block in start'
|
117
|
+
2014-05-27 11:28:12 +0900 [error]: /Users/uu59/.rbenv/versions/2.1.0/lib/ruby/gems/2.1.0/gems/fluentd-0.10.48/lib/fluent/supervisor.rb:229:in `call'
|
118
|
+
2014-05-27 11:28:12 +0900 [error]: /Users/uu59/.rbenv/versions/2.1.0/lib/ruby/gems/2.1.0/gems/fluentd-0.10.48/lib/fluent/supervisor.rb:229:in `main_process'
|
119
|
+
2014-05-27 11:28:12 +0900 [error]: /Users/uu59/.rbenv/versions/2.1.0/lib/ruby/gems/2.1.0/gems/fluentd-0.10.48/lib/fluent/supervisor.rb:204:in `block in supervise'
|
120
|
+
2014-05-27 11:28:12 +0900 [error]: /Users/uu59/.rbenv/versions/2.1.0/lib/ruby/gems/2.1.0/gems/fluentd-0.10.48/lib/fluent/supervisor.rb:203:in `fork'
|
121
|
+
2014-05-27 11:28:12 +0900 [error]: /Users/uu59/.rbenv/versions/2.1.0/lib/ruby/gems/2.1.0/gems/fluentd-0.10.48/lib/fluent/supervisor.rb:203:in `supervise'
|
122
|
+
2014-05-27 11:28:12 +0900 [error]: /Users/uu59/.rbenv/versions/2.1.0/lib/ruby/gems/2.1.0/gems/fluentd-0.10.48/lib/fluent/supervisor.rb:109:in `start'
|
123
|
+
2014-05-27 11:28:12 +0900 [error]: /Users/uu59/.rbenv/versions/2.1.0/lib/ruby/gems/2.1.0/gems/fluentd-0.10.48/lib/fluent/command/fluentd.rb:160:in `<top (required)>'
|
124
|
+
2014-05-27 11:28:12 +0900 [error]: /Users/uu59/.rbenv/versions/2.1.0/lib/ruby/gems/2.1.0/gems/fluentd-0.10.48/bin/fluentd:6:in `require'
|
125
|
+
2014-05-27 11:28:12 +0900 [error]: /Users/uu59/.rbenv/versions/2.1.0/lib/ruby/gems/2.1.0/gems/fluentd-0.10.48/bin/fluentd:6:in `<top (required)>'
|
126
|
+
2014-05-27 11:28:12 +0900 [error]: /Users/uu59/.rbenv/versions/2.1.0/lib/ruby/gems/2.1.0/bin/fluentd:23:in `load'
|
127
|
+
2014-05-27 11:28:12 +0900 [error]: /Users/uu59/.rbenv/versions/2.1.0/lib/ruby/gems/2.1.0/bin/fluentd:23:in `<main>'
|
128
|
+
2014-05-27 11:28:12 +0900 [info]: shutting down fluentd
|
129
|
+
2014-05-27 11:28:12 +0900 [info]: process finished code=0
|
130
|
+
2014-05-27 11:28:12 +0900 [warn]: process died within 1 second. exit.
|
@@ -0,0 +1,114 @@
|
|
1
|
+
shared_examples_for "Fluentd::Agent has common behavior" do |klass|
|
2
|
+
describe "#extra_options" do
|
3
|
+
context "blank" do
|
4
|
+
let(:options) { {} }
|
5
|
+
it { instance.pid_file.should == described_class.default_options[:pid_file] }
|
6
|
+
it { instance.log_file.should == described_class.default_options[:log_file] }
|
7
|
+
it { instance.config_file.should == described_class.default_options[:config_file] }
|
8
|
+
end
|
9
|
+
|
10
|
+
context "given" do
|
11
|
+
let(:options) do
|
12
|
+
{
|
13
|
+
:pid_file => pid_file,
|
14
|
+
:log_file => log_file,
|
15
|
+
:config_file => config_file,
|
16
|
+
}
|
17
|
+
end
|
18
|
+
let(:pid_file) { "pid" }
|
19
|
+
let(:log_file) { "log" }
|
20
|
+
let(:config_file) { "config" }
|
21
|
+
|
22
|
+
it { instance.pid_file.should == pid_file }
|
23
|
+
it { instance.log_file.should == log_file }
|
24
|
+
it { instance.config_file.should == config_file }
|
25
|
+
end
|
26
|
+
end
|
27
|
+
|
28
|
+
describe "#logged_errors" do
|
29
|
+
before { instance.stub(:log_file).and_return(logfile) }
|
30
|
+
|
31
|
+
describe "#errors_since" do
|
32
|
+
let(:logged_time) { Time.parse('2014-05-27') }
|
33
|
+
let(:now) { Time.parse('2014-05-29') }
|
34
|
+
|
35
|
+
before { Timecop.freeze(now) }
|
36
|
+
after { Timecop.return }
|
37
|
+
|
38
|
+
subject { instance.errors_since(days.days.ago) }
|
39
|
+
|
40
|
+
context "has no errors" do
|
41
|
+
let(:logfile) { File.expand_path("./spec/support/fixtures/error0.log", Rails.root) }
|
42
|
+
let(:days) { 100 }
|
43
|
+
|
44
|
+
it "empty array" do
|
45
|
+
should be_empty
|
46
|
+
end
|
47
|
+
end
|
48
|
+
|
49
|
+
context "has errors" do
|
50
|
+
let(:logfile) { File.expand_path("./spec/support/fixtures/error2.log", Rails.root) }
|
51
|
+
|
52
|
+
context "unreachable since" do
|
53
|
+
let(:days) { 0 }
|
54
|
+
it { should be_empty }
|
55
|
+
end
|
56
|
+
|
57
|
+
context "reachable since" do
|
58
|
+
let(:days) { 100 }
|
59
|
+
|
60
|
+
it "contain stack trace" do
|
61
|
+
subject[0][:subject].should include("Address already in use - bind(2)")
|
62
|
+
end
|
63
|
+
|
64
|
+
it "newer(bottom) is first" do
|
65
|
+
one = Time.parse(subject[0][:subject])
|
66
|
+
two = Time.parse(subject[1][:subject])
|
67
|
+
one.should >= two
|
68
|
+
end
|
69
|
+
end
|
70
|
+
end
|
71
|
+
end
|
72
|
+
|
73
|
+
describe "#recent_errors" do
|
74
|
+
context "have 0 error log" do
|
75
|
+
let(:logfile) { File.expand_path("./spec/support/fixtures/error0.log", Rails.root) }
|
76
|
+
subject { instance.recent_errors(2) }
|
77
|
+
|
78
|
+
it "empty array" do
|
79
|
+
should be_empty
|
80
|
+
end
|
81
|
+
end
|
82
|
+
|
83
|
+
context "have 2 error log" do
|
84
|
+
let(:logfile) { File.expand_path("./spec/support/fixtures/error2.log", Rails.root) }
|
85
|
+
subject { instance.recent_errors(2) }
|
86
|
+
|
87
|
+
describe "limit" do
|
88
|
+
subject { instance.recent_errors(limit).length }
|
89
|
+
|
90
|
+
context "=1" do
|
91
|
+
let(:limit) { 1 }
|
92
|
+
it { should == limit }
|
93
|
+
end
|
94
|
+
|
95
|
+
context "=2" do
|
96
|
+
let(:limit) { 2 }
|
97
|
+
it { should == limit }
|
98
|
+
end
|
99
|
+
end
|
100
|
+
|
101
|
+
it "contain stack trace" do
|
102
|
+
subject[0][:subject].should include("Address already in use - bind(2)")
|
103
|
+
end
|
104
|
+
|
105
|
+
it "newer(bottom) is first" do
|
106
|
+
one = Time.parse(subject[0][:subject])
|
107
|
+
two = Time.parse(subject[1][:subject])
|
108
|
+
one.should >= two
|
109
|
+
end
|
110
|
+
end
|
111
|
+
end
|
112
|
+
end
|
113
|
+
end
|
114
|
+
|