require 'spec_helper' require 'gitx/cli/release_command' describe Gitx::Cli::ReleaseCommand do let(:args) { [] } let(:options) { {} } let(:config) do { pretend: true } end let(:cli) { described_class.new(args, options, config) } let(:branch) { double('fake branch', name: 'feature-branch') } let(:authorization_token) { '123123' } let(:repo) { cli.send(:repo) } before do allow(cli).to receive(:current_branch).and_return(branch) end describe '#release' do context 'when user rejects release' do before do expect(cli).to receive(:yes?).and_return(false) expect(cli).to_not receive(:run_cmd) cli.release end it 'only runs update commands' do should meet_expectations end end context 'when user confirms release and pull request exists with non-success status' do before do expect(repo).to receive(:workdir).and_return(temp_dir) expect(cli).to receive(:execute_command).with(Gitx::Cli::UpdateCommand, :update) expect(cli).to receive(:yes?).with('Release feature-branch to master? (y/n)', :green).and_return(true) expect(cli).to receive(:yes?).with('Branch status is currently: failure. Proceed with release? (y/n)', :red).and_return(false) allow(cli).to receive(:authorization_token).and_return(authorization_token) expect(cli).to_not receive(:run_cmd).with('git checkout master') expect(cli).to_not receive(:run_cmd).with('git pull origin master') expect(cli).to_not receive(:run_cmd).with('git merge --no-ff -m "[gitx] Releasing feature-branch to master (Pull request #10)" feature-branch') expect(cli).to_not receive(:run_cmd).with('git push origin HEAD') VCR.use_cassette('pull_request_does_exist_with_failure_status') do cli.release end end it 'runs expected commands' do should meet_expectations end end context 'when user confirms release and pull request exists with success status with default config' do before do expect(repo).to receive(:workdir).and_return(temp_dir) expect(cli).to receive(:execute_command).with(Gitx::Cli::UpdateCommand, :update) expect(cli).to receive(:yes?).and_return(true) allow(cli).to receive(:authorization_token).and_return(authorization_token) expect(cli).to receive(:run_cmd).with('git checkout feature-branch').ordered expect(cli).to receive(:run_cmd).with('git checkout master').ordered expect(cli).to receive(:run_cmd).with('git pull origin master').ordered expect(cli).to receive(:run_cmd).with('git merge --no-ff -m "[gitx] Releasing feature-branch to master (Pull request #10)" feature-branch').ordered expect(cli).to receive(:run_cmd).with('git push origin HEAD').ordered expect(cli).to receive(:run_cmd).with('git integrate').ordered VCR.use_cassette('pull_request_does_exist_with_success_status') do cli.release end end it 'runs expected commands' do should meet_expectations end end context 'when user confirms release and pull request exists with success status with custom after_release config' do let(:gitx_config) do { 'after_release' => ['echo hello'] } end before do expect(repo).to receive(:workdir).and_return(temp_dir) File.open(File.join(temp_dir, '.gitx.yml'), 'w') do |f| f.puts gitx_config.to_yaml end expect(cli).to receive(:execute_command).with(Gitx::Cli::UpdateCommand, :update) expect(cli).to receive(:yes?).and_return(true) allow(cli).to receive(:authorization_token).and_return(authorization_token) expect(cli).to receive(:run_cmd).with('git checkout feature-branch').ordered expect(cli).to receive(:run_cmd).with('git checkout master').ordered expect(cli).to receive(:run_cmd).with('git pull origin master').ordered expect(cli).to receive(:run_cmd).with('git merge --no-ff -m "[gitx] Releasing feature-branch to master (Pull request #10)" feature-branch').ordered expect(cli).to receive(:run_cmd).with('git push origin HEAD').ordered expect(cli).to receive(:run_cmd).with('echo hello').ordered VCR.use_cassette('pull_request_does_exist_with_success_status') do cli.release end end it 'runs expected commands' do should meet_expectations end end context 'when target_branch is not nil and user confirms release and pull request exists with success status' do before do expect(repo).to receive(:workdir).and_return(temp_dir) expect(cli).to receive(:execute_command).with(Gitx::Cli::UpdateCommand, :update) expect(cli).to receive(:yes?).and_return(true) allow(cli).to receive(:authorization_token).and_return(authorization_token) expect(cli).to receive(:run_cmd).with('git checkout feature-branch').ordered expect(cli).to receive(:run_cmd).with('git checkout master').ordered expect(cli).to receive(:run_cmd).with('git pull origin master').ordered expect(cli).to receive(:run_cmd).with('git merge --no-ff -m "[gitx] Releasing feature-branch to master (Pull request #10)" feature-branch').ordered expect(cli).to receive(:run_cmd).with('git push origin HEAD').ordered expect(cli).to receive(:run_cmd).with('git integrate').ordered VCR.use_cassette('pull_request_does_exist_with_success_status') do cli.release 'feature-branch' end end it 'runs expected commands' do should meet_expectations end end context 'when user confirms release and pull request does not exist' do let(:new_pull_request) do { html_url: 'https://path/to/html/pull/request', issue_url: 'https://api/path/to/issue/url', number: 10, head: { ref: 'branch_name' } } end before do expect(repo).to receive(:workdir).and_return(temp_dir) allow(cli).to receive(:authorization_token).and_return(authorization_token) allow(cli).to receive(:ask_editor).and_return('description') expect(cli).to receive(:execute_command).with(Gitx::Cli::UpdateCommand, :update).twice expect(cli).to receive(:yes?).with('Release feature-branch to master? (y/n)', :green).and_return(true) expect(cli).to receive(:yes?).with('Branch status is currently: pending. Proceed with release? (y/n)', :red).and_return(true) expect(cli).to receive(:run_cmd).with('git checkout feature-branch').ordered expect(cli).to receive(:run_cmd).with('git checkout feature-branch').ordered expect(cli).to receive(:run_cmd).with("git log master...feature-branch --reverse --no-merges --pretty=format:'* %B'").and_return('2013-01-01 did some stuff').ordered expect(cli).to receive(:run_cmd).with('git checkout master').ordered expect(cli).to receive(:run_cmd).with('git pull origin master').ordered expect(cli).to receive(:run_cmd).with('git merge --no-ff -m "[gitx] Releasing feature-branch to master (Pull request #10)" feature-branch').ordered expect(cli).to receive(:run_cmd).with('git push origin HEAD').ordered expect(cli).to receive(:run_cmd).with('git integrate').ordered stub_request(:post, 'https://api.github.com/repos/wireframe/gitx/pulls').to_return(status: 201, body: new_pull_request.to_json, headers: { 'Content-Type' => 'application/json' }) VCR.use_cassette('pull_request_does_not_exist') do cli.release end end it 'creates pull request on github' do should meet_expectations end it 'runs expected commands' do should meet_expectations end end context 'when --cleanup flag passed' do let(:options) do { cleanup: true } end before do expect(repo).to receive(:workdir).and_return(temp_dir) expect(cli).to receive(:execute_command).with(Gitx::Cli::UpdateCommand, :update) expect(cli).to receive(:yes?).and_return(true) allow(cli).to receive(:authorization_token).and_return(authorization_token) expect(cli).to receive(:run_cmd).with('git checkout feature-branch').ordered expect(cli).to receive(:run_cmd).with('git checkout master').ordered expect(cli).to receive(:run_cmd).with('git pull origin master').ordered expect(cli).to receive(:run_cmd).with('git merge --no-ff -m "[gitx] Releasing feature-branch to master (Pull request #10)" feature-branch').ordered expect(cli).to receive(:run_cmd).with('git push origin HEAD').ordered expect(cli).to receive(:run_cmd).with('git integrate').ordered expect(cli).to receive(:run_cmd).with('git cleanup').ordered VCR.use_cassette('pull_request_does_exist_with_success_status') do cli.release end end it 'runs expected commands' do should meet_expectations end end end end