require 'spec_helper' describe Sexp do describe "line" do before :each do content = <<-EOF class Demo def test end end EOF @node = parse_content(content) end it "should return class line" do @node.grep_node(:sexp_type => :class).line.should == 1 end it "should return def line" do @node.grep_node(:sexp_type => :def).line.should == 2 end end describe "grep_nodes" do before :each do content = <<-EOF def show current_user.posts.find(params[:id]) end EOF @node = parse_content(content) end it "should get the call nodes with subject current_user" do nodes = [] @node.grep_nodes(:sexp_type => :call, :subject => "current_user") { |node| nodes << node } nodes.should == [s(:call, s(:var_ref, s(:@ident, "current_user", s(2, 8))), :".", s(:@ident, "posts", s(2, 21)))] end it "should get the call nodes with different messages" do nodes = [] @node.grep_nodes(:sexp_type => :call, :message => ["posts", "find"]) { |node| nodes << node } nodes.should == [s(:call, s(:call, s(:var_ref, s(:@ident, "current_user", s(2, 8))), :".", s(:@ident, "posts", s(2, 21))), :".", s(:@ident, "find", s(2, 27))), s(:call, s(:var_ref, s(:@ident, "current_user", s(2, 8))), :".", s(:@ident, "posts", s(2, 21)))] end end describe "grep_node" do before :each do content = <<-EOF def show current_user.posts.find(params[:id]) end EOF @node = parse_content(content) end it "should get first node with empty argument" do node = @node.grep_node(:sexp_type => :call, :subject => "current_user") node.should == s(:call, s(:var_ref, s(:@ident, "current_user", s(2, 8))), :".", s(:@ident, "posts", s(2, 21))) end end describe "grep_nodes_count" do before :each do content = <<-EOF def show current_user.posts.find(params[:id]) end EOF @node = parse_content(content) end it "should get the count of call nodes" do @node.grep_nodes_count(:sexp_type => :call).should == 2 end end describe "subject" do it "should get subject of assign node" do node = parse_content("user.name = params[:name]").grep_node(:sexp_type => :assign) subject = node.subject subject.sexp_type.should == :field subject.subject.to_s.should == "user" subject.message.to_s.should == "name" end it "should get subject of field node" do node = parse_content("user.name = params[:name]").grep_node(:sexp_type => :field) node.subject.to_s.should == "user" end it "should get subject of call node" do node = parse_content("user.name").grep_node(:sexp_type => :call) node.subject.to_s.should == "user" end it "should get subject of binary" do node = parse_content("user == 'user_name'").grep_node(:sexp_type => :binary) node.subject.to_s.should == "user" end it "should get subject of command_call" do content = <<-EOF map.resources :posts do end EOF node = parse_content(content).grep_node(:sexp_type => :command_call) node.subject.to_s.should == "map" end it "should get subject of method_add_arg" do node = parse_content("Post.find(:all)").grep_node(:sexp_type => :method_add_arg) node.subject.to_s.should == "Post" end it "should get subject of method_add_block" do node = parse_content("Post.save do; end").grep_node(:sexp_type => :method_add_block) node.subject.to_s.should == "Post" end end describe "class_name" do it "should get class name of class node" do node = parse_content("class User; end").grep_node(:sexp_type => :class) node.class_name.to_s.should == "User" end end describe "base_class" do it "should get base class of class node" do node = parse_content("class User < ActiveRecord::Base; end").grep_node(:sexp_type => :class) node.base_class.to_s.should == "ActiveRecord::Base" end end describe "left_value" do it "should get the left value of assign" do node = parse_content("user = current_user").grep_node(:sexp_type => :assign) node.left_value.to_s.should == "user" end end describe "right_value" do it "should get the right value of assign" do node = parse_content("user = current_user").grep_node(:sexp_type => :assign) node.right_value.to_s.should == "current_user" end end describe "message" do it "should get the message of command" do node = parse_content("has_many :projects").grep_node(:sexp_type => :command) node.message.to_s.should == "has_many" end it "should get the message of command_call" do node = parse_content("map.resources :posts do; end").grep_node(:sexp_type => :command_call) node.message.to_s.should == "resources" end it "should get the message of field" do node = parse_content("user.name = 'test'").grep_node(:sexp_type => :field) node.message.to_s.should == "name" end it "should get the message of call" do node = parse_content("user.name").grep_node(:sexp_type => :call) node.message.to_s.should == "name" end it "should get the message of binary" do node = parse_content("user.name == 'test'").grep_node(:sexp_type => :binary) node.message.to_s.should == "==" end it "should get the message of fcall" do node = parse_content("test?('world')").grep_node(:sexp_type => :fcall) node.message.to_s.should == "test?" end it "should get the message of method_add_arg" do node = parse_content("Post.find(:all)").grep_node(:sexp_type => :method_add_arg) node.message.to_s.should == "find" end it "should get the message of method_add_block" do node = parse_content("Post.save do; end").grep_node(:sexp_type => :method_add_block) node.message.to_s.should == "save" end end describe "arguments" do it "should get the arguments of command" do node = parse_content("resources :posts do; end").grep_node(:sexp_type => :command) node.arguments.sexp_type.should == :args_add_block end it "should get the arguments of command_call" do node = parse_content("map.resources :posts do; end").grep_node(:sexp_type => :command_call) node.arguments.sexp_type.should == :args_add_block end it "should get the arguments of method_add_args" do node = parse_content("User.find(:all)").grep_node(:sexp_type => :method_add_arg) node.arguments.sexp_type.should == :args_add_block end end describe "argument" do it "should get the argument of binary" do node = parse_content("user == current_user").grep_node(:sexp_type => :binary) node.argument.to_s.should == "current_user" end end describe "all" do it "should get all arguments" do node = parse_content("puts 'hello', 'world'").grep_node(:sexp_type => :args_add_block) node.all.map(&:to_s).should == ["hello", "world"] end end describe "conditional_statement" do it "should get conditional statement of if" do node = parse_content("if true; end").grep_node(:sexp_type => :if) node.conditional_statement.to_s.should == "true" end it "should get conditional statement of unless" do node = parse_content("unless true; end").grep_node(:sexp_type => :unless) node.conditional_statement.to_s.should == "true" end it "should get conditional statement of elsif" do content =<<-EOF if true elsif false end EOF node = parse_content(content).grep_node(:sexp_type => :elsif) node.conditional_statement.to_s.should == "false" end end describe "all_conditions" do it "should get all conditions" do node = parse_content("user == current_user && user.valid? || user.admin?").grep_node(:sexp_type => :binary) node.all_conditions.size.should == 3 end end describe "method_name" do it "should get the method name of defn" do node = parse_content("def show; end").grep_node(:sexp_type => :def) node.method_name.to_s.should == "show" end end describe "body" do it "should get body of class" do node = parse_content("class User; end").grep_node(:sexp_type => :class) node.body.sexp_type.should == :bodystmt end it "should get body of def" do node = parse_content("def login; end").grep_node(:sexp_type => :def) node.body.sexp_type.should == :bodystmt end it "should get body of defs" do node = parse_content("def self.login; end").grep_node(:sexp_type => :defs) node.body.sexp_type.should == :bodystmt end it "should get body of module" do node = parse_content("module Enumerable; end").grep_node(:sexp_type => :module) node.body.sexp_type.should == :bodystmt end it "should get body of if" do node = parse_content("if true; puts 'hello world'; end").grep_node(:sexp_type => :if) node.body.sexp_type.should == :stmts_add end it "should get body of elsif" do node = parse_content("if true; elsif true; puts 'hello world'; end").grep_node(:sexp_type => :elsif) node.body.sexp_type.should == :stmts_add end it "should get body of unless" do node = parse_content("unless true; puts 'hello world'; end").grep_node(:sexp_type => :unless) node.body.sexp_type.should == :stmts_add end it "should get body of else" do node = parse_content("if true; else; puts 'hello world'; end").grep_node(:sexp_type => :else) node.body.sexp_type.should == :stmts_add end end describe "block" do it "sould get block of method_add_block node" do node = parse_content("resources :posts do; resources :comments; end").grep_node(:sexp_type => :method_add_block) node.block.sexp_type.should == :do_block end end describe "statements" do it "should get statements of do_block node" do node = parse_content("resources :posts do; resources :comments; resources :like; end").grep_node(:sexp_type => :do_block) node.statements.size.should == 2 end it "should get statements of bodystmt node" do node = parse_content("class User; def login?; end; def admin?; end; end").grep_node(:sexp_type => :bodystmt) node.statements.size.should == 2 end end describe "hash_value" do it "should get value for hash node" do node = parse_content("{first_name: 'Richard', last_name: 'Huang'}").grep_node(:sexp_type => :hash) node.hash_value("first_name").to_s.should == "Richard" node.hash_value("last_name").to_s.should == "Huang" end it "should get value for bare_assoc_hash" do node = parse_content("add_user :user, first_name: 'Richard', last_name: 'Huang'").grep_node(:sexp_type => :bare_assoc_hash) node.hash_value("first_name").to_s.should == "Richard" node.hash_value("last_name").to_s.should == "Huang" end end describe "hash_size" do it "should get value for hash node" do node = parse_content("{first_name: 'Richard', last_name: 'Huang'}").grep_node(:sexp_type => :hash) node.hash_size.should == 2 end it "should get value for bare_assoc_hash" do node = parse_content("add_user :user, first_name: 'Richard', last_name: 'Huang'").grep_node(:sexp_type => :bare_assoc_hash) node.hash_size.should == 2 end end describe "hash_keys" do it "should get value for hash node" do node = parse_content("{first_name: 'Richard', last_name: 'Huang'}").grep_node(:sexp_type => :hash) node.hash_keys.should == ["first_name", "last_name"] end it "should get value for bare_assoc_hash" do node = parse_content("add_user :user, first_name: 'Richard', last_name: 'Huang'").grep_node(:sexp_type => :bare_assoc_hash) node.hash_keys.should == ["first_name", "last_name"] end end describe "array_size" do it "should get array size" do node = parse_content("['first_name', 'last_name']").grep_node(:sexp_type => :array) node.array_size.should == 2 end end describe "to_object" do it "should to_object" do node = parse_content("['first_name', 'last_name']").grep_node(:sexp_type => :array) node.to_object.should == ["first_name", "last_name"] end end describe "to_s" do it "should get to_s for string" do node = parse_content("'user'").grep_node(:sexp_type => :string_literal) node.to_s.should == "user" end it "should get to_s for symbol" do node = parse_content(":user").grep_node(:sexp_type => :symbol_literal) node.to_s.should == "user" end it "should get to_s for const" do node = parse_content("User").grep_node(:sexp_type => :@const) node.to_s.should == "User" end it "should get to_s for ivar" do node = parse_content("@user").grep_node(:sexp_type => :@ivar) node.to_s.should == "@user" end it "should get to_s for class with module" do node = parse_content("ActiveRecord::Base").grep_node(:sexp_type => :const_path_ref) node.to_s.should == "ActiveRecord::Base" end it "should get to_s for label" do node = parse_content("{first_name: 'Richard'}").grep_node(:sexp_type => :@label) node.to_s.should == "first_name" end end describe "const?" do it "should return true for const with var_ref" do node = parse_content("User.find").grep_node(:sexp_type => :var_ref) node.should be_const end it "should return true for const with @const" do node = parse_content("User.find").grep_node(:sexp_type => :@const) node.should be_const end it "should return false for ivar" do node = parse_content("@user.find").grep_node(:sexp_type => :@ivar) node.should_not be_const end end describe "remove_line_and_column" do it "should remove" do s(:@ident, "test", s(2, 12)).remove_line_and_column.should_equal s(:@ident, "test") end it "should remove child nodes" do s(:const_ref, s(:@const, "Demo", s(1, 12))).remove_line_and_column.should_equal s(:const_def, s(:@const, "Demo")) end end end