requires_approval 1.0.4 → 1.0.5

Sign up to get free protection for your applications and to get access to all the features.
data/VERSION CHANGED
@@ -1 +1 @@
1
- 1.0.4
1
+ 1.0.5
@@ -38,8 +38,10 @@ module RequiresApproval
38
38
  end
39
39
 
40
40
  # if we have approved all requested changes, make our latest
41
- # unapproved version approved
42
- unless self.has_pending_changes?
41
+ # unapproved version approved -
42
+ # this is ALWAYS true for a new record even though its pending_changes
43
+ # hash is forced to have values
44
+ if self.is_first_version? || self.no_pending_changes?
43
45
  self.latest_unapproved_version.update_attribute(:is_approved, true)
44
46
  else
45
47
  # makes our latest_unapproved_version approved and
@@ -89,6 +91,16 @@ module RequiresApproval
89
91
  self.pending_changes.present?
90
92
  end
91
93
 
94
+ # are we the first version?
95
+ def is_first_version?
96
+ !self.has_approved_version?
97
+ end
98
+
99
+ # returns true if there are no changes to approve
100
+ def no_pending_changes?
101
+ !self.has_pending_changes?
102
+ end
103
+
92
104
  # the changes users have requested since the last approval
93
105
  def pending_changes
94
106
  return {} if self.latest_unapproved_version.blank?
@@ -96,12 +108,17 @@ module RequiresApproval
96
108
  ret = {}
97
109
  # check each field requiring approval
98
110
  self.fields_requiring_approval.each do |field|
111
+
99
112
  # if it is the same in the unapproved as in the parent table
100
113
  # we skip it
101
- unless self.send(field) == self.latest_unapproved_version.send(field)
114
+ if self.is_first_version? ||
115
+ self.send(field) != self.latest_unapproved_version.send(field)
116
+
102
117
  # otherwise we get the change set
103
118
  ret[field] = {
104
- "was" => self.send(field),
119
+ # our first version is always nil, regardless of the
120
+ # defaults in that table
121
+ "was" => self.is_first_version? ? nil : self.send(field),
105
122
  "became" => self.latest_unapproved_version.send(field)
106
123
  }
107
124
  end
@@ -5,11 +5,11 @@
5
5
 
6
6
  Gem::Specification.new do |s|
7
7
  s.name = "requires_approval"
8
- s.version = "1.0.4"
8
+ s.version = "1.0.5"
9
9
 
10
10
  s.required_rubygems_version = Gem::Requirement.new(">= 0") if s.respond_to? :required_rubygems_version=
11
11
  s.authors = ["Dan Langevin"]
12
- s.date = "2012-10-02"
12
+ s.date = "2012-10-12"
13
13
  s.description = "Gem to handle versioning and things that require approval"
14
14
  s.email = "dan.langevin@lifebooker.com"
15
15
  s.extra_rdoc_files = [
@@ -13,17 +13,44 @@ describe RequiresApproval do
13
13
  t.string(:first_name)
14
14
  t.string(:last_name)
15
15
  t.date(:birthday)
16
+ t.boolean(:is_alive, :default => true)
16
17
  t.timestamps
17
18
  end
18
19
 
19
20
  class User < ActiveRecord::Base
20
- requires_approval_for(:first_name, :last_name)
21
+ requires_approval_for(:first_name, :last_name, :is_alive)
21
22
  end
22
23
 
23
24
  User.prepare_tables_for_requires_approval
24
25
 
25
26
  end
26
27
 
28
+ context "#pending_changes" do
29
+
30
+ it "gives back all attributes when it is a new record" do
31
+ user = User.create(
32
+ :first_name => "Dan",
33
+ :last_name => "Test",
34
+ :is_alive => true
35
+ )
36
+ user.pending_changes.should eql({
37
+ "first_name" => {
38
+ "was" => nil,
39
+ "became" => "Dan"
40
+ },
41
+ "last_name" => {
42
+ "was" => nil,
43
+ "became" => "Test"
44
+ },
45
+ "is_alive" => {
46
+ "was" => nil,
47
+ "became" => true
48
+ }
49
+ })
50
+ end
51
+
52
+ end
53
+
27
54
 
28
55
  context "setup" do
29
56
 
@@ -317,7 +344,7 @@ describe RequiresApproval do
317
344
  :last_name => "Langevin",
318
345
  :birthday => Date.today
319
346
  )
