mixlib-log-json 0.0.1

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.
checksums.yaml ADDED
@@ -0,0 +1,7 @@
1
+ ---
2
+ SHA1:
3
+ metadata.gz: c25dad227298ddd5086768517888b5246af11f60
4
+ data.tar.gz: 07871c058d23486eac956f6e3d5088d5d6d33ec7
5
+ SHA512:
6
+ metadata.gz: 1aa987fb82c09d93c723fbf058b7aa85ed8ff7f45dc64a3712c2d540b46845de8e1d5f5e2388295bd79981f4b47c2f62b481ff6d452febb47bef930b963316e1
7
+ data.tar.gz: f3d90397d46f9ba92b37455d9b6c7c33ed0839770096e8c2cb5f20c707f94e759d91172e6ffc33b9d49a8b7a047298a0297d4929373152529510fefb8a343702
data/.rspec ADDED
@@ -0,0 +1,2 @@
1
+ --color
2
+
data/Gemfile ADDED
@@ -0,0 +1,13 @@
1
+ source "http://rubygems.org"
2
+
3
+ gem "mixlib-log"
4
+ gem "yajl-ruby"
5
+
6
+ group :development do
7
+ gem "rspec", ">= 2.13.0"
8
+ gem "yard", ">= 0.8"
9
+ gem "cucumber", ">= 0"
10
+ gem "bundler", "~> 1.3.5"
11
+ gem "jeweler", "~> 1.8.4"
12
+ gem "simplecov", "~> 0.7.1"
13
+ end
data/README.md ADDED
@@ -0,0 +1,4 @@
1
+ mixlib-log-json
2
+ ===============
3
+
4
+ A JSON formatter for mixlib-log
data/Rakefile ADDED
@@ -0,0 +1,54 @@
1
+ # encoding: utf-8
2
+
3
+ require 'bundler'
4
+ begin
5
+ Bundler.setup(:default, :development)
6
+ rescue Bundler::BundlerError => e
7
+ $stderr.puts e.message
8
+ $stderr.puts "Run `bundle install` to install missing gems"
9
+ exit e.status_code
10
+ end
11
+ require 'rake'
12
+
13
+ $:.unshift File.join(File.dirname(__FILE__), 'lib')
14
+ require 'jeweler'
15
+ Jeweler::Tasks.new do |gem|
16
+ # gem is a Gem::Specification... see http://docs.rubygems.org/read/chapter/20 for more options
17
+ gem.name = "mixlib-log-json"
18
+ gem.homepage = "http://github.com/seryl/mixlib-log-json"
19
+ gem.license = "MIT"
20
+ gem.summary = %Q{A general JSON logger for mixlib}
21
+ gem.description = %Q{A general JSON logger for mixlib}
22
+ gem.email = "joshtoft@gmail.com"
23
+ gem.authors = ["Josh Toft"]
24
+ gem.version = '0.0.1'
25
+ # dependencies defined in Gemfile
26
+ end
27
+ Jeweler::RubygemsDotOrgTasks.new
28
+
29
+ require 'rspec/core'
30
+ require 'rspec/core/rake_task'
31
+ RSpec::Core::RakeTask.new(:spec) do |spec|
32
+ spec.pattern = FileList['spec/**/*_spec.rb']
33
+ end
34
+
35
+ if RUBY_VERSION.gsub('.', '').to_i >= 190
36
+ desc "Code coverage detail"
37
+ task :simplecov do
38
+ ENV['COVERAGE'] = "true"
39
+ Rake::Task['spec'].execute
40
+ end
41
+ else
42
+ RSpec::Core::RakeTask.new(:rcov) do |spec|
43
+ spec.pattern = 'spec/**/*_spec.rb'
44
+ spec.rcov = true
45
+ end
46
+ end
47
+
48
+ require 'cucumber/rake/task'
49
+ Cucumber::Rake::Task.new(:features)
50
+
51
+ task :default => :spec
52
+
53
+ require 'yard'
54
+ YARD::Rake::YardocTask.new
@@ -0,0 +1,31 @@
1
+ require 'mixlib/log/formatter'
2
+ require 'time'
3
+ require 'yajl'
4
+
5
+ module Mixlib
6
+ module Log
7
+ class JSONFormatter < Mixlib::Log::Formatter
8
+
9
+ def call(severity, time, progname, msg)
10
+ jsonmsg = { s: severity }
11
+ if @@show_time
12
+ jsonmsg[:time] = time.iso8601()
13
+ end
14
+
15
+ sprintf("%s\n", ::Yajl::Encoder.encode(jsonmsg.merge(msg2hash(msg))))
16
+ end
17
+
18
+ def msg2hash(msg)
19
+ case msg
20
+ when ::String
21
+ { m: msg }
22
+ when ::Hash
23
+ msg
24
+ else
25
+ { m: msg2str(msg) }
26
+ end
27
+ end
28
+
29
+ end
30
+ end
31
+ end
@@ -0,0 +1,32 @@
1
+ $:.unshift File.dirname(__FILE__)
2
+ require "spec_helper"
3
+ require 'time'
4
+ require 'yajl'
5
+
6
+ describe Mixlib::Log::JSONFormatter do
7
+ before(:each) do
8
+ @formatter = Mixlib::Log::JSONFormatter.new
9
+ Mixlib::Log::JSONFormatter.show_time = false
10
+ end
11
+
12
+ it "should create a proper json log" do
13
+ time = Time.new
14
+ teststr = "{\"s\":\"monkey\",\"m\":\"mos def\"}\n"
15
+ @formatter.call("monkey", time, "test", "mos def").should == teststr
16
+ end
17
+
18
+ it "should create a proper json log with time" do
19
+ Mixlib::Log::JSONFormatter.show_time = true
20
+ time = Time.new
21
+ iso8601 = time.iso8601()
22
+ teststr = "{\"s\":\"monkey\",\"time\":\"#{iso8601}\",\"m\":\"mos def\"}\n"
23
+ @formatter.call("monkey", time, "test", "mos def").should == teststr
24
+ end
25
+
26
+ it "should be able to log objects" do
27
+ time = Time.new
28
+ teststr = "{\"s\":\"error\",\"m\":\"cool\",\"e\":123,\"error\":\"darn\"}\n"
29
+ @formatter.call('error', time, 'test',
30
+ { m: 'cool', e: 123, error: 'darn' }).should == teststr
31
+ end
32
+ end
@@ -0,0 +1,35 @@
1
+ $LOAD_PATH.unshift(File.join(File.dirname(__FILE__), '..', 'lib'))
2
+ $LOAD_PATH.unshift(File.dirname(__FILE__))
3
+
4
+ if RUBY_VERSION.gsub('.', '').to_i >= 190
5
+ require 'simplecov'
6
+
7
+ module SimpleCov::Configuration
8
+ def clean_filters
9
+ @filters = []
10
+ end
11
+ end
12
+
13
+ SimpleCov.configure do
14
+ clean_filters
15
+ load_adapter 'test_frameworks'
16
+ end
17
+
18
+ ENV["COVERAGE"] && SimpleCov.start do
19
+ add_filter "/.rvm/"
20
+ end
21
+ end
22
+
23
+ require 'rspec'
24
+ require 'mixlib/log'
25
+ require 'mixlib/log/jsonformatter'
26
+
27
+ # Requires supporting files with custom matchers and macros, etc,
28
+ # in ./support/ and its subdirectories.
29
+ Dir["#{File.dirname(__FILE__)}/support/**/*.rb"].each {|f| require f}
30
+
31
+ RSpec.configure do |config|
32
+ end
33
+
34
+ module Helpers
35
+ end
metadata ADDED
@@ -0,0 +1,164 @@
1
+ --- !ruby/object:Gem::Specification
2
+ name: mixlib-log-json
3
+ version: !ruby/object:Gem::Version
4
+ version: 0.0.1
5
+ platform: ruby
6
+ authors:
7
+ - Josh Toft
8
+ autorequire:
9
+ bindir: bin
10
+ cert_chain: []
11
+ date: 2013-08-13 00:00:00.000000000 Z
12
+ dependencies:
13
+ - !ruby/object:Gem::Dependency
14
+ name: mixlib-log
15
+ requirement: !ruby/object:Gem::Requirement
16
+ requirements:
17
+ - - '>='
18
+ - !ruby/object:Gem::Version
19
+ version: '0'
20
+ type: :runtime
21
+ prerelease: false
22
+ version_requirements: !ruby/object:Gem::Requirement
23
+ requirements:
24
+ - - '>='
25
+ - !ruby/object:Gem::Version
26
+ version: '0'
27
+ - !ruby/object:Gem::Dependency
28
+ name: yajl-ruby
29
+ requirement: !ruby/object:Gem::Requirement
30
+ requirements:
31
+ - - '>='
32
+ - !ruby/object:Gem::Version
33
+ version: '0'
34
+ type: :runtime
35
+ prerelease: false
36
+ version_requirements: !ruby/object:Gem::Requirement
37
+ requirements:
38
+ - - '>='
39
+ - !ruby/object:Gem::Version
40
+ version: '0'
41
+ - !ruby/object:Gem::Dependency
42
+ name: rspec
43
+ requirement: !ruby/object:Gem::Requirement
44
+ requirements:
45
+ - - '>='
46
+ - !ruby/object:Gem::Version
47
+ version: 2.13.0
48
+ type: :development
49
+ prerelease: false
50
+ version_requirements: !ruby/object:Gem::Requirement
51
+ requirements:
52
+ - - '>='
53
+ - !ruby/object:Gem::Version
54
+ version: 2.13.0
55
+ - !ruby/object:Gem::Dependency
56
+ name: yard
57
+ requirement: !ruby/object:Gem::Requirement
58
+ requirements:
59
+ - - '>='
60
+ - !ruby/object:Gem::Version
61
+ version: '0.8'
62
+ type: :development
63
+ prerelease: false
64
+ version_requirements: !ruby/object:Gem::Requirement
65
+ requirements:
66
+ - - '>='
67
+ - !ruby/object:Gem::Version
68
+ version: '0.8'
69
+ - !ruby/object:Gem::Dependency
70
+ name: cucumber
71
+ requirement: !ruby/object:Gem::Requirement
72
+ requirements:
73
+ - - '>='
74
+ - !ruby/object:Gem::Version
75
+ version: '0'
76
+ type: :development
77
+ prerelease: false
78
+ version_requirements: !ruby/object:Gem::Requirement
79
+ requirements:
80
+ - - '>='
81
+ - !ruby/object:Gem::Version
82
+ version: '0'
83
+ - !ruby/object:Gem::Dependency
84
+ name: bundler
85
+ requirement: !ruby/object:Gem::Requirement
86
+ requirements:
87
+ - - ~>
88
+ - !ruby/object:Gem::Version
89
+ version: 1.3.5
90
+ type: :development
91
+ prerelease: false
92
+ version_requirements: !ruby/object:Gem::Requirement
93
+ requirements:
94
+ - - ~>
95
+ - !ruby/object:Gem::Version
96
+ version: 1.3.5
97
+ - !ruby/object:Gem::Dependency
98
+ name: jeweler
99
+ requirement: !ruby/object:Gem::Requirement
100
+ requirements:
101
+ - - ~>
102
+ - !ruby/object:Gem::Version
103
+ version: 1.8.4
104
+ type: :development
105
+ prerelease: false
106
+ version_requirements: !ruby/object:Gem::Requirement
107
+ requirements:
108
+ - - ~>
109
+ - !ruby/object:Gem::Version
110
+ version: 1.8.4
111
+ - !ruby/object:Gem::Dependency
112
+ name: simplecov
113
+ requirement: !ruby/object:Gem::Requirement
114
+ requirements:
115
+ - - ~>
116
+ - !ruby/object:Gem::Version
117
+ version: 0.7.1
118
+ type: :development
119
+ prerelease: false
120
+ version_requirements: !ruby/object:Gem::Requirement
121
+ requirements:
122
+ - - ~>
123
+ - !ruby/object:Gem::Version
124
+ version: 0.7.1
125
+ description: A general JSON logger for mixlib
126
+ email: joshtoft@gmail.com
127
+ executables: []
128
+ extensions: []
129
+ extra_rdoc_files:
130
+ - README.md
131
+ files:
132
+ - .rspec
133
+ - Gemfile
134
+ - README.md
135
+ - Rakefile
136
+ - lib/mixlib/log/jsonformatter.rb
137
+ - spec/formatter/json_formatter_spec.rb
138
+ - spec/spec_helper.rb
139
+ homepage: http://github.com/seryl/mixlib-log-json
140
+ licenses:
141
+ - MIT
142
+ metadata: {}
143
+ post_install_message:
144
+ rdoc_options: []
145
+ require_paths:
146
+ - lib
147
+ required_ruby_version: !ruby/object:Gem::Requirement
148
+ requirements:
149
+ - - '>='
150
+ - !ruby/object:Gem::Version
151
+ version: '0'
152
+ required_rubygems_version: !ruby/object:Gem::Requirement
153
+ requirements:
154
+ - - '>='
155
+ - !ruby/object:Gem::Version
156
+ version: '0'
157
+ requirements: []
158
+ rubyforge_project:
159
+ rubygems_version: 2.0.5
160
+ signing_key:
161
+ specification_version: 4
162
+ summary: A general JSON logger for mixlib
163
+ test_files: []
164
+ has_rdoc: