]> source.dussan.org Git - redmine.git/commitdiff
scm: subversion: refactor getting svn version and add lib test (#4273).
authorToshi MARUYAMA <marutosijp2@yahoo.co.jp>
Tue, 15 Feb 2011 02:12:39 +0000 (02:12 +0000)
committerToshi MARUYAMA <marutosijp2@yahoo.co.jp>
Tue, 15 Feb 2011 02:12:39 +0000 (02:12 +0000)
git-svn-id: svn+ssh://rubyforge.org/var/svn/redmine/trunk@4825 e93f8b46-1217-0410-a6f0-8f06a7374b81

lib/redmine/scm/adapters/subversion_adapter.rb
test/unit/lib/redmine/scm/adapters/subversion_adapter_test.rb

index c17d7a5e41469a32b9668a39a3bbdeded390fd4e..802dc4a167ccd7355f15adc380d2f25b85c4a4a2 100644 (file)
@@ -38,19 +38,21 @@ module Redmine
           def client_version\r
             @@client_version ||= (svn_binary_version || [])\r
           end\r
+
+          def client_available
+            !client_version.empty?
+          end
 \r
           def svn_binary_version\r
-            cmd = "#{sq_bin} --version"\r
-            version = nil\r
-            shellout(cmd) do |io|\r
-              # Read svn version in first returned line\r
-              if m = io.read.to_s.match(%r{\A(.*?)((\d+\.)+\d+)})\r
-                version = m[2].scan(%r{\d+}).collect(&:to_i)\r
-              end\r
-            end\r
-            return nil if $? && $?.exitstatus != 0\r
-            version\r
+            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\r
+
+          def scm_version_from_command_line
+            shellout("#{sq_bin} --version") { |io| io.read }.to_s
+          end
         end\r
 \r
         # Get info about the svn repository\r
index 966a829204b95a44a2b1859f62844d7bc9baf093..1d8b9cbe6e6a1f87713aa8bc5c942a8c85d8f1b5 100644 (file)
@@ -24,12 +24,32 @@ begin
   
     if repository_configured?('subversion')
       def setup
+        repo_path = "file://#{self.class.repository_path('subversion')}"
+        @adapter = Redmine::Scm::Adapters::SubversionAdapter.new(repo_path)
       end
 
       def test_client_version
         v = Redmine::Scm::Adapters::SubversionAdapter.client_version
         assert v.is_a?(Array)
       end
+
+      def test_scm_version
+        to_test = { "svn, version 1.6.13 (r1002816)\n"  => [1,6,13],
+                    "svn, versione 1.6.13 (r1002816)\n" => [1,6,13],
+                    "1.6.1\n1.7\n1.8"                   => [1,6,1],
+                    "1.6.2\r\n1.8.1\r\n1.9.1"           => [1,6,2]}
+        to_test.each do |s, v|
+          test_scm_version_for(s, v)
+        end
+      end
+
+      private
+
+      def test_scm_version_for(scm_version, version)
+        @adapter.class.expects(:scm_version_from_command_line).returns(scm_version)
+        assert_equal version, @adapter.class.svn_binary_version
+      end
+
     else
       puts "Subversion test repository NOT FOUND. Skipping unit tests !!!"
       def test_fake; assert true end