rails_stdout_logging 0.0.1 → 0.0.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (54) hide show
  1. checksums.yaml +4 -4
  2. data/.gitignore +2 -0
  3. data/.travis.yml +10 -0
  4. data/Appraisals +15 -0
  5. data/Gemfile +9 -0
  6. data/README.md +59 -2
  7. data/Rakefile +27 -0
  8. data/gemfiles/rails_3.0.x.gemfile +13 -0
  9. data/gemfiles/rails_3.1.x.gemfile +13 -0
  10. data/gemfiles/rails_3.2.x.gemfile +13 -0
  11. data/gemfiles/rails_4.0.x.gemfile +13 -0
  12. data/lib/rails_stdout_logging.rb +0 -2
  13. data/lib/rails_stdout_logging/rails.rb +2 -3
  14. data/lib/rails_stdout_logging/railtie.rb +1 -1
  15. data/lib/rails_stdout_logging/version.rb +1 -1
  16. data/{rails_log_stdout.gemspec → rails_stdout_logging.gemspec} +1 -0
  17. data/test/dummy/Rakefile +7 -0
  18. data/test/dummy/app/controllers/application_controller.rb +3 -0
  19. data/test/dummy/app/controllers/bar_controller.rb +12 -0
  20. data/test/dummy/app/helpers/application_helper.rb +2 -0
  21. data/test/dummy/app/views/bar/index.html.erb +1 -0
  22. data/test/dummy/config.ru +4 -0
  23. data/test/dummy/config/application.rb +45 -0
  24. data/test/dummy/config/boot.rb +10 -0
  25. data/test/dummy/config/database.yml +22 -0
  26. data/test/dummy/config/environment.rb +5 -0
  27. data/test/dummy/config/environments/development.rb +26 -0
  28. data/test/dummy/config/environments/production.rb +49 -0
  29. data/test/dummy/config/environments/test.rb +35 -0
  30. data/test/dummy/config/initializers/backtrace_silencers.rb +7 -0
  31. data/test/dummy/config/initializers/inflections.rb +10 -0
  32. data/test/dummy/config/initializers/mime_types.rb +5 -0
  33. data/test/dummy/config/initializers/secret_token.rb +7 -0
  34. data/test/dummy/config/initializers/session_store.rb +8 -0
  35. data/test/dummy/config/locales/en.yml +9 -0
  36. data/test/dummy/config/locales/es.yml +10 -0
  37. data/test/dummy/config/routes.rb +60 -0
  38. data/test/dummy/public/404.html +26 -0
  39. data/test/dummy/public/422.html +26 -0
  40. data/test/dummy/public/500.html +26 -0
  41. data/test/dummy/public/favicon.ico +0 -0
  42. data/test/dummy/public/javascripts/application.js +2 -0
  43. data/test/dummy/public/javascripts/controls.js +965 -0
  44. data/test/dummy/public/javascripts/dragdrop.js +974 -0
  45. data/test/dummy/public/javascripts/effects.js +1123 -0
  46. data/test/dummy/public/javascripts/prototype.js +6001 -0
  47. data/test/dummy/public/javascripts/rails.js +202 -0
  48. data/test/dummy/public/stylesheets/.gitkeep +0 -0
  49. data/test/dummy/script/rails +6 -0
  50. data/test/integration/controller_logging_test.rb +9 -0
  51. data/test/rails_stdout_logging_test.rb +20 -0
  52. data/test/support/integration_case.rb +6 -0
  53. data/test/test_helper.rb +36 -0
  54. metadata +87 -6
