moe the last (function) tests to new test model
This commit is contained in:
parent
1593d330ae
commit
8151ed6b9d
@ -1,37 +1,36 @@
|
||||
require_relative 'helper'
|
||||
require_relative "helper"
|
||||
|
||||
# Please read note in test_parser
|
||||
class TestFunctionDefinition < MiniTest::Test
|
||||
# include the magic (setup and parse -> test method translation), see there
|
||||
include ParserHelper
|
||||
|
||||
class TransformTest < MiniTest::Test
|
||||
|
||||
def setup
|
||||
@transform = Parser::Transform.new
|
||||
def test_simplest_function
|
||||
@string_input = <<HERE
|
||||
def foo(x)
|
||||
5
|
||||
end
|
||||
|
||||
def check
|
||||
is = @transform.apply @input
|
||||
#puts is.transform
|
||||
assert_equal @transform_output , is
|
||||
end
|
||||
|
||||
def test_function_definition
|
||||
@input = {:function_definition => {:name => 'foo'},
|
||||
:parmeter_list => {:parmeter => {:name => 'x'}},
|
||||
HERE
|
||||
@parse_output = {:function_definition => {:name => 'foo'},
|
||||
:parmeter_list => [{:parmeter => {:name => 'x'}}],
|
||||
:expressions => [{:integer => '5'}]}
|
||||
@transform_output = Parser::FunctionExpression.new('foo',
|
||||
[Parser::NameExpression.new('x')],
|
||||
[Parser::IntegerExpression.new(5)])
|
||||
check
|
||||
end
|
||||
|
||||
def test_function_assignment
|
||||
@input = { :function_definition => { :name => "foo" } ,
|
||||
:parmeter_list => { :parmeter => { :name => "x" } },
|
||||
@string_input = <<HERE
|
||||
def foo(x)
|
||||
abba = 5
|
||||
end
|
||||
HERE
|
||||
@parse_output = { :function_definition => { :name => "foo" } ,
|
||||
:parmeter_list => [{ :parmeter => { :name => "x" } }],
|
||||
:expressions => [ { :asignee => { :name => "abba" }, :asigned => { :integer => "5" } } ]
|
||||
}
|
||||
@transform_output = Parser::FunctionExpression.new( "foo", [Parser::NameExpression.new("x")],
|
||||
[Parser::AssignmentExpression.new( "abba", Parser::IntegerExpression.new(5) ) ])
|
||||
check
|
||||
end
|
||||
|
||||
|
||||
end
|
@ -1,43 +0,0 @@
|
||||
require_relative "helper"
|
||||
|
||||
# Please read note in test_parser
|
||||
|
||||
require_relative 'helper'
|
||||
|
||||
class TestAst < MiniTest::Test
|
||||
|
||||
def setup
|
||||
@parser = Parser::Composed.new
|
||||
@transform = Parser::Transform.new
|
||||
end
|
||||
|
||||
def check
|
||||
syntax = @parser.parse(@string_input)
|
||||
tree = @transform.apply(syntax)
|
||||
# puts tree.inspect
|
||||
assert_equal @transform_output , tree
|
||||
end
|
||||
|
||||
def test_function_definition
|
||||
@string_input = <<HERE
|
||||
def foo(x)
|
||||
5
|
||||
end
|
||||
HERE
|
||||
@transform_output = Parser::FunctionExpression.new('foo',
|
||||
[Parser::NameExpression.new('x')],
|
||||
[Parser::IntegerExpression.new(5)])
|
||||
@parser = @parser.function_definition
|
||||
check
|
||||
end
|
||||
def test_function_assignment
|
||||
@string_input = <<HERE
|
||||
def foo(x)
|
||||
abba = 5
|
||||
end
|
||||
HERE
|
||||
@transform_output = Parser::FunctionExpression.new( "foo", [Parser::NameExpression.new("x")],
|
||||
[Parser::AssignmentExpression.new( "abba", Parser::IntegerExpression.new(5) ) ])
|
||||
check
|
||||
end
|
||||
end
|
@ -1,62 +0,0 @@
|
||||
require_relative 'helper'
|
||||
|
||||
# Some sanity is emerging in the testing of parsers
|
||||
# (Parsers are fiddly in respect to space and order, small changes may and do have unexpected effects)
|
||||
|
||||
# For any functionality that we want to work (ie test), there are actually three tests, with the _same_ name
|
||||
# One in each of the parser/transform/ast classes
|
||||
# Parser test that the parser parses and thet the output is correct. Rules are named and and boil down to
|
||||
# hashes and arrays with lots of symbols for the names the rules (actually the reults) were given
|
||||
# Transform test really just test the tranformation. They basically take the output of the parse
|
||||
# and check that correct Ast classes are produced
|
||||
# Ast tests both steps in one. Ie string input to ast classes output
|
||||
|
||||
# All threee classes are layed out quite similarly in that they use a check method and
|
||||
# each test assigns @string_input and @parse_output which the check methods then checks
|
||||
# The check methods have a pust in it (to be left) which is very handy for checking
|
||||
# also the output of parser.check can actually be used as the input of transform
|
||||
|
||||
# Repeat: For every test in parser, there should beone in transform and ast
|
||||
# The test in transform should use the output of parser as input
|
||||
# The test in ast should expect the same result as transform
|
||||
|
||||
class ParserTest < MiniTest::Test
|
||||
|
||||
def setup
|
||||
@parser = Parser::Composed.new
|
||||
end
|
||||
|
||||
def check
|
||||
is = @parser.parse(@string_input)
|
||||
#puts is.inspect
|
||||
assert_equal @parse_output , is
|
||||
end
|
||||
|
||||
def test_function_definition
|
||||
@string_input = <<HERE
|
||||
def foo(x)
|
||||
5
|
||||
end
|
||||
HERE
|
||||
@parse_output = {:function_definition => {:name => 'foo'},
|
||||
:parmeter_list => {:parmeter => {:name => 'x'}},
|
||||
:expressions => [{:integer => '5'}]}
|
||||
@parser = @parser.function_definition
|
||||
check
|
||||
end
|
||||
|
||||
def test_function_assignment
|
||||
@string_input = <<HERE
|
||||
def foo(x)
|
||||
abba = 5
|
||||
end
|
||||
HERE
|
||||
@parse_output = { :function_definition => { :name => "foo" } ,
|
||||
:parmeter_list => { :parmeter => { :name => "x" } },
|
||||
:expressions => [ { :asignee => { :name => "abba" }, :asigned => { :integer => "5" } } ]
|
||||
}
|
||||
@parser = @parser.function_definition
|
||||
check
|
||||
end
|
||||
|
||||
end
|
Loading…
Reference in New Issue
Block a user