gatoroid 0.1.0 → 0.2.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.
data/.rvmrc ADDED
@@ -0,0 +1,2 @@
1
+ export rvm_trust_rvmrcs_flag=1
2
+ rvm --create use 1.9.3-p125@gatorid
@@ -0,0 +1,55 @@
1
+ GEM
2
+ remote: http://rubygems.org/
3
+ specs:
4
+ activemodel (3.2.3)
5
+ activesupport (= 3.2.3)
6
+ builder (~> 3.0.0)
7
+ activesupport (3.2.3)
8
+ i18n (~> 0.6)
9
+ multi_json (~> 1.0)
10
+ bson (1.6.2)
11
+ bson_ext (1.6.2)
12
+ bson (~> 1.6.2)
13
+ builder (3.0.0)
14
+ diff-lcs (1.1.3)
15
+ git (1.2.5)
16
+ i18n (0.6.0)
17
+ jeweler (1.8.3)
18
+ bundler (~> 1.0)
19
+ git (>= 1.2.5)
20
+ rake
21
+ rdoc
22
+ json (1.6.6)
23
+ metaclass (0.0.1)
24
+ mocha (0.10.5)
25
+ metaclass (~> 0.0.1)
26
+ mongo (1.6.2)
27
+ bson (~> 1.6.2)
28
+ mongoid (2.4.8)
29
+ activemodel (~> 3.1)
30
+ mongo (~> 1.3)
31
+ tzinfo (~> 0.3.22)
32
+ multi_json (1.2.0)
33
+ rake (0.9.2.2)
34
+ rdoc (3.12)
35
+ json (~> 1.4)
36
+ rspec (2.9.0)
37
+ rspec-core (~> 2.9.0)
38
+ rspec-expectations (~> 2.9.0)
39
+ rspec-mocks (~> 2.9.0)
40
+ rspec-core (2.9.0)
41
+ rspec-expectations (2.9.1)
42
+ diff-lcs (~> 1.1.3)
43
+ rspec-mocks (2.9.0)
44
+ tzinfo (0.3.33)
45
+
46
+ PLATFORMS
47
+ ruby
48
+
49
+ DEPENDENCIES
50
+ bson_ext
51
+ jeweler
52
+ mocha
53
+ mongoid (>= 2.1.0)
54
+ rake
55
+ rspec (>= 2.2.0)
data/VERSION CHANGED
@@ -1 +1 @@
1
- 0.1.0
1
+ 0.2.0
@@ -5,11 +5,11 @@
5
5
 
6
6
  Gem::Specification.new do |s|
7
7
  s.name = "gatoroid"
8
- s.version = "0.1.0"
8
+ s.version = "0.2.0"
9
9
 
10
10
  s.required_rubygems_version = Gem::Requirement.new(">= 0") if s.respond_to? :required_rubygems_version=
11
11
  s.authors = ["Kevin Haight"]
12
- s.date = "2012-04-11"
12
+ s.date = "2012-06-07"
13
13
  s.description = "Gatoroid is a way to store analytics using the poweful features of MongoDB for scalability"
14
14
  s.email = "kevinjhaight@gmail.com"
15
15
  s.extra_rdoc_files = [
@@ -18,7 +18,9 @@ Gem::Specification.new do |s|
18
18
  ]
19
19
  s.files = [
20
20
  ".rspec",
21
+ ".rvmrc",
21
22
  "Gemfile",
23
+ "Gemfile.lock",
22
24
  "LICENSE",
23
25
  "README.rdoc",
24
26
  "Rakefile",
@@ -179,7 +179,7 @@ module Mongoid #:nodoc:
179
179
  end
180
180
  end
181
181
  sdate,edate = convert_date_by_level(date,grain) # Set Dates
182
- key_hash[:date] = {"$gte" => normalize_date(sdate), "$lt" => normalize_date(edate)}
182
+ key_hash[:date] = {"$gte" => normalize_date(sdate), "$lte" => normalize_date(edate)}
183
183
  return key_hash
184
184
  end
185
185
 
@@ -1,17 +1,17 @@
1
1
  aggregate_hour:
2
2
  "function(doc) {
3
3
  d = new Date(doc.date* 1000);
4
- return {date: Date.parse((d.getMonth() + 1) + '/' + d.getDate() + '/' + d.getFullYear() + ' ' + d.getHours() + ':00:00') / 1000};
4
+ return {date: (Date.parse((d.getMonth() + 1) + '/' + d.getDate() + '/' + d.getFullYear() + ' ' + d.getHours() + ':00:00') / 1000).toFixed(0)};
5
5
  }"
6
6
 
7
7
  aggregate_day:
8
8
  "function(doc) {
9
9
  d = new Date(doc.date* 1000);
10
- return {date: Date.parse((d.getMonth() + 1) + '/' + d.getDate() + '/' + d.getFullYear()) / 1000};
10
+ return {date: (Date.parse((d.getMonth() + 1) + '/' + d.getDate() + '/' + d.getFullYear()) / 1000).toFixed(0)};
11
11
  }"
12
12
 
13
13
  aggregate_month:
14
14
  "function(doc) {
15
15
  d = new Date(doc.date* 1000);
16
- return {date: Date.parse((d.getMonth() + 1) + '/1/' + d.getFullYear()) / 1000};
16
+ return {date: (Date.parse((d.getMonth() + 1) + '/1/' + d.getFullYear()) / 1000).toFixed(0)};
17
17
  }"
@@ -25,7 +25,41 @@ module Mongoid #:nodoc:
25
25
 
26
26
  # Range - retuns a collection for a specified range on specified level
27
27
  def range(date, grain=DEFAULT_GRAIN, opts={})
28
- collection_for(date,grain,opts)
28
+ data = collection_for(date,grain,opts)
29
+ # Add Zero values for dates missing
30
+ # May want to look into a way to get mongo to do this
31
+ if date.is_a?(Range)
32
+ start_date = date.first
33
+ end_date = date.last
34
+
35
+ case grain
36
+ when HOUR
37
+ start_date = start_date.change(:sec=>0)
38
+ end_date = end_date.change(:sec=>0)
39
+ when DAY
40
+ start_date = start_date.change(:hour=>0).change(:sec=>0)
41
+ end_date = end_date.change(:hour=>0).change(:sec=>0)
42
+ when MONTH
43
+ start_date = start_date.change(:day=>1).change(:hour=>0).change(:sec=>0)
44
+ end_date = start_date.change(:day=>1).change(:hour=>0).change(:sec=>0)
45
+ end
46
+
47
+
48
+ while start_date <= end_date
49
+ if data.select{|item| item['date'].to_i == start_date.to_i}.first.nil?
50
+ data << {"date" => "#{start_date.to_i}", @for => 0}
51
+ end
52
+ case grain
53
+ when HOUR
54
+ start_date = start_date + 1.hour
55
+ when DAY
56
+ start_date = start_date + 1.day
57
+ when MONTH
58
+ start_date = start_date + 1.month
59
+ end
60
+ end
61
+ end
62
+ return data
29
63
  end
30
64
 
31
65
  end
@@ -3,22 +3,11 @@ require 'rubygems'
3
3
 
4
4
  gem "mongoid", ">= 1.9.0"
5
5
 
6
- #require 'gator/errors'
7
- #require 'gator/core_ext'
8
- #require 'gator/reader_extender'
9
- #require 'gator/readers'
10
- #require 'gator/gator'
11
- #require 'gator/aggregates'
12
- #require 'gator/gator_aggregates'
13
- #require '../lib/gator/gatoring.rb'
14
- #require File.expand_path('../gator/errors.rb', __FILE__)
15
- #require File.expand_path('../gator/reader_extender.rb', __FILE__)
16
6
  require File.expand_path('../gator/errors.rb', __FILE__)
17
7
  require File.expand_path('../gator/javascript.rb', __FILE__)
18
8
  require File.expand_path('../gator/readers.rb', __FILE__)
19
9
  require File.expand_path('../gator/gatorer.rb', __FILE__)
20
10
  require File.expand_path('../gator/gator.rb', __FILE__)
21
- #require File.expand_path('../../lib/gator.rb', __FILE__)
22
11
 
23
12
  module Mongoid
24
13
  module Gator
@@ -100,15 +100,15 @@ describe Mongoid::Gator do
100
100
  end
101
101
 
102
102
  it "should have 1 record using range method for today and yesterday at day grain" do
103
- @obj.visits.range(Time.now..Time.now + 1.day,Mongoid::Gator::Readers::DAY, :siteid=>100).should have(1).record
103
+ @obj.visits.range(Time.now..Time.now + 1.day,Mongoid::Gator::Readers::DAY, :siteid=>100).should have(2).record
104
104
  end
105
105
 
106
106
  it "should have 1 record using range method for today and yesterday at hour grain" do
107
- @obj.visits.range(Time.now..Time.now + 1.day,Mongoid::Gator::Readers::HOUR, :siteid=>100).should have(1).record
107
+ @obj.visits.range(Time.now.change(:hour=>0).change(:sec=>0)..Time.now.change(:hour=>0).change(:sec=>0) + 1.day,Mongoid::Gator::Readers::HOUR, :siteid=>100).should have(25).record
108
108
  end
109
109
 
110
110
  it "should have 1 record using range method for today and yesterday at month grain" do
111
- @obj.visits.range(Time.now..Time.now + 1.day,Mongoid::Gator::Readers::HOUR, :siteid=>100).should have(1).record
111
+ @obj.visits.range(Time.now..Time.now + 1.day,Mongoid::Gator::Readers::MONTH, :siteid=>100).should have(1).record
112
112
  end
113
113
 
114
114
  it "should reset value to zero" do
@@ -178,15 +178,15 @@ describe Mongoid::Gator do
178
178
  end
179
179
 
180
180
  it "should have 1 record using range method for today and yesterday at day grain" do
181
- Test.visits.range(Time.now..Time.now + 1.day,Mongoid::Gator::Readers::DAY, :siteid=>200).should have(1).record
181
+ Test.visits.range(Time.now..Time.now + 1.day,Mongoid::Gator::Readers::DAY, :siteid=>200).should have(2).record
182
182
  end
183
183
 
184
184
  it "should have 1 record using range method for today and yesterday at hour grain" do
185
- Test.visits.range(Time.now..Time.now + 1.day,Mongoid::Gator::Readers::HOUR, :siteid=>200).should have(1).record
185
+ Test.visits.range(Time.now.change(:hour=>0).change(:sec=>0)..Time.now.change(:hour=>0).change(:sec=>0) + 1.day,Mongoid::Gator::Readers::HOUR, :siteid=>200).should have(25).record
186
186
  end
187
187
 
188
188
  it "should have 1 record using range method for today and yesterday at month grain" do
189
- Test.visits.range(Time.now..Time.now + 1.day,Mongoid::Gator::Readers::HOUR, :siteid=>200).should have(1).record
189
+ Test.visits.range(Time.now.change(:hour=>0).change(:sec=>0)..Time.now.change(:hour=>0).change(:sec=>0) + 1.day,Mongoid::Gator::Readers::HOUR, :siteid=>200).should have(25).record
190
190
  end
191
191
 
192
192
  it "should reset value to zero" do
metadata CHANGED
@@ -1,7 +1,7 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: gatoroid
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.1.0
4
+ version: 0.2.0
5
5
  prerelease:
6
6
  platform: ruby
7
7
  authors:
@@ -9,11 +9,11 @@ authors:
9
9
  autorequire:
10
10
  bindir: bin
11
11
  cert_chain: []
12
- date: 2012-04-11 00:00:00.000000000 Z
12
+ date: 2012-06-07 00:00:00.000000000 Z
13
13
  dependencies:
14
14
  - !ruby/object:Gem::Dependency
15
15
  name: mongoid
16
- requirement: &2164561420 !ruby/object:Gem::Requirement
16
+ requirement: &2152378340 !ruby/object:Gem::Requirement
17
17
  none: false
18
18
  requirements:
19
19
  - - ! '>='
@@ -21,10 +21,10 @@ dependencies:
21
21
  version: 2.1.0
22
22
  type: :runtime
23
23
  prerelease: false
24
- version_requirements: *2164561420
24
+ version_requirements: *2152378340
25
25
  - !ruby/object:Gem::Dependency
26
26
  name: rake
27
- requirement: &2164560940 !ruby/object:Gem::Requirement
27
+ requirement: &2152377740 !ruby/object:Gem::Requirement
28
28
  none: false
29
29
  requirements:
30
30
  - - ! '>='
@@ -32,10 +32,10 @@ dependencies:
32
32
  version: '0'
33
33
  type: :development
34
34
  prerelease: false
35
- version_requirements: *2164560940
35
+ version_requirements: *2152377740
36
36
  - !ruby/object:Gem::Dependency
37
37
  name: jeweler
38
- requirement: &2164560400 !ruby/object:Gem::Requirement
38
+ requirement: &2152377160 !ruby/object:Gem::Requirement
39
39
  none: false
40
40
  requirements:
41
41
  - - ! '>='
@@ -43,10 +43,10 @@ dependencies:
43
43
  version: '0'
44
44
  type: :development
45
45
  prerelease: false
46
- version_requirements: *2164560400
46
+ version_requirements: *2152377160
47
47
  - !ruby/object:Gem::Dependency
48
48
  name: rspec
49
- requirement: &2164559640 !ruby/object:Gem::Requirement
49
+ requirement: &2152376520 !ruby/object:Gem::Requirement
50
50
  none: false
51
51
  requirements:
52
52
  - - ! '>='
@@ -54,10 +54,10 @@ dependencies:
54
54
  version: 2.2.0
55
55
  type: :development
56
56
  prerelease: false
57
- version_requirements: *2164559640
57
+ version_requirements: *2152376520
58
58
  - !ruby/object:Gem::Dependency
59
59
  name: mocha
60
- requirement: &2164558740 !ruby/object:Gem::Requirement
60
+ requirement: &2152375940 !ruby/object:Gem::Requirement
61
61
  none: false
62
62
  requirements:
63
63
  - - ! '>='
@@ -65,10 +65,10 @@ dependencies:
65
65
  version: '0'
66
66
  type: :development
67
67
  prerelease: false
68
- version_requirements: *2164558740
68
+ version_requirements: *2152375940
69
69
  - !ruby/object:Gem::Dependency
70
70
  name: bson_ext
71
- requirement: &2164557900 !ruby/object:Gem::Requirement
71
+ requirement: &2152375340 !ruby/object:Gem::Requirement
72
72
  none: false
73
73
  requirements:
74
74
  - - ! '>='
@@ -76,7 +76,7 @@ dependencies:
76
76
  version: '0'
77
77
  type: :development
78
78
  prerelease: false
79
- version_requirements: *2164557900
79
+ version_requirements: *2152375340
80
80
  description: Gatoroid is a way to store analytics using the poweful features of MongoDB
81
81
  for scalability
82
82
  email: kevinjhaight@gmail.com
@@ -87,7 +87,9 @@ extra_rdoc_files:
87
87
  - README.rdoc
88
88
  files:
89
89
  - .rspec
90
+ - .rvmrc
90
91
  - Gemfile
92
+ - Gemfile.lock
91
93
  - LICENSE
92
94
  - README.rdoc
93
95
  - Rakefile