spec/rake/funnel/integration/teamcity/service_messages_spec.rb in rake-funnel-0.3.2.pre vs spec/rake/funnel/integration/teamcity/service_messages_spec.rb in rake-funnel-0.4.0.pre
- old
+ new
@@ -1,136 +1,136 @@
-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
+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