Sha256: 231a476863f75fb96ebf240e9280fccb3754f044d160d7a4c041816d7fda03fd

Contents?: true

Size: 1.98 KB

Versions: 5

Compression:

Stored size: 1.98 KB

Contents

require 'rubygems'
require 'restfulie'

class Maze::Enter
  def execute(maze)
    maze.item.start.get
  end
end

class Maze::Move
  def initialize(direction)
    @direction = direction
  end
  def execute(room)
    room.cell.send(@direction).get
  end
end

class Maze::Pick
  def execute(mazes)
    mazes.maze.get
  end
end

class Maze::Back
  def initialize(path)
    @path = path
  end
  def execute(actual)
    return nil if @path.empty?
    last = @path.delete_at(@path.length-1)
    Restfulie.at(last).get
  end
end

class Maze::BackTracObjective
  
  def initialize
    @path = []
    @visited = []
  end

  def next_step(resource)
    next_step2(resource) || Maze::Back.new(@path)
  end
  
  def visited?(uri)
    @visited.include?(uri)
  end

end

class Maze::ExitBackTracking < Maze::BackTracObjective
  
  def completed?(resource)
    resource.respond_to?(:cell) && resource.cell.links(:exit)
  end
  
  def next_step2(resource)
    direction = [:east, :west, :north, :south].find do |direction|
      resource.respond_to?(:cell) && resource.cell.links(direction) && !visited?(resource.cell.links(direction).href)
    end
    if direction
      @path << resource.cell.links(direction).href
      @visited << resource.cell.links(direction).href
      Maze::Move.new(direction) 
    elsif resource.respond_to?(:item) && resource.item.links(:start)
      Maze::Enter.new
    elsif resource.respond_to?(:maze)
      Maze::Pick.new 
    else
      nil
    end
  end
  
end

# def scenarios
#   
#   When can go east
#   Then take east
#   
#   When can go north
#   Then take north
#   
#   When can go west
#   Then take west
#   
#   When can go south
#   Then take south
#   
#   # what about some random stuff?
#   
#   When there is a maze
#   Then enter it
#   
#   When there are mazes
#   Then pick a random one
# 
# end





describe Maze do
  Mikyung.new(Maze::ExitBackTracking.new, Restfulie.at('http://amundsen.com/examples/mazes/2d/five-by-five/').accepts('application/vnd.amundsen.maze+xml').get! ).run
end

Version data entries

5 entries across 5 versions & 2 rubygems

Version Path
restfulie-nosqlite-1.0.4 full-examples/mikemaze/maze_solver_spec.rb
restfulie-1.1.1 full-examples/mikemaze/maze_solver_spec.rb
restfulie-1.1.0 full-examples/mikemaze/maze_solver_spec.rb
restfulie-nosqlite-1.0.3 full-examples/mikemaze/maze_solver_spec.rb
restfulie-1.0.3 full-examples/mikemaze/maze_solver_spec.rb