320
- user.approve_attributes(:first_name, :last_name)
347
+ user.approve_attributes(:first_name, :last_name, :is_alive)
321
348
  user.update_attributes({
322
349
  :first_name => "New Name",
323
350
  :last_name => "New Last Name"
metadata CHANGED
@@ -1,7 +1,7 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: requires_approval
3
3
  version: !ruby/object:Gem::Version
4
- version: 1.0.4
4
+ version: 1.0.5
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-10-02 00:00:00.000000000 Z
12
+ date: 2012-10-12 00:00:00.000000000 Z
13
13
  dependencies:
14
14
  - !ruby/object:Gem::Dependency
15
15
  name: activerecord
16
- requirement: &2156869340 !ruby/object:Gem::Requirement
16
+ requirement: &2168522820 !ruby/object:Gem::Requirement
17
17
  none: false
18
18
  requirements:
19
19
  - - ~>
@@ -21,10 +21,10 @@ dependencies:
21
21
  version: '3'
22
22
  type: :runtime
23
23
  prerelease: false
24
- version_requirements: *2156869340
24
+ version_requirements: *2168522820
25
25
  - !ruby/object:Gem::Dependency
26
26
  name: activesupport
27
- requirement: &2156866560 !ruby/object:Gem::Requirement
27
+ requirement: &2168521560 !ruby/object:Gem::Requirement
28
28
  none: false
29
29
  requirements:
30
30
  - - ~>
@@ -32,10 +32,10 @@ dependencies:
32
32
  version: '3'
33
33
  type: :runtime
34
34
  prerelease: false
35
- version_requirements: *2156866560
35
+ version_requirements: *2168521560
36
36
  - !ruby/object:Gem::Dependency
37
37
  name: bundler
38
- requirement: &2156865100 !ruby/object:Gem::Requirement
38
+ requirement: &2168520320 !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: *2156865100
46
+ version_requirements: *2168520320
47
47
  - !ruby/object:Gem::Dependency
48
48
  name: guard-rspec
49
- requirement: &2156857020 !ruby/object:Gem::Requirement
49
+ requirement: &2168518400 !ruby/object:Gem::Requirement
50
50
  none: false
51
51
  requirements:
52
52
  - - ! '>='
@@ -54,10 +54,10 @@ dependencies:
54
54
  version: '0'
55
55
  type: :development
56
56
  prerelease: false
57
- version_requirements: *2156857020
57
+ version_requirements: *2168518400
58
58
  - !ruby/object:Gem::Dependency
59
59
  name: guard-bundler
60
- requirement: &2156854060 !ruby/object:Gem::Requirement
60
+ requirement: &2168516160 !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: *2156854060
68
+ version_requirements: *2168516160
69
69
  - !ruby/object:Gem::Dependency
70
70
  name: guard-spork
71
- requirement: &2156850320 !ruby/object:Gem::Requirement
71
+ requirement: &2168514860 !ruby/object:Gem::Requirement
72
72
  none: false
73
73
  requirements:
74
74
  - - ! '>='
@@ -76,10 +76,10 @@ dependencies:
76
76
  version: '0'
77
77
  type: :development
78
78
  prerelease: false
79
- version_requirements: *2156850320
79
+ version_requirements: *2168514860
80
80
  - !ruby/object:Gem::Dependency
81
81
  name: jeweler
82
- requirement: &2156841340 !ruby/object:Gem::Requirement
82
+ requirement: &2168513920 !ruby/object:Gem::Requirement
83
83
  none: false
84
84
  requirements:
85
85
  - - ~>
@@ -87,10 +87,10 @@ dependencies:
87
87
  version: 1.8.3
88
88
  type: :development
89
89
  prerelease: false
90
- version_requirements: *2156841340
90
+ version_requirements: *2168513920
91
91
  - !ruby/object:Gem::Dependency
92
92
  name: mocha
93
- requirement: &2156838740 !ruby/object:Gem::Requirement
93
+ requirement: &2168512820 !ruby/object:Gem::Requirement
94
94
  none: false
95
95
  requirements:
96
96
  - - ! '>='
@@ -98,10 +98,10 @@ dependencies:
98
98
  version: '0'
99
99
  type: :development
100
100
  prerelease: false
101
- version_requirements: *2156838740
101
+ version_requirements: *2168512820
102
102
  - !ruby/object:Gem::Dependency
103
103
  name: rdoc
104
- requirement: &2156835720 !ruby/object:Gem::Requirement
104
+ requirement: &2168511880 !ruby/object:Gem::Requirement
105
105
  none: false
106
106
  requirements:
107
107
  - - ! '>='
@@ -109,10 +109,10 @@ dependencies:
109
109
  version: '0'
110
110
  type: :development
111
111
  prerelease: false
112
- version_requirements: *2156835720
112
+ version_requirements: *2168511880
113
113
  - !ruby/object:Gem::Dependency
114
114
  name: rspec
115
- requirement: &2156833420 !ruby/object:Gem::Requirement
115
+ requirement: &2168510840 !ruby/object:Gem::Requirement
116
116
  none: false
117
117
  requirements:
118
118
  - - ! '>='
@@ -120,10 +120,10 @@ dependencies:
120
120
  version: '0'
121
121
  type: :development
122
122
  prerelease: false
123
- version_requirements: *2156833420
123
+ version_requirements: *2168510840
124
124
  - !ruby/object:Gem::Dependency
125
125
  name: ruby-debug19
126
- requirement: &2156830360 !ruby/object:Gem::Requirement
126
+ requirement: &2168509940 !ruby/object:Gem::Requirement
127
127
  none: false
128
128
  requirements:
129
129
  - - ! '>='
@@ -131,10 +131,10 @@ dependencies:
131
131
  version: '0'
132
132
  type: :development
133
133
  prerelease: false
134
- version_requirements: *2156830360
134
+ version_requirements: *2168509940
135
135
  - !ruby/object:Gem::Dependency
136
136
  name: sqlite3
137
- requirement: &2156827980 !ruby/object:Gem::Requirement
137
+ requirement: &2168508940 !ruby/object:Gem::Requirement
138
138
  none: false
139
139
  requirements:
140
140
  - - ! '>='
@@ -142,10 +142,10 @@ dependencies:
142
142
  version: '0'
143
143
  type: :development
144
144
  prerelease: false
145
- version_requirements: *2156827980
145
+ version_requirements: *2168508940
146
146
  - !ruby/object:Gem::Dependency
147
147
  name: yard
148
- requirement: &2156729980 !ruby/object:Gem::Requirement
148
+ requirement: &2168508200 !ruby/object:Gem::Requirement
149
149
  none: false
150
150
  requirements:
151
151
  - - ! '>='
@@ -153,7 +153,7 @@ dependencies:
153
153
  version: '0'
154
154
  type: :development
155
155
  prerelease: false
156
- version_requirements: *2156729980
156
+ version_requirements: *2168508200
157
157
  description: Gem to handle versioning and things that require approval
158
158
  email: dan.langevin@lifebooker.com
159
159
  executables: []
@@ -193,7 +193,7 @@ required_ruby_version: !ruby/object:Gem::Requirement
193
193
  version: '0'
194
194
  segments:
195
195
  - 0
196
- hash: -1714695095380622902
196
+ hash: 2029788370061406567
197
197
  required_rubygems_version: !ruby/object:Gem::Requirement
198
198
  none: false
199
199
  requirements: