2017-02-05 02:54:32 -05:00
|
|
|
# frozen_string_literal: true
|
2014-10-25 23:24:18 -04:00
|
|
|
begin
|
|
|
|
require 'ripper'
|
|
|
|
require 'test/unit'
|
|
|
|
ripper_test = true
|
|
|
|
module TestRipper; end
|
|
|
|
rescue LoadError
|
|
|
|
end
|
|
|
|
|
|
|
|
class TestRipper::Sexp < Test::Unit::TestCase
|
|
|
|
def test_compile_error
|
|
|
|
assert_nil Ripper.sexp("/")
|
|
|
|
assert_nil Ripper.sexp("-")
|
|
|
|
assert_nil Ripper.sexp("+")
|
|
|
|
assert_nil Ripper.sexp("*")
|
|
|
|
assert_nil Ripper.sexp("end")
|
|
|
|
assert_nil Ripper.sexp("end 1")
|
2014-11-19 12:10:35 -05:00
|
|
|
assert_nil Ripper.sexp("/*")
|
|
|
|
assert_nil Ripper.sexp("/*/")
|
|
|
|
assert_nil Ripper.sexp("/+/")
|
2014-10-25 23:24:18 -04:00
|
|
|
end
|
2014-11-30 06:05:58 -05:00
|
|
|
|
|
|
|
def test_regexp_content
|
|
|
|
sexp = Ripper.sexp('//')
|
|
|
|
assert_nil search_sexp(:@tstring_content, search_sexp(:regexp_literal, sexp))
|
|
|
|
|
|
|
|
sexp = Ripper.sexp('/foo/')
|
|
|
|
assert_equal 'foo', search_sexp(:@tstring_content, search_sexp(:regexp_literal, sexp))[1]
|
|
|
|
|
2014-12-01 16:32:04 -05:00
|
|
|
sexp = Ripper.sexp("/foo\nbar/")
|
|
|
|
assert_equal "foo\nbar", search_sexp(:@tstring_content, search_sexp(:regexp_literal, sexp))[1]
|
|
|
|
|
2014-11-30 06:05:58 -05:00
|
|
|
sexp = Ripper.sexp('/(?<n>a(b|\g<n>))/')
|
|
|
|
assert_equal '(?<n>a(b|\g<n>))', search_sexp(:@tstring_content, search_sexp(:regexp_literal, sexp))[1]
|
|
|
|
end
|
|
|
|
|
2015-11-28 05:33:58 -05:00
|
|
|
def test_heredoc_content
|
|
|
|
sexp = Ripper.sexp("<<E\nfoo\nE")
|
|
|
|
assert_equal "foo\n", search_sexp(:@tstring_content, sexp)[1]
|
|
|
|
end
|
|
|
|
|
2015-12-07 09:39:52 -05:00
|
|
|
def test_squiggly_heredoc
|
|
|
|
sexp = Ripper.sexp("<<~eot\n asdf\neot")
|
|
|
|
assert_equal "asdf\n", search_sexp(:@tstring_content, sexp)[1]
|
|
|
|
end
|
|
|
|
|
|
|
|
def test_squiggly_heredoc_with_interpolated_expression
|
|
|
|
sexp1 = Ripper.sexp(<<-eos)
|
|
|
|
<<-eot
|
|
|
|
a\#{1}z
|
|
|
|
eot
|
|
|
|
eos
|
|
|
|
|
|
|
|
sexp2 = Ripper.sexp(<<-eos)
|
|
|
|
<<~eot
|
|
|
|
a\#{1}z
|
|
|
|
eot
|
|
|
|
eos
|
|
|
|
|
|
|
|
assert_equal clear_pos(sexp1), clear_pos(sexp2)
|
|
|
|
end
|
|
|
|
|
2017-06-30 22:01:05 -04:00
|
|
|
def test_params_mlhs
|
|
|
|
sexp = Ripper.sexp("proc {|(w, *x, y), z|}")
|
|
|
|
_, ((mlhs, w, (rest, x), y), z) = search_sexp(:params, sexp)
|
|
|
|
assert_equal(:mlhs, mlhs)
|
|
|
|
assert_equal(:@ident, w[0])
|
|
|
|
assert_equal("w", w[1])
|
|
|
|
assert_equal(:rest_param, rest)
|
|
|
|
assert_equal(:@ident, x[0])
|
|
|
|
assert_equal("x", x[1])
|
|
|
|
assert_equal(:@ident, y[0])
|
|
|
|
assert_equal("y", y[1])
|
|
|
|
assert_equal(:@ident, z[0])
|
|
|
|
assert_equal("z", z[1])
|
|
|
|
end
|
|
|
|
|
2017-10-04 01:30:44 -04:00
|
|
|
def test_def_fname
|
|
|
|
sexp = Ripper.sexp("def t; end")
|
|
|
|
_, (type, fname,) = search_sexp(:def, sexp)
|
|
|
|
assert_equal(:@ident, type)
|
|
|
|
assert_equal("t", fname)
|
|
|
|
|
|
|
|
sexp = Ripper.sexp("def <<; end")
|
|
|
|
_, (type, fname,) = search_sexp(:def, sexp)
|
|
|
|
assert_equal(:@op, type)
|
|
|
|
assert_equal("<<", fname)
|
|
|
|
end
|
|
|
|
|
2014-11-30 06:05:58 -05:00
|
|
|
def search_sexp(sym, sexp)
|
|
|
|
return sexp if !sexp or sexp[0] == sym
|
|
|
|
sexp.find do |e|
|
|
|
|
if Array === e and e = search_sexp(sym, e)
|
|
|
|
return e
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
2015-12-07 09:39:52 -05:00
|
|
|
|
|
|
|
def clear_pos(sexp)
|
|
|
|
return sexp if !sexp
|
|
|
|
sexp.each do |e|
|
|
|
|
if Array === e
|
|
|
|
if e.size == 3 and Array === (last = e.last) and
|
|
|
|
last.size == 2 and Integer === last[0] and Integer === last[1]
|
|
|
|
last.clear
|
|
|
|
else
|
|
|
|
clear_pos(e)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
2014-10-25 23:24:18 -04:00
|
|
|
end if ripper_test
|