drafter 0.2.2 → 0.2.3

Sign up to get free protection for your applications and to get access to all the features.
data/VERSION CHANGED
@@ -1 +1 @@
1
- 0.2.2
1
+ 0.2.3
data/drafter.gemspec CHANGED
@@ -5,11 +5,11 @@
5
5
 
6
6
  Gem::Specification.new do |s|
7
7
  s.name = "drafter"
8
- s.version = "0.2.2"
8
+ s.version = "0.2.3"
9
9
 
10
10
  s.required_rubygems_version = Gem::Requirement.new(">= 0") if s.respond_to? :required_rubygems_version=
11
11
  s.authors = ["futurechimp"]
12
- s.date = "2012-08-21"
12
+ s.date = "2012-08-22"
13
13
  s.description = "A"
14
14
  s.email = "dave.hrycyszyn@headlondon.com"
15
15
  s.extra_rdoc_files = [
@@ -14,10 +14,15 @@ module Drafter
14
14
  def save_draft
15
15
  if self.valid?
16
16
  attrs = self.attributes
17
- uploads = build_draft_uploads(attrs)
18
- self.build_draft(:data => attrs)
17
+ if self.draft
18
+ draft.data = attrs
19
+ else
20
+ self.build_draft(:data => attrs)
21
+ end
22
+ # https://github.com/rails/rails/issues/617
23
+ draft.draftable_type = self.class.to_s
19
24
  self.draft.save!
20
- self.draft.draft_uploads << uploads
25
+ uploads = build_draft_uploads(attrs)
21
26
  self.draft
22
27
  end
23
28
  end
@@ -33,7 +38,7 @@ module Drafter
33
38
  draft_uploads = []
34
39
  attrs.keys.each do |key|
35
40
  if self.send(key).is_a?(CarrierWave::Uploader::Base)
36
- draft_uploads << build_draft_upload(key)
41
+ self.draft.draft_uploads << build_draft_upload(key)
37
42
  end
38
43
  end
39
44
  draft_uploads
@@ -49,8 +54,11 @@ module Drafter
49
54
  def build_draft_upload(key)
50
55
  cw_uploader = self.send(key)
51
56
  file = File.new(cw_uploader.file.path) if cw_uploader.file
52
- draft_upload = DraftUpload.new(
53
- :file_data => file, :draftable_mount_column => key)
57
+ existing_upload = self.draft.draft_uploads.where(:draftable_mount_column => key).first
58
+ draft_upload = existing_upload.nil? ? DraftUpload.new : existing_upload
59
+ draft_upload.file_data = file
60
+ draft_upload.draftable_mount_column = key
61
+ draft_upload
54
62
  end
55
63
 
56
64
  end
@@ -39,6 +39,30 @@ class TestCreation < Minitest::Unit::TestCase
39
39
  assert_equal(1, @draft.draft_uploads.length)
40
40
  assert_equal(DraftUpload.last, @draft.draft_uploads.first)
41
41
  end
42
+
43
+ describe "a second time" do
44
+ before do
45
+ @article_count = Article.count
46
+ @draft_count = Draft.count
47
+ @draft_upload_count = DraftUpload.count
48
+ @article.text = "updated text"
49
+ @article.upload = file_upload("bar.txt")
50
+ @draft = @article.save_draft
51
+ end
52
+
53
+ it "should not create a new Article" do
54
+ assert_equal(@article_count, Article.count)
55
+ end
56
+
57
+ it "should update the Draft in place" do
58
+ assert_equal(@draft_count, Draft.count)
59
+ end
60
+
61
+ it "should update the DraftUpload in place" do
62
+ assert_equal(@draft_upload_count, DraftUpload.count)
63
+ end
64
+
65
+ end
42
66
  end
43
67
 
44
68
  describe "an existing draftable article" do
metadata CHANGED
@@ -1,7 +1,7 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: drafter
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.2.2
4
+ version: 0.2.3
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-08-21 00:00:00.000000000Z
12
+ date: 2012-08-22 00:00:00.000000000Z
13
13
  dependencies:
14
14
  - !ruby/object:Gem::Dependency
15
15
  name: activerecord
16
- requirement: &2172805820 !ruby/object:Gem::Requirement
16
+ requirement: &2171791000 !ruby/object:Gem::Requirement
17
17
  none: false
18
18
  requirements:
19
19
  - - ! '>='
@@ -21,10 +21,10 @@ dependencies:
21
21
  version: '0'
22
22
  type: :runtime
23
23
  prerelease: false
24
- version_requirements: *2172805820
24
+ version_requirements: *2171791000
25
25
  - !ruby/object:Gem::Dependency
26
26
  name: sqlite3
27
- requirement: &2172804980 !ruby/object:Gem::Requirement
27
+ requirement: &2171790300 !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: *2172804980
35
+ version_requirements: *2171790300
36
36
  - !ruby/object:Gem::Dependency
37
37
  name: debugger
38
- requirement: &2172804380 !ruby/object:Gem::Requirement
38
+ requirement: &2171789580 !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: *2172804380
46
+ version_requirements: *2171789580
47
47
  - !ruby/object:Gem::Dependency
48
48
  name: minitest
49
- requirement: &2172803900 !ruby/object:Gem::Requirement
49
+ requirement: &2171788600 !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: *2172803900
57
+ version_requirements: *2171788600
58
58
  - !ruby/object:Gem::Dependency
59
59
  name: bundler
60
- requirement: &2172803380 !ruby/object:Gem::Requirement
60
+ requirement: &2171788060 !ruby/object:Gem::Requirement
61
61
  none: false
62
62
  requirements:
63
63
  - - ~>
@@ -65,10 +65,10 @@ dependencies:
65
65
  version: 1.0.0
66
66
  type: :development
67
67
  prerelease: false
68
- version_requirements: *2172803380
68
+ version_requirements: *2171788060
69
69
  - !ruby/object:Gem::Dependency
70
70
  name: jeweler
71
- requirement: &2172802820 !ruby/object:Gem::Requirement
71
+ requirement: &2171787360 !ruby/object:Gem::Requirement
72
72
  none: false
73
73
  requirements:
74
74
  - - ~>
@@ -76,10 +76,10 @@ dependencies:
76
76
  version: 1.6.4
77
77
  type: :development
78
78
  prerelease: false
79
- version_requirements: *2172802820
79
+ version_requirements: *2171787360
80
80
  - !ruby/object:Gem::Dependency
81
81
  name: rcov
82
- requirement: &2172802280 !ruby/object:Gem::Requirement
82
+ requirement: &2171786560 !ruby/object:Gem::Requirement
83
83
  none: false
84
84
  requirements:
85
85
  - - ! '>='
@@ -87,10 +87,10 @@ dependencies:
87
87
  version: '0'
88
88
  type: :development
89
89
  prerelease: false
90
- version_requirements: *2172802280
90
+ version_requirements: *2171786560
91
91
  - !ruby/object:Gem::Dependency
92
92
  name: turn
93
- requirement: &2172801760 !ruby/object:Gem::Requirement
93
+ requirement: &2171786040 !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: *2172801760
101
+ version_requirements: *2171786040
102
102
  - !ruby/object:Gem::Dependency
103
103
  name: carrierwave
104
- requirement: &2172801160 !ruby/object:Gem::Requirement
104
+ requirement: &2171785520 !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: *2172801160
112
+ version_requirements: *2171785520
113
113
  - !ruby/object:Gem::Dependency
114
114
  name: minitest-rails-shoulda
115
- requirement: &2172800560 !ruby/object:Gem::Requirement
115
+ requirement: &2171784860 !ruby/object:Gem::Requirement
116
116
  none: false
117
117
  requirements:
118
118
  - - ! '>='
@@ -120,7 +120,7 @@ dependencies:
120
120
  version: '0'
121
121
  type: :development
122
122
  prerelease: false
123
- version_requirements: *2172800560
123
+ version_requirements: *2171784860
124
124
  description: A
125
125
  email: dave.hrycyszyn@headlondon.com
126
126
  executables: []
@@ -173,7 +173,7 @@ required_ruby_version: !ruby/object:Gem::Requirement
173
173
  version: '0'
174
174
  segments:
175
175
  - 0
176
- hash: -2617672663622739077
176
+ hash: 3583912681300201080
177
177
  required_rubygems_version: !ruby/object:Gem::Requirement
178
178
  none: false
179
179
  requirements: