aboutsummaryrefslogtreecommitdiffstats
path: root/railties
diff options
context:
space:
mode:
authorSam Stephenson <sam@37signals.com>2005-11-07 04:06:05 +0000
committerSam Stephenson <sam@37signals.com>2005-11-07 04:06:05 +0000
commit5c1eb899dea9aad18220b6403d3dd83863591f28 (patch)
treee17db707a217fa177e23e38ca8fffd91908bcbb5 /railties
parent5feb3124d431b69e9c4921857289593a655f2e86 (diff)
downloadrails-5c1eb899dea9aad18220b6403d3dd83863591f28.tar.gz
rails-5c1eb899dea9aad18220b6403d3dd83863591f28.tar.bz2
rails-5c1eb899dea9aad18220b6403d3dd83863591f28.zip
Make use of silence_stderr in script/lighttpd, script/plugin, and Rails::Info
git-svn-id: http://svn-commit.rubyonrails.org/rails/trunk@2903 5ecf4fe2-1ee6-0310-87b1-e25e094e27de
Diffstat (limited to 'railties')
-rw-r--r--railties/CHANGELOG2
-rw-r--r--railties/lib/commands/lighttpd.rb4
-rw-r--r--railties/lib/commands/plugin.rb2
-rw-r--r--railties/lib/rails_info.rb6
-rw-r--r--railties/test/rails_info_test.rb41
5 files changed, 39 insertions, 16 deletions
diff --git a/railties/CHANGELOG b/railties/CHANGELOG
index 2363bb805c..f3c9e0eb96 100644
--- a/railties/CHANGELOG
+++ b/railties/CHANGELOG
@@ -1,5 +1,7 @@
*SVN*
+* Make use of silence_stderr in script/lighttpd, script/plugin, and Rails::Info [Sam Stephenson]
+
* Enable HTTP installation of plugins when svn isn't avaialable. Closes #2661. [Chad Fowler]
* Load Rails::Info after initialization [Sam Stephenson]
diff --git a/railties/lib/commands/lighttpd.rb b/railties/lib/commands/lighttpd.rb
index 73bd466446..df6ad663f9 100644
--- a/railties/lib/commands/lighttpd.rb
+++ b/railties/lib/commands/lighttpd.rb
@@ -1,4 +1,6 @@
-unless RUBY_PLATFORM !~ /mswin/ && `lighttpd -version 2>/dev/null`.size > 0
+require 'active_support'
+
+unless RUBY_PLATFORM !~ /mswin/ && !silence_stderr { `lighttpd -version` }.blank?
puts "lighttpd is not available on your system (or not in your path)"
exit 1
end
diff --git a/railties/lib/commands/plugin.rb b/railties/lib/commands/plugin.rb
index dc702fb4bb..4dd8689345 100644
--- a/railties/lib/commands/plugin.rb
+++ b/railties/lib/commands/plugin.rb
@@ -119,7 +119,7 @@ class RailsEnvironment
def externals
return [] unless use_externals?
- ext = `svn propget svn:externals #{root}/vendor/plugins 2> /dev/null`
+ ext = silence_stderr { `svn propget svn:externals #{root}/vendor/plugins` }
ext.reject{ |line| line.strip == '' }.map do |line|
line.strip.split(/\s+/, 2)
end
diff --git a/railties/lib/rails_info.rb b/railties/lib/rails_info.rb
index edd90b36ad..c0237dab7c 100644
--- a/railties/lib/rails_info.rb
+++ b/railties/lib/rails_info.rb
@@ -29,8 +29,8 @@ module Rails
"#{component.classify}::Version::STRING".constantize
end
- def edge_rails_revision
- svn_info[/^Revision: (\d+)/, 1] || 'unknown'
+ def edge_rails_revision(info = svn_info)
+ info[/^Revision: (\d+)/, 1]
end
def to_s
@@ -45,7 +45,7 @@ module Rails
protected
def svn_info
Dir.chdir("#{RAILS_ROOT}/vendor/rails") do
- IO.popen('svn info') { |f| f.read }
+ silence_stderr { `svn info` }
end
end
end
diff --git a/railties/test/rails_info_test.rb b/railties/test/rails_info_test.rb
index 4d85d8dae8..e3daf0bcd5 100644
--- a/railties/test/rails_info_test.rb
+++ b/railties/test/rails_info_test.rb
@@ -5,10 +5,22 @@ require 'test/unit'
require 'active_support'
require 'rails_info'
-class << Rails::Info
-protected
- def svn_info
- <<-EOS
+class InfoTest < Test::Unit::TestCase
+ def setup
+ Rails.send :remove_const, :Info
+ silence_warnings { load 'rails_info.rb' }
+ end
+
+ def test_edge_rails_revision_not_set_when_svn_info_is_empty
+ Rails::Info.property 'Test that this will not be defined' do
+ Rails::Info.edge_rails_revision ''
+ end
+ assert !property_defined?('Test that this will not be defined')
+ end
+
+ def test_edge_rails_revision_extracted_from_svn_info
+ Rails::Info.property 'Test Edge Rails revision' do
+ Rails::Info.edge_rails_revision <<-EOS
Path: .
URL: http://www.rubyonrails.com/svn/rails/trunk
Repository UUID: 5ecf4fe2-1ee6-0310-87b1-e25e094e27de
@@ -20,13 +32,10 @@ Last Changed Rev: 2881
Last Changed Date: 2005-11-04 21:04:41 -0600 (Fri, 04 Nov 2005)
Properties Last Updated: 2005-10-28 19:30:00 -0500 (Fri, 28 Oct 2005)
- EOS
- end
-end
-
-class InfoTest < Test::Unit::TestCase
- def test_edge_rails_revision_extracted_from_svn_info
- assert_equal '2881', Rails::Info.edge_rails_revision
+EOS
+ end
+
+ assert_property 'Test Edge Rails revision', '2881'
end
def test_property_with_block_swallows_exceptions_and_ignores_property
@@ -57,6 +66,16 @@ class InfoTest < Test::Unit::TestCase
end
protected
+ def svn_info=(info)
+ Rails::Info.module_eval do
+ class << self
+ def svn_info
+ info
+ end
+ end
+ end
+ end
+
def properties
Rails::Info.properties
end