include Rake::Funnel::Integration describe Rake::Funnel::Integration::TeamCity::ServiceMessages do before { allow(TeamCity).to receive(:running?).and_return(teamcity_running?) allow($stdout).to receive(:puts) } context 'when running outside TeamCity' do let(:teamcity_running?) { false } it 'should not publish messages' do described_class.progress_start 'foo' expect($stdout).not_to have_received(:puts) end end context 'when running inside TeamCity' do let(:teamcity_running?) { true } describe 'escaping' do context 'when publishing messages without special characters' do it 'should not escape' do described_class.progress_start "the message" expect($stdout).to have_received(:puts).with("##teamcity[progressStart 'the message']") end end context 'when publishing messages with special characters' do it 'should escape apostrophes' do described_class.progress_start "'" expect($stdout).to have_received(:puts).with("##teamcity[progressStart '|'']") end it 'should escape line feeds' do described_class.progress_start "\n" expect($stdout).to have_received(:puts).with("##teamcity[progressStart '|n']") end it 'should escape carriage returns' do described_class.progress_start "\r" expect($stdout).to have_received(:puts).with("##teamcity[progressStart '|r']") end it 'should escape next lines' do described_class.progress_start "\u0085" expect($stdout).to have_received(:puts).with("##teamcity[progressStart '|x']") end it 'should escape line separators' do described_class.progress_start "\u2028" expect($stdout).to have_received(:puts).with("##teamcity[progressStart '|l']") end it 'should escape paragraph separators' do described_class.progress_start "\u2029" expect($stdout).to have_received(:puts).with("##teamcity[progressStart '|p']") end it 'should escape vertical bars' do described_class.progress_start '|' expect($stdout).to have_received(:puts).with("##teamcity[progressStart '||']") end it 'should escape opening brackets' do described_class.progress_start '[' expect($stdout).to have_received(:puts).with("##teamcity[progressStart '|[']") end it 'should escape closing brackets' do described_class.progress_start ']' expect($stdout).to have_received(:puts).with("##teamcity[progressStart '|]']") end it 'should escape all special characters in a string' do described_class.progress_start "[\r|\n]" expect($stdout).to have_received(:puts).with("##teamcity[progressStart '|[|r|||n|]']") end end end describe 'parameters' do context 'when reporting a message without parameters' do it 'should print the service message' do described_class.enable_service_messages expect($stdout).to have_received(:puts).with('##teamcity[enableServiceMessages]') end end context 'when reporting a message with an unnamed parameter' do it 'should print the service message' do described_class.progress_message 'the message' expect($stdout).to have_received(:puts).with("##teamcity[progressMessage 'the message']") end end context 'when reporting a message with a named parameter' do it 'should print the service message' do described_class.block_opened({ name: 'block name' }) expect($stdout).to have_received(:puts).with("##teamcity[blockOpened name='block name']") end end context 'when reporting a message with multiple named parameters' do it 'should print the service message' do described_class.test_started ({ name: 'test name', captureStandardOutput: true }) expect($stdout).to have_received(:puts).with("##teamcity[testStarted name='test name' captureStandardOutput='true']") end end context 'when reporting a message with Ruby-style named parameters' do it 'should print the service message' do described_class.test_started ({ capture_standard_output: true }) expect($stdout).to have_received(:puts).with("##teamcity[testStarted captureStandardOutput='true']") end end end end end