test_squad 0.0.1
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +7 -0
- data/MIT-LICENSE +20 -0
- data/README.md +194 -0
- data/Rakefile +18 -0
- data/app/assets/javascripts/jasmine/boot.js +67 -0
- data/app/assets/javascripts/test_squad/jasmine-phantom.js +85 -0
- data/app/assets/javascripts/test_squad/mocha-reporter.js +104 -0
- data/app/assets/javascripts/test_squad/qunit-phantom.js +84 -0
- data/app/assets/stylesheets/test_squad/ember.css +16 -0
- data/app/controllers/test_squad_controller.rb +6 -0
- data/app/views/test_squad/ember.html.erb +14 -0
- data/app/views/test_squad/jasmine.html.erb +15 -0
- data/app/views/test_squad/mocha.html.erb +11 -0
- data/app/views/test_squad/qunit.html.erb +13 -0
- data/config/routes.rb +5 -0
- data/lib/generators/test_squad/install/USAGE +8 -0
- data/lib/generators/test_squad/install/install_generator.rb +86 -0
- data/lib/generators/test_squad/install/templates/ember/router_test.js +11 -0
- data/lib/generators/test_squad/install/templates/ember/test_helper.js.erb +15 -0
- data/lib/generators/test_squad/install/templates/jasmine/answer_spec.js +6 -0
- data/lib/generators/test_squad/install/templates/jasmine/spec_helper.js.erb +3 -0
- data/lib/generators/test_squad/install/templates/mocha/answer_spec.js +6 -0
- data/lib/generators/test_squad/install/templates/mocha/spec_helper.js.erb +12 -0
- data/lib/generators/test_squad/install/templates/qunit/answer_test.js +6 -0
- data/lib/generators/test_squad/install/templates/qunit/test_helper.js.erb +3 -0
- data/lib/generators/test_squad/install/templates/test_squad.rb.erb +5 -0
- data/lib/tasks/test_squad_tasks.rake +39 -0
- data/lib/terminal.png +0 -0
- data/lib/test_squad.rb +26 -0
- data/lib/test_squad/engine.rb +36 -0
- data/lib/test_squad/version.rb +3 -0
- data/phantomjs/helpers.js +24 -0
- data/phantomjs/runner.js +176 -0
- data/test/dummy/README.rdoc +28 -0
- data/test/dummy/Rakefile +6 -0
- data/test/dummy/app/assets/javascripts/application.js +13 -0
- data/test/dummy/app/assets/stylesheets/application.css +15 -0
- data/test/dummy/app/controllers/application_controller.rb +5 -0
- data/test/dummy/app/helpers/application_helper.rb +2 -0
- data/test/dummy/app/views/layouts/application.html.erb +14 -0
- data/test/dummy/bin/bundle +3 -0
- data/test/dummy/bin/rails +4 -0
- data/test/dummy/bin/rake +4 -0
- data/test/dummy/bin/setup +29 -0
- data/test/dummy/config.ru +4 -0
- data/test/dummy/config/application.rb +29 -0
- data/test/dummy/config/boot.rb +5 -0
- data/test/dummy/config/environment.rb +5 -0
- data/test/dummy/config/environments/development.rb +38 -0
- data/test/dummy/config/environments/production.rb +76 -0
- data/test/dummy/config/environments/test.rb +42 -0
- data/test/dummy/config/initializers/assets.rb +11 -0
- data/test/dummy/config/initializers/backtrace_silencers.rb +7 -0
- data/test/dummy/config/initializers/cookies_serializer.rb +3 -0
- data/test/dummy/config/initializers/filter_parameter_logging.rb +4 -0
- data/test/dummy/config/initializers/inflections.rb +16 -0
- data/test/dummy/config/initializers/mime_types.rb +4 -0
- data/test/dummy/config/initializers/session_store.rb +3 -0
- data/test/dummy/config/initializers/wrap_parameters.rb +9 -0
- data/test/dummy/config/locales/en.yml +23 -0
- data/test/dummy/config/routes.rb +56 -0
- data/test/dummy/config/secrets.yml +22 -0
- data/test/dummy/public/404.html +67 -0
- data/test/dummy/public/422.html +67 -0
- data/test/dummy/public/500.html +66 -0
- data/test/dummy/public/favicon.ico +0 -0
- data/test/integration/navigation_test.rb +9 -0
- data/test/lib/generators/squad/install_generator_test.rb +14 -0
- data/test/test_helper.rb +17 -0
- data/test/test_squad_test.rb +7 -0
- data/vendor/assets/libs/jasmine/boot.js +120 -0
- data/vendor/assets/libs/jasmine/console.js +190 -0
- data/vendor/assets/libs/jasmine/jasmine-html.js +404 -0
- data/vendor/assets/libs/jasmine/jasmine.css +62 -0
- data/vendor/assets/libs/jasmine/jasmine.js +2908 -0
- data/vendor/assets/libs/jasmine/jasmine_favicon.png +0 -0
- metadata +186 -0
@@ -0,0 +1,24 @@
|
|
1
|
+
var system = require('system');
|
2
|
+
|
3
|
+
var COLORS = {
|
4
|
+
red: '\033[31m',
|
5
|
+
green: '\033[32m',
|
6
|
+
yellow: '\033[33m',
|
7
|
+
gray: '\033[0;37m',
|
8
|
+
clear: '\033[0m'
|
9
|
+
};
|
10
|
+
|
11
|
+
function colored(message, color) {
|
12
|
+
var color = COLORS[color] || COLORS.clear;
|
13
|
+
|
14
|
+
return color + message + COLORS.clear;
|
15
|
+
}
|
16
|
+
|
17
|
+
function output(message, color) {
|
18
|
+
system.stdout.write(colored(message, color));
|
19
|
+
}
|
20
|
+
|
21
|
+
module.exports = {
|
22
|
+
colored: colored,
|
23
|
+
output: output
|
24
|
+
};
|
data/phantomjs/runner.js
ADDED
@@ -0,0 +1,176 @@
|
|
1
|
+
(function () {
|
2
|
+
'use strict';
|
3
|
+
|
4
|
+
var system = require('system');
|
5
|
+
var webpage = require('webpage');
|
6
|
+
var output = require('./helpers').output;
|
7
|
+
var colored = require('./helpers').colored;
|
8
|
+
|
9
|
+
var args = system.args;
|
10
|
+
var url = args[1];
|
11
|
+
var timeout = parseInt(args[2], 10);
|
12
|
+
var enableLog = args[3] !== 'false';
|
13
|
+
var page = webpage.create();
|
14
|
+
var suites = [];
|
15
|
+
var suite, test;
|
16
|
+
var errorBuffer = [];
|
17
|
+
var pendingBuffer = [];
|
18
|
+
|
19
|
+
page.viewportSize = {
|
20
|
+
width: 800,
|
21
|
+
height: 800
|
22
|
+
};
|
23
|
+
|
24
|
+
var testOutput = function(test) {
|
25
|
+
if (test.passed) {
|
26
|
+
output('•', 'green');
|
27
|
+
} else if (test.pending) {
|
28
|
+
output('*', 'yellow');
|
29
|
+
pendingBuffer.push(testDescription(test, 'yellow'));
|
30
|
+
} else {
|
31
|
+
output('×', 'red');
|
32
|
+
errorBuffer.push(testDescription(test, 'red'));
|
33
|
+
}
|
34
|
+
};
|
35
|
+
|
36
|
+
var testDescription = function(test, color) {
|
37
|
+
var status = test.pending? '[PENDING]' : '[FAILURE]';
|
38
|
+
|
39
|
+
var description = test.suites.map(function(suite) {
|
40
|
+
return suite.title;
|
41
|
+
}).join(' ') + ' ' + test.title;
|
42
|
+
|
43
|
+
description = status + ' ' + description.replace(/^\s+/gm, '');
|
44
|
+
|
45
|
+
if (test.failure) {
|
46
|
+
description += '\n';
|
47
|
+
description += test.failure.replace(/^\s*/gm, ' ');
|
48
|
+
}
|
49
|
+
|
50
|
+
description = colored(description, color);
|
51
|
+
|
52
|
+
if (test.logging.length) {
|
53
|
+
description += '\n';
|
54
|
+
|
55
|
+
for (var i = 0; i < test.logging.length; i++) {
|
56
|
+
var lines = test.logging[i].split(/\r?\n/);
|
57
|
+
description += '\n';
|
58
|
+
description += colored(' => ' + lines.shift(), 'gray');
|
59
|
+
|
60
|
+
if (lines.length > 0) {
|
61
|
+
description += '\n';
|
62
|
+
description += colored(lines.join('\n').replace(/^/gm, ' '), 'gray');
|
63
|
+
}
|
64
|
+
}
|
65
|
+
}
|
66
|
+
|
67
|
+
return description;
|
68
|
+
};
|
69
|
+
|
70
|
+
var pluralize = function(count, singular, plural) {
|
71
|
+
if (!plural) {
|
72
|
+
plural = singular + 's';
|
73
|
+
}
|
74
|
+
|
75
|
+
return count + ' ' + (count === 1 ? singular : plural);
|
76
|
+
}
|
77
|
+
|
78
|
+
page.onConsoleMessage = function(message, lineNumber, sourceId) {
|
79
|
+
if (test) {
|
80
|
+
test.logging.push(message);
|
81
|
+
} else {
|
82
|
+
console.log(colored('=> ' + message, 'gray'));
|
83
|
+
}
|
84
|
+
};
|
85
|
+
|
86
|
+
page.onCallback = function(message){
|
87
|
+
if (message.name === 'suite start') {
|
88
|
+
suite = {tests: []};
|
89
|
+
suite.title = message.title;
|
90
|
+
|
91
|
+
if (message.title) {
|
92
|
+
suites.push(suite);
|
93
|
+
}
|
94
|
+
} else if (message.name === 'suite end') {
|
95
|
+
suites = [];
|
96
|
+
} else if (message.name === 'test start') {
|
97
|
+
test = {logging: []};
|
98
|
+
test.suites = suites;
|
99
|
+
suite.tests.push(test);
|
100
|
+
} else if (message.name === 'test end') {
|
101
|
+
test.title = message.title;
|
102
|
+
test.passed = message.passed;
|
103
|
+
test.pending = message.pending;
|
104
|
+
test.failure = message.failure;
|
105
|
+
testOutput(test);
|
106
|
+
test = null;
|
107
|
+
} else if (message.name === 'end') {
|
108
|
+
var stats = message.stats;
|
109
|
+
var summary = [];
|
110
|
+
var color;
|
111
|
+
var hasErrorBuffer = errorBuffer.length > 0;
|
112
|
+
var hasPendingBuffer = pendingBuffer.length > 0;
|
113
|
+
|
114
|
+
if (hasErrorBuffer || hasPendingBuffer) {
|
115
|
+
console.log('');
|
116
|
+
}
|
117
|
+
|
118
|
+
if (hasErrorBuffer) {
|
119
|
+
console.log('\n' + errorBuffer.join('\n\n'));
|
120
|
+
}
|
121
|
+
|
122
|
+
if (hasPendingBuffer) {
|
123
|
+
console.log('\n' + pendingBuffer.join('\n'));
|
124
|
+
}
|
125
|
+
|
126
|
+
console.log('');
|
127
|
+
|
128
|
+
if (stats.tests > 0) {
|
129
|
+
summary.push(pluralize(stats.tests, 'test'));
|
130
|
+
stats.assertions && summary.push(pluralize(stats.assertions, 'assertion'));
|
131
|
+
stats.pending && summary.push(pluralize(stats.pending, 'test') + ' pending');
|
132
|
+
stats.fails && summary.push(pluralize(stats.fails, 'test') + ' failed');
|
133
|
+
} else {
|
134
|
+
summary.push('No tests were found.');
|
135
|
+
}
|
136
|
+
|
137
|
+
if (stats.fails) {
|
138
|
+
color = 'red';
|
139
|
+
} else if (stats.pending) {
|
140
|
+
color = 'yellow';
|
141
|
+
} else {
|
142
|
+
console.log('');
|
143
|
+
color = 'green';
|
144
|
+
}
|
145
|
+
|
146
|
+
summary = colored(summary.join(', '), color);
|
147
|
+
summary += colored(' (' + (stats.elapsed / 1000) + 's)', 'gray');
|
148
|
+
|
149
|
+
console.log(summary);
|
150
|
+
exit(stats.fails ? 1 : 0);
|
151
|
+
}
|
152
|
+
};
|
153
|
+
|
154
|
+
page.open(url, function(status){
|
155
|
+
if (status !== 'success') {
|
156
|
+
console.error('Unable to access network: ' + status);
|
157
|
+
exit(1);
|
158
|
+
} else {
|
159
|
+
// Set a timeout on the test running, otherwise tests with async problems will hang forever
|
160
|
+
setTimeout(function(){
|
161
|
+
console.error('The specified timeout of ' + timeout + ' seconds has expired. Aborting...');
|
162
|
+
exit(1);
|
163
|
+
}, timeout * 1000);
|
164
|
+
}
|
165
|
+
});
|
166
|
+
|
167
|
+
function exit(code) {
|
168
|
+
if (page) {
|
169
|
+
page.close();
|
170
|
+
}
|
171
|
+
|
172
|
+
setTimeout(function(){
|
173
|
+
phantom.exit(code);
|
174
|
+
}, 0);
|
175
|
+
}
|
176
|
+
})();
|
@@ -0,0 +1,28 @@
|
|
1
|
+
== README
|
2
|
+
|
3
|
+
This README would normally document whatever steps are necessary to get the
|
4
|
+
application up and running.
|
5
|
+
|
6
|
+
Things you may want to cover:
|
7
|
+
|
8
|
+
* Ruby version
|
9
|
+
|
10
|
+
* System dependencies
|
11
|
+
|
12
|
+
* Configuration
|
13
|
+
|
14
|
+
* Database creation
|
15
|
+
|
16
|
+
* Database initialization
|
17
|
+
|
18
|
+
* How to run the test suite
|
19
|
+
|
20
|
+
* Services (job queues, cache servers, search engines, etc.)
|
21
|
+
|
22
|
+
* Deployment instructions
|
23
|
+
|
24
|
+
* ...
|
25
|
+
|
26
|
+
|
27
|
+
Please feel free to use a different markup language if you do not plan to run
|
28
|
+
<tt>rake doc:app</tt>.
|
data/test/dummy/Rakefile
ADDED
@@ -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 any plugin's vendor/assets/javascripts directory 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
|
+
// compiled file.
|
9
|
+
//
|
10
|
+
// Read Sprockets README (https://github.com/sstephenson/sprockets#sprockets-directives) for details
|
11
|
+
// about supported directives.
|
12
|
+
//
|
13
|
+
//= require_tree .
|
@@ -0,0 +1,15 @@
|
|
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 any plugin's vendor/assets/stylesheets directory 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 bottom of the
|
9
|
+
* compiled file so the styles you add here take precedence over styles defined in any styles
|
10
|
+
* defined in the other CSS/SCSS files in this directory. It is generally better to create a new
|
11
|
+
* file per style scope.
|
12
|
+
*
|
13
|
+
*= require_tree .
|
14
|
+
*= require_self
|
15
|
+
*/
|
@@ -0,0 +1,14 @@
|
|
1
|
+
<!DOCTYPE html>
|
2
|
+
<html>
|
3
|
+
<head>
|
4
|
+
<title>Dummy</title>
|
5
|
+
<%= stylesheet_link_tag 'application', media: 'all', 'data-turbolinks-track' => true %>
|
6
|
+
<%= javascript_include_tag 'application', 'data-turbolinks-track' => true %>
|
7
|
+
<%= csrf_meta_tags %>
|
8
|
+
</head>
|
9
|
+
<body>
|
10
|
+
|
11
|
+
<%= yield %>
|
12
|
+
|
13
|
+
</body>
|
14
|
+
</html>
|
data/test/dummy/bin/rake
ADDED
@@ -0,0 +1,29 @@
|
|
1
|
+
#!/usr/bin/env ruby
|
2
|
+
require 'pathname'
|
3
|
+
|
4
|
+
# path to your application root.
|
5
|
+
APP_ROOT = Pathname.new File.expand_path('../../', __FILE__)
|
6
|
+
|
7
|
+
Dir.chdir APP_ROOT do
|
8
|
+
# This script is a starting point to setup your application.
|
9
|
+
# Add necessary setup steps to this file:
|
10
|
+
|
11
|
+
puts "== Installing dependencies =="
|
12
|
+
system "gem install bundler --conservative"
|
13
|
+
system "bundle check || bundle install"
|
14
|
+
|
15
|
+
# puts "\n== Copying sample files =="
|
16
|
+
# unless File.exist?("config/database.yml")
|
17
|
+
# system "cp config/database.yml.sample config/database.yml"
|
18
|
+
# end
|
19
|
+
|
20
|
+
puts "\n== Preparing database =="
|
21
|
+
system "bin/rake db:setup"
|
22
|
+
|
23
|
+
puts "\n== Removing old logs and tempfiles =="
|
24
|
+
system "rm -f log/*"
|
25
|
+
system "rm -rf tmp/cache"
|
26
|
+
|
27
|
+
puts "\n== Restarting application server =="
|
28
|
+
system "touch tmp/restart.txt"
|
29
|
+
end
|
@@ -0,0 +1,29 @@
|
|
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 "action_view/railtie"
|
8
|
+
require "sprockets/railtie"
|
9
|
+
require "rails/test_unit/railtie"
|
10
|
+
|
11
|
+
Bundler.require(*Rails.groups)
|
12
|
+
require "test_squad"
|
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
|
+
# Set Time.zone default to the specified zone and make Active Record auto-convert to this zone.
|
21
|
+
# Run "rake -D time" for a list of tasks for finding time zone names. Default is UTC.
|
22
|
+
# config.time_zone = 'Central Time (US & Canada)'
|
23
|
+
|
24
|
+
# The default locale is :en and all translations from config/locales/*.rb,yml are auto loaded.
|
25
|
+
# config.i18n.load_path += Dir[Rails.root.join('my', 'locales', '*.{rb,yml}').to_s]
|
26
|
+
# config.i18n.default_locale = :de
|
27
|
+
end
|
28
|
+
end
|
29
|
+
|
@@ -0,0 +1,38 @@
|
|
1
|
+
Rails.application.configure do
|
2
|
+
# Settings specified here will take precedence over those in config/application.rb.
|
3
|
+
|
4
|
+
# In the development environment your application's code is reloaded on
|
5
|
+
# every request. This slows down response time but is perfect for development
|
6
|
+
# since you don't have to restart the web server when you make code changes.
|
7
|
+
config.cache_classes = false
|
8
|
+
|
9
|
+
# Do not eager load code on boot.
|
10
|
+
config.eager_load = false
|
11
|
+
|
12
|
+
# Show full error reports and disable caching.
|
13
|
+
config.consider_all_requests_local = true
|
14
|
+
config.action_controller.perform_caching = false
|
15
|
+
|
16
|
+
# Don't care if the mailer can't send.
|
17
|
+
config.action_mailer.raise_delivery_errors = false
|
18
|
+
|
19
|
+
# Print deprecation notices to the Rails logger.
|
20
|
+
config.active_support.deprecation = :log
|
21
|
+
|
22
|
+
# Debug mode disables concatenation and preprocessing of assets.
|
23
|
+
# This option may cause significant delays in view rendering with a large
|
24
|
+
# number of complex assets.
|
25
|
+
config.assets.debug = true
|
26
|
+
|
27
|
+
# Asset digests allow you to set far-future HTTP expiration dates on all assets,
|
28
|
+
# yet still be able to expire them through the digest params.
|
29
|
+
config.assets.digest = true
|
30
|
+
|
31
|
+
# Adds additional error checking when serving assets at runtime.
|
32
|
+
# Checks for improperly declared sprockets dependencies.
|
33
|
+
# Raises helpful error messages.
|
34
|
+
config.assets.raise_runtime_errors = true
|
35
|
+
|
36
|
+
# Raises error for missing translations
|
37
|
+
# config.action_view.raise_on_missing_translations = true
|
38
|
+
end
|
@@ -0,0 +1,76 @@
|
|
1
|
+
Rails.application.configure do
|
2
|
+
# Settings specified here will take precedence over those in config/application.rb.
|
3
|
+
|
4
|
+
# Code is not reloaded between requests.
|
5
|
+
config.cache_classes = true
|
6
|
+
|
7
|
+
# Eager load code on boot. This eager loads most of Rails and
|
8
|
+
# your application in memory, allowing both threaded web servers
|
9
|
+
# and those relying on copy on write to perform better.
|
10
|
+
# Rake tasks automatically ignore this option for performance.
|
11
|
+
config.eager_load = true
|
12
|
+
|
13
|
+
# Full error reports are disabled and caching is turned on.
|
14
|
+
config.consider_all_requests_local = false
|
15
|
+
config.action_controller.perform_caching = true
|
16
|
+
|
17
|
+
# Enable Rack::Cache to put a simple HTTP cache in front of your application
|
18
|
+
# Add `rack-cache` to your Gemfile before enabling this.
|
19
|
+
# For large-scale production use, consider using a caching reverse proxy like
|
20
|
+
# NGINX, varnish or squid.
|
21
|
+
# config.action_dispatch.rack_cache = true
|
22
|
+
|
23
|
+
# Disable serving static files from the `/public` folder by default since
|
24
|
+
# Apache or NGINX already handles this.
|
25
|
+
config.serve_static_files = ENV['RAILS_SERVE_STATIC_FILES'].present?
|
26
|
+
|
27
|
+
# Compress JavaScripts and CSS.
|
28
|
+
config.assets.js_compressor = :uglifier
|
29
|
+
# config.assets.css_compressor = :sass
|
30
|
+
|
31
|
+
# Do not fallback to assets pipeline if a precompiled asset is missed.
|
32
|
+
config.assets.compile = false
|
33
|
+
|
34
|
+
# Asset digests allow you to set far-future HTTP expiration dates on all assets,
|
35
|
+
# yet still be able to expire them through the digest params.
|
36
|
+
config.assets.digest = true
|
37
|
+
|
38
|
+
# `config.assets.precompile` and `config.assets.version` have moved to config/initializers/assets.rb
|
39
|
+
|
40
|
+
# Specifies the header that your server uses for sending files.
|
41
|
+
# config.action_dispatch.x_sendfile_header = 'X-Sendfile' # for Apache
|
42
|
+
# config.action_dispatch.x_sendfile_header = 'X-Accel-Redirect' # for NGINX
|
43
|
+
|
44
|
+
# Force all access to the app over SSL, use Strict-Transport-Security, and use secure cookies.
|
45
|
+
# config.force_ssl = true
|
46
|
+
|
47
|
+
# Use the lowest log level to ensure availability of diagnostic information
|
48
|
+
# when problems arise.
|
49
|
+
config.log_level = :debug
|
50
|
+
|
51
|
+
# Prepend all log lines with the following tags.
|
52
|
+
# config.log_tags = [ :subdomain, :uuid ]
|
53
|
+
|
54
|
+
# Use a different logger for distributed setups.
|
55
|
+
# config.logger = ActiveSupport::TaggedLogging.new(SyslogLogger.new)
|
56
|
+
|
57
|
+
# Use a different cache store in production.
|
58
|
+
# config.cache_store = :mem_cache_store
|
59
|
+
|
60
|
+
# Enable serving of images, stylesheets, and JavaScripts from an asset server.
|
61
|
+
# config.action_controller.asset_host = 'http://assets.example.com'
|
62
|
+
|
63
|
+
# Ignore bad email addresses and do not raise email delivery errors.
|
64
|
+
# Set this to true and configure the email server for immediate delivery to raise delivery errors.
|
65
|
+
# config.action_mailer.raise_delivery_errors = false
|
66
|
+
|
67
|
+
# Enable locale fallbacks for I18n (makes lookups for any locale fall back to
|
68
|
+
# the I18n.default_locale when a translation cannot be found).
|
69
|
+
config.i18n.fallbacks = true
|
70
|
+
|
71
|
+
# Send deprecation notices to registered listeners.
|
72
|
+
config.active_support.deprecation = :notify
|
73
|
+
|
74
|
+
# Use default logging formatter so that PID and timestamp are not suppressed.
|
75
|
+
config.log_formatter = ::Logger::Formatter.new
|
76
|
+
end
|