diff options
| -rw-r--r-- | lib/puppet/provider/vcsrepo/git.rb | 3 | ||||
| -rw-r--r-- | spec/unit/puppet/provider/vcsrepo/git_spec.rb | 2 | 
2 files changed, 3 insertions, 2 deletions
diff --git a/lib/puppet/provider/vcsrepo/git.rb b/lib/puppet/provider/vcsrepo/git.rb index 9d3f7f3..000032e 100644 --- a/lib/puppet/provider/vcsrepo/git.rb +++ b/lib/puppet/provider/vcsrepo/git.rb @@ -142,7 +142,8 @@ Puppet::Type.type(:vcsrepo).provide(:git, :parent => Puppet::Provider::Vcsrepo)      # we loop around the hash. Otherwise, we assume single url specified      # in source property      if @resource.value(:source).is_a?(Hash) -      @resource.value(:source).each do |remote_name, remote_url| +      @resource.value(:source).keys.sort.each do |remote_name| +        remote_url = @resource.value(:source)[remote_name]          at_path { do_update |= update_remote_url(remote_name, remote_url) }        end      else diff --git a/spec/unit/puppet/provider/vcsrepo/git_spec.rb b/spec/unit/puppet/provider/vcsrepo/git_spec.rb index d0153a1..d33c98a 100644 --- a/spec/unit/puppet/provider/vcsrepo/git_spec.rb +++ b/spec/unit/puppet/provider/vcsrepo/git_spec.rb @@ -263,7 +263,7 @@ branches      context "when multiple sources are modified" do        it "should update the urls" do          resource[:source] = {"origin" => "git://git@foo.com/bar.git", "new_remote" => "git://git@foo.com/baz.git"} -        provider.expects(:git).at_least_once.with('config', '-l').returns("remote.origin.url=git://git@foo.com/foo.git\n", "remote.origin.url=git://git@foo.com/bar.git\n") +        provider.expects(:git).at_least_once.with('config', '-l').returns("remote.origin.url=git://git@foo.com/bar.git\n", "remote.origin.url=git://git@foo.com/foo.git\n")          provider.expects(:git).with('remote', 'set-url', 'origin', 'git://git@foo.com/bar.git')          provider.expects(:git).with('remote', 'add', 'new_remote', 'git://git@foo.com/baz.git')          provider.expects(:git).with('remote','update')  | 
