web-dev-qa-db-fra.com

Test du contenu de hachage à l'aide de RSpec

J'ai un test comme ça:

it "should not indicate backwards jumps if the checker position is not a king" do
    board = Board.new
    game_board = board.create_test_board
    board.add_checker(game_board, :red, 3, 3)
    x_coord = 3
    y_coord = 3
    jump_locations = {}
    jump_locations["upper_left"]  = true 
    jump_locations["upper_right"] = false 
    jump_locations["lower_left"]  = false
    jump_locations["lower_right"] = true
    adjusted_jump_locations = @bs.adjust_jump_locations_if_not_king(game_board, x_coord, y_coord, jump_locations)
    adjusted_jump_locations["upper_left"].should == true 
    adjusted_jump_locations["upper_right"].should == false 
    adjusted_jump_locations["lower_left"].should == false
    adjusted_jump_locations["lower_right"].should == false
  end 

qui, je le sais, est verbeux. Existe-t-il un moyen plus concis d'exprimer mes attentes. J'ai regardé les documents mais je ne vois pas où compresser mes attentes. Merci.

51
steve_gallagher

http://rubydoc.info/gems/rspec-expectations/RSpec/Matchers:include

Cela fonctionne aussi pour les hachages:

jump_locations.should include(
  "upper_left" => true,
  "upper_right" => false,
  "lower_left" => false,
  "lower_right" => true
)
87
David Chelimsky

Je veux juste ajouter à la réponse de @ David. Vous pouvez imbriquer et utiliser des matchers dans votre include hachage. Par exemple:

# Pass
expect({
  "num" => 5, 
  "a" => { 
    "b" => [3, 4, 5] 
  }
}).to include({
  "num" => a_value_between(3, 10), 
  "a" => {
    "b" => be_an(Array)
  }
})

Une mise en garde: un hachage include imbriqué doit tester toutes les clés ou le test échouera, par exemple:

# Fail
expect({
  "a" => { 
    "b" => 1,
    "c" => 2
  }
}).to include({
  "a" => {
    "b" => 1
  }
})
28
Benjamin Cheah

La syntaxe a changé pour RSpec 3, mais le matcher d'inclusion est toujours celui-ci:

expect(jump_locations).to include(
  "upper_left" => true,
  "upper_right" => false,
  "lower_left" => false,
  "lower_right" => true
)

Voir matchers intégrés # include-matcher .

3
Marko Avlijaš

Un autre moyen simple de tester si tout le contenu est un hachage est de vérifier si le contenu est lui-même l'objet de hachage:

it 'is to be a Hash Object' do
    workbook = {name: 'A', address: 'La'}
    expect(workbook.is_a?(Hash)).to be_truthy
end
0
Kiry Meas