summaryrefslogtreecommitdiff
path: root/test/irb
diff options
context:
space:
mode:
authorStan Lo <stan.lo@shopify.com>2022-12-12 21:04:58 +0000
committergit <svn-admin@ruby-lang.org>2022-12-12 21:05:03 +0000
commitf88f2bd92f4a1760c0f323614c45369d6a281317 (patch)
tree65781e9eee2f630857327ac38a80ce128676a2af /test/irb
parent258ac07907b2e3561db48d53ed0a50c8dd05f102 (diff)
downloadruby-f88f2bd92f4a1760c0f323614c45369d6a281317.tar.gz
[ruby/irb] Group show_doc tests and update the expectation
(https://github.com/ruby/irb/pull/479) https://github.com/ruby/irb/commit/bede04c14a
Diffstat (limited to 'test/irb')
-rw-r--r--test/irb/test_cmd.rb66
1 files changed, 34 insertions, 32 deletions
diff --git a/test/irb/test_cmd.rb b/test/irb/test_cmd.rb
index 3602b7c331..719a2bbf8f 100644
--- a/test/irb/test_cmd.rb
+++ b/test/irb/test_cmd.rb
@@ -376,38 +376,6 @@ module TestIRB
assert_match(/Please specify the file name./, out)
end
- def test_help_and_show_doc
- ["help", "show_doc"].each do |cmd|
- out, _ = execute_lines(
- "#{cmd} String#gsub\n",
- "\n",
- )
-
- # the former is what we'd get without document content installed, like on CI
- # the latter is what we may get locally
- possible_rdoc_output = [/Nothing known about String#gsub/, /str.gsub\(pattern\)/]
- assert(possible_rdoc_output.any? { |output| output.match?(out) }, "Expect the `#{cmd}` command to match one of the possible outputs")
- end
- ensure
- # this is the only way to reset the redefined method without coupling the test with its implementation
- EnvUtil.suppress_warning { load "irb/cmd/help.rb" }
- end
-
- def test_help_without_rdoc
- out, _ = without_rdoc do
- execute_lines(
- "help 'String#gsub'\n",
- "\n",
- )
- end
-
- # if it fails to require rdoc, it only returns the command object
- assert_match(/=> IRB::ExtendCommand::Help\n/, out)
- ensure
- # this is the only way to reset the redefined method without coupling the test with its implementation
- EnvUtil.suppress_warning { load "irb/cmd/help.rb" }
- end
-
def test_irb_load
File.write("#{@tmpdir}/a.rb", "a = 'hi'\n")
out, err = execute_lines(
@@ -612,6 +580,40 @@ module TestIRB
assert_match(/Start the debugger of debug\.gem/, out)
end
+ class ShowDocTest < CommandTestCase
+ def test_help_and_show_doc
+ ["help", "show_doc"].each do |cmd|
+ out, _ = execute_lines(
+ "#{cmd} String#gsub\n",
+ "\n",
+ )
+
+ # the former is what we'd get without document content installed, like on CI
+ # the latter is what we may get locally
+ possible_rdoc_output = [/Nothing known about String#gsub/, /gsub\(pattern\)/]
+ assert(possible_rdoc_output.any? { |output| output.match?(out) }, "Expect the `#{cmd}` command to match one of the possible outputs. Got:\n#{out}")
+ end
+ ensure
+ # this is the only way to reset the redefined method without coupling the test with its implementation
+ EnvUtil.suppress_warning { load "irb/cmd/help.rb" }
+ end
+
+ def test_show_doc_without_rdoc
+ out, _ = without_rdoc do
+ execute_lines(
+ "show_doc String#gsub\n",
+ "\n",
+ )
+ end
+
+ # if it fails to require rdoc, it only returns the command object
+ assert_match(/=> IRB::ExtendCommand::Help\n/, out)
+ ensure
+ # this is the only way to reset the redefined method without coupling the test with its implementation
+ EnvUtil.suppress_warning { load "irb/cmd/help.rb" }
+ end
+ end
+
class EditTest < CommandTestCase
def setup
@original_editor = ENV["EDITOR"]