# frozen_string_literal: true require 'helper' describe RbST do def setup [:rst, :html, :latex].each do |f| instance_variable_set( :"@#{f}_file_path", File.join(File.dirname(__FILE__), 'files', "test.#{f}") ) end @rst2parts_path = File.expand_path( File.join(File.dirname(__FILE__), '..', 'lib', 'rst2parts') ) end it 'should call bare rest2parts when passed no options' do converter = RbST.new([@rst_file_path]) converter \ .expects(:execute) \ .with("python #{@rst2parts_path}/rst2html.py") \ .returns(true) assert converter.convert end it 'should convert with custom executable' do executables = { html: '/some/path/2html.py' } default_executables = RbST.executables RbST.executables = executables converter = RbST.new([@rst_file_path]) converter \ .expects(:execute) \ .with("python #{executables[:html]}") \ .returns(true) assert converter.to_html RbST.executables = default_executables end it 'should raise error when passed bad executable key' do executables = { markdown: '/some/path/2markdown.py' } begin RbST.executables = executables flunk rescue ArgumentError assert true end end it 'should convert ReST to html' do html = RbST.new([@rst_file_path]).to_html assert_equal( File.read(@html_file_path), html ) end it 'should convert ReST to LaTeX' do latex = RbST.new([@rst_file_path]).to_latex assert_equal( File.read(@latex_file_path), latex ) end [:html, :latex].each do |f| it "should accept options on #to_#{f}" do converter = RbST.new([@rst_file_path]) converter \ .expects(:execute) \ .with("python #{@rst2parts_path}/rst2#{f}.py --raw-enabled") \ .returns(true) assert converter.send("to_#{f}", :raw_enabled) end end it 'should recognize strip_comments option' do html_with_comment = RbST.convert('.. comment') assert_equal( html_with_comment, %|
| + %|| + %|steve@mac.com| + %|
\nhello world
\nhello world
\n|, fragment ) end it 'should convert to html with unicode' do test_string = 'Hello ☃' output = RbST.new(test_string).to_html(part: :fragment) assert_equal( %|#{test_string}
\n|, output ) end it 'should convert to latex with unicode' do test_string = 'Hello ☃' output = RbST.new(test_string).to_latex(part: :body) assert_equal( %|\n#{test_string}\n|, output ) end it 'should preserve file paths in strings without array' do output = RbST.new(@rst_file_path).to_html(part: :fragment) assert_equal( %|#{@rst_file_path}
\n|, output ) end it 'should execute with custom python path' do RbST.python_path = '/usr/bin/env python3' converter = RbST.new([@rst_file_path]) converter \ .expects(:execute) \ .with("/usr/bin/env python3 #{@rst2parts_path}/rst2html.py") \ .returns(true) assert converter.convert RbST.python_path = 'python' end it 'should convert to html with python3' do RbST.python_path = '/usr/bin/env python3' test_string = 'Hello ☃' output = RbST.new(test_string).to_html(part: :fragment) assert_equal( %|#{test_string}
\n|, output ) RbST.python_path = 'python' end it 'should convert to latex with python3' do RbST.python_path = '/usr/bin/env python3' test_string = 'Hello ☃' output = RbST.new(test_string).to_latex(part: :body) assert_equal( %|\n#{test_string}\n|, output ) RbST.python_path = 'python' end it 'should convert to html with python2' do RbST.python_path = '/usr/bin/env python2' test_string = 'Hello ☃' output = RbST.new(test_string).to_html(part: :fragment) assert_equal( %|#{test_string}
\n|, output ) RbST.python_path = 'python' end it 'should convert to latex with python2' do RbST.python_path = '/usr/bin/env python2' test_string = 'Hello ☃' output = RbST.new(test_string).to_latex(part: :body) assert_equal( %|\n#{test_string}\n|, output ) RbST.python_path = 'python' end end