@@ -0,0 +1,202 @@
1
+ (function() {
2
+ Ajax.Responders.register({
3
+ onCreate: function(request) {
4
+ var token = $$('meta[name=csrf-token]')[0];
5
+ if (token) {
6
+ if (!request.options.requestHeaders) request.options.requestHeaders = {};
7
+ request.options.requestHeaders['X-CSRF-Token'] = token.readAttribute('content');
8
+ }
9
+ }
10
+ });
11
+
12
+ // Technique from Juriy Zaytsev
13
+ // http://thinkweb2.com/projects/prototype/detecting-event-support-without-browser-sniffing/
14
+ function isEventSupported(eventName) {
15
+ var el = document.createElement('div');
16
+ eventName = 'on' + eventName;
17
+ var isSupported = (eventName in el);
18
+ if (!isSupported) {
19
+ el.setAttribute(eventName, 'return;');
20
+ isSupported = typeof el[eventName] == 'function';
21
+ }
22
+ el = null;
23
+ return isSupported;
24
+ }
25
+
26
+ function isForm(element) {
27
+ return Object.isElement(element) && element.nodeName.toUpperCase() == 'FORM';
28
+ }
29
+
30
+ function isInput(element) {
31
+ if (Object.isElement(element)) {
32
+ var name = element.nodeName.toUpperCase();
33
+ return name == 'INPUT' || name == 'SELECT' || name == 'TEXTAREA';
34
+ }
35
+ else return false;
36
+ }
37
+
38
+ var submitBubbles = isEventSupported('submit'),
39
+ changeBubbles = isEventSupported('change');
40
+
41
+ if (!submitBubbles || !changeBubbles) {
42
+ // augment the Event.Handler class to observe custom events when needed
43
+ Event.Handler.prototype.initialize = Event.Handler.prototype.initialize.wrap(
44
+ function(init, element, eventName, selector, callback) {
45
+ init(element, eventName, selector, callback);
46
+ // is the handler being attached to an element that doesn't support this event?
47
+ if ( (!submitBubbles && this.eventName == 'submit' && !isForm(this.element)) ||
48
+ (!changeBubbles && this.eventName == 'change' && !isInput(this.element)) ) {
49
+ // "submit" => "emulated:submit"
50
+ this.eventName = 'emulated:' + this.eventName;
51
+ }
52
+ }
53
+ );
54
+ }
55
+
56
+ if (!submitBubbles) {
57
+ // discover forms on the page by observing focus events which always bubble
58
+ document.on('focusin', 'form', function(focusEvent, form) {
59
+ // special handler for the real "submit" event (one-time operation)
60
+ if (!form.retrieve('emulated:submit')) {
61
+ form.on('submit', function(submitEvent) {
62
+ var emulated = form.fire('emulated:submit', submitEvent, true);
63
+ // if custom event received preventDefault, cancel the real one too
64
+ if (emulated.returnValue === false) submitEvent.preventDefault();
65
+ });
66
+ form.store('emulated:submit', true);
67
+ }
68
+ });
69
+ }
70
+
71
+ if (!changeBubbles) {
72
+ // discover form inputs on the page
73
+ document.on('focusin', 'input, select, textarea', function(focusEvent, input) {
74
+ // special handler for real "change" events
75
+ if (!input.retrieve('emulated:change')) {
76
+ input.on('change', function(changeEvent) {
77
+ input.fire('emulated:change', changeEvent, true);
78
+ });
79
+ input.store('emulated:change', true);
80
+ }
81
+ });
82
+ }
83
+
84
+ function handleRemote(element) {
85
+ var method, url, params;
86
+
87
+ var event = element.fire("ajax:before");
88
+ if (event.stopped) return false;
89
+
90
+ if (element.tagName.toLowerCase() === 'form') {
91
+ method = element.readAttribute('method') || 'post';
92
+ url = element.readAttribute('action');
93
+ // serialize the form with respect to the submit button that was pressed
94
+ params = element.serialize({ submit: element.retrieve('rails:submit-button') });
95
+ // clear the pressed submit button information
96
+ element.store('rails:submit-button', null);
97
+ } else {
98
+ method = element.readAttribute('data-method') || 'get';
99
+ url = element.readAttribute('href');
100
+ params = {};
101
+ }
102
+
103
+ new Ajax.Request(url, {
104
+ method: method,
105
+ parameters: params,
106
+ evalScripts: true,
107
+
108
+ onCreate: function(response) { element.fire("ajax:create", response); },
109
+ onComplete: function(response) { element.fire("ajax:complete", response); },
110
+ onSuccess: function(response) { element.fire("ajax:success", response); },
111
+ onFailure: function(response) { element.fire("ajax:failure", response); }
112
+ });
113
+
114
+ element.fire("ajax:after");
115
+ }
116
+
117
+ function insertHiddenField(form, name, value) {
118
+ form.insert(new Element('input', { type: 'hidden', name: name, value: value }));
119
+ }
120
+
121
+ function handleMethod(element) {
122
+ var method = element.readAttribute('data-method'),
123
+ url = element.readAttribute('href'),
124
+ csrf_param = $$('meta[name=csrf-param]')[0],
125
+ csrf_token = $$('meta[name=csrf-token]')[0];
126
+
127
+ var form = new Element('form', { method: "POST", action: url, style: "display: none;" });
128
+ $(element.parentNode).insert(form);
129
+
130
+ if (method !== 'post') {
131
+ insertHiddenField(form, '_method', method);
132
+ }
133
+
134
+ if (csrf_param) {
135
+ insertHiddenField(form, csrf_param.readAttribute('content'), csrf_token.readAttribute('content'));
136
+ }
137
+
138
+ form.submit();
139
+ }
140
+
141
+ function disableFormElements(form) {
142
+ form.select('input[type=submit][data-disable-with]').each(function(input) {
143
+ input.store('rails:original-value', input.getValue());
144
+ input.setValue(input.readAttribute('data-disable-with')).disable();
145
+ });
146
+ }
147
+
148
+ function enableFormElements(form) {
149
+ form.select('input[type=submit][data-disable-with]').each(function(input) {
150
+ input.setValue(input.retrieve('rails:original-value')).enable();
151
+ });
152
+ }
153
+
154
+ function allowAction(element) {
155
+ var message = element.readAttribute('data-confirm');
156
+ return !message || confirm(message);
157
+ }
158
+
159
+ document.on('click', 'a[data-confirm], a[data-remote], a[data-method]', function(event, link) {
160
+ if (!allowAction(link)) {
161
+ event.stop();
162
+ return false;
163
+ }
164
+
165
+ if (link.readAttribute('data-remote')) {
166
+ handleRemote(link);
167
+ event.stop();
168
+ } else if (link.readAttribute('data-method')) {
169
+ handleMethod(link);
170
+ event.stop();
171
+ }
172
+ });
173
+
174
+ document.on("click", "form input[type=submit], form button[type=submit], form button:not([type])", function(event, button) {
175
+ // register the pressed submit button
176
+ event.findElement('form').store('rails:submit-button', button.name || false);
177
+ });
178
+
179
+ document.on("submit", function(event) {
180
+ var form = event.findElement();
181
+
182
+ if (!allowAction(form)) {
183
+ event.stop();
184
+ return false;
185
+ }
186
+
187
+ if (form.readAttribute('data-remote')) {
188
+ handleRemote(form);
189
+ event.stop();
190
+ } else {
191
+ disableFormElements(form);
192
+ }
193
+ });
194
+
195
+ document.on('ajax:create', 'form', function(event, form) {
196
+ if (form == event.findElement()) disableFormElements(form);
197
+ });
198
+
199
+ document.on('ajax:complete', 'form', function(event, form) {
200
+ if (form == event.findElement()) enableFormElements(form);
201
+ });
202
+ })();
File without changes
@@ -0,0 +1,6 @@
1
+ #!/usr/bin/env ruby
2
+ # This command will automatically be run when you run "rails" with Rails 3 gems installed from the root of your application.
3
+
4
+ APP_PATH = File.expand_path('../../config/application', __FILE__)
5
+ require File.expand_path('../../config/boot', __FILE__)
6
+ require 'rails/commands'
@@ -0,0 +1,9 @@
1
+ require 'test_helper'
2
+
3
+ class ControllerLoggingTest < ActiveSupport::IntegrationCase
4
+ test 'Log from a controller' do
5
+ visit bar_index_path
6
+ assert_match "Logging with Rails.logger", STDOUT.string
7
+ assert_match "Logging with logger", STDOUT.string
8
+ end
9
+ end
@@ -0,0 +1,20 @@
1
+ require 'test_helper'
2
+
3
+ class ServeStaticAssets < ActiveSupport::TestCase
4
+ test "truth" do
5
+ assert_kind_of Module, RailsStdoutLogging
6
+ end
7
+
8
+ test "Active Record" do
9
+ str = "#{Time.now} ActiveRecord logs to stdout"
10
+ ActiveRecord::Base.logger.info(str)
11
+ assert_match str, STDOUT.string
12
+ end
13
+
14
+ test "Action Mailer" do
15
+ str = "#{Time.now} ActionMailer logs to stdout"
16
+ ActionMailer::Base.logger.info(str)
17
+ assert_match str, STDOUT.string
18
+ end
19
+
20
+ end
@@ -0,0 +1,6 @@
1
+ # Define a bare test case to use with Capybara
2
+ class ActiveSupport::IntegrationCase < ActiveSupport::TestCase
3
+ include Capybara::DSL
4
+ include Rails.application.routes.url_helpers
5
+
6
+ end
@@ -0,0 +1,36 @@
1
+ # Configure Rails Envinronment
2
+ ENV["RAILS_ENV"] = "test"
3
+
4
+ DEBUG_STDOUT = STDOUT
5
+ STDOUT = StringIO.new
6
+
7
+ ENGINE_RAILS_ROOT=File.join(File.dirname(__FILE__), '../')
8
+ require File.expand_path("../dummy/config/environment.rb", __FILE__)
9
+ require "rails/test_help"
10
+
11
+
12
+
13
+
14
+ ActionMailer::Base.delivery_method = :test
15
+ ActionMailer::Base.perform_deliveries = true
16
+ ActionMailer::Base.default_url_options[:host] = "test.com"
17
+
18
+ Rails.backtrace_cleaner.remove_silencers!
19
+
20
+ # Configure capybara for integration testing
21
+ require "capybara/rails"
22
+ Capybara.default_driver = :rack_test
23
+ Capybara.default_selector = :css
24
+
25
+
26
+
27
+ # Run any available migration
28
+ ActiveRecord::Migrator.migrate File.expand_path("../dummy/db/migrate/", __FILE__)
29
+
30
+ # Load support files
31
+ Dir["#{File.dirname(__FILE__)}/support/**/*.rb"].each { |f| require f }
32
+
33
+ def puts(msg)
34
+ DEBUG_STDOUT.puts(msg)
35
+ end
36
+
metadata CHANGED
@@ -1,7 +1,7 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: rails_stdout_logging
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.0.1
4
+ version: 0.0.2
5
5
  platform: ruby
6
6
  authors:
7
7
  - David Dollar
@@ -10,7 +10,7 @@ authors:
10
10
  autorequire:
11
11
  bindir: bin
12
12
  cert_chain: []
13
- date: 2013-06-12 00:00:00.000000000 Z
13
+ date: 2013-08-30 00:00:00.000000000 Z
14
14
  dependencies: []
15
15
  description: Sets Rails to log to stdout
16
16
  email:
@@ -22,10 +22,16 @@ extensions: []
22
22
  extra_rdoc_files: []
23
23
  files:
24
24
  - .gitignore
25
+ - .travis.yml
26
+ - Appraisals
25
27
  - Gemfile
26
28
  - LICENSE
27
29
  - README.md
28
30
  - Rakefile
31
+ - gemfiles/rails_3.0.x.gemfile
32
+ - gemfiles/rails_3.1.x.gemfile
33
+ - gemfiles/rails_3.2.x.gemfile
34
+ - gemfiles/rails_4.0.x.gemfile
29
35
  - init.rb
30
36
  - lib/rails_stdout_logging.rb
31
37
  - lib/rails_stdout_logging/rails.rb
@@ -33,9 +39,47 @@ files:
33
39
  - lib/rails_stdout_logging/rails3.rb
34
40
  - lib/rails_stdout_logging/railtie.rb
35
41
  - lib/rails_stdout_logging/version.rb
36
- - rails_log_stdout.gemspec
42
+ - rails_stdout_logging.gemspec
43
+ - test/dummy/Rakefile
44
+ - test/dummy/app/controllers/application_controller.rb
45
+ - test/dummy/app/controllers/bar_controller.rb
46
+ - test/dummy/app/helpers/application_helper.rb
47
+ - test/dummy/app/views/bar/index.html.erb
48
+ - test/dummy/config.ru
49
+ - test/dummy/config/application.rb
50
+ - test/dummy/config/boot.rb
51
+ - test/dummy/config/database.yml
52
+ - test/dummy/config/environment.rb
53
+ - test/dummy/config/environments/development.rb
54
+ - test/dummy/config/environments/production.rb
55
+ - test/dummy/config/environments/test.rb
56
+ - test/dummy/config/initializers/backtrace_silencers.rb
57
+ - test/dummy/config/initializers/inflections.rb
58
+ - test/dummy/config/initializers/mime_types.rb
59
+ - test/dummy/config/initializers/secret_token.rb
60
+ - test/dummy/config/initializers/session_store.rb
61
+ - test/dummy/config/locales/en.yml
62
+ - test/dummy/config/locales/es.yml
63
+ - test/dummy/config/routes.rb
64
+ - test/dummy/public/404.html
65
+ - test/dummy/public/422.html
66
+ - test/dummy/public/500.html
67
+ - test/dummy/public/favicon.ico
68
+ - test/dummy/public/javascripts/application.js
69
+ - test/dummy/public/javascripts/controls.js
70
+ - test/dummy/public/javascripts/dragdrop.js
71
+ - test/dummy/public/javascripts/effects.js
72
+ - test/dummy/public/javascripts/prototype.js
73
+ - test/dummy/public/javascripts/rails.js
74
+ - test/dummy/public/stylesheets/.gitkeep
75
+ - test/dummy/script/rails
76
+ - test/integration/controller_logging_test.rb
77
+ - test/rails_stdout_logging_test.rb
78
+ - test/support/integration_case.rb
79
+ - test/test_helper.rb
37
80
  homepage: https://github.com/heroku/rails_stdout_logging
