thoth 0.0.2

Sign up to get free protection for your applications and to get access to all the features.
Files changed (82) hide show
  1. checksums.yaml +7 -0
  2. data/.gitignore +22 -0
  3. data/Gemfile +4 -0
  4. data/LICENSE.txt +22 -0
  5. data/README.md +77 -0
  6. data/Rakefile +2 -0
  7. data/lib/thoth/context.rb +21 -0
  8. data/lib/thoth/default_logger.rb +13 -0
  9. data/lib/thoth/logger.rb +32 -0
  10. data/lib/thoth/output/json.rb +14 -0
  11. data/lib/thoth/rails/controller_context.rb +26 -0
  12. data/lib/thoth/rails/model.rb +45 -0
  13. data/lib/thoth/rails/railtie.rb +14 -0
  14. data/lib/thoth/version.rb +3 -0
  15. data/lib/thoth.rb +10 -0
  16. data/spec/dummy/.gitignore +15 -0
  17. data/spec/dummy/Gemfile +40 -0
  18. data/spec/dummy/README.rdoc +261 -0
  19. data/spec/dummy/Rakefile +7 -0
  20. data/spec/dummy/app/assets/images/rails.png +0 -0
  21. data/spec/dummy/app/assets/javascripts/application.js +15 -0
  22. data/spec/dummy/app/assets/stylesheets/application.css +13 -0
  23. data/spec/dummy/app/controllers/application_controller.rb +3 -0
  24. data/spec/dummy/app/helpers/application_helper.rb +2 -0
  25. data/spec/dummy/app/mailers/.gitkeep +0 -0
  26. data/spec/dummy/app/models/.gitkeep +0 -0
  27. data/spec/dummy/app/models/car.rb +3 -0
  28. data/spec/dummy/app/models/cat.rb +7 -0
  29. data/spec/dummy/app/models/person.rb +3 -0
  30. data/spec/dummy/app/views/layouts/application.html.erb +14 -0
  31. data/spec/dummy/config/application.rb +62 -0
  32. data/spec/dummy/config/boot.rb +6 -0
  33. data/spec/dummy/config/database.yml +25 -0
  34. data/spec/dummy/config/environment.rb +5 -0
  35. data/spec/dummy/config/environments/development.rb +37 -0
  36. data/spec/dummy/config/environments/production.rb +67 -0
  37. data/spec/dummy/config/environments/test.rb +37 -0
  38. data/spec/dummy/config/initializers/backtrace_silencers.rb +7 -0
  39. data/spec/dummy/config/initializers/inflections.rb +15 -0
  40. data/spec/dummy/config/initializers/mime_types.rb +5 -0
  41. data/spec/dummy/config/initializers/secret_token.rb +7 -0
  42. data/spec/dummy/config/initializers/session_store.rb +8 -0
  43. data/spec/dummy/config/initializers/wrap_parameters.rb +14 -0
  44. data/spec/dummy/config/locales/en.yml +5 -0
  45. data/spec/dummy/config/routes.rb +58 -0
  46. data/spec/dummy/config.ru +4 -0
  47. data/spec/dummy/db/migrate/20140926015139_create_people.rb +8 -0
  48. data/spec/dummy/db/migrate/20140926022006_create_cars.rb +9 -0
  49. data/spec/dummy/db/migrate/20140926022112_create_cats.rb +8 -0
  50. data/spec/dummy/db/schema.rb +39 -0
  51. data/spec/dummy/db/seeds.rb +7 -0
  52. data/spec/dummy/lib/assets/.gitkeep +0 -0
  53. data/spec/dummy/lib/tasks/.gitkeep +0 -0
  54. data/spec/dummy/log/.gitkeep +0 -0
  55. data/spec/dummy/public/404.html +26 -0
  56. data/spec/dummy/public/422.html +26 -0
  57. data/spec/dummy/public/500.html +25 -0
  58. data/spec/dummy/public/favicon.ico +0 -0
  59. data/spec/dummy/public/index.html +241 -0
  60. data/spec/dummy/public/robots.txt +5 -0
  61. data/spec/dummy/script/rails +6 -0
  62. data/spec/dummy/test/fixtures/.gitkeep +0 -0
  63. data/spec/dummy/test/fixtures/cars.yml +11 -0
  64. data/spec/dummy/test/fixtures/cats.yml +11 -0
  65. data/spec/dummy/test/fixtures/people.yml +11 -0
  66. data/spec/dummy/test/functional/.gitkeep +0 -0
  67. data/spec/dummy/test/integration/.gitkeep +0 -0
  68. data/spec/dummy/test/performance/browsing_test.rb +12 -0
  69. data/spec/dummy/test/test_helper.rb +13 -0
  70. data/spec/dummy/test/unit/.gitkeep +0 -0
  71. data/spec/dummy/test/unit/car_test.rb +7 -0
  72. data/spec/dummy/test/unit/cat_test.rb +7 -0
  73. data/spec/dummy/test/unit/person_test.rb +7 -0
  74. data/spec/dummy/vendor/assets/javascripts/.gitkeep +0 -0
  75. data/spec/dummy/vendor/assets/stylesheets/.gitkeep +0 -0
  76. data/spec/dummy/vendor/plugins/.gitkeep +0 -0
  77. data/spec/spec_helper.rb +13 -0
  78. data/spec/thoth/logger_spec.rb +79 -0
  79. data/spec/thoth/rails/controller_context_spec.rb +29 -0
  80. data/spec/thoth/rails/model_spec.rb +105 -0
  81. data/thoth.gemspec +30 -0
  82. 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&rsquo;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&rsquo;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&rsquo;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">&nbsp;</div>
239
+ </div>
240
+ </body>
241
+ </html>
@@ -0,0 +1,5 @@
1
+ # See http://www.robotstxt.org/wc/norobots.html for documentation on how to use the robots.txt file
2
+ #
3
+ # To ban all spiders from the entire site uncomment the next two lines:
4
+ # User-Agent: *
5
+ # Disallow: /
@@ -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
@@ -0,0 +1,7 @@
1
+ require 'test_helper'
2
+
3
+ class CarTest < ActiveSupport::TestCase
4
+ # test "the truth" do
5
+ # assert true
6
+ # end
7
+ end
@@ -0,0 +1,7 @@
1
+ require 'test_helper'
2
+
3
+ class CatTest < ActiveSupport::TestCase
4
+ # test "the truth" do
5
+ # assert true
6
+ # end
7
+ end
@@ -0,0 +1,7 @@
1
+ require 'test_helper'
2
+
3
+ class PersonTest < ActiveSupport::TestCase
4
+ # test "the truth" do
5
+ # assert true
6
+ # end
7
+ end
File without changes
File without changes
File without changes
@@ -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