2011-09-12 12:06:31 -04:00
|
|
|
# coding:utf-8
|
2010-04-26 03:36:13 -04:00
|
|
|
require "isolation/abstract_unit"
|
2013-02-18 19:26:25 -05:00
|
|
|
require "active_support/core_ext/string/strip"
|
2010-04-26 03:36:13 -04:00
|
|
|
|
|
|
|
module ApplicationTests
|
2012-01-05 20:30:17 -05:00
|
|
|
class RakeTest < ActiveSupport::TestCase
|
2010-04-26 03:36:13 -04:00
|
|
|
include ActiveSupport::Testing::Isolation
|
|
|
|
|
|
|
|
def setup
|
|
|
|
build_app
|
|
|
|
boot_rails
|
|
|
|
FileUtils.rm_rf("#{app_path}/config/environments")
|
|
|
|
end
|
2010-06-19 11:51:29 -04:00
|
|
|
|
2011-06-06 08:54:05 -04:00
|
|
|
def teardown
|
|
|
|
teardown_app
|
|
|
|
end
|
|
|
|
|
2010-04-26 03:36:13 -04:00
|
|
|
def test_gems_tasks_are_loaded_first_than_application_ones
|
|
|
|
app_file "lib/tasks/app.rake", <<-RUBY
|
|
|
|
$task_loaded = Rake::Task.task_defined?("db:create:all")
|
|
|
|
RUBY
|
2010-08-14 01:13:00 -04:00
|
|
|
|
2010-04-26 03:36:13 -04:00
|
|
|
require "#{app_path}/config/environment"
|
|
|
|
::Rails.application.load_tasks
|
|
|
|
assert $task_loaded
|
|
|
|
end
|
2010-04-29 02:39:44 -04:00
|
|
|
|
|
|
|
def test_environment_is_required_in_rake_tasks
|
|
|
|
app_file "config/environment.rb", <<-RUBY
|
|
|
|
SuperMiddleware = Struct.new(:app)
|
|
|
|
|
2013-06-09 22:47:07 -04:00
|
|
|
Rails.application.configure do
|
2010-04-29 02:39:44 -04:00
|
|
|
config.middleware.use SuperMiddleware
|
|
|
|
end
|
|
|
|
|
2013-06-03 23:57:01 -04:00
|
|
|
Rails.application.initialize!
|
2010-04-29 02:39:44 -04:00
|
|
|
RUBY
|
|
|
|
|
2011-05-23 20:45:00 -04:00
|
|
|
assert_match("SuperMiddleware", Dir.chdir(app_path){ `rake middleware` })
|
2010-04-29 02:39:44 -04:00
|
|
|
end
|
2010-09-24 09:06:35 -04:00
|
|
|
|
2010-11-18 11:19:29 -05:00
|
|
|
def test_initializers_are_executed_in_rake_tasks
|
|
|
|
add_to_config <<-RUBY
|
|
|
|
initializer "do_something" do
|
|
|
|
puts "Doing something..."
|
|
|
|
end
|
|
|
|
|
|
|
|
rake_tasks do
|
2012-10-14 06:03:39 -04:00
|
|
|
task do_nothing: :environment do
|
2010-11-18 11:19:29 -05:00
|
|
|
end
|
|
|
|
end
|
|
|
|
RUBY
|
|
|
|
|
|
|
|
output = Dir.chdir(app_path){ `rake do_nothing` }
|
|
|
|
assert_match "Doing something...", output
|
|
|
|
end
|
|
|
|
|
2012-08-01 09:07:01 -04:00
|
|
|
def test_does_not_explode_when_accessing_a_model_with_eager_load
|
|
|
|
add_to_config <<-RUBY
|
|
|
|
config.eager_load = true
|
|
|
|
|
|
|
|
rake_tasks do
|
2012-10-14 06:03:39 -04:00
|
|
|
task do_nothing: :environment do
|
2012-08-01 09:07:01 -04:00
|
|
|
Hello.new.world
|
|
|
|
end
|
|
|
|
end
|
|
|
|
RUBY
|
|
|
|
|
|
|
|
app_file "app/models/hello.rb", <<-RUBY
|
|
|
|
class Hello
|
|
|
|
def world
|
|
|
|
puts "Hello world"
|
|
|
|
end
|
|
|
|
end
|
|
|
|
RUBY
|
|
|
|
|
|
|
|
output = Dir.chdir(app_path){ `rake do_nothing` }
|
|
|
|
assert_match "Hello world", output
|
|
|
|
end
|
|
|
|
|
2013-04-11 06:10:54 -04:00
|
|
|
def test_should_not_eager_load_model_path_for_rake
|
|
|
|
add_to_config <<-RUBY
|
|
|
|
config.eager_load = true
|
|
|
|
|
|
|
|
rake_tasks do
|
|
|
|
task do_nothing: :environment do
|
|
|
|
end
|
|
|
|
end
|
|
|
|
RUBY
|
|
|
|
|
|
|
|
app_file "app/models/hello.rb", <<-RUBY
|
|
|
|
raise 'should not be pre-required for rake even `eager_load=true`'
|
|
|
|
RUBY
|
|
|
|
|
|
|
|
Dir.chdir(app_path){ `rake do_nothing` }
|
|
|
|
end
|
|
|
|
|
2010-09-24 09:06:35 -04:00
|
|
|
def test_code_statistics_sanity
|
|
|
|
assert_match "Code LOC: 5 Test LOC: 0 Code to Test Ratio: 1:0.0",
|
|
|
|
Dir.chdir(app_path){ `rake stats` }
|
|
|
|
end
|
2010-11-09 00:10:39 -05:00
|
|
|
|
2012-11-09 18:08:30 -05:00
|
|
|
def test_rake_test_uncommitted_always_find_git_in_parent_dir
|
2013-03-30 11:25:18 -04:00
|
|
|
return "FIXME :'("
|
2012-11-09 18:08:30 -05:00
|
|
|
app_name = File.basename(app_path)
|
|
|
|
app_dir = File.dirname(app_path)
|
|
|
|
moved_app_name = app_name + '_moved'
|
|
|
|
|
|
|
|
Dir.chdir(app_dir) do
|
|
|
|
# Go from "./app/" to "./app/app_moved"
|
|
|
|
FileUtils.mv(app_name, moved_app_name)
|
|
|
|
FileUtils.mkdir(app_name)
|
|
|
|
FileUtils.mv(moved_app_name, app_name)
|
|
|
|
# Initialize the git repository and start the test.
|
|
|
|
Dir.chdir(app_name) do
|
|
|
|
`git init`
|
|
|
|
Dir.chdir(moved_app_name){ `rake db:migrate` }
|
|
|
|
silence_stderr { Dir.chdir(moved_app_name) { `rake test:uncommitted` } }
|
|
|
|
assert_equal 0, $?.exitstatus
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def test_rake_test_uncommitted_fails_with_no_scm
|
|
|
|
Dir.chdir(app_path){ `rake db:migrate` }
|
|
|
|
Dir.chdir(app_path) do
|
|
|
|
silence_stderr { `rake test:uncommitted` }
|
|
|
|
assert_equal 1, $?.exitstatus
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2013-02-25 17:04:01 -05:00
|
|
|
def test_rake_test_deprecation_messages
|
|
|
|
Dir.chdir(app_path){ `rails generate scaffold user name:string` }
|
|
|
|
Dir.chdir(app_path){ `rake db:migrate` }
|
|
|
|
|
2013-04-05 17:48:49 -04:00
|
|
|
%w(recent uncommitted).each do |test_suit_name|
|
2013-02-25 17:04:01 -05:00
|
|
|
output = Dir.chdir(app_path) { `rake test:#{test_suit_name} 2>&1` }
|
2013-04-04 00:51:43 -04:00
|
|
|
assert_match(/DEPRECATION WARNING: `rake test:#{test_suit_name}` is deprecated/, output)
|
2013-02-25 17:04:01 -05:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2011-09-09 21:50:32 -04:00
|
|
|
def test_rake_routes_calls_the_route_inspector
|
2010-11-09 00:10:39 -05:00
|
|
|
app_file "config/routes.rb", <<-RUBY
|
2013-06-09 22:47:07 -04:00
|
|
|
Rails.application.routes.draw do
|
2012-10-14 06:03:39 -04:00
|
|
|
get '/cart', to: 'cart#show'
|
2010-11-09 00:10:39 -05:00
|
|
|
end
|
|
|
|
RUBY
|
2013-02-19 07:21:03 -05:00
|
|
|
|
|
|
|
output = Dir.chdir(app_path){ `rake routes` }
|
2013-05-29 17:25:25 -04:00
|
|
|
assert_equal "Prefix Verb URI Pattern Controller#Action\ncart GET /cart(.:format) cart#show\n", output
|
|
|
|
end
|
|
|
|
|
|
|
|
def test_rake_routes_with_controller_environment
|
|
|
|
app_file "config/routes.rb", <<-RUBY
|
2013-06-09 22:47:07 -04:00
|
|
|
Rails.application.routes.draw do
|
2013-05-29 17:25:25 -04:00
|
|
|
get '/cart', to: 'cart#show'
|
|
|
|
get '/basketball', to: 'basketball#index'
|
|
|
|
end
|
|
|
|
RUBY
|
|
|
|
|
2013-05-31 10:00:58 -04:00
|
|
|
ENV['CONTROLLER'] = 'cart'
|
|
|
|
output = Dir.chdir(app_path){ `rake routes` }
|
2013-02-19 07:21:03 -05:00
|
|
|
assert_equal "Prefix Verb URI Pattern Controller#Action\ncart GET /cart(.:format) cart#show\n", output
|
2010-11-09 00:10:39 -05:00
|
|
|
end
|
2011-01-01 15:21:25 -05:00
|
|
|
|
2013-02-18 13:26:59 -05:00
|
|
|
def test_rake_routes_displays_message_when_no_routes_are_defined
|
|
|
|
app_file "config/routes.rb", <<-RUBY
|
2013-06-09 22:47:07 -04:00
|
|
|
Rails.application.routes.draw do
|
2013-02-18 13:26:59 -05:00
|
|
|
end
|
|
|
|
RUBY
|
|
|
|
|
2013-02-18 19:26:25 -05:00
|
|
|
assert_equal <<-MESSAGE.strip_heredoc, Dir.chdir(app_path){ `rake routes` }
|
|
|
|
You don't have any routes defined!
|
2013-02-18 13:26:59 -05:00
|
|
|
|
2013-02-18 19:26:25 -05:00
|
|
|
Please add some routes in config/routes.rb.
|
2013-02-18 13:26:59 -05:00
|
|
|
|
2013-02-18 19:33:50 -05:00
|
|
|
For more information about routes, see the Rails guide: http://guides.rubyonrails.org/routing.html.
|
2013-02-19 07:21:03 -05:00
|
|
|
MESSAGE
|
2013-02-18 13:26:59 -05:00
|
|
|
end
|
|
|
|
|
2011-05-05 16:51:29 -04:00
|
|
|
def test_logger_is_flushed_when_exiting_production_rake_tasks
|
|
|
|
add_to_config <<-RUBY
|
|
|
|
rake_tasks do
|
2012-10-14 06:03:39 -04:00
|
|
|
task log_something: :environment do
|
2011-05-05 16:51:29 -04:00
|
|
|
Rails.logger.error("Sample log message")
|
|
|
|
end
|
|
|
|
end
|
|
|
|
RUBY
|
|
|
|
|
|
|
|
output = Dir.chdir(app_path){ `rake log_something RAILS_ENV=production && cat log/production.log` }
|
|
|
|
assert_match "Sample log message", output
|
|
|
|
end
|
|
|
|
|
2011-01-12 18:18:45 -05:00
|
|
|
def test_loading_specific_fixtures
|
|
|
|
Dir.chdir(app_path) do
|
2012-03-08 17:32:41 -05:00
|
|
|
`rails generate model user username:string password:string;
|
|
|
|
rails generate model product name:string;
|
|
|
|
rake db:migrate`
|
2011-01-12 18:18:45 -05:00
|
|
|
end
|
|
|
|
|
|
|
|
require "#{rails_root}/config/environment"
|
2011-06-06 08:54:05 -04:00
|
|
|
|
2011-01-12 18:18:45 -05:00
|
|
|
# loading a specific fixture
|
|
|
|
errormsg = Dir.chdir(app_path) { `rake db:fixtures:load FIXTURES=products` }
|
|
|
|
assert $?.success?, errormsg
|
|
|
|
|
|
|
|
assert_equal 2, ::AppTemplate::Application::Product.count
|
|
|
|
assert_equal 0, ::AppTemplate::Application::User.count
|
|
|
|
end
|
2011-07-07 17:58:04 -04:00
|
|
|
|
2012-06-16 13:37:00 -04:00
|
|
|
def test_loading_only_yml_fixtures
|
|
|
|
Dir.chdir(app_path) do
|
|
|
|
`rake db:migrate`
|
|
|
|
end
|
|
|
|
|
|
|
|
app_file "test/fixtures/products.csv", ""
|
|
|
|
|
|
|
|
require "#{rails_root}/config/environment"
|
|
|
|
errormsg = Dir.chdir(app_path) { `rake db:fixtures:load` }
|
|
|
|
assert $?.success?, errormsg
|
|
|
|
end
|
|
|
|
|
2011-07-07 17:58:04 -04:00
|
|
|
def test_scaffold_tests_pass_by_default
|
2012-03-14 13:36:15 -04:00
|
|
|
output = Dir.chdir(app_path) do
|
2012-03-08 17:32:41 -05:00
|
|
|
`rails generate scaffold user username:string password:string;
|
|
|
|
bundle exec rake db:migrate db:test:clone test`
|
2011-07-07 17:58:04 -04:00
|
|
|
end
|
|
|
|
|
2013-05-06 20:38:45 -04:00
|
|
|
assert_match(/7 runs, 13 assertions, 0 failures, 0 errors/, output)
|
2012-03-14 13:36:15 -04:00
|
|
|
assert_no_match(/Errors running/, output)
|
|
|
|
end
|
|
|
|
|
2012-12-09 22:35:03 -05:00
|
|
|
def test_scaffold_with_references_columns_tests_pass_by_default
|
|
|
|
output = Dir.chdir(app_path) do
|
|
|
|
`rails generate scaffold LineItems product:references cart:belongs_to;
|
|
|
|
bundle exec rake db:migrate db:test:clone test`
|
|
|
|
end
|
|
|
|
|
2013-05-06 20:38:45 -04:00
|
|
|
assert_match(/7 runs, 13 assertions, 0 failures, 0 errors/, output)
|
2012-12-09 22:35:03 -05:00
|
|
|
assert_no_match(/Errors running/, output)
|
|
|
|
end
|
|
|
|
|
2012-06-25 13:33:08 -04:00
|
|
|
def test_db_test_clone_when_using_sql_format
|
|
|
|
add_to_config "config.active_record.schema_format = :sql"
|
|
|
|
output = Dir.chdir(app_path) do
|
|
|
|
`rails generate scaffold user username:string;
|
|
|
|
bundle exec rake db:migrate db:test:clone 2>&1 --trace`
|
|
|
|
end
|
|
|
|
assert_match(/Execute db:test:clone_structure/, output)
|
|
|
|
end
|
|
|
|
|
2012-06-25 13:40:06 -04:00
|
|
|
def test_db_test_prepare_when_using_sql_format
|
|
|
|
add_to_config "config.active_record.schema_format = :sql"
|
|
|
|
output = Dir.chdir(app_path) do
|
|
|
|
`rails generate scaffold user username:string;
|
2012-06-27 11:33:08 -04:00
|
|
|
bundle exec rake db:migrate db:test:prepare 2>&1 --trace`
|
2012-06-25 13:40:06 -04:00
|
|
|
end
|
|
|
|
assert_match(/Execute db:test:load_structure/, output)
|
|
|
|
end
|
|
|
|
|
2011-12-18 14:43:36 -05:00
|
|
|
def test_rake_dump_structure_should_respect_db_structure_env_variable
|
|
|
|
Dir.chdir(app_path) do
|
2012-03-08 17:32:41 -05:00
|
|
|
# ensure we have a schema_migrations table to dump
|
|
|
|
`bundle exec rake db:migrate db:structure:dump DB_STRUCTURE=db/my_structure.sql`
|
2011-12-18 14:43:36 -05:00
|
|
|
end
|
|
|
|
assert File.exists?(File.join(app_path, 'db', 'my_structure.sql'))
|
|
|
|
end
|
2012-02-29 11:01:12 -05:00
|
|
|
|
2012-03-17 00:57:10 -04:00
|
|
|
def test_rake_dump_structure_should_be_called_twice_when_migrate_redo
|
|
|
|
add_to_config "config.active_record.schema_format = :sql"
|
|
|
|
|
|
|
|
output = Dir.chdir(app_path) do
|
|
|
|
`rails g model post title:string;
|
|
|
|
bundle exec rake db:migrate:redo 2>&1 --trace;`
|
|
|
|
end
|
|
|
|
|
|
|
|
# expect only Invoke db:structure:dump (first_time)
|
|
|
|
assert_no_match(/^\*\* Invoke db:structure:dump\s+$/, output)
|
|
|
|
end
|
|
|
|
|
2012-02-29 11:01:12 -05:00
|
|
|
def test_rake_dump_schema_cache
|
|
|
|
Dir.chdir(app_path) do
|
2012-03-08 17:32:41 -05:00
|
|
|
`rails generate model post title:string;
|
|
|
|
rails generate model product name:string;
|
|
|
|
bundle exec rake db:migrate db:schema:cache:dump`
|
2012-02-29 11:01:12 -05:00
|
|
|
end
|
|
|
|
assert File.exists?(File.join(app_path, 'db', 'schema_cache.dump'))
|
|
|
|
end
|
|
|
|
|
|
|
|
def test_rake_clear_schema_cache
|
|
|
|
Dir.chdir(app_path) do
|
2012-03-08 17:32:41 -05:00
|
|
|
`bundle exec rake db:schema:cache:dump db:schema:cache:clear`
|
2012-02-29 11:01:12 -05:00
|
|
|
end
|
|
|
|
assert !File.exists?(File.join(app_path, 'db', 'schema_cache.dump'))
|
|
|
|
end
|
2012-05-28 11:10:04 -04:00
|
|
|
|
2012-06-10 10:26:55 -04:00
|
|
|
def test_copy_templates
|
|
|
|
Dir.chdir(app_path) do
|
|
|
|
`bundle exec rake rails:templates:copy`
|
|
|
|
%w(controller mailer scaffold).each do |dir|
|
|
|
|
assert File.exists?(File.join(app_path, 'lib', 'templates', 'erb', dir))
|
|
|
|
end
|
|
|
|
%w(controller helper scaffold_controller assets).each do |dir|
|
|
|
|
assert File.exists?(File.join(app_path, 'lib', 'templates', 'rails', dir))
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
2010-04-26 03:36:13 -04:00
|
|
|
end
|
2011-09-09 21:50:32 -04:00
|
|
|
end
|