thoth 0.0.2
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 +7 -0
- data/.gitignore +22 -0
- data/Gemfile +4 -0
- data/LICENSE.txt +22 -0
- data/README.md +77 -0
- data/Rakefile +2 -0
- data/lib/thoth/context.rb +21 -0
- data/lib/thoth/default_logger.rb +13 -0
- data/lib/thoth/logger.rb +32 -0
- data/lib/thoth/output/json.rb +14 -0
- data/lib/thoth/rails/controller_context.rb +26 -0
- data/lib/thoth/rails/model.rb +45 -0
- data/lib/thoth/rails/railtie.rb +14 -0
- data/lib/thoth/version.rb +3 -0
- data/lib/thoth.rb +10 -0
- data/spec/dummy/.gitignore +15 -0
- data/spec/dummy/Gemfile +40 -0
- data/spec/dummy/README.rdoc +261 -0
- data/spec/dummy/Rakefile +7 -0
- data/spec/dummy/app/assets/images/rails.png +0 -0
- data/spec/dummy/app/assets/javascripts/application.js +15 -0
- data/spec/dummy/app/assets/stylesheets/application.css +13 -0
- data/spec/dummy/app/controllers/application_controller.rb +3 -0
- data/spec/dummy/app/helpers/application_helper.rb +2 -0
- data/spec/dummy/app/mailers/.gitkeep +0 -0
- data/spec/dummy/app/models/.gitkeep +0 -0
- data/spec/dummy/app/models/car.rb +3 -0
- data/spec/dummy/app/models/cat.rb +7 -0
- data/spec/dummy/app/models/person.rb +3 -0
- data/spec/dummy/app/views/layouts/application.html.erb +14 -0
- data/spec/dummy/config/application.rb +62 -0
- data/spec/dummy/config/boot.rb +6 -0
- data/spec/dummy/config/database.yml +25 -0
- data/spec/dummy/config/environment.rb +5 -0
- data/spec/dummy/config/environments/development.rb +37 -0
- data/spec/dummy/config/environments/production.rb +67 -0
- data/spec/dummy/config/environments/test.rb +37 -0
- data/spec/dummy/config/initializers/backtrace_silencers.rb +7 -0
- data/spec/dummy/config/initializers/inflections.rb +15 -0
- data/spec/dummy/config/initializers/mime_types.rb +5 -0
- data/spec/dummy/config/initializers/secret_token.rb +7 -0
- data/spec/dummy/config/initializers/session_store.rb +8 -0
- data/spec/dummy/config/initializers/wrap_parameters.rb +14 -0
- data/spec/dummy/config/locales/en.yml +5 -0
- data/spec/dummy/config/routes.rb +58 -0
- data/spec/dummy/config.ru +4 -0
- data/spec/dummy/db/migrate/20140926015139_create_people.rb +8 -0
- data/spec/dummy/db/migrate/20140926022006_create_cars.rb +9 -0
- data/spec/dummy/db/migrate/20140926022112_create_cats.rb +8 -0
- data/spec/dummy/db/schema.rb +39 -0
- data/spec/dummy/db/seeds.rb +7 -0
- data/spec/dummy/lib/assets/.gitkeep +0 -0
- data/spec/dummy/lib/tasks/.gitkeep +0 -0
- data/spec/dummy/log/.gitkeep +0 -0
- data/spec/dummy/public/404.html +26 -0
- data/spec/dummy/public/422.html +26 -0
- data/spec/dummy/public/500.html +25 -0
- data/spec/dummy/public/favicon.ico +0 -0
- data/spec/dummy/public/index.html +241 -0
- data/spec/dummy/public/robots.txt +5 -0
- data/spec/dummy/script/rails +6 -0
- data/spec/dummy/test/fixtures/.gitkeep +0 -0
- data/spec/dummy/test/fixtures/cars.yml +11 -0
- data/spec/dummy/test/fixtures/cats.yml +11 -0
- data/spec/dummy/test/fixtures/people.yml +11 -0
- data/spec/dummy/test/functional/.gitkeep +0 -0
- data/spec/dummy/test/integration/.gitkeep +0 -0
- data/spec/dummy/test/performance/browsing_test.rb +12 -0
- data/spec/dummy/test/test_helper.rb +13 -0
- data/spec/dummy/test/unit/.gitkeep +0 -0
- data/spec/dummy/test/unit/car_test.rb +7 -0
- data/spec/dummy/test/unit/cat_test.rb +7 -0
- data/spec/dummy/test/unit/person_test.rb +7 -0
- data/spec/dummy/vendor/assets/javascripts/.gitkeep +0 -0
- data/spec/dummy/vendor/assets/stylesheets/.gitkeep +0 -0
- data/spec/dummy/vendor/plugins/.gitkeep +0 -0
- data/spec/spec_helper.rb +13 -0
- data/spec/thoth/logger_spec.rb +79 -0
- data/spec/thoth/rails/controller_context_spec.rb +29 -0
- data/spec/thoth/rails/model_spec.rb +105 -0
- data/thoth.gemspec +30 -0
- metadata +321 -0
@@ -0,0 +1,241 @@
|
|
1
|
+
<!DOCTYPE html>
|
2
|
+
<html>
|
3
|
+
<head>
|
4
|
+
<title>Ruby on Rails: Welcome aboard</title>
|
5
|
+
<style type="text/css" media="screen">
|
6
|
+
body {
|
7
|
+
margin: 0;
|
8
|
+
margin-bottom: 25px;
|
9
|
+
padding: 0;
|
10
|
+
background-color: #f0f0f0;
|
11
|
+
font-family: "Lucida Grande", "Bitstream Vera Sans", "Verdana";
|
12
|
+
font-size: 13px;
|
13
|
+
color: #333;
|
14
|
+
}
|
15
|
+
|
16
|
+
h1 {
|
17
|
+
font-size: 28px;
|
18
|
+
color: #000;
|
19
|
+
}
|
20
|
+
|
21
|
+
a {color: #03c}
|
22
|
+
a:hover {
|
23
|
+
background-color: #03c;
|
24
|
+
color: white;
|
25
|
+
text-decoration: none;
|
26
|
+
}
|
27
|
+
|
28
|
+
|
29
|
+
#page {
|
30
|
+
background-color: #f0f0f0;
|
31
|
+
width: 750px;
|
32
|
+
margin: 0;
|
33
|
+
margin-left: auto;
|
34
|
+
margin-right: auto;
|
35
|
+
}
|
36
|
+
|
37
|
+
#content {
|
38
|
+
float: left;
|
39
|
+
background-color: white;
|
40
|
+
border: 3px solid #aaa;
|
41
|
+
border-top: none;
|
42
|
+
padding: 25px;
|
43
|
+
width: 500px;
|
44
|
+
}
|
45
|
+
|
46
|
+
#sidebar {
|
47
|
+
float: right;
|
48
|
+
width: 175px;
|
49
|
+
}
|
50
|
+
|
51
|
+
#footer {
|
52
|
+
clear: both;
|
53
|
+
}
|
54
|
+
|
55
|
+
#header, #about, #getting-started {
|
56
|
+
padding-left: 75px;
|
57
|
+
padding-right: 30px;
|
58
|
+
}
|
59
|
+
|
60
|
+
|
61
|
+
#header {
|
62
|
+
background-image: url("assets/rails.png");
|
63
|
+
background-repeat: no-repeat;
|
64
|
+
background-position: top left;
|
65
|
+
height: 64px;
|
66
|
+
}
|
67
|
+
#header h1, #header h2 {margin: 0}
|
68
|
+
#header h2 {
|
69
|
+
color: #888;
|
70
|
+
font-weight: normal;
|
71
|
+
font-size: 16px;
|
72
|
+
}
|
73
|
+
|
74
|
+
|
75
|
+
#about h3 {
|
76
|
+
margin: 0;
|
77
|
+
margin-bottom: 10px;
|
78
|
+
font-size: 14px;
|
79
|
+
}
|
80
|
+
|
81
|
+
#about-content {
|
82
|
+
background-color: #ffd;
|
83
|
+
border: 1px solid #fc0;
|
84
|
+
margin-left: -55px;
|
85
|
+
margin-right: -10px;
|
86
|
+
}
|
87
|
+
#about-content table {
|
88
|
+
margin-top: 10px;
|
89
|
+
margin-bottom: 10px;
|
90
|
+
font-size: 11px;
|
91
|
+
border-collapse: collapse;
|
92
|
+
}
|
93
|
+
#about-content td {
|
94
|
+
padding: 10px;
|
95
|
+
padding-top: 3px;
|
96
|
+
padding-bottom: 3px;
|
97
|
+
}
|
98
|
+
#about-content td.name {color: #555}
|
99
|
+
#about-content td.value {color: #000}
|
100
|
+
|
101
|
+
#about-content ul {
|
102
|
+
padding: 0;
|
103
|
+
list-style-type: none;
|
104
|
+
}
|
105
|
+
|
106
|
+
#about-content.failure {
|
107
|
+
background-color: #fcc;
|
108
|
+
border: 1px solid #f00;
|
109
|
+
}
|
110
|
+
#about-content.failure p {
|
111
|
+
margin: 0;
|
112
|
+
padding: 10px;
|
113
|
+
}
|
114
|
+
|
115
|
+
|
116
|
+
#getting-started {
|
117
|
+
border-top: 1px solid #ccc;
|
118
|
+
margin-top: 25px;
|
119
|
+
padding-top: 15px;
|
120
|
+
}
|
121
|
+
#getting-started h1 {
|
122
|
+
margin: 0;
|
123
|
+
font-size: 20px;
|
124
|
+
}
|
125
|
+
#getting-started h2 {
|
126
|
+
margin: 0;
|
127
|
+
font-size: 14px;
|
128
|
+
font-weight: normal;
|
129
|
+
color: #333;
|
130
|
+
margin-bottom: 25px;
|
131
|
+
}
|
132
|
+
#getting-started ol {
|
133
|
+
margin-left: 0;
|
134
|
+
padding-left: 0;
|
135
|
+
}
|
136
|
+
#getting-started li {
|
137
|
+
font-size: 18px;
|
138
|
+
color: #888;
|
139
|
+
margin-bottom: 25px;
|
140
|
+
}
|
141
|
+
#getting-started li h2 {
|
142
|
+
margin: 0;
|
143
|
+
font-weight: normal;
|
144
|
+
font-size: 18px;
|
145
|
+
color: #333;
|
146
|
+
}
|
147
|
+
#getting-started li p {
|
148
|
+
color: #555;
|
149
|
+
font-size: 13px;
|
150
|
+
}
|
151
|
+
|
152
|
+
|
153
|
+
#sidebar ul {
|
154
|
+
margin-left: 0;
|
155
|
+
padding-left: 0;
|
156
|
+
}
|
157
|
+
#sidebar ul h3 {
|
158
|
+
margin-top: 25px;
|
159
|
+
font-size: 16px;
|
160
|
+
padding-bottom: 10px;
|
161
|
+
border-bottom: 1px solid #ccc;
|
162
|
+
}
|
163
|
+
#sidebar li {
|
164
|
+
list-style-type: none;
|
165
|
+
}
|
166
|
+
#sidebar ul.links li {
|
167
|
+
margin-bottom: 5px;
|
168
|
+
}
|
169
|
+
|
170
|
+
.filename {
|
171
|
+
font-style: italic;
|
172
|
+
}
|
173
|
+
</style>
|
174
|
+
<script type="text/javascript">
|
175
|
+
function about() {
|
176
|
+
info = document.getElementById('about-content');
|
177
|
+
if (window.XMLHttpRequest)
|
178
|
+
{ xhr = new XMLHttpRequest(); }
|
179
|
+
else
|
180
|
+
{ xhr = new ActiveXObject("Microsoft.XMLHTTP"); }
|
181
|
+
xhr.open("GET","rails/info/properties",false);
|
182
|
+
xhr.send("");
|
183
|
+
info.innerHTML = xhr.responseText;
|
184
|
+
info.style.display = 'block'
|
185
|
+
}
|
186
|
+
</script>
|
187
|
+
</head>
|
188
|
+
<body>
|
189
|
+
<div id="page">
|
190
|
+
<div id="sidebar">
|
191
|
+
<ul id="sidebar-items">
|
192
|
+
<li>
|
193
|
+
<h3>Browse the documentation</h3>
|
194
|
+
<ul class="links">
|
195
|
+
<li><a href="http://guides.rubyonrails.org/">Rails Guides</a></li>
|
196
|
+
<li><a href="http://api.rubyonrails.org/">Rails API</a></li>
|
197
|
+
<li><a href="http://www.ruby-doc.org/core/">Ruby core</a></li>
|
198
|
+
<li><a href="http://www.ruby-doc.org/stdlib/">Ruby standard library</a></li>
|
199
|
+
</ul>
|
200
|
+
</li>
|
201
|
+
</ul>
|
202
|
+
</div>
|
203
|
+
|
204
|
+
<div id="content">
|
205
|
+
<div id="header">
|
206
|
+
<h1>Welcome aboard</h1>
|
207
|
+
<h2>You’re riding Ruby on Rails!</h2>
|
208
|
+
</div>
|
209
|
+
|
210
|
+
<div id="about">
|
211
|
+
<h3><a href="rails/info/properties" onclick="about(); return false">About your application’s environment</a></h3>
|
212
|
+
<div id="about-content" style="display: none"></div>
|
213
|
+
</div>
|
214
|
+
|
215
|
+
<div id="getting-started">
|
216
|
+
<h1>Getting started</h1>
|
217
|
+
<h2>Here’s how to get rolling:</h2>
|
218
|
+
|
219
|
+
<ol>
|
220
|
+
<li>
|
221
|
+
<h2>Use <code>rails generate</code> to create your models and controllers</h2>
|
222
|
+
<p>To see all available options, run it without parameters.</p>
|
223
|
+
</li>
|
224
|
+
|
225
|
+
<li>
|
226
|
+
<h2>Set up a default route and remove <span class="filename">public/index.html</span></h2>
|
227
|
+
<p>Routes are set up in <span class="filename">config/routes.rb</span>.</p>
|
228
|
+
</li>
|
229
|
+
|
230
|
+
<li>
|
231
|
+
<h2>Create your database</h2>
|
232
|
+
<p>Run <code>rake db:create</code> to create your database. If you're not using SQLite (the default), edit <span class="filename">config/database.yml</span> with your username and password.</p>
|
233
|
+
</li>
|
234
|
+
</ol>
|
235
|
+
</div>
|
236
|
+
</div>
|
237
|
+
|
238
|
+
<div id="footer"> </div>
|
239
|
+
</div>
|
240
|
+
</body>
|
241
|
+
</html>
|
@@ -0,0 +1,6 @@
|
|
1
|
+
#!/usr/bin/env ruby
|
2
|
+
# This command will automatically be run when you run "rails" with Rails 3 gems installed from the root of your application.
|
3
|
+
|
4
|
+
APP_PATH = File.expand_path('../../config/application', __FILE__)
|
5
|
+
require File.expand_path('../../config/boot', __FILE__)
|
6
|
+
require 'rails/commands'
|
File without changes
|
@@ -0,0 +1,11 @@
|
|
1
|
+
# Read about fixtures at http://api.rubyonrails.org/classes/ActiveRecord/Fixtures.html
|
2
|
+
|
3
|
+
# This model initially had no columns defined. If you add columns to the
|
4
|
+
# model remove the '{}' from the fixture names and add the columns immediately
|
5
|
+
# below each fixture, per the syntax in the comments below
|
6
|
+
#
|
7
|
+
one: {}
|
8
|
+
# column: value
|
9
|
+
#
|
10
|
+
two: {}
|
11
|
+
# column: value
|
@@ -0,0 +1,11 @@
|
|
1
|
+
# Read about fixtures at http://api.rubyonrails.org/classes/ActiveRecord/Fixtures.html
|
2
|
+
|
3
|
+
# This model initially had no columns defined. If you add columns to the
|
4
|
+
# model remove the '{}' from the fixture names and add the columns immediately
|
5
|
+
# below each fixture, per the syntax in the comments below
|
6
|
+
#
|
7
|
+
one: {}
|
8
|
+
# column: value
|
9
|
+
#
|
10
|
+
two: {}
|
11
|
+
# column: value
|
@@ -0,0 +1,11 @@
|
|
1
|
+
# Read about fixtures at http://api.rubyonrails.org/classes/ActiveRecord/Fixtures.html
|
2
|
+
|
3
|
+
# This model initially had no columns defined. If you add columns to the
|
4
|
+
# model remove the '{}' from the fixture names and add the columns immediately
|
5
|
+
# below each fixture, per the syntax in the comments below
|
6
|
+
#
|
7
|
+
one: {}
|
8
|
+
# column: value
|
9
|
+
#
|
10
|
+
two: {}
|
11
|
+
# column: value
|
File without changes
|
File without changes
|
@@ -0,0 +1,12 @@
|
|
1
|
+
require 'test_helper'
|
2
|
+
require 'rails/performance_test_help'
|
3
|
+
|
4
|
+
class BrowsingTest < ActionDispatch::PerformanceTest
|
5
|
+
# Refer to the documentation for all available options
|
6
|
+
# self.profile_options = { :runs => 5, :metrics => [:wall_time, :memory]
|
7
|
+
# :output => 'tmp/performance', :formats => [:flat] }
|
8
|
+
|
9
|
+
def test_homepage
|
10
|
+
get '/'
|
11
|
+
end
|
12
|
+
end
|
@@ -0,0 +1,13 @@
|
|
1
|
+
ENV["RAILS_ENV"] = "test"
|
2
|
+
require File.expand_path('../../config/environment', __FILE__)
|
3
|
+
require 'rails/test_help'
|
4
|
+
|
5
|
+
class ActiveSupport::TestCase
|
6
|
+
# Setup all fixtures in test/fixtures/*.(yml|csv) for all tests in alphabetical order.
|
7
|
+
#
|
8
|
+
# Note: You'll currently still have to declare fixtures explicitly in integration tests
|
9
|
+
# -- they do not yet inherit this setting
|
10
|
+
fixtures :all
|
11
|
+
|
12
|
+
# Add more helper methods to be used by all tests here...
|
13
|
+
end
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
data/spec/spec_helper.rb
ADDED
@@ -0,0 +1,13 @@
|
|
1
|
+
require 'bundler/setup'
|
2
|
+
Bundler.setup
|
3
|
+
|
4
|
+
ENV["RAILS_ENV"] ||= 'test'
|
5
|
+
require 'thoth'
|
6
|
+
require File.expand_path("../dummy/config/environment", __FILE__)
|
7
|
+
require 'rspec/rails'
|
8
|
+
require 'pry-remote'
|
9
|
+
require 'timecop'
|
10
|
+
|
11
|
+
RSpec.configure do |config|
|
12
|
+
config.infer_spec_type_from_file_location!
|
13
|
+
end
|
@@ -0,0 +1,79 @@
|
|
1
|
+
require 'spec_helper'
|
2
|
+
|
3
|
+
describe Thoth::Logger do
|
4
|
+
|
5
|
+
describe '#log' do
|
6
|
+
let(:output) { StringIO.new('', 'r+') }
|
7
|
+
let(:logger) { Thoth::Logger.new(output) }
|
8
|
+
|
9
|
+
it "writes log to given output" do
|
10
|
+
logger.log('checkout')
|
11
|
+
expect(output.string).to include('checkout')
|
12
|
+
end
|
13
|
+
|
14
|
+
it "includes timestamp" do
|
15
|
+
Timecop.freeze('2014-01-03 2:15:09 UTC') do
|
16
|
+
logger.log('checkout')
|
17
|
+
expect(output.string).to include(':time=>"03/Jan/2014:02:15:09 +0000"')
|
18
|
+
end
|
19
|
+
end
|
20
|
+
|
21
|
+
context "and Thoth.context contains data" do
|
22
|
+
before do
|
23
|
+
Thoth.context = {source: :api}
|
24
|
+
end
|
25
|
+
|
26
|
+
after do
|
27
|
+
Thoth.clear_context!
|
28
|
+
end
|
29
|
+
|
30
|
+
it "includes the context" do
|
31
|
+
logger.log('checkout')
|
32
|
+
|
33
|
+
expect(output.string).to include(':context=>{:source=>:api}')
|
34
|
+
end
|
35
|
+
|
36
|
+
context "and context data passed to #log" do
|
37
|
+
it "merges the context data into the log" do
|
38
|
+
logger.log('checkout', {}, customer: 1)
|
39
|
+
expect(output.string).to include(':context=>{:source=>:api, :customer=>1}')
|
40
|
+
end
|
41
|
+
end
|
42
|
+
end
|
43
|
+
|
44
|
+
context "with details and context" do
|
45
|
+
it "includes the details in the log" do
|
46
|
+
logger.log('checkout', {total: 2399}, customer: 1)
|
47
|
+
expect(output.string).to include(':context=>{:customer=>1}')
|
48
|
+
end
|
49
|
+
|
50
|
+
it "includes the context in the log" do
|
51
|
+
logger.log('checkout', {total: 2399}, customer: 1)
|
52
|
+
expect(output.string).to include(':details=>{:total=>2399}')
|
53
|
+
end
|
54
|
+
end
|
55
|
+
|
56
|
+
context "with custom timestamp format" do
|
57
|
+
let(:logger) { Thoth::Logger.new(output, timestamp_format: '%Y-%m-%d') }
|
58
|
+
|
59
|
+
it "records timestamp with given format" do
|
60
|
+
Timecop.freeze('2014-01-03 2:15:09 UTC') do
|
61
|
+
logger.log('checkout')
|
62
|
+
expect(output.string).to include(':time=>"2014-01-03"')
|
63
|
+
end
|
64
|
+
end
|
65
|
+
end
|
66
|
+
|
67
|
+
context "with custom timestamp key" do
|
68
|
+
let(:logger) { Thoth::Logger.new(output, timestamp_key: 'timestamp') }
|
69
|
+
|
70
|
+
it "records timestamp with given format" do
|
71
|
+
Timecop.freeze('2014-01-03 2:15:09 UTC') do
|
72
|
+
logger.log('checkout')
|
73
|
+
expect(output.string).to include('"timestamp"=>"03/Jan/2014:02:15:09 +0000"')
|
74
|
+
end
|
75
|
+
end
|
76
|
+
end
|
77
|
+
end
|
78
|
+
|
79
|
+
end
|
@@ -0,0 +1,29 @@
|
|
1
|
+
require 'spec_helper'
|
2
|
+
require 'thoth/rails/railtie'
|
3
|
+
|
4
|
+
DummyUser = Struct.new(:id)
|
5
|
+
class ControllerWithThothContextController < ActionController::Base
|
6
|
+
include Thoth::Rails::ControllerContext
|
7
|
+
|
8
|
+
def show
|
9
|
+
@context = Thoth.context
|
10
|
+
head 200
|
11
|
+
end
|
12
|
+
|
13
|
+
def current_user
|
14
|
+
DummyUser.new(1)
|
15
|
+
end
|
16
|
+
end
|
17
|
+
|
18
|
+
describe ControllerWithThothContextController, type: :controller do
|
19
|
+
before do
|
20
|
+
routes.draw { get "show" => "controller_with_thoth_context#show" }
|
21
|
+
end
|
22
|
+
|
23
|
+
context "on any action" do
|
24
|
+
it "stores params in the Thoth.context" do
|
25
|
+
get :show
|
26
|
+
expect(assigns(:context)).to eq({"controller"=>"controller_with_thoth_context", "action"=>"show", "current_user"=>1})
|
27
|
+
end
|
28
|
+
end
|
29
|
+
end
|
@@ -0,0 +1,105 @@
|
|
1
|
+
require 'spec_helper'
|
2
|
+
require 'thoth/rails/railtie'
|
3
|
+
|
4
|
+
describe Thoth::Rails::Model do
|
5
|
+
before(:all) do
|
6
|
+
Thoth.logger ||= Thoth::Logger.new(StringIO.new('', 'r+'))
|
7
|
+
end
|
8
|
+
|
9
|
+
class Person < ActiveRecord::Base
|
10
|
+
include Thoth::Rails::Model
|
11
|
+
log_events
|
12
|
+
end
|
13
|
+
|
14
|
+
|
15
|
+
context "on create" do
|
16
|
+
it "records the create event" do
|
17
|
+
expect(Thoth).to receive(:logger).and_return(double(log: true))
|
18
|
+
Person.create(name: 'Lee')
|
19
|
+
end
|
20
|
+
|
21
|
+
context "and not recording create events" do
|
22
|
+
class Cat < ActiveRecord::Base
|
23
|
+
include Thoth::Rails::Model
|
24
|
+
log_events on: :update
|
25
|
+
end
|
26
|
+
|
27
|
+
it "does not record anything" do
|
28
|
+
expect(Thoth).not_to receive(:logger)
|
29
|
+
Cat.create!
|
30
|
+
end
|
31
|
+
end
|
32
|
+
|
33
|
+
end
|
34
|
+
|
35
|
+
context "on destroy" do
|
36
|
+
let!(:person) { Person.create(name: 'Lee') }
|
37
|
+
|
38
|
+
it "records the destroy event" do
|
39
|
+
expect(Thoth).to receive(:logger).and_return(double(log: true))
|
40
|
+
person.destroy
|
41
|
+
end
|
42
|
+
|
43
|
+
context "and not recording destroy events" do
|
44
|
+
class Cat < ActiveRecord::Base
|
45
|
+
include Thoth::Rails::Model
|
46
|
+
log_events on: :update
|
47
|
+
end
|
48
|
+
|
49
|
+
let!(:cat) { Cat.create }
|
50
|
+
|
51
|
+
it "does not record anything" do
|
52
|
+
expect(Thoth).not_to receive(:logger)
|
53
|
+
cat.destroy
|
54
|
+
end
|
55
|
+
end
|
56
|
+
end
|
57
|
+
|
58
|
+
context "on update" do
|
59
|
+
let!(:person) { Person.create(name: 'Lee') }
|
60
|
+
|
61
|
+
it "records the update event" do
|
62
|
+
expect(Thoth).to receive(:logger).and_return(double(log: true))
|
63
|
+
person.update_attributes!(name: 'Smith')
|
64
|
+
end
|
65
|
+
|
66
|
+
context "when logging only changes to certain attribute" do
|
67
|
+
class PersonWithOnly < Person
|
68
|
+
include Thoth::Rails::Model
|
69
|
+
log_events only: :name
|
70
|
+
end
|
71
|
+
|
72
|
+
let!(:person) { PersonWithOnly.create(name: 'Lee') }
|
73
|
+
|
74
|
+
|
75
|
+
context "and a watched attribute changes" do
|
76
|
+
it "records the update event" do
|
77
|
+
expect(Thoth).to receive(:logger).and_return(double(log: true))
|
78
|
+
person.update_attributes!(name: 'Smith', color: :blue)
|
79
|
+
end
|
80
|
+
end
|
81
|
+
|
82
|
+
context "and a watched attribute does not change" do
|
83
|
+
it "does not record anything" do
|
84
|
+
expect(Thoth).not_to receive(:logger)
|
85
|
+
person.update_attributes!(color: :blue)
|
86
|
+
end
|
87
|
+
end
|
88
|
+
end
|
89
|
+
|
90
|
+
context "and not recording update events" do
|
91
|
+
class Car < ActiveRecord::Base
|
92
|
+
include Thoth::Rails::Model
|
93
|
+
log_events on: :destroy
|
94
|
+
end
|
95
|
+
|
96
|
+
let!(:car) { Car.create(make: 'Tesla', model: 'S') }
|
97
|
+
|
98
|
+
it "does not record anything" do
|
99
|
+
expect(Thoth).not_to receive(:logger)
|
100
|
+
car.update_attributes!(model: 'X')
|
101
|
+
end
|
102
|
+
end
|
103
|
+
end
|
104
|
+
|
105
|
+
end
|
data/thoth.gemspec
ADDED
@@ -0,0 +1,30 @@
|
|
1
|
+
# coding: utf-8
|
2
|
+
lib = File.expand_path('../lib', __FILE__)
|
3
|
+
$LOAD_PATH.unshift(lib) unless $LOAD_PATH.include?(lib)
|
4
|
+
require 'thoth/version'
|
5
|
+
|
6
|
+
Gem::Specification.new do |spec|
|
7
|
+
spec.name = "thoth"
|
8
|
+
spec.version = Thoth::VERSION
|
9
|
+
spec.authors = ["Philippe Huibonhoa"]
|
10
|
+
spec.email = ["phuibonhoa@gmail.com"]
|
11
|
+
spec.summary = %q{Easy event logging for rails.}
|
12
|
+
spec.homepage = "https://github.com/bkr/thoth"
|
13
|
+
spec.license = "MIT"
|
14
|
+
|
15
|
+
spec.files = `git ls-files -z`.split("\x0")
|
16
|
+
spec.executables = spec.files.grep(%r{^bin/}) { |f| File.basename(f) }
|
17
|
+
spec.test_files = spec.files.grep(%r{^(test|spec|features)/})
|
18
|
+
spec.require_paths = ["lib"]
|
19
|
+
|
20
|
+
spec.add_dependency 'activesupport', ['>= 3.0', '< 5.0']
|
21
|
+
spec.add_dependency 'request_store'
|
22
|
+
|
23
|
+
spec.add_development_dependency "bundler", "~> 1.6"
|
24
|
+
spec.add_development_dependency "rake"
|
25
|
+
spec.add_development_dependency 'rails', '~> 3.2.18'
|
26
|
+
spec.add_development_dependency 'rspec-rails', '~> 2.14'
|
27
|
+
spec.add_development_dependency 'sqlite3'
|
28
|
+
spec.add_development_dependency 'pry-remote'
|
29
|
+
spec.add_development_dependency 'timecop'
|
30
|
+
end
|