logsly 1.2.0 → 1.3.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (40) hide show
  1. checksums.yaml +4 -4
  2. data/README.md +5 -3
  3. data/lib/logsly/colors.rb +2 -2
  4. data/lib/logsly/logging182/appender.rb +290 -0
  5. data/lib/logsly/logging182/appenders/buffering.rb +398 -0
  6. data/lib/logsly/logging182/appenders/console.rb +81 -0
  7. data/lib/logsly/logging182/appenders/email.rb +178 -0
  8. data/lib/logsly/logging182/appenders/file.rb +85 -0
  9. data/lib/logsly/logging182/appenders/growl.rb +200 -0
  10. data/lib/logsly/logging182/appenders/io.rb +84 -0
  11. data/lib/logsly/logging182/appenders/rolling_file.rb +338 -0
  12. data/lib/logsly/logging182/appenders/string_io.rb +92 -0
  13. data/lib/logsly/logging182/appenders/syslog.rb +215 -0
  14. data/lib/logsly/logging182/appenders.rb +64 -0
  15. data/lib/logsly/logging182/color_scheme.rb +248 -0
  16. data/lib/logsly/logging182/config/configurator.rb +187 -0
  17. data/lib/logsly/logging182/config/yaml_configurator.rb +190 -0
  18. data/lib/logsly/logging182/diagnostic_context.rb +332 -0
  19. data/lib/logsly/logging182/layout.rb +132 -0
  20. data/lib/logsly/logging182/layouts/basic.rb +38 -0
  21. data/lib/logsly/logging182/layouts/parseable.rb +256 -0
  22. data/lib/logsly/logging182/layouts/pattern.rb +568 -0
  23. data/lib/logsly/logging182/layouts.rb +9 -0
  24. data/lib/logsly/logging182/log_event.rb +44 -0
  25. data/lib/logsly/logging182/logger.rb +509 -0
  26. data/lib/logsly/logging182/proxy.rb +59 -0
  27. data/lib/logsly/logging182/rails_compat.rb +36 -0
  28. data/lib/logsly/logging182/repository.rb +231 -0
  29. data/lib/logsly/logging182/root_logger.rb +60 -0
  30. data/lib/logsly/logging182/stats.rb +277 -0
  31. data/lib/logsly/logging182/utils.rb +231 -0
  32. data/lib/logsly/logging182.rb +559 -0
  33. data/lib/logsly/outputs.rb +5 -5
  34. data/lib/logsly/version.rb +1 -1
  35. data/lib/logsly.rb +6 -6
  36. data/logsly.gemspec +4 -2
  37. data/test/unit/colors_tests.rb +3 -3
  38. data/test/unit/logsly_tests.rb +14 -14
  39. data/test/unit/outputs_tests.rb +34 -24
  40. metadata +45 -6
@@ -1,7 +1,7 @@
1
1
  require 'assert'
2
2
  require 'logsly'
3
3
 
4
- require 'logging'
4
+ require 'logsly/logging182'
5
5
  require 'logsly/colors'
6
6
  require 'logsly/outputs'
7
7
  require 'test/support/logger'
@@ -125,30 +125,30 @@ module Logsly
125
125
  assert_equal [:stdout], log.outputs
126
126
  end
127
127
 
128
- should "create a Logging::Logger" do
128
+ should "create a Logsly::Logging182::Logger" do
129
129
  assert_not_nil subject.logger
130
- assert_kind_of Logging::Logger, subject.logger
130
+ assert_kind_of Logsly::Logging182::Logger, subject.logger
131
131
  end
132
132
 
133
- should "create the Logging::Logger with a unique name" do
133
+ should "create the Logsly::Logging182::Logger with a unique name" do
134
134
  exp = "#{subject.class.name}-testy_log_logger-#{subject.object_id}"
135
135
  assert_equal exp, subject.logger.name
136
136
  end
137
137
 
138
138
  should "set the logger's level" do
139
- assert_equal Logging::LEVELS['info'], subject.logger.level
139
+ assert_equal Logsly::Logging182::LEVELS['info'], subject.logger.level
140
140
 
141
141
  log = TestLogger.new('test', :level => :debug)
142
- assert_equal Logging::LEVELS['debug'], log.logger.level
142
+ assert_equal Logsly::Logging182::LEVELS['debug'], log.logger.level
143
143
  end
144
144
 
145
145
  should "set mdc key/value pairs" do
146
146
  key = Factory.string
147
- assert_nil Logging.mdc[key]
147
+ assert_nil Logsly::Logging182.mdc[key]
148
148
 
149
149
  value = Factory.string
150
150
  subject.mdc(key, value)
151
- assert_equal value, Logging.mdc[key]
151
+ assert_equal value, Logsly::Logging182.mdc[key]
152
152
  end
153
153
 
154
154
  should "not have a file path if no file appender is specified" do
@@ -173,7 +173,7 @@ module Logsly
173
173
 
174
174
  should "add a named stdout appender" do
175
175
  log = TestLogger.new(:test, :outputs => 'my_stdout')
176
- assert_includes_appender Logging::Appenders::Stdout, log
176
+ assert_includes_appender Logsly::Logging182::Appenders::Stdout, log
177
177
  assert_nil log.file_path
178
178
  end
179
179
 
@@ -181,14 +181,14 @@ module Logsly
181
181
  log = TestLogger.new(:test, :outputs => 'my_file')
182
182
  filelog = extract_appender_from_logger(log, :file)
183
183
 
184
- assert_includes_appender Logging::Appenders::File, log
184
+ assert_includes_appender Logsly::Logging182::Appenders::File, log
185
185
  assert_equal 'log/development-test.log', filelog.name
186
186
  assert_equal 'log/development-test.log', log.file_path
187
187
  end
188
188
 
189
189
  should "add a named syslog appender" do
190
190
  log = TestLogger.new(:test, :outputs => 'my_syslog')
191
- assert_includes_appender Logging::Appenders::Syslog, log
191
+ assert_includes_appender Logsly::Logging182::Appenders::Syslog, log
192
192
  assert_nil log.file_path
193
193
  end
194
194
 
@@ -215,11 +215,11 @@ module Logsly
215
215
  def extract_appender_from_logger(logger, type)
216
216
  klass = case type
217
217
  when :syslog
218
- Logging::Appenders::Syslog
218
+ Logsly::Logging182::Appenders::Syslog
219
219
  when :file
220
- Logging::Appenders::File
220
+ Logsly::Logging182::Appenders::File
221
221
  when :stdout
222
- Logging::Appenders::Stdout
222
+ Logsly::Logging182::Appenders::Stdout
223
223
  end
224
224
 
225
225
  logger.appenders.detect{ |a| a.is_a?(klass) }
@@ -1,7 +1,7 @@
1
1
  require 'assert'
2
2
  require 'logsly/outputs'
3
3
 
4
- require 'logging'
4
+ require 'logsly/logging182'
5
5
  require 'logsly'
6
6
 
7
7
  module Logsly::Outputs
@@ -40,21 +40,31 @@ module Logsly::Outputs
40
40
  desc "given a build"
41
41
  setup do
42
42
  Logsly.colors('a_color_scheme') do
43
- debug :white
43
+ debug_line :white
44
44
  end
45
45
  @out = Base.new do |*args|
46
- pattern args.to_s
46
+ pattern args.first
47
47
  colors 'a_color_scheme'
48
48
  end
49
49
  end
50
50
 
51
- should "build a Logging pattern layout" do
52
- data = BaseData.new('%d : %m\n', &@out.build)
51
+ should "build a Logsly::Logging182 pattern layout" do
52
+ data = BaseData.new('[%c{2}] [%l] %d : %m :\n', &@out.build)
53
53
  lay = subject.to_layout(data)
54
54
 
55
- assert_kind_of Logging::Layout, lay
56
- assert_equal '%d : %m\n', lay.pattern
57
- assert_kind_of Logging::ColorScheme, lay.color_scheme
55
+ assert_kind_of Logsly::Logging182::Layout, lay
56
+ assert_kind_of Logsly::Logging182::ColorScheme, lay.color_scheme
57
+ assert_equal '[%c{2}] [%l] %d : %m :\n', lay.pattern
58
+
59
+ assert_nothing_raised do
60
+ event = ::Logsly::Logging182::LogEvent.new(
61
+ Factory.string,
62
+ ::Logsly::Logging182::LEVELS['debug'],
63
+ {},
64
+ []
65
+ )
66
+ lay.format(event)
67
+ end
58
68
  end
59
69
 
60
70
  end
@@ -122,13 +132,13 @@ module Logsly::Outputs
122
132
  assert_kind_of Base, subject
123
133
  end
124
134
 
125
- should "build a Logging stdout appender, passing args to the builds" do
135
+ should "build a Logsly::Logging182 stdout appender, passing args to the builds" do
126
136
  appender = subject.to_appender @logger
127
137
 
128
- assert_kind_of Logging::Appenders::Stdout, appender
129
- assert_kind_of Logging::Layouts::Pattern, appender.layout
130
- assert_equal '%d : %m\n', appender.layout.pattern
131
- assert_kind_of Logging::ColorScheme, appender.layout.color_scheme
138
+ assert_kind_of Logsly::Logging182::Appenders::Stdout, appender
139
+ assert_kind_of Logsly::Logging182::Layouts::Pattern, appender.layout
140
+ assert_kind_of Logsly::Logging182::ColorScheme, appender.layout.color_scheme
141
+ assert_equal '%d : %m\n', appender.layout.pattern
132
142
  end
133
143
 
134
144
  end
@@ -158,14 +168,14 @@ module Logsly::Outputs
158
168
  assert_kind_of Base, subject
159
169
  end
160
170
 
161
- should "build a Logging file appender, passing args to the builds" do
171
+ should "build a Logsly::Logging182 file appender, passing args to the builds" do
162
172
  appender = subject.to_appender @logger
163
173
 
164
- assert_kind_of Logging::Appenders::File, appender
165
- assert_equal 'log/dev.log', appender.name
166
- assert_kind_of Logging::Layouts::Pattern, appender.layout
167
- assert_equal '%d : %m\n', appender.layout.pattern
168
- assert_kind_of Logging::ColorScheme, appender.layout.color_scheme
174
+ assert_kind_of Logsly::Logging182::Appenders::File, appender
175
+ assert_kind_of Logsly::Logging182::Layouts::Pattern, appender.layout
176
+ assert_kind_of Logsly::Logging182::ColorScheme, appender.layout.color_scheme
177
+ assert_equal 'log/dev.log', appender.name
178
+ assert_equal '%d : %m\n', appender.layout.pattern
169
179
  end
170
180
 
171
181
  end
@@ -208,13 +218,13 @@ module Logsly::Outputs
208
218
  assert_kind_of Base, subject
209
219
  end
210
220
 
211
- should "build a Logging syslog appender, passing args to the builds" do
221
+ should "build a Logsly::Logging182 syslog appender, passing args to the builds" do
212
222
  appender = subject.to_appender @logger
213
223
 
214
- assert_kind_of Logging::Appenders::Syslog, appender
215
- assert_kind_of Logging::Layouts::Pattern, appender.layout
216
- assert_equal '%d : %m\n', appender.layout.pattern
217
- assert_kind_of Logging::ColorScheme, appender.layout.color_scheme
224
+ assert_kind_of Logsly::Logging182::Appenders::Syslog, appender
225
+ assert_kind_of Logsly::Logging182::Layouts::Pattern, appender.layout
226
+ assert_kind_of Logsly::Logging182::ColorScheme, appender.layout.color_scheme
227
+ assert_equal '%d : %m\n', appender.layout.pattern
218
228
  end
219
229
 
220
230
  end
metadata CHANGED
@@ -1,7 +1,7 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: logsly
3
3
  version: !ruby/object:Gem::Version
4
- version: 1.2.0
4
+ version: 1.3.0
5
5
  platform: ruby
6
6
  authors:
7
7
  - Kelly Redding
@@ -10,7 +10,7 @@ autorequire:
10
10
  bindir: bin
11
11
  cert_chain: []
12
12
 
13
- date: 2016-06-13 00:00:00 Z
13
+ date: 2016-06-17 00:00:00 Z
14
14
  dependencies:
15
15
  - !ruby/object:Gem::Dependency
16
16
  name: assert
@@ -33,15 +33,25 @@ dependencies:
33
33
  type: :runtime
34
34
  version_requirements: *id002
35
35
  - !ruby/object:Gem::Dependency
36
- name: logging
36
+ name: little-plugger
37
37
  prerelease: false
38
38
  requirement: &id003 !ruby/object:Gem::Requirement
39
39
  requirements:
40
40
  - - ~>
41
41
  - !ruby/object:Gem::Version
42
- version: "1.7"
42
+ version: 1.1.4
43
43
  type: :runtime
44
44
  version_requirements: *id003
45
+ - !ruby/object:Gem::Dependency
46
+ name: multi_json
47
+ prerelease: false
48
+ requirement: &id004 !ruby/object:Gem::Requirement
49
+ requirements:
50
+ - - ~>
51
+ - !ruby/object:Gem::Version
52
+ version: 1.12.1
53
+ type: :runtime
54
+ version_requirements: *id004
45
55
  description: Create custom loggers.
46
56
  email:
47
57
  - kelly@kellyredding.com
@@ -59,6 +69,35 @@ files:
59
69
  - README.md
60
70
  - lib/logsly.rb
61
71
  - lib/logsly/colors.rb
72
+ - lib/logsly/logging182.rb
73
+ - lib/logsly/logging182/appender.rb
74
+ - lib/logsly/logging182/appenders.rb
75
+ - lib/logsly/logging182/appenders/buffering.rb
76
+ - lib/logsly/logging182/appenders/console.rb
77
+ - lib/logsly/logging182/appenders/email.rb
78
+ - lib/logsly/logging182/appenders/file.rb
79
+ - lib/logsly/logging182/appenders/growl.rb
80
+ - lib/logsly/logging182/appenders/io.rb
81
+ - lib/logsly/logging182/appenders/rolling_file.rb
82
+ - lib/logsly/logging182/appenders/string_io.rb
83
+ - lib/logsly/logging182/appenders/syslog.rb
84
+ - lib/logsly/logging182/color_scheme.rb
85
+ - lib/logsly/logging182/config/configurator.rb
86
+ - lib/logsly/logging182/config/yaml_configurator.rb
87
+ - lib/logsly/logging182/diagnostic_context.rb
88
+ - lib/logsly/logging182/layout.rb
89
+ - lib/logsly/logging182/layouts.rb
90
+ - lib/logsly/logging182/layouts/basic.rb
91
+ - lib/logsly/logging182/layouts/parseable.rb
92
+ - lib/logsly/logging182/layouts/pattern.rb
93
+ - lib/logsly/logging182/log_event.rb
94
+ - lib/logsly/logging182/logger.rb
95
+ - lib/logsly/logging182/proxy.rb
96
+ - lib/logsly/logging182/rails_compat.rb
97
+ - lib/logsly/logging182/repository.rb
98
+ - lib/logsly/logging182/root_logger.rb
99
+ - lib/logsly/logging182/stats.rb
100
+ - lib/logsly/logging182/utils.rb
62
101
  - lib/logsly/outputs.rb
63
102
  - lib/logsly/version.rb
64
103
  - log/.gitkeep
@@ -82,13 +121,13 @@ require_paths:
82
121
  - lib
83
122
  required_ruby_version: !ruby/object:Gem::Requirement
84
123
  requirements:
85
- - &id004
124
+ - &id005
86
125
  - ">="
87
126
  - !ruby/object:Gem::Version
88
127
  version: "0"
89
128
  required_rubygems_version: !ruby/object:Gem::Requirement
90
129
  requirements:
91
- - *id004
130
+ - *id005
92
131
  requirements: []
93
132
 
94
133
  rubyforge_project: