yarder 0.0.1
Sign up to get free protection for your applications and to get access to all the features.
- data/MIT-LICENSE +20 -0
- data/README.md +87 -0
- data/Rakefile +38 -0
- data/lib/tasks/yarder_tasks.rake +4 -0
- data/lib/yarder.rb +15 -0
- data/lib/yarder/action_controller/log_subscriber.rb +74 -0
- data/lib/yarder/action_view/log_subscriber.rb +31 -0
- data/lib/yarder/active_record/log_subscriber.rb +75 -0
- data/lib/yarder/active_resource/log_subscriber.rb +34 -0
- data/lib/yarder/configuration.rb +8 -0
- data/lib/yarder/core_ext/object/blank.rb +105 -0
- data/lib/yarder/logger.rb +55 -0
- data/lib/yarder/rack/logger.rb +72 -0
- data/lib/yarder/railtie.rb +69 -0
- data/lib/yarder/tagged_logging.rb +102 -0
- data/lib/yarder/version.rb +3 -0
- data/test/action_controller/log_subscriber_test.rb +165 -0
- data/test/action_view/log_subscriber_test.rb +89 -0
- data/test/active_record/log_subscriber_test.rb +87 -0
- data/test/active_resource/log_subscriber_test.rb +42 -0
- data/test/dummy/README.rdoc +261 -0
- data/test/dummy/Rakefile +7 -0
- data/test/dummy/app/assets/javascripts/application.js +13 -0
- data/test/dummy/app/assets/javascripts/widgets.js +2 -0
- data/test/dummy/app/assets/stylesheets/application.css +13 -0
- data/test/dummy/app/assets/stylesheets/scaffold.css +56 -0
- data/test/dummy/app/assets/stylesheets/widgets.css +4 -0
- data/test/dummy/app/controllers/application_controller.rb +3 -0
- data/test/dummy/app/controllers/log_subscriber_controller.rb +56 -0
- data/test/dummy/app/controllers/widgets_controller.rb +83 -0
- data/test/dummy/app/helpers/application_helper.rb +2 -0
- data/test/dummy/app/helpers/widgets_helper.rb +2 -0
- data/test/dummy/app/models/widget.rb +3 -0
- data/test/dummy/app/views/customers/_customer.html.erb +1 -0
- data/test/dummy/app/views/good_customers/_good_customer.html.erb +1 -0
- data/test/dummy/app/views/layouts/application.html.erb +14 -0
- data/test/dummy/app/views/test/_customer.erb +1 -0
- data/test/dummy/app/views/test/hello_world.erb +1 -0
- data/test/dummy/app/views/widgets/_form.html.erb +17 -0
- data/test/dummy/app/views/widgets/edit.html.erb +6 -0
- data/test/dummy/app/views/widgets/index.html.erb +21 -0
- data/test/dummy/app/views/widgets/new.html.erb +5 -0
- data/test/dummy/app/views/widgets/show.html.erb +5 -0
- data/test/dummy/config.ru +4 -0
- data/test/dummy/config/application.rb +69 -0
- data/test/dummy/config/boot.rb +10 -0
- data/test/dummy/config/database.yml +22 -0
- data/test/dummy/config/environment.rb +5 -0
- data/test/dummy/config/environments/development.rb +31 -0
- data/test/dummy/config/environments/production.rb +64 -0
- data/test/dummy/config/environments/test.rb +35 -0
- data/test/dummy/config/initializers/backtrace_silencers.rb +7 -0
- data/test/dummy/config/initializers/inflections.rb +15 -0
- data/test/dummy/config/initializers/mime_types.rb +5 -0
- data/test/dummy/config/initializers/secret_token.rb +7 -0
- data/test/dummy/config/initializers/session_store.rb +8 -0
- data/test/dummy/config/initializers/wrap_parameters.rb +10 -0
- data/test/dummy/config/locales/en.yml +5 -0
- data/test/dummy/config/routes.rb +69 -0
- data/test/dummy/db/migrate/20120927084605_create_widgets.rb +8 -0
- data/test/dummy/db/schema.rb +16 -0
- data/test/dummy/log/development.log +19 -0
- data/test/dummy/log/test.log +10694 -0
- data/test/dummy/public/404.html +26 -0
- data/test/dummy/public/422.html +26 -0
- data/test/dummy/public/500.html +25 -0
- data/test/dummy/public/favicon.ico +0 -0
- data/test/dummy/script/rails +6 -0
- data/test/logger_test.rb +126 -0
- data/test/rack/logger_test.rb +68 -0
- data/test/support/fake_models.rb +12 -0
- data/test/support/integration_case.rb +5 -0
- data/test/support/multibyte_test_helpers.rb +19 -0
- data/test/tagged_logging_test.rb +155 -0
- data/test/test_helper.rb +31 -0
- data/test/yarder_test.rb +7 -0
- metadata +236 -0
data/test/dummy/Rakefile
ADDED
@@ -0,0 +1,7 @@
|
|
1
|
+
#!/usr/bin/env rake
|
2
|
+
# Add your own tasks in files placed in lib/tasks ending in .rake,
|
3
|
+
# for example lib/tasks/capistrano.rake, and they will automatically be available to Rake.
|
4
|
+
|
5
|
+
require File.expand_path('../config/application', __FILE__)
|
6
|
+
|
7
|
+
Dummy::Application.load_tasks
|
@@ -0,0 +1,13 @@
|
|
1
|
+
// This is a manifest file that'll be compiled into application.js, which will include all the files
|
2
|
+
// listed below.
|
3
|
+
//
|
4
|
+
// Any JavaScript/Coffee file within this directory, lib/assets/javascripts, vendor/assets/javascripts,
|
5
|
+
// or vendor/assets/javascripts of plugins, if any, can be referenced here using a relative path.
|
6
|
+
//
|
7
|
+
// It's not advisable to add code directly here, but if you do, it'll appear at the bottom of the
|
8
|
+
// the compiled file.
|
9
|
+
//
|
10
|
+
// WARNING: THE FIRST BLANK LINE MARKS THE END OF WHAT'S TO BE PROCESSED, ANY BLANK LINE SHOULD
|
11
|
+
// GO AFTER THE REQUIRES BELOW.
|
12
|
+
//
|
13
|
+
//= require_tree .
|
@@ -0,0 +1,13 @@
|
|
1
|
+
/*
|
2
|
+
* This is a manifest file that'll be compiled into application.css, which will include all the files
|
3
|
+
* listed below.
|
4
|
+
*
|
5
|
+
* Any CSS and SCSS file within this directory, lib/assets/stylesheets, vendor/assets/stylesheets,
|
6
|
+
* or vendor/assets/stylesheets of plugins, if any, can be referenced here using a relative path.
|
7
|
+
*
|
8
|
+
* You're free to add application-wide styles to this file and they'll appear at the top of the
|
9
|
+
* compiled file, but it's generally better to create a new file per style scope.
|
10
|
+
*
|
11
|
+
*= require_self
|
12
|
+
*= require_tree .
|
13
|
+
*/
|
@@ -0,0 +1,56 @@
|
|
1
|
+
body { background-color: #fff; color: #333; }
|
2
|
+
|
3
|
+
body, p, ol, ul, td {
|
4
|
+
font-family: verdana, arial, helvetica, sans-serif;
|
5
|
+
font-size: 13px;
|
6
|
+
line-height: 18px;
|
7
|
+
}
|
8
|
+
|
9
|
+
pre {
|
10
|
+
background-color: #eee;
|
11
|
+
padding: 10px;
|
12
|
+
font-size: 11px;
|
13
|
+
}
|
14
|
+
|
15
|
+
a { color: #000; }
|
16
|
+
a:visited { color: #666; }
|
17
|
+
a:hover { color: #fff; background-color:#000; }
|
18
|
+
|
19
|
+
div.field, div.actions {
|
20
|
+
margin-bottom: 10px;
|
21
|
+
}
|
22
|
+
|
23
|
+
#notice {
|
24
|
+
color: green;
|
25
|
+
}
|
26
|
+
|
27
|
+
.field_with_errors {
|
28
|
+
padding: 2px;
|
29
|
+
background-color: red;
|
30
|
+
display: table;
|
31
|
+
}
|
32
|
+
|
33
|
+
#error_explanation {
|
34
|
+
width: 450px;
|
35
|
+
border: 2px solid red;
|
36
|
+
padding: 7px;
|
37
|
+
padding-bottom: 0;
|
38
|
+
margin-bottom: 20px;
|
39
|
+
background-color: #f0f0f0;
|
40
|
+
}
|
41
|
+
|
42
|
+
#error_explanation h2 {
|
43
|
+
text-align: left;
|
44
|
+
font-weight: bold;
|
45
|
+
padding: 5px 5px 5px 15px;
|
46
|
+
font-size: 12px;
|
47
|
+
margin: -7px;
|
48
|
+
margin-bottom: 0px;
|
49
|
+
background-color: #c00;
|
50
|
+
color: #fff;
|
51
|
+
}
|
52
|
+
|
53
|
+
#error_explanation ul li {
|
54
|
+
font-size: 12px;
|
55
|
+
list-style: square;
|
56
|
+
}
|
@@ -0,0 +1,56 @@
|
|
1
|
+
class LogSubscribersController < ActionController::Base
|
2
|
+
wrap_parameters :person, :include => :name, :format => :json
|
3
|
+
|
4
|
+
class SpecialException < Exception
|
5
|
+
end
|
6
|
+
|
7
|
+
rescue_from SpecialException do
|
8
|
+
head :status => 406
|
9
|
+
end
|
10
|
+
|
11
|
+
before_filter :redirector, :only => :never_executed
|
12
|
+
|
13
|
+
def never_executed
|
14
|
+
end
|
15
|
+
|
16
|
+
def show
|
17
|
+
render :nothing => true
|
18
|
+
end
|
19
|
+
|
20
|
+
def redirector
|
21
|
+
redirect_to "http://foo.bar/"
|
22
|
+
end
|
23
|
+
|
24
|
+
def data_sender
|
25
|
+
send_data "cool data", :filename => "file.txt"
|
26
|
+
end
|
27
|
+
|
28
|
+
def file_sender
|
29
|
+
send_file File.expand_path(File.join("test","dummy","public","favicon.ico"))
|
30
|
+
end
|
31
|
+
|
32
|
+
def with_fragment_cache
|
33
|
+
render :inline => "<%= cache('foo'){ 'bar' } %>"
|
34
|
+
end
|
35
|
+
|
36
|
+
def with_fragment_cache_and_percent_in_key
|
37
|
+
render :inline => "<%= cache('foo%bar'){ 'Contains % sign in key' } %>"
|
38
|
+
end
|
39
|
+
|
40
|
+
def with_page_cache
|
41
|
+
cache_page("Super soaker", "/index.html")
|
42
|
+
render :nothing => true
|
43
|
+
end
|
44
|
+
|
45
|
+
def with_exception
|
46
|
+
raise Exception
|
47
|
+
end
|
48
|
+
|
49
|
+
def with_rescued_exception
|
50
|
+
raise SpecialException
|
51
|
+
end
|
52
|
+
|
53
|
+
def with_action_not_found
|
54
|
+
raise AbstractController::ActionNotFound
|
55
|
+
end
|
56
|
+
end
|
@@ -0,0 +1,83 @@
|
|
1
|
+
class WidgetsController < ApplicationController
|
2
|
+
# GET /widgets
|
3
|
+
# GET /widgets.json
|
4
|
+
def index
|
5
|
+
@widgets = Widget.all
|
6
|
+
|
7
|
+
respond_to do |format|
|
8
|
+
format.html # index.html.erb
|
9
|
+
format.json { render json: @widgets }
|
10
|
+
end
|
11
|
+
end
|
12
|
+
|
13
|
+
# GET /widgets/1
|
14
|
+
# GET /widgets/1.json
|
15
|
+
def show
|
16
|
+
@widget = Widget.find(params[:id])
|
17
|
+
|
18
|
+
respond_to do |format|
|
19
|
+
format.html # show.html.erb
|
20
|
+
format.json { render json: @widget }
|
21
|
+
end
|
22
|
+
end
|
23
|
+
|
24
|
+
# GET /widgets/new
|
25
|
+
# GET /widgets/new.json
|
26
|
+
def new
|
27
|
+
@widget = Widget.new
|
28
|
+
|
29
|
+
respond_to do |format|
|
30
|
+
format.html # new.html.erb
|
31
|
+
format.json { render json: @widget }
|
32
|
+
end
|
33
|
+
end
|
34
|
+
|
35
|
+
# GET /widgets/1/edit
|
36
|
+
def edit
|
37
|
+
@widget = Widget.find(params[:id])
|
38
|
+
end
|
39
|
+
|
40
|
+
# POST /widgets
|
41
|
+
# POST /widgets.json
|
42
|
+
def create
|
43
|
+
@widget = Widget.new(params[:widget])
|
44
|
+
|
45
|
+
respond_to do |format|
|
46
|
+
if @widget.save
|
47
|
+
format.html { redirect_to @widget, notice: 'Widget was successfully created.' }
|
48
|
+
format.json { render json: @widget, status: :created, location: @widget }
|
49
|
+
else
|
50
|
+
format.html { render action: "new" }
|
51
|
+
format.json { render json: @widget.errors, status: :unprocessable_entity }
|
52
|
+
end
|
53
|
+
end
|
54
|
+
end
|
55
|
+
|
56
|
+
# PUT /widgets/1
|
57
|
+
# PUT /widgets/1.json
|
58
|
+
def update
|
59
|
+
@widget = Widget.find(params[:id])
|
60
|
+
|
61
|
+
respond_to do |format|
|
62
|
+
if @widget.update_attributes(params[:widget])
|
63
|
+
format.html { redirect_to @widget, notice: 'Widget was successfully updated.' }
|
64
|
+
format.json { head :no_content }
|
65
|
+
else
|
66
|
+
format.html { render action: "edit" }
|
67
|
+
format.json { render json: @widget.errors, status: :unprocessable_entity }
|
68
|
+
end
|
69
|
+
end
|
70
|
+
end
|
71
|
+
|
72
|
+
# DELETE /widgets/1
|
73
|
+
# DELETE /widgets/1.json
|
74
|
+
def destroy
|
75
|
+
@widget = Widget.find(params[:id])
|
76
|
+
@widget.destroy
|
77
|
+
|
78
|
+
respond_to do |format|
|
79
|
+
format.html { redirect_to widgets_url }
|
80
|
+
format.json { head :no_content }
|
81
|
+
end
|
82
|
+
end
|
83
|
+
end
|
@@ -0,0 +1 @@
|
|
1
|
+
<%= greeting %>: <%= customer.name %>
|
@@ -0,0 +1 @@
|
|
1
|
+
<%= greeting %> good customer: <%= good_customer.name %><%= good_customer_counter %>
|
@@ -0,0 +1 @@
|
|
1
|
+
Hello: <%= customer.name rescue "Anonymous" %>
|
@@ -0,0 +1 @@
|
|
1
|
+
Hello world!
|
@@ -0,0 +1,17 @@
|
|
1
|
+
<%= form_for(@widget) do |f| %>
|
2
|
+
<% if @widget.errors.any? %>
|
3
|
+
<div id="error_explanation">
|
4
|
+
<h2><%= pluralize(@widget.errors.count, "error") %> prohibited this widget from being saved:</h2>
|
5
|
+
|
6
|
+
<ul>
|
7
|
+
<% @widget.errors.full_messages.each do |msg| %>
|
8
|
+
<li><%= msg %></li>
|
9
|
+
<% end %>
|
10
|
+
</ul>
|
11
|
+
</div>
|
12
|
+
<% end %>
|
13
|
+
|
14
|
+
<div class="actions">
|
15
|
+
<%= f.submit %>
|
16
|
+
</div>
|
17
|
+
<% end %>
|
@@ -0,0 +1,21 @@
|
|
1
|
+
<h1>Listing widgets</h1>
|
2
|
+
|
3
|
+
<table>
|
4
|
+
<tr>
|
5
|
+
<th></th>
|
6
|
+
<th></th>
|
7
|
+
<th></th>
|
8
|
+
</tr>
|
9
|
+
|
10
|
+
<% @widgets.each do |widget| %>
|
11
|
+
<tr>
|
12
|
+
<td><%= link_to 'Show', widget %></td>
|
13
|
+
<td><%= link_to 'Edit', edit_widget_path(widget) %></td>
|
14
|
+
<td><%= link_to 'Destroy', widget, method: :delete, data: { confirm: 'Are you sure?' } %></td>
|
15
|
+
</tr>
|
16
|
+
<% end %>
|
17
|
+
</table>
|
18
|
+
|
19
|
+
<br />
|
20
|
+
|
21
|
+
<%= link_to 'New Widget', new_widget_path %>
|
@@ -0,0 +1,69 @@
|
|
1
|
+
require File.expand_path('../boot', __FILE__)
|
2
|
+
|
3
|
+
# Pick the frameworks you want:
|
4
|
+
require "active_record/railtie"
|
5
|
+
require "action_controller/railtie"
|
6
|
+
require "action_mailer/railtie"
|
7
|
+
require "active_resource/railtie"
|
8
|
+
# require "sprockets/railtie"
|
9
|
+
require "rails/test_unit/railtie"
|
10
|
+
|
11
|
+
Bundler.require
|
12
|
+
require "yarder"
|
13
|
+
|
14
|
+
module Dummy
|
15
|
+
class Application < Rails::Application
|
16
|
+
# Settings in config/environments/* take precedence over those specified here.
|
17
|
+
# Application configuration should go into files in config/initializers
|
18
|
+
# -- all .rb files in that directory are automatically loaded.
|
19
|
+
|
20
|
+
# Custom directories with classes and modules you want to be autoloadable.
|
21
|
+
# config.autoload_paths += %W(#{config.root}/extras)
|
22
|
+
|
23
|
+
# Only load the plugins named here, in the order given (default is alphabetical).
|
24
|
+
# :all can be used as a placeholder for all plugins not explicitly named.
|
25
|
+
# config.plugins = [ :exception_notification, :ssl_requirement, :all ]
|
26
|
+
|
27
|
+
# Activate observers that should always be running.
|
28
|
+
# config.active_record.observers = :cacher, :garbage_collector, :forum_observer
|
29
|
+
|
30
|
+
# Set Time.zone default to the specified zone and make Active Record auto-convert to this zone.
|
31
|
+
# Run "rake -D time" for a list of tasks for finding time zone names. Default is UTC.
|
32
|
+
# config.time_zone = 'Central Time (US & Canada)'
|
33
|
+
|
34
|
+
# The default locale is :en and all translations from config/locales/*.rb,yml are auto loaded.
|
35
|
+
# config.i18n.load_path += Dir[Rails.root.join('my', 'locales', '*.{rb,yml}').to_s]
|
36
|
+
# config.i18n.default_locale = :de
|
37
|
+
|
38
|
+
# Configure the default encoding used in templates for Ruby 1.9.
|
39
|
+
config.encoding = "utf-8"
|
40
|
+
|
41
|
+
# Configure sensitive parameters which will be filtered from the log file.
|
42
|
+
config.filter_parameters += [:password]
|
43
|
+
|
44
|
+
# Enable escaping HTML in JSON.
|
45
|
+
config.active_support.escape_html_entities_in_json = true
|
46
|
+
|
47
|
+
# Use SQL instead of Active Record's schema dumper when creating the database.
|
48
|
+
# This is necessary if your schema can't be completely dumped by the schema dumper,
|
49
|
+
# like if you have constraints or database-specific column types
|
50
|
+
# config.active_record.schema_format = :sql
|
51
|
+
|
52
|
+
# Enforce whitelist mode for mass assignment.
|
53
|
+
# This will create an empty whitelist of attributes available for mass-assignment for all models
|
54
|
+
# in your app. As such, your models will need to explicitly whitelist or blacklist accessible
|
55
|
+
# parameters by using an attr_accessible or attr_protected declaration.
|
56
|
+
# config.active_record.whitelist_attributes = true
|
57
|
+
|
58
|
+
config.logger = Yarder::Logger.new(Rails.root.join('log',"#{Rails.env}.log").to_s)
|
59
|
+
|
60
|
+
config.log_tags = ["Hello", :uuid, Proc.new { "Proc" }]
|
61
|
+
|
62
|
+
# Enable the asset pipeline
|
63
|
+
config.assets.enabled = true
|
64
|
+
|
65
|
+
# Version of your assets, change this if you want to expire all your assets
|
66
|
+
config.assets.version = '1.0'
|
67
|
+
end
|
68
|
+
end
|
69
|
+
|