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

Modules: FeatureAnnotations 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



226
227
228
# File 'lib/appmap/rspec.rb', line 226

def add_event_methods(event_methods)
  @event_methods += event_methods
end

.begin_spec(example) ⇒ Object



211
212
213
# File 'lib/appmap/rspec.rb', line 211

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

.configObject



222
223
224
# File 'lib/appmap/rspec.rb', line 222

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

.enabled?Boolean

Returns:

  • (Boolean)


263
264
265
# File 'lib/appmap/rspec.rb', line 263

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

.end_spec(example) ⇒ Object



215
216
217
218
219
220
# File 'lib/appmap/rspec.rb', line 215

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



205
206
207
208
209
# File 'lib/appmap/rspec.rb', line 205

def init
  warn 'Configuring AppMap recorder for RSpec'

  FileUtils.mkdir_p APPMAP_OUTPUT_DIR
end

.metadataObject



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

def self.
  AppMap.
end


258
259
260
261
# File 'lib/appmap/rspec.rb', line 258

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

.runObject



267
268
269
270
271
272
# File 'lib/appmap/rspec.rb', line 267

def run
  init
  at_exit do
    print_inventory
  end
end

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



230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
# File 'lib/appmap/rspec.rb', line 230

def save(example_name, class_map, events: nil, feature_name: nil, feature_group_name: nil, labels: nil)
   = AppMap::RSpec..tap do |m|
    m[:name] = example_name
    m[:app] = AppMap.configuration.name
    m[:feature] = feature_name if feature_name
    m[:feature_group] = feature_group_name if feature_group_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