Class: Cucumber::Messages::TestCase

Inherits:
Message
  • Object
show all
Defined in:
lib/cucumber/messages/test_case.rb

Overview

Represents the TestCase message in Cucumber’s message protocol.

//// TestCases

*

A `TestCase` contains a sequence of `TestStep`s.

Instance Attribute Summary collapse

Class Method Summary collapse

Instance Method Summary collapse

Methods inherited from Message

camelize, from_json, #to_h, #to_json

Constructor Details

#initialize(id: '', pickle_id: '', test_steps: []) ⇒ TestCase

Returns a new instance of TestCase.



25
26
27
28
29
30
31
32
33
34
# File 'lib/cucumber/messages/test_case.rb', line 25

def initialize(
  id: '',
  pickle_id: '',
  test_steps: []
)
  @id = id
  @pickle_id = pickle_id
  @test_steps = test_steps
  super()
end

Instance Attribute Details

#idObject (readonly)

Returns the value of attribute id.



16
17
18
# File 'lib/cucumber/messages/test_case.rb', line 16

def id
  @id
end

#pickle_idObject (readonly)

The ID of the ‘Pickle` this `TestCase` is derived from.



21
22
23
# File 'lib/cucumber/messages/test_case.rb', line 21

def pickle_id
  @pickle_id
end

#test_stepsObject (readonly)

Returns the value of attribute test_steps.



23
24
25
# File 'lib/cucumber/messages/test_case.rb', line 23

def test_steps
  @test_steps
end

Class Method Details

.from_h(hash) ⇒ Object

Returns a new TestCase from the given hash. If the hash keys are camelCased, they are properly assigned to the corresponding snake_cased attributes.

Cucumber::Messages::TestCase.from_h(some_hash) # => #<Cucumber::Messages::TestCase:0x... ...>


43
44
45
46
47
48
49
50
51
# File 'lib/cucumber/messages/test_case.rb', line 43

def self.from_h(hash)
  return nil if hash.nil?

  new(
    id: hash[:id],
    pickle_id: hash[:pickleId],
    test_steps: hash[:testSteps]&.map { |item| TestStep.from_h(item) }
  )
end