38
- licenses: []
81
+ licenses:
82
+ - MIT
39
83
  metadata: {}
40
84
  post_install_message:
41
85
  rdoc_options: []
@@ -53,8 +97,45 @@ required_rubygems_version: !ruby/object:Gem::Requirement
53
97
  version: '0'
54
98
  requirements: []
55
99
  rubyforge_project:
56
- rubygems_version: 2.0.2
100
+ rubygems_version: 2.0.3
57
101
  signing_key:
58
102
  specification_version: 4
59
103
  summary: Overrides Rails' built in logger to send all logs to stdout
60
- test_files: []
104
+ test_files:
105
+ - test/dummy/Rakefile
106
+ - test/dummy/app/controllers/application_controller.rb
107
+ - test/dummy/app/controllers/bar_controller.rb
108
+ - test/dummy/app/helpers/application_helper.rb
109
+ - test/dummy/app/views/bar/index.html.erb
110
+ - test/dummy/config.ru
111
+ - test/dummy/config/application.rb
112
+ - test/dummy/config/boot.rb
113
+ - test/dummy/config/database.yml
114
+ - test/dummy/config/environment.rb
115
+ - test/dummy/config/environments/development.rb
116
+ - test/dummy/config/environments/production.rb
117
+ - test/dummy/config/environments/test.rb
118
+ - test/dummy/config/initializers/backtrace_silencers.rb
119
+ - test/dummy/config/initializers/inflections.rb
120
+ - test/dummy/config/initializers/mime_types.rb
121
+ - test/dummy/config/initializers/secret_token.rb
122
+ - test/dummy/config/initializers/session_store.rb
123
+ - test/dummy/config/locales/en.yml
124
+ - test/dummy/config/locales/es.yml
125
+ - test/dummy/config/routes.rb
126
+ - test/dummy/public/404.html
127
+ - test/dummy/public/422.html
128
+ - test/dummy/public/500.html
129
+ - test/dummy/public/favicon.ico
130
+ - test/dummy/public/javascripts/application.js
131
+ - test/dummy/public/javascripts/controls.js
132
+ - test/dummy/public/javascripts/dragdrop.js
133
+ - test/dummy/public/javascripts/effects.js
134
+ - test/dummy/public/javascripts/prototype.js
135
+ - test/dummy/public/javascripts/rails.js
136
+ - test/dummy/public/stylesheets/.gitkeep
137
+ - test/dummy/script/rails
138
+ - test/integration/controller_logging_test.rb
139
+ - test/rails_stdout_logging_test.rb
140
+ - test/support/integration_case.rb
141
+ - test/test_helper.rb