Skip to content

Commit

Permalink
merge revision(s) 9718ff6,20ad1017017ea736667d86fa0250dc1a39daefa1: […
Browse files Browse the repository at this point in the history
…Backport #17211]

	Show stdout and stderr when history tests fail

	Remove system method for E2E testing because depends on ruby command
  • Loading branch information
nagachika committed Oct 11, 2020
1 parent 48ac737 commit d1ba554
Show file tree
Hide file tree
Showing 2 changed files with 84 additions and 64 deletions.
146 changes: 83 additions & 63 deletions test/irb/test_history.rb
@@ -1,6 +1,7 @@
# frozen_string_literal: false
require 'test/unit'
require 'irb'
require 'irb/ext/save-history'
require 'readline'

module TestIRB
Expand All @@ -13,133 +14,152 @@ def teardown
IRB.conf[:RC_NAME_GENERATOR] = nil
end

class TestInputMethod < ::IRB::InputMethod
HISTORY = Array.new

include IRB::HistorySavingAbility

attr_reader :list, :line_no

def initialize(list = [])
super("test")
@line_no = 0
@list = list
end

def gets
@list[@line_no]&.tap {@line_no += 1}
end

def eof?
@line_no >= @list.size
end

def encoding
Encoding.default_external
end

def reset
@line_no = 0
end

def winsize
[10, 20]
end
end

def test_history_save_1
omit "Skip Editline" if /EditLine/n.match(Readline::VERSION)
_result_output, result_history_file = launch_irb_with_irbrc_and_irb_history(<<~IRBRC, <<~IRB_HISTORY) do |stdin|
IRB.conf[:USE_READLINE] = true
IRB.conf[:SAVE_HISTORY] = 1
IRB.conf[:USE_READLINE] = true
IRBRC
IRB.conf[:SAVE_HISTORY] = 1
assert_history(<<~EXPECTED_HISTORY, <<~INITIAL_HISTORY, <<~INPUT)
exit
EXPECTED_HISTORY
1
2
3
4
IRB_HISTORY
stdin.write("5\nexit\n")
end

assert_equal(<<~HISTORY_FILE, result_history_file)
INITIAL_HISTORY
5
exit
HISTORY_FILE
INPUT
end

def test_history_save_100
omit "Skip Editline" if /EditLine/n.match(Readline::VERSION)
_result_output, result_history_file = launch_irb_with_irbrc_and_irb_history(<<~IRBRC, <<~IRB_HISTORY) do |stdin|
IRB.conf[:USE_READLINE] = true
IRB.conf[:SAVE_HISTORY] = 100
IRB.conf[:USE_READLINE] = true
IRBRC
IRB.conf[:SAVE_HISTORY] = 100
assert_history(<<~EXPECTED_HISTORY, <<~INITIAL_HISTORY, <<~INPUT)
1
2
3
4
IRB_HISTORY
stdin.write("5\nexit\n")
end

assert_equal(<<~HISTORY_FILE, result_history_file)
5
exit
EXPECTED_HISTORY
1
2
3
4
INITIAL_HISTORY
5
exit
HISTORY_FILE
INPUT
end

def test_history_save_bignum
omit "Skip Editline" if /EditLine/n.match(Readline::VERSION)
_result_output, result_history_file = launch_irb_with_irbrc_and_irb_history(<<~IRBRC, <<~IRB_HISTORY) do |stdin|
IRB.conf[:USE_READLINE] = true
IRB.conf[:SAVE_HISTORY] = 10 ** 19
IRB.conf[:USE_READLINE] = true
IRBRC
IRB.conf[:SAVE_HISTORY] = 10 ** 19
assert_history(<<~EXPECTED_HISTORY, <<~INITIAL_HISTORY, <<~INPUT)
1
2
3
4
IRB_HISTORY
stdin.write("5\nexit\n")
end

assert_equal(<<~HISTORY_FILE, result_history_file)
5
exit
EXPECTED_HISTORY
1
2
3
4
INITIAL_HISTORY
5
exit
HISTORY_FILE
INPUT
end

def test_history_save_minus_as_infinity
omit "Skip Editline" if /EditLine/n.match(Readline::VERSION)
_result_output, result_history_file = launch_irb_with_irbrc_and_irb_history(<<~IRBRC, <<~IRB_HISTORY) do |stdin|
IRB.conf[:USE_READLINE] = true
IRB.conf[:SAVE_HISTORY] = -1 # infinity
IRB.conf[:USE_READLINE] = true
IRBRC
IRB.conf[:SAVE_HISTORY] = -1 # infinity
assert_history(<<~EXPECTED_HISTORY, <<~INITIAL_HISTORY, <<~INPUT)
1
2
3
4
IRB_HISTORY
stdin.write("5\nexit\n")
end

assert_equal(<<~HISTORY_FILE, result_history_file)
5
exit
EXPECTED_HISTORY
1
2
3
4
INITIAL_HISTORY
5
exit
HISTORY_FILE
INPUT
end

private

def launch_irb_with_irbrc_and_irb_history(irbrc, irb_history)
result = nil
result_history = nil
backup_irbrc = ENV.delete("IRBRC")
def assert_history(expected_history, initial_irb_history, input)
backup_verbose, $VERBOSE = $VERBOSE, nil
backup_home = ENV["HOME"]
IRB.conf[:LC_MESSAGES] = IRB::Locale.new
actual_history = nil
Dir.mktmpdir("test_irb_history_#{$$}") do |tmpdir|
ENV["HOME"] = tmpdir
open(IRB.rc_file, "w") do |f|
f.write(irbrc)
end
open(IRB.rc_file("_history"), "w") do |f|
f.write(irb_history)
f.write(initial_irb_history)
end

with_temp_stdio do |stdin, stdout|
yield(stdin, stdout)
stdin.close
stdout.flush
system('ruby', '-Ilib', '-Itest', '-W0', '-rirb', '-e', 'IRB.start(__FILE__)', in: stdin.path, out: stdout.path)
result = stdout.read
stdout.close
end
io = TestInputMethod.new
io.class::HISTORY.clear
io.load_history
io.class::HISTORY.concat(input.split)
io.save_history

io.load_history
open(IRB.rc_file("_history"), "r") do |f|
result_history = f.read
actual_history = f.read
end
end
[result, result_history]
assert_equal(expected_history, actual_history, <<~MESSAGE)
expected:
#{expected_history}
but actual:
#{actual_history}
MESSAGE
ensure
$VERBOSE = backup_verbose
ENV["HOME"] = backup_home
ENV["IRBRC"] = backup_irbrc
end

def with_temp_stdio
Expand Down
2 changes: 1 addition & 1 deletion version.h
Expand Up @@ -2,7 +2,7 @@
# define RUBY_VERSION_MINOR RUBY_API_VERSION_MINOR
#define RUBY_VERSION_TEENY 3
#define RUBY_RELEASE_DATE RUBY_RELEASE_YEAR_STR"-"RUBY_RELEASE_MONTH_STR"-"RUBY_RELEASE_DAY_STR
#define RUBY_PATCHLEVEL 138
#define RUBY_PATCHLEVEL 139

#define RUBY_RELEASE_YEAR 2020
#define RUBY_RELEASE_MONTH 10
Expand Down

0 comments on commit d1ba554

Please sign in to comment.