diff options
Diffstat (limited to 'spec/ruby/command_line')
41 files changed, 143 insertions, 661 deletions
diff --git a/spec/ruby/command_line/backtrace_limit_spec.rb b/spec/ruby/command_line/backtrace_limit_spec.rb deleted file mode 100644 index bc40a542a0..0000000000 --- a/spec/ruby/command_line/backtrace_limit_spec.rb +++ /dev/null @@ -1,46 +0,0 @@ -require_relative '../spec_helper' - -describe "The --backtrace-limit command line option" do - it "limits top-level backtraces to a given number of entries" do - file = fixture(__FILE__ , "backtrace.rb") - out = ruby_exe(file, options: "--backtrace-limit=2", args: "top 2>&1", exit_status: 1) - out = out.gsub(__dir__, '') - - out.should == <<-MSG -top -/fixtures/backtrace.rb:2:in `a': oops (RuntimeError) -\tfrom /fixtures/backtrace.rb:6:in `b' -\tfrom /fixtures/backtrace.rb:10:in `c' -\t ... 2 levels... - MSG - end - - it "affects Exception#full_message" do - file = fixture(__FILE__ , "backtrace.rb") - out = ruby_exe(file, options: "--backtrace-limit=2", args: "full_message 2>&1") - out = out.gsub(__dir__, '') - - out.should == <<-MSG -full_message -/fixtures/backtrace.rb:2:in `a': oops (RuntimeError) -\tfrom /fixtures/backtrace.rb:6:in `b' -\tfrom /fixtures/backtrace.rb:10:in `c' -\t ... 2 levels... - MSG - end - - it "does not affect Exception#backtrace" do - file = fixture(__FILE__ , "backtrace.rb") - out = ruby_exe(file, options: "--backtrace-limit=2", args: "backtrace 2>&1") - out = out.gsub(__dir__, '') - - out.should == <<-MSG -backtrace -/fixtures/backtrace.rb:2:in `a' -/fixtures/backtrace.rb:6:in `b' -/fixtures/backtrace.rb:10:in `c' -/fixtures/backtrace.rb:14:in `d' -/fixtures/backtrace.rb:29:in `<main>' - MSG - end -end diff --git a/spec/ruby/command_line/dash_a_spec.rb b/spec/ruby/command_line/dash_a_spec.rb index 43d923ce16..65f79ec208 100644 --- a/spec/ruby/command_line/dash_a_spec.rb +++ b/spec/ruby/command_line/dash_a_spec.rb @@ -1,18 +1,16 @@ -require_relative '../spec_helper' - describe "The -a command line option" do before :each do @names = fixture __FILE__, "full_names.txt" end it "runs the code in loop conditional on Kernel.gets()" do - ruby_exe("puts $F.last", options: "-n -a", + ruby_exe("puts $F.last", options: "-n -a", escape: true, args: " < #{@names}").should == "jones\nfield\ngrey\n" end it "sets $-a" do - ruby_exe("puts $-a", options: "-n -a", + ruby_exe("puts $-a", options: "-n -a", escape: true, args: " < #{@names}").should == "true\ntrue\ntrue\n" end diff --git a/spec/ruby/command_line/dash_c_spec.rb b/spec/ruby/command_line/dash_c_spec.rb index 6b3a5de685..375d945a07 100644 --- a/spec/ruby/command_line/dash_c_spec.rb +++ b/spec/ruby/command_line/dash_c_spec.rb @@ -1,4 +1,4 @@ -require_relative '../spec_helper' +require File.expand_path('../../spec_helper', __FILE__) describe "The -c command line option" do it "checks syntax in given file" do diff --git a/spec/ruby/command_line/dash_d_spec.rb b/spec/ruby/command_line/dash_d_spec.rb index 26891b4791..009a14e16c 100644 --- a/spec/ruby/command_line/dash_d_spec.rb +++ b/spec/ruby/command_line/dash_d_spec.rb @@ -1,4 +1,4 @@ -require_relative '../spec_helper' +require File.expand_path('../../spec_helper', __FILE__) describe "The -d command line option" do before :each do diff --git a/spec/ruby/command_line/dash_e_spec.rb b/spec/ruby/command_line/dash_e_spec.rb index 24ed34376d..3435e78e29 100644 --- a/spec/ruby/command_line/dash_e_spec.rb +++ b/spec/ruby/command_line/dash_e_spec.rb @@ -1,4 +1,4 @@ -require_relative '../spec_helper' +require File.expand_path('../../spec_helper', __FILE__) describe "The -e command line option" do it "evaluates the given string" do @@ -23,7 +23,7 @@ describe "The -e command line option" do #needs to test return => LocalJumpError - describe "with -n and an Integer range" do + describe "with -n and a Fixnum range" do before :each do @script = "-ne 'print if %s' #{fixture(__FILE__, "conditional_range.txt")}" end diff --git a/spec/ruby/command_line/dash_encoding_spec.rb b/spec/ruby/command_line/dash_encoding_spec.rb deleted file mode 100644 index 5803d328c1..0000000000 --- a/spec/ruby/command_line/dash_encoding_spec.rb +++ /dev/null @@ -1,36 +0,0 @@ -require_relative '../spec_helper' - -describe "The --encoding command line option" do - before :each do - @test_string = "print [Encoding.default_external.name, Encoding.default_internal&.name].inspect" - @enc2 = Encoding::ISO_8859_1 - end - - describe "sets Encoding.default_external and optionally Encoding.default_internal" do - it "if given a single encoding with an =" do - ruby_exe(@test_string, options: "--disable-gems --encoding=big5").should == [Encoding::Big5.name, nil].inspect - end - - it "if given a single encoding as a separate argument" do - ruby_exe(@test_string, options: "--disable-gems --encoding big5").should == [Encoding::Big5.name, nil].inspect - end - - it "if given two encodings with an =" do - ruby_exe(@test_string, options: "--disable-gems --encoding=big5:#{@enc2}").should == [Encoding::Big5.name, @enc2.name].inspect - end - - it "if given two encodings as a separate argument" do - ruby_exe(@test_string, options: "--disable-gems --encoding big5:#{@enc2}").should == [Encoding::Big5.name, @enc2.name].inspect - end - end - - it "does not accept a third encoding" do - options = { - options: "--disable-gems --encoding big5:#{@enc2}:utf-32le", - args: "2>&1", - exit_status: 1 - } - - ruby_exe(@test_string, options).should =~ /extra argument for --encoding: utf-32le/ - end -end diff --git a/spec/ruby/command_line/dash_external_encoding_spec.rb b/spec/ruby/command_line/dash_external_encoding_spec.rb deleted file mode 100644 index f052674dc8..0000000000 --- a/spec/ruby/command_line/dash_external_encoding_spec.rb +++ /dev/null @@ -1,15 +0,0 @@ -require_relative '../spec_helper' - -describe 'The --external-encoding command line option sets Encoding.default_external' do - before :each do - @test_string = "print Encoding.default_external.name" - end - - it "if given an encoding with an =" do - ruby_exe(@test_string, options: '--external-encoding=big5').should == Encoding::Big5.name - end - - it "if given an encoding as a separate argument" do - ruby_exe(@test_string, options: '--external-encoding big5').should == Encoding::Big5.name - end -end diff --git a/spec/ruby/command_line/dash_internal_encoding_spec.rb b/spec/ruby/command_line/dash_internal_encoding_spec.rb deleted file mode 100644 index 3049040bb4..0000000000 --- a/spec/ruby/command_line/dash_internal_encoding_spec.rb +++ /dev/null @@ -1,15 +0,0 @@ -require_relative '../spec_helper' - -describe 'The --internal-encoding command line option sets Encoding.default_internal' do - before :each do - @test_string = "print Encoding.default_internal.name" - end - - it "if given an encoding with an =" do - ruby_exe(@test_string, options: '--internal-encoding=big5').should == Encoding::Big5.name - end - - it "if given an encoding as a separate argument" do - ruby_exe(@test_string, options: '--internal-encoding big5').should == Encoding::Big5.name - end -end diff --git a/spec/ruby/command_line/dash_l_spec.rb b/spec/ruby/command_line/dash_l_spec.rb deleted file mode 100644 index 44a98445f3..0000000000 --- a/spec/ruby/command_line/dash_l_spec.rb +++ /dev/null @@ -1,31 +0,0 @@ -require_relative '../spec_helper' - -describe "The -l command line option" do - before :each do - @names = fixture __FILE__, "full_names.txt" - end - - it "chomps lines with default separator" do - ruby_exe('puts $_.end_with?("\n")', options: "-n -l", - args: " < #{@names}").should == - "false\nfalse\nfalse\n" - end - - it "chomps last line based on $/" do - ruby_exe('BEGIN { $/ = "ones\n" }; puts $_', options: "-W0 -n -l", - args: " < #{@names}").should == - "alice j\nbob field\njames grey\n" - end - - it "sets $\\ to the value of $/" do - ruby_exe("puts $\\ == $/", options: "-W0 -n -l", - args: " < #{@names}").should == - "true\ntrue\ntrue\n" - end - - it "sets $-l" do - ruby_exe("puts $-l", options: "-n -l", - args: " < #{@names}").should == - "true\ntrue\ntrue\n" - end -end diff --git a/spec/ruby/command_line/dash_n_spec.rb b/spec/ruby/command_line/dash_n_spec.rb index 1dd9379259..f4dd9f1851 100644 --- a/spec/ruby/command_line/dash_n_spec.rb +++ b/spec/ruby/command_line/dash_n_spec.rb @@ -1,24 +1,22 @@ -require_relative '../spec_helper' - describe "The -n command line option" do before :each do @names = fixture __FILE__, "names.txt" end it "runs the code in loop conditional on Kernel.gets()" do - ruby_exe("puts $_", options: "-n", + ruby_exe("puts $_", options: "-n", escape: true, args: " < #{@names}").should == "alice\nbob\njames\n" end it "only evaluates BEGIN blocks once" do - ruby_exe("BEGIN { puts \"hi\" }; puts $_", options: "-n", + ruby_exe("BEGIN { puts \"hi\" }; puts $_", options: "-n", escape: true, args: " < #{@names}").should == "hi\nalice\nbob\njames\n" end it "only evaluates END blocks once" do - ruby_exe("puts $_; END {puts \"bye\"}", options: "-n", + ruby_exe("puts $_; END {puts \"bye\"}", options: "-n", escape: true, args: " < #{@names}").should == "alice\nbob\njames\nbye\n" end @@ -29,7 +27,7 @@ describe "The -n command line option" do $total += 1 END { puts $total } script - ruby_exe(script, options: "-n", + ruby_exe(script, options: "-n", escape: true, args: " < #{@names}").should == "3\n" end diff --git a/spec/ruby/command_line/dash_p_spec.rb b/spec/ruby/command_line/dash_p_spec.rb index 967e3796de..67562b5bc3 100644 --- a/spec/ruby/command_line/dash_p_spec.rb +++ b/spec/ruby/command_line/dash_p_spec.rb @@ -1,18 +1,16 @@ -require_relative '../spec_helper' - describe "The -p command line option" do before :each do @names = fixture __FILE__, "names.txt" end it "runs the code in loop conditional on Kernel.gets() and prints $_" do - ruby_exe("$_ = $_.upcase", options: "-p", + ruby_exe("$_ = $_.upcase", options: "-p", escape: true, args: " < #{@names}").should == "ALICE\nBOB\nJAMES\n" end it "sets $-p" do - ruby_exe("$_ = $-p", options: "-p", + ruby_exe("$_ = $-p", options: "-p", escape: true, args: " < #{@names}").should == "truetruetrue" end diff --git a/spec/ruby/command_line/dash_r_spec.rb b/spec/ruby/command_line/dash_r_spec.rb index ea5bde5adf..3d3abcf0b7 100644 --- a/spec/ruby/command_line/dash_r_spec.rb +++ b/spec/ruby/command_line/dash_r_spec.rb @@ -1,4 +1,4 @@ -require_relative '../spec_helper' +require File.expand_path('../../spec_helper', __FILE__) describe "The -r command line option" do before :each do @@ -7,22 +7,7 @@ describe "The -r command line option" do end it "requires the specified file" do - out = ruby_exe(@script, options: "-r #{@test_file}") - out.should include("REQUIRED") - out.should include(@test_file + ".rb") - end - - it "requires the file before parsing the main script" do - out = ruby_exe(fixture(__FILE__, "bad_syntax.rb"), options: "-r #{@test_file}", args: "2>&1", exit_status: 1) - $?.should_not.success? - out.should include("REQUIRED") - out.should include("syntax error") - end - - it "does not require the file if the main script file does not exist" do - out = `#{ruby_exe.to_a.join(' ')} -r #{@test_file} #{fixture(__FILE__, "does_not_exist.rb")} 2>&1` - $?.should_not.success? - out.should_not.include?("REQUIRED") - out.should.include?("No such file or directory") + result = ruby_exe(@script, options: "-r #{@test_file}") + result.should include(@test_file + ".rb") end end diff --git a/spec/ruby/command_line/dash_s_spec.rb b/spec/ruby/command_line/dash_s_spec.rb index eaaeea7c96..70e41208e0 100644 --- a/spec/ruby/command_line/dash_s_spec.rb +++ b/spec/ruby/command_line/dash_s_spec.rb @@ -1,4 +1,4 @@ -require_relative '../spec_helper' +require File.expand_path('../../spec_helper', __FILE__) describe "The -s command line option" do describe "when using -- to stop parsing" do diff --git a/spec/ruby/command_line/dash_upper_c_spec.rb b/spec/ruby/command_line/dash_upper_c_spec.rb index ece1b32105..e8a54b01c1 100644 --- a/spec/ruby/command_line/dash_upper_c_spec.rb +++ b/spec/ruby/command_line/dash_upper_c_spec.rb @@ -1,6 +1,18 @@ -require_relative '../spec_helper' -require_relative 'shared/change_directory' +require File.expand_path('../../spec_helper', __FILE__) -describe "The -C command line option" do - it_behaves_like :command_line_change_directory, "-C" +describe 'The -C command line option' do + before :all do + @script = fixture(__FILE__, 'dash_upper_c_script.rb') + @tempdir = File.dirname(@script) + end + + it 'changes the PWD when using a file' do + output = ruby_exe(@script, options: "-C #{@tempdir}") + output.should == @tempdir + end + + it 'changes the PWD when using -e' do + output = ruby_exe(nil, options: "-C #{@tempdir} -e 'print Dir.pwd'") + output.should == @tempdir + end end diff --git a/spec/ruby/command_line/dash_upper_e_spec.rb b/spec/ruby/command_line/dash_upper_e_spec.rb index 5a83962583..716f1304b7 100644 --- a/spec/ruby/command_line/dash_upper_e_spec.rb +++ b/spec/ruby/command_line/dash_upper_e_spec.rb @@ -1,37 +1,7 @@ -require_relative '../spec_helper' - describe "ruby -E" do - it "sets the external encoding with '-E external'" do - result = ruby_exe("print Encoding.default_external", options: '-E euc-jp') - result.should == "EUC-JP" - end - - platform_is_not :windows do - it "also sets the filesystem encoding with '-E external'" do - result = ruby_exe("print Encoding.find('filesystem')", options: '-E euc-jp') - result.should == "EUC-JP" - end - end - - it "sets the external encoding with '-E external:'" do - result = ruby_exe("print Encoding.default_external", options: '-E Shift_JIS:') - result.should == "Shift_JIS" - end - - it "sets the internal encoding with '-E :internal'" do - ruby_exe("print Encoding.default_internal", options: '-E :SHIFT_JIS'). - should == 'Shift_JIS' - end - - it "sets the external and internal encodings with '-E external:internal'" do - ruby_exe("puts Encoding.default_external, Encoding.default_internal", options: '-E euc-jp:SHIFT_JIS'). - should == "EUC-JP\nShift_JIS\n" - end - it "raises a RuntimeError if used with -U" do ruby_exe("p 1", options: '-Eascii:ascii -U', - args: '2>&1', - exit_status: 1).should =~ /RuntimeError/ + args: '2>&1').should =~ /RuntimeError/ end end diff --git a/spec/ruby/command_line/dash_upper_f_spec.rb b/spec/ruby/command_line/dash_upper_f_spec.rb index 5c10a7140d..020968b1f9 100644 --- a/spec/ruby/command_line/dash_upper_f_spec.rb +++ b/spec/ruby/command_line/dash_upper_f_spec.rb @@ -1,12 +1,10 @@ -require_relative '../spec_helper' - describe "the -F command line option" do before :each do @passwd = fixture __FILE__, "passwd_file.txt" end it "specifies the field separator pattern for -a" do - ruby_exe("puts $F[0]", options: "-naF:", + ruby_exe("puts $F[0]", options: "-naF:", escape: true, args: " < #{@passwd}").should == "nobody\nroot\ndaemon\n" end diff --git a/spec/ruby/command_line/dash_upper_i_spec.rb b/spec/ruby/command_line/dash_upper_i_spec.rb index 4cafb724e3..0a00059949 100644 --- a/spec/ruby/command_line/dash_upper_i_spec.rb +++ b/spec/ruby/command_line/dash_upper_i_spec.rb @@ -1,4 +1,4 @@ -require_relative '../spec_helper' +require File.expand_path('../../spec_helper', __FILE__) describe "The -I command line option" do before :each do @@ -8,44 +8,4 @@ describe "The -I command line option" do it "adds the path to the load path ($:)" do ruby_exe(@script, options: "-I fixtures").should include("fixtures") end - - it "adds the path at the front of $LOAD_PATH" do - lines = ruby_exe(@script, options: "-I fixtures").lines - if PlatformGuard.implementation? :ruby - # In a MRI checkout, $PWD ends up as the first entry in $LOAD_PATH. - # So just assert that it's at the beginning. - idx = lines.index { |l| l.include?("fixtures") } - idx.should < 2 - idx.should < lines.size-1 - else - lines[0].should include("fixtures") - end - end - - it "adds the path expanded from CWD to $LOAD_PATH" do - ruby_exe(@script, options: "-I fixtures").lines.should include "#{Dir.pwd}/fixtures\n" - end - - it "expands a path from CWD even if it does not exist" do - ruby_exe(@script, options: "-I not_exist/not_exist").lines.should include "#{Dir.pwd}/not_exist/not_exist\n" - end -end - -platform_is_not :windows do - describe "The -I command line option" do - before :each do - @script = fixture __FILE__, "loadpath.rb" - @fixtures = File.dirname(@script) - @symlink = tmp("loadpath_symlink") - File.symlink(@fixtures, @symlink) - end - - after :each do - rm_r @symlink - end - - it "does not expand symlinks" do - ruby_exe(@script, options: "-I #{@symlink}").lines.should include "#{@symlink}\n" - end - end end diff --git a/spec/ruby/command_line/dash_upper_k_spec.rb b/spec/ruby/command_line/dash_upper_k_spec.rb index 7e71532295..3c3b9fa4d3 100644 --- a/spec/ruby/command_line/dash_upper_k_spec.rb +++ b/spec/ruby/command_line/dash_upper_k_spec.rb @@ -1,65 +1,33 @@ -require_relative '../spec_helper' - -describe 'The -K command line option' do - before :each do - @test_string = "print [__ENCODING__&.name, Encoding.default_external&.name, Encoding.default_internal&.name].inspect" +describe 'The -K command line option sets __ENCODING__' do + it "to Encoding::ASCII_8BIT with -Ka" do + ruby_exe("print __ENCODING__", options: '-Ka').should == Encoding::ASCII_8BIT.to_s end - describe 'sets __ENCODING__ and Encoding.default_external' do - it "to Encoding::BINARY with -Ka" do - ruby_exe(@test_string, options: '-Ka').should == - [Encoding::BINARY.name, Encoding::BINARY.name, nil].inspect - end - - it "to Encoding::BINARY with -KA" do - ruby_exe(@test_string, options: '-KA').should == - [Encoding::BINARY.name, Encoding::BINARY.name, nil].inspect - end - - it "to Encoding::BINARY with -Kn" do - ruby_exe(@test_string, options: '-Kn').should == - [Encoding::BINARY.name, Encoding::BINARY.name, nil].inspect - end - - it "to Encoding::BINARY with -KN" do - ruby_exe(@test_string, options: '-KN').should == - [Encoding::BINARY.name, Encoding::BINARY.name, nil].inspect - end - - it "to Encoding::EUC_JP with -Ke" do - ruby_exe(@test_string, options: '-Ke').should == - [Encoding::EUC_JP.name, Encoding::EUC_JP.name, nil].inspect - end + it "to Encoding::ASCII_8BIT with -KA" do + ruby_exe("print __ENCODING__", options: '-KA').should == Encoding::ASCII_8BIT.to_s + end - it "to Encoding::EUC_JP with -KE" do - ruby_exe(@test_string, options: '-KE').should == - [Encoding::EUC_JP.name, Encoding::EUC_JP.name, nil].inspect - end + it "to Encoding::EUC_JP with -Ke" do + ruby_exe("print __ENCODING__", options: '-Ke').should == Encoding::EUC_JP.to_s + end - it "to Encoding::UTF_8 with -Ku" do - ruby_exe(@test_string, options: '-Ku').should == - [Encoding::UTF_8.name, Encoding::UTF_8.name, nil].inspect - end + it "to Encoding::EUC_JP with -KE" do + ruby_exe("print __ENCODING__", options: '-KE').should == Encoding::EUC_JP.to_s + end - it "to Encoding::UTF_8 with -KU" do - ruby_exe(@test_string, options: '-KU').should == - [Encoding::UTF_8.name, Encoding::UTF_8.name, nil].inspect - end + it "to Encoding::UTF_8 with -Ku" do + ruby_exe("print __ENCODING__", options: '-Ku').should == Encoding::UTF_8.to_s + end - it "to Encoding::Windows_31J with -Ks" do - ruby_exe(@test_string, options: '-Ks').should == - [Encoding::Windows_31J.name, Encoding::Windows_31J.name, nil].inspect - end + it "to Encoding::UTF_8 with -KU" do + ruby_exe("print __ENCODING__", options: '-KU').should == Encoding::UTF_8.to_s + end - it "to Encoding::Windows_31J with -KS" do - ruby_exe(@test_string, options: '-KS').should == - [Encoding::Windows_31J.name, Encoding::Windows_31J.name, nil].inspect - end + it "to Encoding::Windows_31J with -Ks" do + ruby_exe("print __ENCODING__", options: '-Ks').should == Encoding::Windows_31J.to_s end - it "ignores unknown codes" do - external = Encoding.find('external') - ruby_exe(@test_string, options: '-KZ').should == - [Encoding::UTF_8.name, external.name, nil].inspect + it "to Encoding::Windows_31J with -KS" do + ruby_exe("print __ENCODING__", options: '-KS').should == Encoding::Windows_31J.to_s end end diff --git a/spec/ruby/command_line/dash_upper_s_spec.rb b/spec/ruby/command_line/dash_upper_s_spec.rb index 17991503f1..2e293e9a62 100644 --- a/spec/ruby/command_line/dash_upper_s_spec.rb +++ b/spec/ruby/command_line/dash_upper_s_spec.rb @@ -1,4 +1,4 @@ -require_relative '../spec_helper' +require File.expand_path('../../spec_helper', __FILE__) describe 'The -S command line option' do before :each do @@ -21,7 +21,7 @@ describe 'The -S command line option' do end it "runs launcher found in PATH and sets the exit status to 1 if it fails" do - result = ruby_exe(nil, options: '-S dash_s_fail', env: { 'PATH' => @path }, args: '2>&1', exit_status: 1) + result = ruby_exe(nil, options: '-S dash_s_fail', env: { 'PATH' => @path }, args: '2>&1') result.should =~ /\bdie\b/ $?.exitstatus.should == 1 end diff --git a/spec/ruby/command_line/dash_upper_u_spec.rb b/spec/ruby/command_line/dash_upper_u_spec.rb index 15854e7b73..6cd52a3647 100644 --- a/spec/ruby/command_line/dash_upper_u_spec.rb +++ b/spec/ruby/command_line/dash_upper_u_spec.rb @@ -1,18 +1,9 @@ -require_relative '../spec_helper' - describe "ruby -U" do it "sets Encoding.default_internal to UTF-8" do ruby_exe('print Encoding.default_internal.name', options: '-U').should == 'UTF-8' end - it "sets Encoding.default_internal to UTF-8 when RUBYOPT is empty or only spaces" do - ruby_exe('p Encoding.default_internal', - options: '-U', env: { 'RUBYOPT' => '' }).should == "#<Encoding:UTF-8>\n" - ruby_exe('p Encoding.default_internal', - options: '-U', env: { 'RUBYOPT' => ' ' }).should == "#<Encoding:UTF-8>\n" - end - it "does nothing different if specified multiple times" do ruby_exe('print Encoding.default_internal.name', options: '-U -U').should == 'UTF-8' @@ -39,14 +30,12 @@ describe "ruby -U" do it "raises a RuntimeError if used with -Eext:int" do ruby_exe("p 1", options: '-U -Eascii:ascii', - args: '2>&1', - exit_status: 1).should =~ /RuntimeError/ + args: '2>&1').should =~ /RuntimeError/ end it "raises a RuntimeError if used with -E:int" do ruby_exe("p 1", options: '-U -E:ascii', - args: '2>&1', - exit_status: 1).should =~ /RuntimeError/ + args: '2>&1').should =~ /RuntimeError/ end end diff --git a/spec/ruby/command_line/dash_upper_w_spec.rb b/spec/ruby/command_line/dash_upper_w_spec.rb index 4019510d42..4e517a422a 100644 --- a/spec/ruby/command_line/dash_upper_w_spec.rb +++ b/spec/ruby/command_line/dash_upper_w_spec.rb @@ -1,5 +1,5 @@ -require_relative '../spec_helper' -require_relative 'shared/verbose' +require File.expand_path('../../spec_helper', __FILE__) +require File.expand_path('../shared/verbose', __FILE__) describe "The -W command line option" do before :each do @@ -18,27 +18,3 @@ end describe "The -W command line option with 2" do it_behaves_like :command_line_verbose, "-W2" end - -describe "The -W command line option with :deprecated" do - it "enables deprecation warnings" do - ruby_exe('p Warning[:deprecated]', options: '-W:deprecated').should == "true\n" - end -end - -describe "The -W command line option with :no-deprecated" do - it "suppresses deprecation warnings" do - ruby_exe('p Warning[:deprecated]', options: '-w -W:no-deprecated').should == "false\n" - end -end - -describe "The -W command line option with :experimental" do - it "enables experimental warnings" do - ruby_exe('p Warning[:experimental]', options: '-W:experimental').should == "true\n" - end -end - -describe "The -W command line option with :no-experimental" do - it "suppresses experimental warnings" do - ruby_exe('p Warning[:experimental]', options: '-w -W:no-experimental').should == "false\n" - end -end diff --git a/spec/ruby/command_line/dash_upper_x_spec.rb b/spec/ruby/command_line/dash_upper_x_spec.rb deleted file mode 100644 index 8ef9aae4b1..0000000000 --- a/spec/ruby/command_line/dash_upper_x_spec.rb +++ /dev/null @@ -1,6 +0,0 @@ -require_relative '../spec_helper' -require_relative 'shared/change_directory' - -describe "The -X command line option" do - it_behaves_like :command_line_change_directory, "-X" -end diff --git a/spec/ruby/command_line/dash_v_spec.rb b/spec/ruby/command_line/dash_v_spec.rb index 7c7ca1bca6..2ee9099419 100644 --- a/spec/ruby/command_line/dash_v_spec.rb +++ b/spec/ruby/command_line/dash_v_spec.rb @@ -1,14 +1,12 @@ -require_relative '../spec_helper' -require_relative 'shared/verbose' +require File.expand_path('../../spec_helper', __FILE__) +require File.expand_path('../shared/verbose', __FILE__) describe "The -v command line option" do it_behaves_like :command_line_verbose, "-v" describe "when used alone" do it "prints version and ends" do - ruby_exe(nil, args: '-v').should include(RUBY_DESCRIPTION) - end unless (defined?(RubyVM::YJIT) && RubyVM::YJIT.enabled?) || - (defined?(RubyVM::RJIT) && RubyVM::RJIT.enabled?) || - (ENV['RUBY_MN_THREADS'] == '1') + ruby_exe(nil, args: '-v').include?(RUBY_DESCRIPTION).should == true + end end end diff --git a/spec/ruby/command_line/dash_w_spec.rb b/spec/ruby/command_line/dash_w_spec.rb index f310dca3ed..bb038cb10c 100644 --- a/spec/ruby/command_line/dash_w_spec.rb +++ b/spec/ruby/command_line/dash_w_spec.rb @@ -1,10 +1,6 @@ -require_relative '../spec_helper' -require_relative 'shared/verbose' +require File.expand_path('../../spec_helper', __FILE__) +require File.expand_path('../shared/verbose', __FILE__) describe "The -w command line option" do it_behaves_like :command_line_verbose, "-w" - - it "enables both deprecated and experimental warnings" do - ruby_exe('p Warning[:deprecated]; p Warning[:experimental]', options: '-w').should == "true\ntrue\n" - end end diff --git a/spec/ruby/command_line/dash_x_spec.rb b/spec/ruby/command_line/dash_x_spec.rb index ae14b61070..a5306b4f75 100644 --- a/spec/ruby/command_line/dash_x_spec.rb +++ b/spec/ruby/command_line/dash_x_spec.rb @@ -1,5 +1,3 @@ -require_relative '../spec_helper' - describe "The -x command line option" do it "runs code after the first /\#!.*ruby.*/-ish line in target file" do embedded_ruby = fixture __FILE__, "bin/embedded_ruby.txt" @@ -9,7 +7,7 @@ describe "The -x command line option" do it "fails when /\#!.*ruby.*/-ish line in target file is not found" do bad_embedded_ruby = fixture __FILE__, "bin/bad_embedded_ruby.txt" - result = ruby_exe(bad_embedded_ruby, options: '-x', args: '2>&1', exit_status: 1) + result = ruby_exe(bad_embedded_ruby, options: '-x', args: '2>&1') result.should include "no Ruby script found in input" end @@ -18,4 +16,6 @@ describe "The -x command line option" do result = ruby_exe(embedded_ruby) result.should == "success\n" end + + it "needs to be reviewed for spec completeness" end diff --git a/spec/ruby/command_line/error_message_spec.rb b/spec/ruby/command_line/error_message_spec.rb index 02150f30ce..6212452739 100644 --- a/spec/ruby/command_line/error_message_spec.rb +++ b/spec/ruby/command_line/error_message_spec.rb @@ -1,11 +1,11 @@ -require_relative '../spec_helper' +require File.expand_path('../../spec_helper', __FILE__) describe "The error message caused by an exception" do it "is not printed to stdout" do - out = ruby_exe("this_does_not_exist", args: "2> #{File::NULL}", exit_status: 1) - out.chomp.should.empty? + out = ruby_exe("this_does_not_exist", args: "2> #{File::NULL}") + out.chomp.empty?.should == true - out = ruby_exe("end #syntax error", args: "2> #{File::NULL}", exit_status: 1) - out.chomp.should.empty? + out = ruby_exe("end #syntax error", args: "2> #{File::NULL}") + out.chomp.empty?.should == true end end diff --git a/spec/ruby/command_line/feature_spec.rb b/spec/ruby/command_line/feature_spec.rb deleted file mode 100644 index 4a24cc6795..0000000000 --- a/spec/ruby/command_line/feature_spec.rb +++ /dev/null @@ -1,71 +0,0 @@ -require_relative '../spec_helper' - -describe "The --enable and --disable flags" do - before :all do - # Since some specs disable reading RUBYOPT, we instead pass its contents as :options for those specs - rubyopt = [ENV["RUBYOPT"]] - rubyopt << ENV["#{RUBY_ENGINE.upcase}OPT"] unless RUBY_ENGINE == 'ruby' - @rubyopt = RUBY_ENGINE == "ruby" ? "" : rubyopt.compact.join(" ") - end - - it "can be used with gems" do - ruby_exe("p defined?(Gem)", options: "--enable=gems").chomp.should == "\"constant\"" - ruby_exe("p defined?(Gem)", options: "--disable=gems").chomp.should == "nil" - ruby_exe("p defined?(Gem)", options: "--enable-gems").chomp.should == "\"constant\"" - ruby_exe("p defined?(Gem)", options: "--disable-gems").chomp.should == "nil" - end - - it "can be used with gem" do - ruby_exe("p defined?(Gem)", options: "--enable=gem").chomp.should == "\"constant\"" - ruby_exe("p defined?(Gem)", options: "--disable=gem").chomp.should == "nil" - ruby_exe("p defined?(Gem)", options: "--enable-gem").chomp.should == "\"constant\"" - ruby_exe("p defined?(Gem)", options: "--disable-gem").chomp.should == "nil" - end - - it "can be used with did_you_mean" do - ruby_exe("p defined?(DidYouMean)", options: "--enable=did_you_mean").chomp.should == "\"constant\"" - ruby_exe("p defined?(DidYouMean)", options: "--disable=did_you_mean").chomp.should == "nil" - ruby_exe("p defined?(DidYouMean)", options: "--enable-did_you_mean").chomp.should == "\"constant\"" - ruby_exe("p defined?(DidYouMean)", options: "--disable-did_you_mean").chomp.should == "nil" - end - - it "can be used with rubyopt" do - ruby_exe("p $VERBOSE", options: "--enable=rubyopt", env: {'RUBYOPT' => '-w'}).chomp.should == "true" - ruby_exe("p $VERBOSE", options: "#{@rubyopt} --disable=rubyopt", env: {'RUBYOPT' => '-w'}).chomp.should == "false" - ruby_exe("p $VERBOSE", options: "--enable-rubyopt", env: {'RUBYOPT' => '-w'}).chomp.should == "true" - ruby_exe("p $VERBOSE", options: "#{@rubyopt} --disable-rubyopt", env: {'RUBYOPT' => '-w'}).chomp.should == "false" - end - - it "can be used with frozen-string-literal" do - ruby_exe("p 'foo'.frozen?", options: "--enable=frozen-string-literal").chomp.should == "true" - ruby_exe("p 'foo'.frozen?", options: "--disable=frozen-string-literal").chomp.should == "false" - ruby_exe("p 'foo'.frozen?", options: "--enable-frozen-string-literal").chomp.should == "true" - ruby_exe("p 'foo'.frozen?", options: "--disable-frozen-string-literal").chomp.should == "false" - end - - # frequently hangs for >60s on GitHub Actions macos-latest - # MinGW's YJIT support seems broken - platform_is_not :darwin, :mingw do - it "can be used with all for enable" do - e = "p [defined?(Gem), defined?(DidYouMean), $VERBOSE, 'foo'.frozen?]" - env = {'RUBYOPT' => '-w'} - # Use a single variant here because it can be quite slow as it might enable jit, etc - ruby_exe(e, options: "--enable-all", env: env).chomp.should == "[\"constant\", \"constant\", true, true]" - end - end - - it "can be used with all for disable" do - e = "p [defined?(Gem), defined?(DidYouMean), $VERBOSE, 'foo'.frozen?]" - env = {'RUBYOPT' => '-w'} - ruby_exe(e, options: "#{@rubyopt} --disable=all", env: env).chomp.should == "[nil, nil, false, false]" - ruby_exe(e, options: "#{@rubyopt} --disable-all", env: env).chomp.should == "[nil, nil, false, false]" - end - - it "prints a warning for unknown features" do - ruby_exe("p 14", options: "--enable=ruby-spec-feature-does-not-exist 2>&1").chomp.should include('warning: unknown argument for --enable') - ruby_exe("p 14", options: "--disable=ruby-spec-feature-does-not-exist 2>&1").chomp.should include('warning: unknown argument for --disable') - ruby_exe("p 14", options: "--enable-ruby-spec-feature-does-not-exist 2>&1").chomp.should include('warning: unknown argument for --enable') - ruby_exe("p 14", options: "--disable-ruby-spec-feature-does-not-exist 2>&1").chomp.should include('warning: unknown argument for --disable') - end - -end diff --git a/spec/ruby/command_line/fixtures/backtrace.rb b/spec/ruby/command_line/fixtures/backtrace.rb deleted file mode 100644 index 99acae95c8..0000000000 --- a/spec/ruby/command_line/fixtures/backtrace.rb +++ /dev/null @@ -1,35 +0,0 @@ -def a - raise 'oops' -end - -def b - a -end - -def c - b -end - -def d - c -end - -arg = ARGV.first -$stderr.puts arg - -case arg -when 'full_message' - begin - d - rescue => exc - puts exc.full_message - end -when 'backtrace' - begin - d - rescue => exc - puts exc.backtrace - end -else - d -end diff --git a/spec/ruby/command_line/fixtures/bin/embedded_ruby.txt b/spec/ruby/command_line/fixtures/bin/embedded_ruby.txt index 1da779b1b9..c556bf0b71 100644 --- a/spec/ruby/command_line/fixtures/bin/embedded_ruby.txt +++ b/spec/ruby/command_line/fixtures/bin/embedded_ruby.txt @@ -1,3 +1,3 @@ @@@This line is not value Ruby #!ruby -puts 'success' +puts 'success'
\ No newline at end of file diff --git a/spec/ruby/command_line/fixtures/bin/hybrid_launcher.sh b/spec/ruby/command_line/fixtures/bin/hybrid_launcher.sh index fd3249f0e5..0eede2a99f 100644 --- a/spec/ruby/command_line/fixtures/bin/hybrid_launcher.sh +++ b/spec/ruby/command_line/fixtures/bin/hybrid_launcher.sh @@ -1,4 +1,4 @@ #!/usr/bin/env bash -echo 'error' && exit 1 +exec somehow this file #!ruby puts 'success' diff --git a/spec/ruby/command_line/fixtures/bin/launcher.rb b/spec/ruby/command_line/fixtures/bin/launcher.rb index 92a0ee2b49..92a0ee2b49 100755..100644 --- a/spec/ruby/command_line/fixtures/bin/launcher.rb +++ b/spec/ruby/command_line/fixtures/bin/launcher.rb diff --git a/spec/ruby/command_line/fixtures/change_directory_script.rb b/spec/ruby/command_line/fixtures/dash_upper_c_script.rb index abe244705f..abe244705f 100644 --- a/spec/ruby/command_line/fixtures/change_directory_script.rb +++ b/spec/ruby/command_line/fixtures/dash_upper_c_script.rb diff --git a/spec/ruby/command_line/fixtures/freeze_flag_required_diff_enc.rb b/spec/ruby/command_line/fixtures/freeze_flag_required_diff_enc.rb Binary files differindex df4b952c46..fa348d59e7 100644 --- a/spec/ruby/command_line/fixtures/freeze_flag_required_diff_enc.rb +++ b/spec/ruby/command_line/fixtures/freeze_flag_required_diff_enc.rb diff --git a/spec/ruby/command_line/fixtures/freeze_flag_two_literals.rb b/spec/ruby/command_line/fixtures/freeze_flag_two_literals.rb index f5547a5bae..074092c9d9 100644 --- a/spec/ruby/command_line/fixtures/freeze_flag_two_literals.rb +++ b/spec/ruby/command_line/fixtures/freeze_flag_two_literals.rb @@ -1 +1 @@ -p "abc".equal?("abc") +p "abc".object_id == "abc".object_id diff --git a/spec/ruby/command_line/fixtures/test_file.rb b/spec/ruby/command_line/fixtures/test_file.rb index 30a832299e..961e3c0b0c 100644 --- a/spec/ruby/command_line/fixtures/test_file.rb +++ b/spec/ruby/command_line/fixtures/test_file.rb @@ -1 +1 @@ -puts "REQUIRED" +"test file" diff --git a/spec/ruby/command_line/frozen_strings_spec.rb b/spec/ruby/command_line/frozen_strings_spec.rb index 647b69daed..f3ee797c78 100644 --- a/spec/ruby/command_line/frozen_strings_spec.rb +++ b/spec/ruby/command_line/frozen_strings_spec.rb @@ -1,29 +1,30 @@ -require_relative '../spec_helper' +require File.expand_path('../../spec_helper', __FILE__) -describe "The --enable-frozen-string-literal flag causes string literals to" do +ruby_version_is "2.3" do + describe "The --enable-frozen-string-literal flag causes string literals to" do - it "produce the same object each time" do - ruby_exe(fixture(__FILE__, "freeze_flag_one_literal.rb"), options: "--enable-frozen-string-literal").chomp.should == "true" - end + it "produce the same object each time" do + ruby_exe(fixture(__FILE__, "freeze_flag_one_literal.rb"), options: "--enable-frozen-string-literal").chomp.should == "true" + end - it "produce the same object for literals with the same content" do - ruby_exe(fixture(__FILE__, "freeze_flag_two_literals.rb"), options: "--enable-frozen-string-literal").chomp.should == "true" - end + it "produce the same object for literals with the same content" do + ruby_exe(fixture(__FILE__, "freeze_flag_two_literals.rb"), options: "--enable-frozen-string-literal").chomp.should == "true" + end - it "produce the same object for literals with the same content in different files" do - ruby_exe(fixture(__FILE__, "freeze_flag_across_files.rb"), options: "--enable-frozen-string-literal").chomp.should == "true" - end + it "produce the same object for literals with the same content in different files" do + ruby_exe(fixture(__FILE__, "freeze_flag_across_files.rb"), options: "--enable-frozen-string-literal").chomp.should == "true" + end - it "produce different objects for literals with the same content in different files if they have different encodings" do - ruby_exe(fixture(__FILE__, "freeze_flag_across_files_diff_enc.rb"), options: "--enable-frozen-string-literal").chomp.should == "true" + it "produce different objects for literals with the same content in different files if they have different encodings" do + ruby_exe(fixture(__FILE__, "freeze_flag_across_files_diff_enc.rb"), options: "--enable-frozen-string-literal").chomp.should == "true" + end end -end -describe "The --debug flag produces" do - it "debugging info on attempted frozen string modification" do - error_str = ruby_exe(fixture(__FILE__, 'debug_info.rb'), options: '--debug', args: "2>&1") - error_str.should include("can't modify frozen String") - error_str.should include("created at") - error_str.should include("command_line/fixtures/debug_info.rb:2") + describe "The --debug flag produces" do + it "debugging info on attempted frozen string modification" do + error_str = ruby_exe(fixture(__FILE__, 'debug_info.rb'), options: '--debug', args: "2>&1") + error_str.should include("can't modify frozen String, created at ") + error_str.should include("command_line/fixtures/debug_info.rb:2") + end end end diff --git a/spec/ruby/command_line/rubylib_spec.rb b/spec/ruby/command_line/rubylib_spec.rb deleted file mode 100644 index b45919b997..0000000000 --- a/spec/ruby/command_line/rubylib_spec.rb +++ /dev/null @@ -1,69 +0,0 @@ -require_relative '../spec_helper' - -describe "The RUBYLIB environment variable" do - before :each do - @rubylib, ENV["RUBYLIB"] = ENV["RUBYLIB"], nil - @pre = @rubylib.nil? ? '' : @rubylib + File::PATH_SEPARATOR - end - - after :each do - ENV["RUBYLIB"] = @rubylib - end - - it "adds a directory to $LOAD_PATH" do - dir = tmp("rubylib/incl") - ENV["RUBYLIB"] = @pre + dir - paths = ruby_exe("puts $LOAD_PATH").lines.map(&:chomp) - paths.should include(dir) - end - - it "adds a File::PATH_SEPARATOR-separated list of directories to $LOAD_PATH" do - dir1, dir2 = tmp("rubylib/incl1"), tmp("rubylib/incl2") - ENV["RUBYLIB"] = @pre + "#{dir1}#{File::PATH_SEPARATOR}#{dir2}" - paths = ruby_exe("puts $LOAD_PATH").lines.map(&:chomp) - paths.should include(dir1) - paths.should include(dir2) - paths.index(dir1).should < paths.index(dir2) - end - - it "adds the directory at the front of $LOAD_PATH" do - dir = tmp("rubylib/incl_front") - ENV["RUBYLIB"] = @pre + dir - paths = ruby_exe("puts $LOAD_PATH").lines.map(&:chomp) - paths.shift if paths.first.end_with?('/gem-rehash') - if PlatformGuard.implementation? :ruby - # In a MRI checkout, $PWD and some extra -I entries end up as - # the first entries in $LOAD_PATH. So just assert that it's not last. - idx = paths.index(dir) - idx.should < paths.size-1 - else - paths[0].should == dir - end - end - - it "adds the directory after directories added by -I" do - dash_i_dir = tmp("dash_I_include") - rubylib_dir = tmp("rubylib_include") - ENV["RUBYLIB"] = @pre + rubylib_dir - paths = ruby_exe("puts $LOAD_PATH", options: "-I #{dash_i_dir}").lines.map(&:chomp) - paths.should include(dash_i_dir) - paths.should include(rubylib_dir) - paths.index(dash_i_dir).should < paths.index(rubylib_dir) - end - - it "adds the directory after directories added by -I within RUBYOPT" do - rubyopt_dir = tmp("rubyopt_include") - rubylib_dir = tmp("rubylib_include") - ENV["RUBYLIB"] = @pre + rubylib_dir - paths = ruby_exe("puts $LOAD_PATH", env: { "RUBYOPT" => "-I#{rubyopt_dir}" }).lines.map(&:chomp) - paths.should include(rubyopt_dir) - paths.should include(rubylib_dir) - paths.index(rubyopt_dir).should < paths.index(rubylib_dir) - end - - it "keeps spaces in the value" do - ENV["RUBYLIB"] = @pre + " rubylib/incl " - out = ruby_exe("puts $LOAD_PATH") - out.should include(" rubylib/incl ") - end -end diff --git a/spec/ruby/command_line/rubyopt_spec.rb b/spec/ruby/command_line/rubyopt_spec.rb index 734db8d519..a662b026bf 100644 --- a/spec/ruby/command_line/rubyopt_spec.rb +++ b/spec/ruby/command_line/rubyopt_spec.rb @@ -1,80 +1,60 @@ -require_relative '../spec_helper' +require File.expand_path('../../spec_helper', __FILE__) describe "Processing RUBYOPT" do - before :each do + before (:each) do @rubyopt, ENV["RUBYOPT"] = ENV["RUBYOPT"], nil end - after :each do + after (:each) do ENV["RUBYOPT"] = @rubyopt end it "adds the -I path to $LOAD_PATH" do ENV["RUBYOPT"] = "-Ioptrubyspecincl" - result = ruby_exe("puts $LOAD_PATH.grep(/byspecin/)") + result = ruby_exe("puts $LOAD_PATH.grep(/byspecin/)", escape: true) result.chomp[-15..-1].should == "optrubyspecincl" end it "sets $DEBUG to true for '-d'" do ENV["RUBYOPT"] = '-d' command = %[puts "value of $DEBUG is \#{$DEBUG}"] - result = ruby_exe(command, args: "2>&1") + result = ruby_exe(command, escape: true, args: "2>&1") result.should =~ /value of \$DEBUG is true/ end - guard -> { not CROSS_COMPILING } do - it "prints the version number for '-v'" do - ENV["RUBYOPT"] = '-v' - ruby_exe("")[/\A.*/].should == RUBY_DESCRIPTION - end + it "prints the version number for '-v'" do + ENV["RUBYOPT"] = '-v' + ruby_exe("")[/\A.*/].should == RUBY_DESCRIPTION + end - it "ignores whitespace around the option" do - ENV["RUBYOPT"] = ' -v ' - ruby_exe("")[/\A.*/].should == RUBY_DESCRIPTION - end + it "ignores whitespace around the option" do + ENV["RUBYOPT"] = ' -v ' + ruby_exe("")[/\A.*/].should == RUBY_DESCRIPTION end it "sets $VERBOSE to true for '-w'" do ENV["RUBYOPT"] = '-w' - ruby_exe("p $VERBOSE").chomp.should == "true" + ruby_exe("p $VERBOSE", escape: true).chomp.should == "true" end it "sets $VERBOSE to true for '-W'" do ENV["RUBYOPT"] = '-W' - ruby_exe("p $VERBOSE").chomp.should == "true" + ruby_exe("p $VERBOSE", escape: true).chomp.should == "true" end it "sets $VERBOSE to nil for '-W0'" do ENV["RUBYOPT"] = '-W0' - ruby_exe("p $VERBOSE").chomp.should == "nil" + ruby_exe("p $VERBOSE", escape: true).chomp.should == "nil" end it "sets $VERBOSE to false for '-W1'" do ENV["RUBYOPT"] = '-W1' - ruby_exe("p $VERBOSE").chomp.should == "false" + ruby_exe("p $VERBOSE", escape: true).chomp.should == "false" end it "sets $VERBOSE to true for '-W2'" do ENV["RUBYOPT"] = '-W2' - ruby_exe("p $VERBOSE").chomp.should == "true" - end - - it "suppresses deprecation warnings for '-W:no-deprecated'" do - ENV["RUBYOPT"] = '-W:no-deprecated' - result = ruby_exe('$; = ""', args: '2>&1') - result.should == "" - end - - it "suppresses experimental warnings for '-W:no-experimental'" do - ENV["RUBYOPT"] = '-W:no-experimental' - result = ruby_exe('case 0; in a; end', args: '2>&1') - result.should == "" - end - - it "suppresses deprecation and experimental warnings for '-W:no-deprecated -W:no-experimental'" do - ENV["RUBYOPT"] = '-W:no-deprecated -W:no-experimental' - result = ruby_exe('case ($; = ""); in a; end', args: '2>&1') - result.should == "" + ruby_exe("p $VERBOSE", escape: true).chomp.should == "true" end it "requires the file for '-r'" do @@ -85,101 +65,101 @@ describe "Processing RUBYOPT" do it "raises a RuntimeError for '-a'" do ENV["RUBYOPT"] = '-a' - ruby_exe("", args: '2>&1', exit_status: 1).should =~ /RuntimeError/ + ruby_exe("", args: '2>&1').should =~ /RuntimeError/ end it "raises a RuntimeError for '-p'" do ENV["RUBYOPT"] = '-p' - ruby_exe("", args: '2>&1', exit_status: 1).should =~ /RuntimeError/ + ruby_exe("", args: '2>&1').should =~ /RuntimeError/ end it "raises a RuntimeError for '-n'" do ENV["RUBYOPT"] = '-n' - ruby_exe("", args: '2>&1', exit_status: 1).should =~ /RuntimeError/ + ruby_exe("", args: '2>&1').should =~ /RuntimeError/ end it "raises a RuntimeError for '-y'" do ENV["RUBYOPT"] = '-y' - ruby_exe("", args: '2>&1', exit_status: 1).should =~ /RuntimeError/ + ruby_exe("", args: '2>&1').should =~ /RuntimeError/ end it "raises a RuntimeError for '-c'" do ENV["RUBYOPT"] = '-c' - ruby_exe("", args: '2>&1', exit_status: 1).should =~ /RuntimeError/ + ruby_exe("", args: '2>&1').should =~ /RuntimeError/ end it "raises a RuntimeError for '-s'" do ENV["RUBYOPT"] = '-s' - ruby_exe("", args: '2>&1', exit_status: 1).should =~ /RuntimeError/ + ruby_exe("", args: '2>&1').should =~ /RuntimeError/ end it "raises a RuntimeError for '-h'" do ENV["RUBYOPT"] = '-h' - ruby_exe("", args: '2>&1', exit_status: 1).should =~ /RuntimeError/ + ruby_exe("", args: '2>&1').should =~ /RuntimeError/ end it "raises a RuntimeError for '--help'" do ENV["RUBYOPT"] = '--help' - ruby_exe("", args: '2>&1', exit_status: 1).should =~ /RuntimeError/ + ruby_exe("", args: '2>&1').should =~ /RuntimeError/ end it "raises a RuntimeError for '-l'" do ENV["RUBYOPT"] = '-l' - ruby_exe("", args: '2>&1', exit_status: 1).should =~ /RuntimeError/ + ruby_exe("", args: '2>&1').should =~ /RuntimeError/ end it "raises a RuntimeError for '-S'" do ENV["RUBYOPT"] = '-S irb' - ruby_exe("", args: '2>&1', exit_status: 1).should =~ /RuntimeError/ + ruby_exe("", args: '2>&1').should =~ /RuntimeError/ end it "raises a RuntimeError for '-e'" do ENV["RUBYOPT"] = '-e0' - ruby_exe("", args: '2>&1', exit_status: 1).should =~ /RuntimeError/ + ruby_exe("", args: '2>&1').should =~ /RuntimeError/ end it "raises a RuntimeError for '-i'" do ENV["RUBYOPT"] = '-i.bak' - ruby_exe("", args: '2>&1', exit_status: 1).should =~ /RuntimeError/ + ruby_exe("", args: '2>&1').should =~ /RuntimeError/ end it "raises a RuntimeError for '-x'" do ENV["RUBYOPT"] = '-x' - ruby_exe("", args: '2>&1', exit_status: 1).should =~ /RuntimeError/ + ruby_exe("", args: '2>&1').should =~ /RuntimeError/ end it "raises a RuntimeError for '-C'" do ENV["RUBYOPT"] = '-C' - ruby_exe("", args: '2>&1', exit_status: 1).should =~ /RuntimeError/ + ruby_exe("", args: '2>&1').should =~ /RuntimeError/ end it "raises a RuntimeError for '-X'" do ENV["RUBYOPT"] = '-X.' - ruby_exe("", args: '2>&1', exit_status: 1).should =~ /RuntimeError/ + ruby_exe("", args: '2>&1').should =~ /RuntimeError/ end it "raises a RuntimeError for '-F'" do ENV["RUBYOPT"] = '-F' - ruby_exe("", args: '2>&1', exit_status: 1).should =~ /RuntimeError/ + ruby_exe("", args: '2>&1').should =~ /RuntimeError/ end it "raises a RuntimeError for '-0'" do ENV["RUBYOPT"] = '-0' - ruby_exe("", args: '2>&1', exit_status: 1).should =~ /RuntimeError/ + ruby_exe("", args: '2>&1').should =~ /RuntimeError/ end it "raises a RuntimeError for '--copyright'" do ENV["RUBYOPT"] = '--copyright' - ruby_exe("", args: '2>&1', exit_status: 1).should =~ /RuntimeError/ + ruby_exe("", args: '2>&1').should =~ /RuntimeError/ end it "raises a RuntimeError for '--version'" do ENV["RUBYOPT"] = '--version' - ruby_exe("", args: '2>&1', exit_status: 1).should =~ /RuntimeError/ + ruby_exe("", args: '2>&1').should =~ /RuntimeError/ end it "raises a RuntimeError for '--yydebug'" do ENV["RUBYOPT"] = '--yydebug' - ruby_exe("", args: '2>&1', exit_status: 1).should =~ /RuntimeError/ + ruby_exe("", args: '2>&1').should =~ /RuntimeError/ end end diff --git a/spec/ruby/command_line/shared/change_directory.rb b/spec/ruby/command_line/shared/change_directory.rb deleted file mode 100644 index 9cb6e90ac6..0000000000 --- a/spec/ruby/command_line/shared/change_directory.rb +++ /dev/null @@ -1,21 +0,0 @@ -describe :command_line_change_directory, shared: true do - before :all do - @script = fixture(__FILE__, 'change_directory_script.rb') - @tempdir = File.dirname(@script) - end - - it 'changes the PWD when using a file' do - output = ruby_exe(@script, options: "#{@method} #{@tempdir}") - output.should == @tempdir - end - - it 'does not need a space after -C for the argument' do - output = ruby_exe(@script, options: "#{@method}#{@tempdir}") - output.should == @tempdir - end - - it 'changes the PWD when using -e' do - output = ruby_exe(nil, options: "#{@method} #{@tempdir} -e 'print Dir.pwd'") - output.should == @tempdir - end -end diff --git a/spec/ruby/command_line/shared/verbose.rb b/spec/ruby/command_line/shared/verbose.rb index c5c44c269e..457fe3006a 100644 --- a/spec/ruby/command_line/shared/verbose.rb +++ b/spec/ruby/command_line/shared/verbose.rb @@ -4,6 +4,6 @@ describe :command_line_verbose, shared: true do end it "sets $VERBOSE to true" do - ruby_exe(@script, options: @method).chomp.b.split.last.should == "true" + ruby_exe(@script, options: @method).chomp.split.last.should == "true" end end diff --git a/spec/ruby/command_line/syntax_error_spec.rb b/spec/ruby/command_line/syntax_error_spec.rb index 444ea9635c..71cee32e23 100644 --- a/spec/ruby/command_line/syntax_error_spec.rb +++ b/spec/ruby/command_line/syntax_error_spec.rb @@ -1,13 +1,13 @@ -require_relative '../spec_helper' +require File.expand_path('../../spec_helper', __FILE__) describe "The interpreter" do it "prints an error when given a file with invalid syntax" do - out = ruby_exe(fixture(__FILE__, "bad_syntax.rb"), args: "2>&1", exit_status: 1) + out = ruby_exe(fixture(__FILE__, "bad_syntax.rb"), args: "2>&1") out.should include "syntax error" end it "prints an error when given code via -e with invalid syntax" do - out = ruby_exe(nil, args: "-e 'a{' 2>&1", exit_status: 1) + out = ruby_exe(nil, args: "-e 'a{' 2>&1") out.should include "syntax error" end end |
