tagged_logger 0.5.1 → 0.5.5

Sign up to get free protection for your applications and to get access to all the features.
Files changed (65) hide show
  1. data/README.markdown +9 -7
  2. data/lib/tagged_logger/railtie.rb +23 -13
  3. data/lib/tagged_logger/tagged_logger.rb +3 -5
  4. data/test/test_rails.rb +1 -2
  5. data/test/test_rails_app/Gemfile +12 -0
  6. data/test/test_rails_app/Gemfile.lock +115 -0
  7. data/test/test_rails_app/README +256 -0
  8. data/test/test_rails_app/Rakefile +7 -0
  9. data/test/test_rails_app/app/controllers/application_controller.rb +3 -0
  10. data/test/test_rails_app/app/controllers/users_controller.rb +8 -0
  11. data/test/test_rails_app/app/helpers/application_helper.rb +2 -0
  12. data/test/test_rails_app/app/helpers/users_helper.rb +2 -0
  13. data/test/test_rails_app/app/mailers/user_mailer.rb +6 -0
  14. data/test/test_rails_app/app/models/user.rb +6 -0
  15. data/test/test_rails_app/app/views/layouts/application.html.erb +14 -0
  16. data/test/test_rails_app/app/views/user_mailer/index_email.html.erb +2 -0
  17. data/test/test_rails_app/app/views/users/index.html.erb +1 -0
  18. data/test/test_rails_app/config/application.rb +42 -0
  19. data/test/test_rails_app/config/boot.rb +13 -0
  20. data/test/test_rails_app/config/database.yml +22 -0
  21. data/test/test_rails_app/config/environment.rb +5 -0
  22. data/test/test_rails_app/config/environments/development.rb +26 -0
  23. data/test/test_rails_app/config/environments/production.rb +49 -0
  24. data/test/test_rails_app/config/environments/test.rb +41 -0
  25. data/test/test_rails_app/config/initializers/backtrace_silencers.rb +7 -0
  26. data/test/test_rails_app/config/initializers/generators.rb +2 -0
  27. data/test/test_rails_app/config/initializers/inflections.rb +10 -0
  28. data/test/test_rails_app/config/initializers/mime_types.rb +5 -0
  29. data/test/test_rails_app/config/initializers/secret_token.rb +7 -0
  30. data/test/test_rails_app/config/initializers/session_store.rb +8 -0
  31. data/test/test_rails_app/config/initializers/tagged_logger.rb +11 -0
  32. data/test/test_rails_app/config/locales/en.yml +5 -0
  33. data/test/test_rails_app/config/routes.rb +60 -0
  34. data/test/test_rails_app/config.ru +4 -0
  35. data/test/test_rails_app/db/development.sqlite3 +0 -0
  36. data/test/test_rails_app/db/migrate/20101031213200_create_users.rb +12 -0
  37. data/test/test_rails_app/db/schema.rb +20 -0
  38. data/test/test_rails_app/db/seeds.rb +7 -0
  39. data/test/test_rails_app/db/test.sqlite3 +0 -0
  40. data/test/test_rails_app/doc/README_FOR_APP +2 -0
  41. data/test/test_rails_app/lib/test_logger.rb +14 -0
  42. data/test/test_rails_app/log/development.log +69 -0
  43. data/test/test_rails_app/log/production.log +0 -0
  44. data/test/test_rails_app/log/server.log +0 -0
  45. data/test/test_rails_app/log/test.log +105 -0
  46. data/test/test_rails_app/public/404.html +26 -0
  47. data/test/test_rails_app/public/422.html +26 -0
  48. data/test/test_rails_app/public/500.html +26 -0
  49. data/test/test_rails_app/public/favicon.ico +0 -0
  50. data/test/test_rails_app/public/images/rails.png +0 -0
  51. data/test/test_rails_app/public/index.html +239 -0
  52. data/test/test_rails_app/public/javascripts/application.js +2 -0
  53. data/test/test_rails_app/public/javascripts/controls.js +965 -0
  54. data/test/test_rails_app/public/javascripts/dragdrop.js +974 -0
  55. data/test/test_rails_app/public/javascripts/effects.js +1123 -0
  56. data/test/test_rails_app/public/javascripts/prototype.js +6001 -0
  57. data/test/test_rails_app/public/javascripts/rails.js +175 -0
  58. data/test/test_rails_app/public/robots.txt +5 -0
  59. data/test/test_rails_app/script/rails +6 -0
  60. data/test/test_rails_app/test/integration/logging_test.rb +63 -0
  61. data/test/test_rails_app/test/performance/browsing_test.rb +9 -0
  62. data/test/test_rails_app/test/test_helper.rb +6 -0
  63. data/test/test_rails_app/tmp/capybara/capybara-20101031161745.html +239 -0
  64. data/test/test_rails_app/tmp/capybara/capybara-20101031162015.html +239 -0
  65. metadata +67 -7
@@ -0,0 +1,175 @@
1
+ (function() {
2
+ // Technique from Juriy Zaytsev
3
+ // http://thinkweb2.com/projects/prototype/detecting-event-support-without-browser-sniffing/
4
+ function isEventSupported(eventName) {
5
+ var el = document.createElement('div');
6
+ eventName = 'on' + eventName;
7
+ var isSupported = (eventName in el);
8
+ if (!isSupported) {
9
+ el.setAttribute(eventName, 'return;');
10
+ isSupported = typeof el[eventName] == 'function';
11
+ }
12
+ el = null;
13
+ return isSupported;
14
+ }
15
+
16
+ function isForm(element) {
17
+ return Object.isElement(element) && element.nodeName.toUpperCase() == 'FORM'
18
+ }
19
+
20
+ function isInput(element) {
21
+ if (Object.isElement(element)) {
22
+ var name = element.nodeName.toUpperCase()
23
+ return name == 'INPUT' || name == 'SELECT' || name == 'TEXTAREA'
24
+ }
25
+ else return false
26
+ }
27
+
28
+ var submitBubbles = isEventSupported('submit'),
29
+ changeBubbles = isEventSupported('change')
30
+
31
+ if (!submitBubbles || !changeBubbles) {
32
+ // augment the Event.Handler class to observe custom events when needed
33
+ Event.Handler.prototype.initialize = Event.Handler.prototype.initialize.wrap(
34
+ function(init, element, eventName, selector, callback) {
35
+ init(element, eventName, selector, callback)
36
+ // is the handler being attached to an element that doesn't support this event?
37
+ if ( (!submitBubbles && this.eventName == 'submit' && !isForm(this.element)) ||
38
+ (!changeBubbles && this.eventName == 'change' && !isInput(this.element)) ) {
39
+ // "submit" => "emulated:submit"
40
+ this.eventName = 'emulated:' + this.eventName
41
+ }
42
+ }
43
+ )
44
+ }
45
+
46
+ if (!submitBubbles) {
47
+ // discover forms on the page by observing focus events which always bubble
48
+ document.on('focusin', 'form', function(focusEvent, form) {
49
+ // special handler for the real "submit" event (one-time operation)
50
+ if (!form.retrieve('emulated:submit')) {
51
+ form.on('submit', function(submitEvent) {
52
+ var emulated = form.fire('emulated:submit', submitEvent, true)
53
+ // if custom event received preventDefault, cancel the real one too
54
+ if (emulated.returnValue === false) submitEvent.preventDefault()
55
+ })
56
+ form.store('emulated:submit', true)
57
+ }
58
+ })
59
+ }
60
+
61
+ if (!changeBubbles) {
62
+ // discover form inputs on the page
63
+ document.on('focusin', 'input, select, texarea', function(focusEvent, input) {
64
+ // special handler for real "change" events
65
+ if (!input.retrieve('emulated:change')) {
66
+ input.on('change', function(changeEvent) {
67
+ input.fire('emulated:change', changeEvent, true)
68
+ })
69
+ input.store('emulated:change', true)
70
+ }
71
+ })
72
+ }
73
+
74
+ function handleRemote(element) {
75
+ var method, url, params;
76
+
77
+ var event = element.fire("ajax:before");
78
+ if (event.stopped) return false;
79
+
80
+ if (element.tagName.toLowerCase() === 'form') {
81
+ method = element.readAttribute('method') || 'post';
82
+ url = element.readAttribute('action');
83
+ params = element.serialize();
84
+ } else {
85
+ method = element.readAttribute('data-method') || 'get';
86
+ url = element.readAttribute('href');
87
+ params = {};
88
+ }
89
+
90
+ new Ajax.Request(url, {
91
+ method: method,
92
+ parameters: params,
93
+ evalScripts: true,
94
+
95
+ onComplete: function(request) { element.fire("ajax:complete", request); },
96
+ onSuccess: function(request) { element.fire("ajax:success", request); },
97
+ onFailure: function(request) { element.fire("ajax:failure", request); }
98
+ });
99
+
100
+ element.fire("ajax:after");
101
+ }
102
+
103
+ function handleMethod(element) {
104
+ var method = element.readAttribute('data-method'),
105
+ url = element.readAttribute('href'),
106
+ csrf_param = $$('meta[name=csrf-param]')[0],
107
+ csrf_token = $$('meta[name=csrf-token]')[0];
108
+
109
+ var form = new Element('form', { method: "POST", action: url, style: "display: none;" });
110
+ element.parentNode.insert(form);
111
+
112
+ if (method !== 'post') {
113
+ var field = new Element('input', { type: 'hidden', name: '_method', value: method });
114
+ form.insert(field);
115
+ }
116
+
117
+ if (csrf_param) {
118
+ var param = csrf_param.readAttribute('content'),
119
+ token = csrf_token.readAttribute('content'),
120
+ field = new Element('input', { type: 'hidden', name: param, value: token });
121
+ form.insert(field);
122
+ }
123
+
124
+ form.submit();
125
+ }
126
+
127
+
128
+ document.on("click", "*[data-confirm]", function(event, element) {
129
+ var message = element.readAttribute('data-confirm');
130
+ if (!confirm(message)) event.stop();
131
+ });
132
+
133
+ document.on("click", "a[data-remote]", function(event, element) {
134
+ if (event.stopped) return;
135
+ handleRemote(element);
136
+ event.stop();
137
+ });
138
+
139
+ document.on("click", "a[data-method]", function(event, element) {
140
+ if (event.stopped) return;
141
+ handleMethod(element);
142
+ event.stop();
143
+ });
144
+
145
+ document.on("submit", function(event) {
146
+ var element = event.findElement(),
147
+ message = element.readAttribute('data-confirm');
148
+ if (message && !confirm(message)) {
149
+ event.stop();
150
+ return false;
151
+ }
152
+
153
+ var inputs = element.select("input[type=submit][data-disable-with]");
154
+ inputs.each(function(input) {
155
+ input.disabled = true;
156
+ input.writeAttribute('data-original-value', input.value);
157
+ input.value = input.readAttribute('data-disable-with');
158
+ });
159
+
160
+ var element = event.findElement("form[data-remote]");
161
+ if (element) {
162
+ handleRemote(element);
163
+ event.stop();
164
+ }
165
+ });
166
+
167
+ document.on("ajax:after", "form", function(event, element) {
168
+ var inputs = element.select("input[type=submit][disabled=true][data-disable-with]");
169
+ inputs.each(function(input) {
170
+ input.value = input.readAttribute('data-original-value');
171
+ input.removeAttribute('data-original-value');
172
+ input.disabled = false;
173
+ });
174
+ });
175
+ })();
@@ -0,0 +1,5 @@
1
+ # See http://www.robotstxt.org/wc/norobots.html for documentation on how to use the robots.txt file
2
+ #
3
+ # To ban all spiders from the entire site uncomment the next two lines:
4
+ # User-Agent: *
5
+ # Disallow: /
@@ -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,63 @@
1
+ require 'test_helper'
2
+ require 'capybara/rails'
3
+
4
+ class LogOutput < DelegateClass(Array)
5
+ def debug(msg); self << msg; end
6
+ def info(msg); self << msg; end
7
+ def warn(msg); self << msg; end
8
+ def error(msg); self << msg; end
9
+ def fatal(msg); self << msg; end
10
+
11
+ def debug?; true; end
12
+ def info?; true; end
13
+ def warn?; true; end
14
+ def error?; true; end
15
+ def fatal?; true; end
16
+ end
17
+
18
+ class LoggingTest < ActionDispatch::IntegrationTest
19
+ include Capybara
20
+
21
+ setup do
22
+ @output = []
23
+ TestLogger.reset(LogOutput.new(@output))
24
+ end
25
+
26
+ test "logging in Rails is redirected by TaggedLogger to @output and contains expeced entries" do
27
+ visit '/users'
28
+ output = @output.join
29
+ assert_match /UsersController\#index/, output
30
+ assert_match /GET.+\/users/, output
31
+ end
32
+
33
+ def clean(out)
34
+ result = []
35
+ out.each do |line|
36
+ next if line.strip.empty?
37
+ line.gsub! /^.*>>> /, ''
38
+ line.gsub! /[\d\.]+ms/, ''
39
+ line.gsub! /at (.+)/, ''
40
+ line.gsub! /^Date:.*/, ''
41
+ line.gsub! /Message-ID:.*@/, ''
42
+ end
43
+ end
44
+
45
+ test "logs are same with and without TaggedLogger" do
46
+ visit '/users'
47
+ puts "Captured output:"
48
+ puts @output.join("\n")
49
+
50
+ second_run_out = []
51
+ TestLogger.reset(LogOutput.new(second_run_out))
52
+ TaggedLogger.reset
53
+ ActionController::Base.logger = TestLogger.instance
54
+ ActionMailer::Base.logger = TestLogger.instance
55
+ ActiveRecord::Base.logger = TestLogger.instance
56
+ visit '/users'
57
+
58
+ second_run_out = clean(second_run_out)
59
+ first_run_out = clean(@output)
60
+ assert_equal first_run_out, second_run_out
61
+ end
62
+
63
+ end
@@ -0,0 +1,9 @@
1
+ require 'test_helper'
2
+ require 'rails/performance_test_help'
3
+
4
+ # Profiling results for each test method are written to tmp/performance.
5
+ class BrowsingTest < ActionDispatch::PerformanceTest
6
+ def test_homepage
7
+ get '/'
8
+ end
9
+ end
@@ -0,0 +1,6 @@
1
+ ENV["RAILS_ENV"] = "test"
2
+ require File.expand_path('../../config/environment', __FILE__)
3
+ require 'rails/test_help'
4
+
5
+ class ActiveSupport::TestCase
6
+ end
@@ -0,0 +1,239 @@
1
+ <!DOCTYPE html>
2
+ <html>
3
+ <head>
4
+ <title>Ruby on Rails: Welcome aboard</title>
5
+ <style type="text/css" media="screen">
6
+ body {
7
+ margin: 0;
8
+ margin-bottom: 25px;
9
+ padding: 0;
10
+ background-color: #f0f0f0;
11
+ font-family: "Lucida Grande", "Bitstream Vera Sans", "Verdana";
12
+ font-size: 13px;
13
+ color: #333;
14
+ }
15
+
16
+ h1 {
17
+ font-size: 28px;
18
+ color: #000;
19
+ }
20
+
21
+ a {color: #03c}
22
+ a:hover {
23
+ background-color: #03c;
24
+ color: white;
25
+ text-decoration: none;
26
+ }
27
+
28
+
29
+ #page {
30
+ background-color: #f0f0f0;
31
+ width: 750px;
32
+ margin: 0;
33
+ margin-left: auto;
34
+ margin-right: auto;
35
+ }
36
+
37
+ #content {
38
+ float: left;
39
+ background-color: white;
40
+ border: 3px solid #aaa;
41
+ border-top: none;
42
+ padding: 25px;
43
+ width: 500px;
44
+ }
45
+
46
+ #sidebar {
47
+ float: right;
48
+ width: 175px;
49
+ }
50
+
51
+ #footer {
52
+ clear: both;
53
+ }
54
+
55
+
56
+ #header, #about, #getting-started {
57
+ padding-left: 75px;
58
+ padding-right: 30px;
59
+ }
60
+
61
+
62
+ #header {
63
+ background-image: url("images/rails.png");
64
+ background-repeat: no-repeat;
65
+ background-position: top left;
66
+ height: 64px;
67
+ }
68
+ #header h1, #header h2 {margin: 0}
69
+ #header h2 {
70
+ color: #888;
71
+ font-weight: normal;
72
+ font-size: 16px;
73
+ }
74
+
75
+
76
+ #about h3 {
77
+ margin: 0;
78
+ margin-bottom: 10px;
79
+ font-size: 14px;
80
+ }
81
+
82
+ #about-content {
83
+ background-color: #ffd;
84
+ border: 1px solid #fc0;
85
+ margin-left: -55px;
86
+ margin-right: -10px;
87
+ }
88
+ #about-content table {
89
+ margin-top: 10px;
90
+ margin-bottom: 10px;
91
+ font-size: 11px;
92
+ border-collapse: collapse;
93
+ }
94
+ #about-content td {
95
+ padding: 10px;
96
+ padding-top: 3px;
97
+ padding-bottom: 3px;
98
+ }
99
+ #about-content td.name {color: #555}
100
+ #about-content td.value {color: #000}
101
+
102
+ #about-content ul {
103
+ padding: 0;
104
+ list-style-type: none;
105
+ }
106
+
107
+ #about-content.failure {
108
+ background-color: #fcc;
109
+ border: 1px solid #f00;
110
+ }
111
+ #about-content.failure p {
112
+ margin: 0;
113
+ padding: 10px;
114
+ }
115
+
116
+
117
+ #getting-started {
118
+ border-top: 1px solid #ccc;
119
+ margin-top: 25px;
120
+ padding-top: 15px;
121
+ }
122
+ #getting-started h1 {
123
+ margin: 0;
124
+ font-size: 20px;
125
+ }
126
+ #getting-started h2 {
127
+ margin: 0;
128
+ font-size: 14px;
129
+ font-weight: normal;
130
+ color: #333;
131
+ margin-bottom: 25px;
132
+ }
133
+ #getting-started ol {
134
+ margin-left: 0;
135
+ padding-left: 0;
136
+ }
137
+ #getting-started li {
138
+ font-size: 18px;
139
+ color: #888;
140
+ margin-bottom: 25px;
141
+ }
142
+ #getting-started li h2 {
143
+ margin: 0;
144
+ font-weight: normal;
145
+ font-size: 18px;
146
+ color: #333;
147
+ }
148
+ #getting-started li p {
149
+ color: #555;
150
+ font-size: 13px;
151
+ }
152
+
153
+
154
+ #sidebar ul {
155
+ margin-left: 0;
156
+ padding-left: 0;
157
+ }
158
+ #sidebar ul h3 {
159
+ margin-top: 25px;
160
+ font-size: 16px;
161
+ padding-bottom: 10px;
162
+ border-bottom: 1px solid #ccc;
163
+ }
164
+ #sidebar li {
165
+ list-style-type: none;
166
+ }
167
+ #sidebar ul.links li {
168
+ margin-bottom: 5px;
169
+ }
170
+
171
+ </style>
172
+ <script type="text/javascript">
173
+ function about() {
174
+ info = document.getElementById('about-content');
175
+ if (window.XMLHttpRequest)
176
+ { xhr = new XMLHttpRequest(); }
177
+ else
178
+ { xhr = new ActiveXObject("Microsoft.XMLHTTP"); }
179
+ xhr.open("GET","rails/info/properties",false);
180
+ xhr.send("");
181
+ info.innerHTML = xhr.responseText;
182
+ info.style.display = 'block'
183
+ }
184
+ </script>
185
+ </head>
186
+ <body>
187
+ <div id="page">
188
+ <div id="sidebar">
189
+ <ul id="sidebar-items">
190
+ <li>
191
+ <h3>Browse the documentation</h3>
192
+ <ul class="links">
193
+ <li><a href="http://api.rubyonrails.org/">Rails API</a></li>
194
+ <li><a href="http://stdlib.rubyonrails.org/">Ruby standard library</a></li>
195
+ <li><a href="http://corelib.rubyonrails.org/">Ruby core</a></li>
196
+ <li><a href="http://guides.rubyonrails.org/">Rails Guides</a></li>
197
+ </ul>
198
+ </li>
199
+ </ul>
200
+ </div>
201
+
202
+ <div id="content">
203
+ <div id="header">
204
+ <h1>Welcome aboard</h1>
205
+ <h2>You&rsquo;re riding Ruby on Rails!</h2>
206
+ </div>
207
+
208
+ <div id="about">
209
+ <h3><a href="rails/info/properties" onclick="about(); return false">About your application&rsquo;s environment</a></h3>
210
+ <div id="about-content" style="display: none"></div>
211
+ </div>
212
+
213
+ <div id="getting-started">
214
+ <h1>Getting started</h1>
215
+ <h2>Here&rsquo;s how to get rolling:</h2>
216
+
217
+ <ol>
218
+ <li>
219
+ <h2>Use <code>rails generate</code> to create your models and controllers</h2>
220
+ <p>To see all available options, run it without parameters.</p>
221
+ </li>
222
+
223
+ <li>
224
+ <h2>Set up a default route and remove or rename this file</h2>
225
+ <p>Routes are set up in config/routes.rb.</p>
226
+ </li>
227
+
228
+ <li>
229
+ <h2>Create your database</h2>
230
+ <p>Run <code>rake db:migrate</code> to create your database. If you're not using SQLite (the default), edit <code>config/database.yml</code> with your username and password.</p>
231
+ </li>
232
+ </ol>
233
+ </div>
234
+ </div>
235
+
236
+ <div id="footer">&nbsp;</div>
237
+ </div>
238
+ </body>
239
+ </html>