1
0
Fork 0
mirror of https://github.com/pry/pry.git synced 2022-11-09 12:35:05 -05:00
pry--pry/spec/editor_spec.rb
Kyrylo Silin 92a1b86e1e Fix errors in "edit_spec.rb" and "editor_spec.rb"
Basically, the condition was a bit wrong. Let's hope this commit fixes
it.
2013-01-14 18:43:19 +02:00

79 lines
1.9 KiB
Ruby

require 'pathname'
require 'helper'
describe Pry::Editor do
class << Pry::Editor
public :build_editor_invocation_string
end
before do
# OS-specific tempdir name. For GNU/Linux it's "tmp", for Windows it's
# something "Temp".
@tf_dir =
if Pry::Helpers::BaseHelpers.mri_19?
Pathname.new(Dir::Tmpname.tmpdir)
else
Pathname.new(Dir.tmpdir)
end
@tf_path = File.join(@tf_dir.to_s, 'hello world.rb')
end
unless Pry::Helpers::BaseHelpers.windows?
describe "build_editor_invocation_string" do
before do
class << Pry::Editor
public :build_editor_invocation_string
end
end
it 'should shell-escape files' do
invocation_str = Pry::Editor.build_editor_invocation_string(@tf_path, 5, true)
invocation_str.should =~ /#@tf_dir.+hello\\ world\.rb/
end
end
end
describe "build_editor_invocation_string on windows" do
before do
class << Pry::Editor
def windows?; true; end
end
end
after do
class << Pry::Editor
undef windows?
end
end
it "should replace / by \\" do
invocation_str = Pry::Editor.build_editor_invocation_string(@tf_path, 5, true)
invocation_str.should =~ %r(\\#{@tf_dir.basename}\\)
end
it "should not shell-escape files" do
invocation_str = Pry::Editor.build_editor_invocation_string(@tf_path, 5, true)
invocation_str.should =~ /hello world\.rb/
end
end
describe 'invoke_editor with a proc' do
before do
@old_editor = Pry.config.editor
Pry.config.editor = proc{ |file, line, blocking|
@file = file
nil
}
end
after do
Pry.config.editor = @old_editor
end
it 'should not shell-escape files' do
Pry::Editor.invoke_editor(@tf_path, 10, true)
@file.should == @tf_path
end
end
end