summaryrefslogtreecommitdiffstats
path: root/lib
diff options
context:
space:
mode:
authorToshi MARUYAMA <marutosijp2@yahoo.co.jp>2011-02-15 02:12:39 +0000
committerToshi MARUYAMA <marutosijp2@yahoo.co.jp>2011-02-15 02:12:39 +0000
commit41f190e8edf0771ca63476e12e294283cdfd8a03 (patch)
tree03b97969bf5a27d26b65b622725fc28551d2b2bc /lib
parent60d80653ba4b063af233e497231e2cfe9f6ff9a0 (diff)
downloadredmine-41f190e8edf0771ca63476e12e294283cdfd8a03.tar.gz
redmine-41f190e8edf0771ca63476e12e294283cdfd8a03.zip
scm: subversion: refactor getting svn version and add lib test (#4273).
git-svn-id: svn+ssh://rubyforge.org/var/svn/redmine/trunk@4825 e93f8b46-1217-0410-a6f0-8f06a7374b81
Diffstat (limited to 'lib')
-rw-r--r--lib/redmine/scm/adapters/subversion_adapter.rb22
1 files changed, 12 insertions, 10 deletions
diff --git a/lib/redmine/scm/adapters/subversion_adapter.rb b/lib/redmine/scm/adapters/subversion_adapter.rb
index c17d7a5e4..802dc4a16 100644
--- a/lib/redmine/scm/adapters/subversion_adapter.rb
+++ b/lib/redmine/scm/adapters/subversion_adapter.rb
@@ -38,19 +38,21 @@ module Redmine
def client_version
@@client_version ||= (svn_binary_version || [])
end
+
+ def client_available
+ !client_version.empty?
+ end
def svn_binary_version
- cmd = "#{sq_bin} --version"
- version = nil
- shellout(cmd) do |io|
- # Read svn version in first returned line
- if m = io.read.to_s.match(%r{\A(.*?)((\d+\.)+\d+)})
- version = m[2].scan(%r{\d+}).collect(&:to_i)
- end
- end
- return nil if $? && $?.exitstatus != 0
- version
+ scm_version = scm_version_from_command_line
+ if m = scm_version.match(%r{\A(.*?)((\d+\.)+\d+)})
+ m[2].scan(%r{\d+}).collect(&:to_i)
+ end
end
+
+ def scm_version_from_command_line
+ shellout("#{sq_bin} --version") { |io| io.read }.to_s
+ end
end
# Get info about the svn repository