require File.expand_path(File.dirname(__FILE__) + '/../../test_helper') describe ::Inch::CodeObject::Docstring do # # loose TomDoc compatibility # it "should notice things in tomdoc style docs" do text = <<-DOC Public: Detects the Language of the blob. param1 - String filename param2 - String blob data. A block also maybe passed in for lazy loading. This behavior is deprecated and you should always pass in a String. param3 - Optional String mode (defaults to nil) Returns Language or nil. DOC docstring = ::Inch::CodeObject::Docstring.new(text) assert docstring.mentions_parameter?(:param1) assert docstring.mentions_parameter?(:param2) assert docstring.mentions_parameter?(:param3) assert docstring.describes_parameter?(:param1) assert docstring.describes_parameter?(:param2) assert docstring.describes_parameter?(:param3) refute docstring.contains_code_example? assert docstring.mentions_return? assert docstring.describes_return? end it "should notice things in tomdoc style docs 2" do text = <<-DOC Public: Look up Language by one of its aliases. param1 - A String alias of the Language Examples Language.find_by_alias('cpp') # => # Returns the Lexer or nil if none was found. DOC docstring = ::Inch::CodeObject::Docstring.new(text) assert docstring.mentions_parameter?(:param1) assert docstring.describes_parameter?(:param1) refute docstring.mentions_parameter?(:alias) refute docstring.mentions_parameter?(:Look) assert docstring.contains_code_example? assert docstring.mentions_return? assert docstring.describes_return? end it "should notice things in tomdoc style docs 3" do text = <<-DOC Public: Look up Language by one of its aliases. param1 - A String alias of the Language Examples Language.find_by_alias('cpp') # => # Returns the Lexer or nil if none was found. DOC docstring = ::Inch::CodeObject::Docstring.new(text) assert docstring.mentions_parameter?(:param1) assert docstring.describes_parameter?(:param1) refute docstring.mentions_parameter?(:alias) refute docstring.mentions_parameter?(:Look) assert docstring.contains_code_example? assert docstring.mentions_return? assert docstring.describes_return? end # # PARAMETER MENTIONS # it "should work 2" do text = <<-DOC Just because format_html is mentioned here, does not mean the first parameter is mentioned. DOC docstring = ::Inch::CodeObject::Docstring.new(text) refute docstring.mentions_parameter?(:format) refute docstring.contains_code_example? end it "should work 2" do text = <<-DOC Just because format is mentioned here, does not mean the first parameter is meant. DOC docstring = ::Inch::CodeObject::Docstring.new(text) refute docstring.mentions_parameter?(:format) refute docstring.contains_code_example? end # # CODE EXAMPLES # it "should work 3" do text = <<-DOC An example of a method using RDoc rather than YARD. == Parameters: param1:: A Symbol declaring some markup language like `:md` or `:html`. == Returns: A string in the specified format. DOC docstring = ::Inch::CodeObject::Docstring.new(text) refute docstring.contains_code_example? end it "should work with code example" do text = <<-DOC Another example. method_with_code_example() # => some value Params: +param1+:: param1 line string to be executed by the system +param2+:: +Proc+ object that takes a pipe object as first and only param (may be nil) +param3+:: +Proc+ object that takes a pipe object as first and only param (may be nil) DOC docstring = ::Inch::CodeObject::Docstring.new(text) assert docstring.contains_code_example? assert docstring.mentions_parameter?(:param1) assert docstring.mentions_parameter?(:param2) assert docstring.mentions_parameter?(:param3) assert docstring.describes_parameter?(:param1) assert docstring.describes_parameter?(:param2) assert docstring.describes_parameter?(:param3) end it "should work with code example 2" do text = <<-DOC Just because format_html is mentioned here, does not mean the first parameter is mentioned. method_with_code_example() # => some value method_with_missing_param_doc(param1, param2, param3) DOC docstring = ::Inch::CodeObject::Docstring.new(text) assert docstring.contains_code_example? assert_equal 1, docstring.code_examples.size end it "should work with code example 3" do text = <<-DOC An example of a method using RDoc rather than YARD. method_with_code_example() # => some value == Parameters: param1:: A Symbol declaring some markup language like `:md` or `:html`. == Returns: A string in the specified format. DOC docstring = ::Inch::CodeObject::Docstring.new(text) assert docstring.contains_code_example? assert_equal 1, docstring.code_examples.size assert docstring.mentions_parameter?(:param1) assert docstring.describes_parameter?(:param1) end it "should work with multiple code examples" do text = <<-DOC An example of a method using RDoc rather than YARD. method_with_code_example() # => some value Another example of a method: Article.__elasticsearch__.create_index! 1, force: true Article.__elasticsearch__.create_index! 2, force: true == Parameters: param1:: A Symbol declaring some markup language like `:md` or `:html`. == Returns: A string in the specified format. DOC docstring = ::Inch::CodeObject::Docstring.new(text) assert docstring.contains_code_example? assert_equal 2, docstring.code_examples.size assert docstring.code_examples.last.index("create_index! 2") end end