Module: AppMap::RSpec

Defined in:
lib/appmap/rspec.rb

Overview

Integration of AppMap with RSpec. When enabled with APPMAP=true, the AppMap tracer will be activated around each scenario which has the metadata key :appmap.

Defined Under Namespace

Classes: Recording, ScopeExample, ScopeExampleGroup

Constant Summary collapse

APPMAP_OUTPUT_DIR =
'tmp/appmap/rspec'
LOG =
false

Class Method Summary collapse

Class Method Details

.add_event_methods(event_methods) ⇒ Object



162
163
164
# File 'lib/appmap/rspec.rb', line 162

def add_event_methods(event_methods)
  @event_methods += event_methods
end

.begin_spec(example) ⇒ Object



147
148
149
# File 'lib/appmap/rspec.rb', line 147

def begin_spec(example)
  @recordings_by_example[example.object_id] = Recording.new(example)
end

.configObject



158
159
160
# File 'lib/appmap/rspec.rb', line 158

def config
  @config or raise "AppMap is not configured"
end

.enabled?Boolean

Returns:

  • (Boolean)


198
199
200
# File 'lib/appmap/rspec.rb', line 198

def enabled?
  ENV['APPMAP'] == 'true'
end

.end_spec(example) ⇒ Object



151
152
153
154
155
156
# File 'lib/appmap/rspec.rb', line 151

def end_spec(example)
  recording = @recordings_by_example.delete(example.object_id)
  return warn "No recording found for #{example}" unless recording

  recording.finish
end

.initObject



141
142
143
144
145
# File 'lib/appmap/rspec.rb', line 141

def init
  warn 'Configuring AppMap recorder for RSpec'

  FileUtils.mkdir_p APPMAP_OUTPUT_DIR
end

.metadataObject



13
14
15
# File 'lib/appmap/rspec.rb', line 13

def self.
  AppMap.
end


193
194
195
196
# File 'lib/appmap/rspec.rb', line 193

def print_inventory
  class_map = AppMap.class_map(@event_methods)
  save 'Inventory', class_map, labels: %w[inventory]
end

.runObject



202
203
204
205
206
207
# File 'lib/appmap/rspec.rb', line 202

def run
  init
  at_exit do
    print_inventory
  end
end

.save(example_name, class_map, source_location, events: nil, labels: nil) ⇒ Object



166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
# File 'lib/appmap/rspec.rb', line 166

def save(example_name, class_map, source_location, events: nil, labels: nil)
   = AppMap::RSpec..tap do |m|
    m[:name] = example_name
    m[:source_location] = source_location
    m[:app] = AppMap.configuration.name
    m[:labels] = labels if labels
    m[:frameworks] ||= []
    m[:frameworks] << {
      name: 'rspec',
      version: Gem.loaded_specs['rspec-core']&.version&.to_s
    }
    m[:recorder] = {
      name: 'rspec'
    }
  end

  appmap = {
    version: AppMap::APPMAP_FORMAT_VERSION,
    metadata: ,
    classMap: class_map,
    events: events
  }.compact
  fname = AppMap::Util.scenario_filename(example_name)

  File.write(File.join(APPMAP_OUTPUT_DIR, fname), JSON.generate(appmap))
end