File: capture.rb

package info (click to toggle)
ruby-console 1.34.3-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 272 kB
  • sloc: ruby: 1,509; makefile: 4
file content (126 lines) | stat: -rw-r--r-- 3,134 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
# frozen_string_literal: true

# Released under the MIT License.
# Copyright, 2019-2025, by Samuel Williams.

require_relative "filter"
require_relative "output/failure"

module Console
	# A buffer which captures all logged messages into a buffer.
	class Capture
		# Create a new log capture buffer.
		def initialize
			@records = []
			@verbose = false
		end
		
		# @attribute [Array(Hash)] All records captured by this buffer.
		attr :records
		
		# @deprecated Use {records} instead of {buffer}.
		alias buffer records
		
		# @deprecated Use {records} instead of {to_a}.
		alias to_a records
		
		# @attribute [Boolean] If true, the buffer will capture verbose messages.
		attr :verbose
		
		# Whether the buffer includes any records with the given subject or message pattern.
		#
		# @returns [Boolean] True if the buffer includes any records with the given pattern.
		def include?(pattern)
			@records.any? do |record|
				record[:subject].to_s&.match?(pattern) or record[:message].to_s&.match?(pattern)
			end
		end
		
		# Iterate over all records in the buffer.
		#
		# @yields {|record| ...} each record in the buffer.
		# 	@parameter record [Hash] The record itself.
		def each(&block)
			@records.each(&block)
		end
		
		include Enumerable
		
		# @returns [Hash] The first record in the buffer.
		def first
			@records.first
		end
		
		# @returns [Hash] The last record in the buffer.
		def last
			@records.last
		end
		
		# Clear all records from the buffer.
		def clear
			@records.clear
		end
		
		# @returns [Boolean] True if the buffer is empty.
		def empty?
			@records.empty?
		end
		
		# Sets the verbose flag which controls whether verbose messages are captured.
		def verbose!(value = true)
			@verbose = value
		end
		
		# @returns [Boolean] True if the buffer is capturing verbose messages.
		def verbose?
			@verbose
		end
		
		# Record a log message in the buffer.
		#
		# @parameter subject [Object] The subject of the log message.
		# @parameter arguments [Array] The arguments to the log message.
		# @parameter severity [Symbol] The severity of the log message.
		# @parameter event [Event] The event associated with the log message.
		# @parameter options [Hash] Additional options to pass to the log message.
		# @yields {|buffer| ...} A block which can be used to write additional information to the log message.
		# 	@parameter buffer [IO] The (optional) buffer to write to.
		def call(subject = nil, *arguments, severity: UNKNOWN, event: nil, **options, &block)
			record = {
				time: ::Time.now.iso8601,
				severity: severity,
				**options,
			}
			
			if subject
				record[:subject] = subject
			end
			
			if event
				record[:event] = event.to_hash
			end
			
			if arguments.any?
				record[:arguments] = arguments
			end
			
			if annotation = Fiber.current.annotation
				record[:annotation] = annotation
			end
			
			if block_given?
				if block.arity.zero?
					record[:message] = yield
				else
					buffer = StringIO.new
					yield buffer
					record[:message] = buffer.string
				end
			else
				record[:message] = arguments.join(" ")
			end
			
			@records << record
		end
	end
end