When I try to use the rps_game_winner
method (see below) in CodeAcademy Labs, it works fine with the following input:
> rps_game_winner([ ["Dave", "P"], ["Armando", "S"] ])
valid value: p
valid value: s
=> ["Armando", "S"]
> rps_game_winner([ ["Allen", "P"], ["Richard", "P"] ])[0]
valid value: p
valid value: p
=> "Allen"
When I submit it for autograder homework, it always fails with a NoSuchStrategyError
.
Failure/Error: rps_game_winner([ ["Dave", "P"], ["Armando", "S"] ])[0].should eq("Armando"), "Incorrect Winner returned"
NoSuchStrategyError:
NoSuchStrategyError
Can someone please help? Thanks.
def rps_game_winner(game)
raise WrongNumberOfPlayersError unless game.length == 2
a1=[(game[0][1]).downcase]
a2=[(game[1][1]).downcase]
a3=a1.to_s
a4=a2.to_s
valid=["r","p","s"]
if(valid.include?(a3))
puts "valid value: "+a3
else
raise NoSuchStrategyError
end
if(valid.include?(a4))
puts "valid value: "+a4
else
raise NoSuchStrategyError
end
if(win(a1, a2))
return game[0]
else
if a1.eql?(a2)
return game[0]
else
return game[1]
end
end
return game[0] if a1.eql?(a2)
end