diff options
author | Dmitriy Zaporozhets <dmitriy.zaporozhets@gmail.com> | 2013-03-25 23:29:37 -0700 |
---|---|---|
committer | Dmitriy Zaporozhets <dmitriy.zaporozhets@gmail.com> | 2013-03-25 23:29:37 -0700 |
commit | 05382645f0bd3a28d114ef4b21f334372737685e (patch) | |
tree | a5ef146a1ea12b29e622adbba29b23601d7ac62d | |
parent | 02c7da2e484478a88825f2350a391c13773944ab (diff) | |
parent | 7d4780eca8dc964ac5b825b183a1fd73a074514e (diff) | |
download | gitlab-shell-05382645f0bd3a28d114ef4b21f334372737685e.tar.gz |
Merge pull request #16 from docwhat/exec
Improve gitlab_shell spec and replace `system()` with `exec()`
-rw-r--r-- | lib/gitlab_shell.rb | 6 | ||||
-rw-r--r-- | spec/gitlab_shell_spec.rb | 107 |
2 files changed, 83 insertions, 30 deletions
diff --git a/lib/gitlab_shell.rb b/lib/gitlab_shell.rb index abc5ac2..2d49370 100644 --- a/lib/gitlab_shell.rb +++ b/lib/gitlab_shell.rb @@ -44,13 +44,17 @@ class GitlabShell def process_cmd repo_full_path = File.join(repos_path, repo_name) - system("#{@git_cmd} #{repo_full_path}") + exec_cmd "#{@git_cmd} #{repo_full_path}" end def validate_access api.allowed?(@git_cmd, @repo_name, @key_id, '_any') end + def exec_cmd args + Kernel::exec args + end + def api GitlabNet.new end diff --git a/spec/gitlab_shell_spec.rb b/spec/gitlab_shell_spec.rb index 11815d7..da91c36 100644 --- a/spec/gitlab_shell_spec.rb +++ b/spec/gitlab_shell_spec.rb @@ -2,58 +2,113 @@ require_relative 'spec_helper' require_relative '../lib/gitlab_shell' describe GitlabShell do - describe :initialize do - before do - ssh_cmd 'git-receive-pack' - ARGV[0] = 'key-56' - @shell = GitlabShell.new + subject do + ARGV[0] = key_id + GitlabShell.new.tap do |shell| + shell.stub(exec_cmd: :exec_called) + shell.stub(api: api) + end + end + let(:api) do + double(GitlabNet).tap do |api| + api.stub(discover: 'John Doe') + api.stub(allowed?: true) end + end + let(:key_id) { "key-#{rand(100) + 100}" } + let(:repository_path) { "/home/git#{rand(100)}/repos" } + before { GitlabConfig.any_instance.stub(:repos_path).and_return(repository_path) } - it { @shell.key_id.should == 'key-56' } - it { @shell.repos_path.should == "/home/git/repositories" } + describe :initialize do + before { ssh_cmd 'git-receive-pack' } + + its(:key_id) { should == key_id } + its(:repos_path) { should == repository_path } end describe :parse_cmd do context 'w/o namespace' do before do ssh_cmd 'git-upload-pack gitlab-ci.git' - @shell = GitlabShell.new - @shell.send :parse_cmd + subject.send :parse_cmd end - it { @shell.repo_name.should == 'gitlab-ci.git' } - it { @shell.git_cmd.should == 'git-upload-pack' } + its(:repo_name) { should == 'gitlab-ci.git' } + its(:git_cmd) { should == 'git-upload-pack' } end context 'namespace' do before do ssh_cmd 'git-upload-pack dmitriy.zaporozhets/gitlab-ci.git' - @shell = GitlabShell.new - @shell.send :parse_cmd + subject.send :parse_cmd end - it { @shell.repo_name.should == 'dmitriy.zaporozhets/gitlab-ci.git' } - it { @shell.git_cmd.should == 'git-upload-pack' } + its(:repo_name) { should == 'dmitriy.zaporozhets/gitlab-ci.git' } + its(:git_cmd) { should == 'git-upload-pack' } end end describe :exec do context 'git-upload-pack' do - before do - ssh_cmd 'git-upload-pack gitlab-ci.git' - stubbed_shell + before { ssh_cmd 'git-upload-pack gitlab-ci.git' } + after { subject.exec } + + it "should process the command" do + subject.should_receive(:process_cmd).with() + end + + it "should execute the command" do + subject.should_receive(:exec_cmd).with("git-upload-pack #{File.join(repository_path, 'gitlab-ci.git')}") end - it { @shell.exec.should be_true } + it "should set the GL_ID environment variable" do + ENV.should_receive("[]=").with("GL_ID", key_id) + end end context 'git-receive-pack' do - before do - ssh_cmd 'git-receive-pack gitlab-ci.git' - stubbed_shell + before { ssh_cmd 'git-receive-pack gitlab-ci.git' } + after { subject.exec } + + it "should process the command" do + subject.should_receive(:process_cmd).with() + end + + it "should execute the command" do + subject.should_receive(:exec_cmd).with("git-receive-pack #{File.join(repository_path, 'gitlab-ci.git')}") + end + end + + context 'arbitrary command' do + before { ssh_cmd 'arbitrary command' } + after { subject.exec } + + it "should not process the command" do + subject.should_not_receive(:process_cmd) end - it { @shell.exec.should be_true } + it "should not execute the command" do + subject.should_not_receive(:exec_cmd) + end + end + + context 'no command' do + before { ssh_cmd nil } + after { subject.exec } + + it "should call api.discover" do + api.should_receive(:discover).with(key_id) + end + end + end + + describe :validate_access do + before { ssh_cmd 'git-upload-pack gitlab-ci.git' } + after { subject.exec } + + it "should call api.allowed?" do + api.should_receive(:allowed?). + with('git-upload-pack', 'gitlab-ci.git', key_id, '_any') end end @@ -61,10 +116,4 @@ describe GitlabShell do ENV['SSH_ORIGINAL_COMMAND'] = cmd end - def stubbed_shell - ARGV[0] = 'key-56' - @shell = GitlabShell.new - @shell.stub(validate_access: true) - @shell.stub(process_cmd: true) - end end |