2014-06-04 19:51:25 +02:00
|
|
|
require_relative "setup"
|
2014-06-04 18:56:50 +02:00
|
|
|
require "parslet/convenience"
|
|
|
|
|
2015-09-18 20:55:02 +02:00
|
|
|
|
|
|
|
|
|
|
|
# Older test harness
|
2014-06-04 18:56:50 +02:00
|
|
|
module ParserHelper
|
2015-09-15 17:57:31 +02:00
|
|
|
|
2014-06-04 18:56:50 +02:00
|
|
|
def self.included(base)
|
|
|
|
base.send :include, InstanceMethods #provides helpers and setup
|
2015-10-09 16:23:43 +02:00
|
|
|
base.send :include, AST::true_statements
|
2014-06-04 18:56:50 +02:00
|
|
|
base.send :extend, ClassMethods #gets the method creation going
|
|
|
|
end
|
2015-09-15 17:57:31 +02:00
|
|
|
|
2014-06-04 18:56:50 +02:00
|
|
|
module InstanceMethods
|
|
|
|
def setup
|
2014-07-29 17:36:18 +02:00
|
|
|
@parser = Parser::Salama.new
|
2014-06-04 18:56:50 +02:00
|
|
|
@transform = Parser::Transform.new
|
|
|
|
end
|
|
|
|
|
|
|
|
# check that @string_input parses correctly to @parse_output
|
|
|
|
def check_parse
|
|
|
|
is = @parser.parse_with_debug(@string_input)
|
|
|
|
assert_equal @parse_output , is
|
|
|
|
end
|
|
|
|
|
|
|
|
#check that @parse_output transforms to @transform_output
|
|
|
|
def check_transform
|
|
|
|
is = @transform.apply @parse_output
|
|
|
|
#puts is.transform
|
|
|
|
assert_equal @transform_output , is
|
|
|
|
end
|
|
|
|
|
|
|
|
# check that @string_input parses and transforms to @transform_output
|
|
|
|
def check_ast
|
|
|
|
syntax = @parser.parse(@string_input)
|
|
|
|
is = @transform.apply(syntax)
|
2015-09-18 20:55:02 +02:00
|
|
|
puts is.inspect
|
2014-06-04 18:56:50 +02:00
|
|
|
assert_equal @transform_output , is
|
|
|
|
end
|
2015-09-18 20:55:02 +02:00
|
|
|
|
|
|
|
def check_write test
|
|
|
|
dirname = decamelize(self.class.name)[10 .. -1]
|
|
|
|
test = test[5 .. -1]
|
|
|
|
syntax = @parser.parse_with_debug(@string_input)
|
|
|
|
out = Parser::Transform.new.apply(syntax).inspect
|
|
|
|
dir = File.dirname(__FILE__) + "/" + dirname
|
|
|
|
FileUtils.mkdir_p(dir) unless File.exists?(dir)
|
|
|
|
out_file = File.new(dir + "/" + test + ".tst", "w")
|
|
|
|
out_file.puts @string_input
|
|
|
|
out_file.puts "-- -- --"
|
|
|
|
out_file.puts out
|
|
|
|
out_file.close
|
|
|
|
end
|
|
|
|
|
|
|
|
def decamelize str
|
|
|
|
str.gsub(/(^|[a-z])([A-Z])/) do
|
|
|
|
($1.empty?)? $2 : "#{$1}_#{$2}"
|
|
|
|
end.downcase
|
|
|
|
end
|
|
|
|
|
|
|
|
def camelize str
|
|
|
|
str.gsub(/(^|_)([a-z])/) { $2.upcase }
|
|
|
|
end
|
2014-06-04 18:56:50 +02:00
|
|
|
end
|
|
|
|
|
2015-09-18 20:55:02 +02:00
|
|
|
|
2014-06-04 18:56:50 +02:00
|
|
|
module ClassMethods
|
2015-09-15 17:57:31 +02:00
|
|
|
# this creates test methods dynamically. For each test_* method we create
|
2014-06-04 18:56:50 +02:00
|
|
|
# three test_*[ast/parse/transf] methods that in turn check the three phases.
|
|
|
|
# runnable_methods is called by minitest to determine which tests to run
|
|
|
|
def runnable_methods
|
|
|
|
tests = []
|
|
|
|
public_instance_methods(true).grep(/^test_/).map(&:to_s).each do |test|
|
2015-09-18 20:55:02 +02:00
|
|
|
["write"].each do |what|
|
2014-06-04 18:56:50 +02:00
|
|
|
name = "#{test}_#{what}"
|
|
|
|
tests << name
|
|
|
|
self.send(:define_method, name ) do
|
|
|
|
send(test)
|
2015-09-18 20:55:02 +02:00
|
|
|
send("check_#{what}" , test)
|
2014-06-04 18:56:50 +02:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
tests
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|