From 9e75a50315ffc5532dc3fc62ae5c5360927aa0d4 Mon Sep 17 00:00:00 2001 From: Torsten Ruger Date: Tue, 29 Apr 2014 16:21:28 +0300 Subject: [PATCH] improved the framework a bit --- test/parser/README.markdown | 23 +++++++++++++++++++++-- test/parser/helper.rb | 12 ++++++------ 2 files changed, 27 insertions(+), 8 deletions(-) diff --git a/test/parser/README.markdown b/test/parser/README.markdown index 232cb30b..ae655ce7 100644 --- a/test/parser/README.markdown +++ b/test/parser/README.markdown @@ -14,6 +14,25 @@ Each test must thus specify (as instance variables): - the parse output - the transform output -Test are grouped by functionality into cases and define methods parse_* +Magic +----- + +Test are grouped by functionality into cases (classes) and define methods test_* Test cases must include ParserHelper, which includes the magic to write the 3 test methods for each -parse method. See test_basic ofr easy example. +test method. See test_basic for easy example. + +Example: + + def test_number + @string_input = '42 ' + @test_output = {:integer => '42'} + @transform_output = Parser::IntegerExpression.new(42) + @parser = @parser.integer + end + +The first three lines define the data as described above. +The last line tells the parser what to parse. This is off couse only needed when a non-root rule is tested +and should be left out if possible. + +As can be seen, there are no asserts. All asserting is done by the created methods, which call +the check_* methods in helper. \ No newline at end of file diff --git a/test/parser/helper.rb b/test/parser/helper.rb index 2bfec550..c3dae2c2 100644 --- a/test/parser/helper.rb +++ b/test/parser/helper.rb @@ -38,17 +38,17 @@ module ParserHelper end module ClassMethods - # this creates test methods dynamically. For each parse_* method we create - # three test_* methods that in turn check the three phases. - # runnable_methods is called by minitest to determine which tests to run (ie normally test_*) + # this creates test methods dynamically. For each test_* method we create + # 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(/^parse_/).map(&:to_s).each do |parse| + public_instance_methods(true).grep(/^test_/).map(&:to_s).each do |test| ["ast" , "transform" , "parse"].each do |what| - name = "parse_#{what}" + name = "#{test}_#{what}" tests << name self.send(:define_method, name ) do - send(parse) + send(test) send("check_#{what}") end end