Module: AppMap::RSpec

Defined in:
lib/appmap/rspec.rb

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



179
180
181
# File 'lib/appmap/rspec.rb', line 179

def add_event_methods(event_methods)
  @event_methods += event_methods
end

.begin_spec(example) ⇒ Object



155
156
157
158
159
160
161
162
163
164
165
166
# File 'lib/appmap/rspec.rb', line 155

def begin_spec(example)
  AppMap.info 'Configuring AppMap recorder for RSpec' if first_recording?
  @recording_count += 1

  recording = if example.[:appmap] != false
    Recording.new(example)
  else
    :false
  end

  @recordings_by_example[example.object_id] = recording
end

.configObject



175
176
177
# File 'lib/appmap/rspec.rb', line 175

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

.enabled?Boolean

Returns:

  • (Boolean)


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

def enabled?
  AppMap.recording_enabled?(:rspec)
end

.end_spec(example, exception:) ⇒ Object



168
169
170
171
172
173
# File 'lib/appmap/rspec.rb', line 168

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

  recording.finish exception unless recording == :false
end

.first_recording?Boolean

Returns:

  • (Boolean)


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

def first_recording?
  @recording_count == 0
end

.initObject



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

def init
  FileUtils.mkdir_p APPMAP_OUTPUT_DIR
end

.metadataObject



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

def self.
  AppMap.
end

.runObject



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

def run
  init
end

.save(name:, class_map:, source_location:, test_status:, exception:, events:) ⇒ Object



183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
# File 'lib/appmap/rspec.rb', line 183

def save(name:, class_map:, source_location:, test_status:, exception:, events:)
   = AppMap::RSpec..tap do |m|
    m[:name] = name
    m[:source_location] = source_location
    m[:app] = AppMap.configuration.name
    m[:frameworks] ||= []
    m[:frameworks] << {
      name: 'rspec',
      version: Gem.loaded_specs['rspec-core']&.version&.to_s
    }
    m[:recorder] = {
      name: 'rspec',
      type: 'tests'
    }
    m[:test_status] = test_status
    if exception
      m[:exception] = {
        class: exception.class.name,
        message: AppMap::Event::MethodEvent.display_string(exception.to_s)
      }
    end
  end

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

  AppMap::Util.write_appmap(File.join(APPMAP_OUTPUT_DIR, fname), appmap)
end