datashift 0.15.0 → 0.16.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +7 -0
- data/README.markdown +91 -55
- data/VERSION +1 -1
- data/datashift.gemspec +8 -23
- data/lib/applications/jexcel_file.rb +1 -2
- data/lib/datashift.rb +34 -15
- data/lib/datashift/column_packer.rb +98 -34
- data/lib/datashift/data_transforms.rb +83 -0
- data/lib/datashift/delimiters.rb +58 -10
- data/lib/datashift/excel_base.rb +123 -0
- data/lib/datashift/exceptions.rb +45 -7
- data/lib/datashift/load_object.rb +25 -0
- data/lib/datashift/mapping_service.rb +91 -0
- data/lib/datashift/method_detail.rb +40 -62
- data/lib/datashift/method_details_manager.rb +18 -2
- data/lib/datashift/method_dictionary.rb +27 -10
- data/lib/datashift/method_mapper.rb +49 -41
- data/lib/datashift/model_mapper.rb +42 -22
- data/lib/datashift/populator.rb +258 -143
- data/lib/datashift/thor_base.rb +38 -0
- data/lib/exporters/csv_exporter.rb +57 -145
- data/lib/exporters/excel_exporter.rb +73 -60
- data/lib/generators/csv_generator.rb +65 -5
- data/lib/generators/generator_base.rb +69 -3
- data/lib/generators/mapping_generator.rb +112 -0
- data/lib/helpers/core_ext/csv_file.rb +33 -0
- data/lib/loaders/csv_loader.rb +41 -39
- data/lib/loaders/excel_loader.rb +130 -116
- data/lib/loaders/loader_base.rb +190 -146
- data/lib/loaders/paperclip/attachment_loader.rb +4 -4
- data/lib/loaders/paperclip/datashift_paperclip.rb +5 -3
- data/lib/loaders/paperclip/image_loading.rb +9 -7
- data/lib/loaders/reporter.rb +17 -8
- data/lib/thor/export.thor +12 -13
- data/lib/thor/generate.thor +1 -9
- data/lib/thor/import.thor +13 -24
- data/lib/thor/mapping.thor +65 -0
- data/spec/Gemfile +13 -11
- data/spec/Gemfile.lock +98 -93
- data/spec/csv_exporter_spec.rb +104 -99
- data/spec/csv_generator_spec.rb +159 -0
- data/spec/csv_loader_spec.rb +197 -16
- data/spec/datashift_spec.rb +9 -0
- data/spec/excel_exporter_spec.rb +149 -58
- data/spec/excel_generator_spec.rb +35 -44
- data/spec/excel_loader_spec.rb +196 -178
- data/spec/excel_spec.rb +8 -5
- data/spec/loader_base_spec.rb +47 -7
- data/spec/mapping_spec.rb +117 -0
- data/spec/method_dictionary_spec.rb +24 -11
- data/spec/method_mapper_spec.rb +5 -7
- data/spec/model_mapper_spec.rb +41 -0
- data/spec/paperclip_loader_spec.rb +3 -6
- data/spec/populator_spec.rb +48 -14
- data/spec/spec_helper.rb +85 -73
- data/spec/thor_spec.rb +40 -5
- metadata +93 -86
- data/lib/applications/excel_base.rb +0 -63
data/spec/excel_spec.rb
CHANGED
@@ -76,7 +76,7 @@ describe 'Excel Proxy' do
|
|
76
76
|
@excel.create_worksheet( :name => "autechre")
|
77
77
|
@excel.create_worksheet( :name => "swarms")
|
78
78
|
|
79
|
-
@excel.worksheets.
|
79
|
+
expect(@excel.worksheets.size).to eq 4
|
80
80
|
end
|
81
81
|
|
82
82
|
it "can access a worksheet by index" do
|
@@ -175,9 +175,12 @@ describe 'Excel Proxy' do
|
|
175
175
|
end
|
176
176
|
|
177
177
|
|
178
|
-
it "can support bools" do
|
179
|
-
|
180
|
-
|
178
|
+
#it "can support bools" do
|
179
|
+
# pending "reading back value sometimes returns "" when cell was set to false"
|
180
|
+
|
181
|
+
# sheet = @excel.create_worksheet
|
182
|
+
|
183
|
+
#end
|
181
184
|
|
182
185
|
it "can write an Excel file" do
|
183
186
|
@excel = Excel.new
|
@@ -193,7 +196,7 @@ describe 'Excel Proxy' do
|
|
193
196
|
|
194
197
|
@excel.write( expected )
|
195
198
|
|
196
|
-
File.exists?(expected).
|
199
|
+
expect(File.exists?(expected)).to eq true
|
197
200
|
|
198
201
|
end
|
199
202
|
end
|
data/spec/loader_base_spec.rb
CHANGED
@@ -11,18 +11,16 @@ require 'erb'
|
|
11
11
|
|
12
12
|
describe 'LoaderBase' do
|
13
13
|
|
14
|
-
include_context "ActiveRecordTestModelsConnected"
|
15
|
-
|
16
|
-
include_context "ClearAndPopulateProject"
|
17
|
-
|
18
14
|
before(:each) do
|
19
15
|
@loader = DataShift::LoaderBase.new(Project)
|
20
16
|
end
|
17
|
+
|
18
|
+
let(:loader) {DataShift::LoaderBase.new(Project) }
|
21
19
|
|
22
20
|
it "should be able to create a new loader and load object" do
|
23
21
|
@loader.load_object.should_not be_nil
|
24
22
|
@loader.load_object.should be_is_a(Project)
|
25
|
-
@loader.load_object.new_record
|
23
|
+
expect(@loader.load_object.new_record?).to eq true
|
26
24
|
end
|
27
25
|
|
28
26
|
|
@@ -33,7 +31,7 @@ describe 'LoaderBase' do
|
|
33
31
|
|
34
32
|
@loader.find_and_process(column, row)
|
35
33
|
|
36
|
-
@loader.load_object.errors.
|
34
|
+
expect(@loader.load_object.errors.size).to eq 0
|
37
35
|
end
|
38
36
|
|
39
37
|
it "should process a string field against an assigment method detail" do
|
@@ -114,7 +112,7 @@ describe 'LoaderBase' do
|
|
114
112
|
it "should be able to mark a load attempt as a failure" do
|
115
113
|
|
116
114
|
failed_count = @loader.failed_count
|
117
|
-
@loader.load_object.new_record
|
115
|
+
expect(@loader.load_object.new_record?).to eq true
|
118
116
|
|
119
117
|
@loader.load_object.save!
|
120
118
|
|
@@ -122,5 +120,47 @@ describe 'LoaderBase' do
|
|
122
120
|
|
123
121
|
@loader.failed_count.should == failed_count + 1
|
124
122
|
end
|
123
|
+
|
124
|
+
|
125
|
+
it "should be able to set a plain default value" do
|
126
|
+
|
127
|
+
loader.configure_from( ifixture_file('ProjectsDefaults.yml') )
|
128
|
+
|
129
|
+
loader.process_defaults
|
130
|
+
|
131
|
+
expect(loader.load_object.value_as_string).to eq "Default Project Value"
|
132
|
+
|
133
|
+
end
|
134
|
+
|
135
|
+
it "should be able to set an association default value" do
|
136
|
+
|
137
|
+
skip "pending more work on Populator to make this advanced lookup style work"
|
138
|
+
|
139
|
+
loader.configure_from( ifixture_file('ProjectsDefaults.yml') )
|
140
|
+
|
141
|
+
loader.process_defaults
|
142
|
+
|
143
|
+
expect(loader.load_object.categories.first.reference).to eq "category_002"
|
144
|
+
|
145
|
+
end
|
146
|
+
|
147
|
+
|
148
|
+
it "should be able to set a eval default value" do
|
149
|
+
|
150
|
+
loader.configure_from( ifixture_file('ProjectsDefaults.yml') )
|
151
|
+
|
152
|
+
puts loader.load_object.inspect
|
153
|
+
puts loader.load_object.value_as_datetime.inspect
|
154
|
+
|
155
|
+
loader.process_defaults
|
156
|
+
|
157
|
+
puts loader.load_object.inspect
|
158
|
+
puts loader.load_object.value_as_datetime.inspect
|
159
|
+
|
160
|
+
expect(loader.load_object.value_as_datetime).to be
|
161
|
+
expect(loader.load_object.value_as_datetime).to be <= Time.now.to_s(:db)
|
162
|
+
end
|
163
|
+
|
164
|
+
|
125
165
|
|
126
166
|
end
|
@@ -0,0 +1,117 @@
|
|
1
|
+
# Copyright:: (c) Autotelik Media Ltd 2015
|
2
|
+
# Author :: Tom Statter
|
3
|
+
# Date :: Aug 2015
|
4
|
+
# License:: MIT
|
5
|
+
#
|
6
|
+
# Details:: Specs for Mapping aspects
|
7
|
+
# Provides automatic mapping between different system's column headings
|
8
|
+
#
|
9
|
+
require File.join(File.dirname(__FILE__), 'spec_helper')
|
10
|
+
|
11
|
+
require 'mapping_generator'
|
12
|
+
|
13
|
+
describe 'Mapping Services' do
|
14
|
+
|
15
|
+
before(:all) do
|
16
|
+
DataShift::MethodDictionary.clear
|
17
|
+
DataShift::MethodDictionary.find_operators( Project )
|
18
|
+
end
|
19
|
+
|
20
|
+
before(:each) do
|
21
|
+
load File.join( rspec_datashift_root,'lib/thor/mapping.thor')
|
22
|
+
end
|
23
|
+
|
24
|
+
|
25
|
+
it "should generate an empty mapping doc" do
|
26
|
+
|
27
|
+
f = result_file("mapper.yaml")
|
28
|
+
|
29
|
+
mapper = DataShift::MappingGenerator.new(f)
|
30
|
+
|
31
|
+
mapper.generate(nil, {:file => f} )
|
32
|
+
|
33
|
+
expect(File.exists?(f)).to be true
|
34
|
+
end
|
35
|
+
|
36
|
+
|
37
|
+
it "should generate a mapping doc with pre supplied title" do
|
38
|
+
|
39
|
+
f = result_file("mapper.yaml")
|
40
|
+
|
41
|
+
mapper = DataShift::MappingGenerator.new(f)
|
42
|
+
|
43
|
+
mapper.generate(nil, {:file => f} )
|
44
|
+
|
45
|
+
expect(File.exists?(f)).to be true
|
46
|
+
end
|
47
|
+
|
48
|
+
it "should generate a populated mapping doc for a class" do
|
49
|
+
|
50
|
+
f = result_file("mapper_project.yaml")
|
51
|
+
|
52
|
+
mapper = DataShift::MappingGenerator.new(f)
|
53
|
+
|
54
|
+
mapper.generate( Project, {:file => f} )
|
55
|
+
|
56
|
+
expect(File.exists?(f)).to be true
|
57
|
+
end
|
58
|
+
|
59
|
+
it "should be able to create a mapping service for a class" do
|
60
|
+
mapping_services = DataShift::MappingService.new(Project)
|
61
|
+
|
62
|
+
expect(mapping_services).to be
|
63
|
+
end
|
64
|
+
|
65
|
+
it "should be able to read a mapping" do
|
66
|
+
|
67
|
+
f = result_file("mapping_service_project.yaml")
|
68
|
+
|
69
|
+
mapper = DataShift::MappingGenerator.new(f)
|
70
|
+
|
71
|
+
mapper.generate(Project, {:file => f} )
|
72
|
+
|
73
|
+
expect(File.exists?(f)).to be true
|
74
|
+
|
75
|
+
mapping_service = DataShift::MappingService.new(Project)
|
76
|
+
|
77
|
+
mapping_service.read(f)
|
78
|
+
|
79
|
+
expect(mapping_service.map_file_name).to eq f
|
80
|
+
|
81
|
+
expect(mapping_service.raw_data).to_not be_empty
|
82
|
+
expect(mapping_service.yaml_data).to_not be_empty
|
83
|
+
|
84
|
+
expect(mapping_service.mapping_entry).to be_a OpenStruct
|
85
|
+
|
86
|
+
# puts mapping_service.mapping_entry.inspect
|
87
|
+
expect(mapping_service.mapping_entry.mappings).to be_a Hash
|
88
|
+
expect(mapping_service.mapping_entry['mappings']).to be_a Hash
|
89
|
+
|
90
|
+
end
|
91
|
+
|
92
|
+
it "should be able to generate a mapping from_excel" do
|
93
|
+
|
94
|
+
f = result_file("mapping_service_excel.yaml")
|
95
|
+
|
96
|
+
mapper = DataShift::MappingGenerator.new(f)
|
97
|
+
|
98
|
+
mapper.generate_from_excel(ifixture_file('SimpleProjects.xls'), :file => f )
|
99
|
+
|
100
|
+
end
|
101
|
+
|
102
|
+
it "should provide tasks to generate a mapping doc" do
|
103
|
+
|
104
|
+
opts = {:model => "Project", :result => "#{results_path}"}
|
105
|
+
|
106
|
+
run_in(rails_sandbox()) do
|
107
|
+
output = capture(:stdout) { Datashift::Mapping.new.invoke(:template, [], opts) }
|
108
|
+
|
109
|
+
puts output
|
110
|
+
|
111
|
+
expect(output).to include("Output generated")
|
112
|
+
end
|
113
|
+
end
|
114
|
+
|
115
|
+
|
116
|
+
|
117
|
+
end
|
@@ -12,8 +12,6 @@ require File.join(File.dirname(__FILE__), 'spec_helper')
|
|
12
12
|
require 'method_dictionary'
|
13
13
|
|
14
14
|
describe 'Method Dictionary' do
|
15
|
-
|
16
|
-
include_context "ActiveRecordTestModelsConnected"
|
17
15
|
|
18
16
|
before(:each) do
|
19
17
|
DataShift::MethodDictionary.clear
|
@@ -42,7 +40,7 @@ describe 'Method Dictionary' do
|
|
42
40
|
DataShift::MethodDictionary.assignments[Project].should include('value_as_text')
|
43
41
|
|
44
42
|
DataShift::MethodDictionary.belongs_to.should_not be_empty
|
45
|
-
DataShift::MethodDictionary.belongs_to[Project].
|
43
|
+
expect(DataShift::MethodDictionary.belongs_to[Project]).to include 'user'
|
46
44
|
|
47
45
|
|
48
46
|
DataShift::MethodDictionary.column_types.should be_is_a(Hash)
|
@@ -80,11 +78,11 @@ describe 'Method Dictionary' do
|
|
80
78
|
method_details.operator.should == 'value_as_string'
|
81
79
|
method_details.operator_for(:assignment).should == 'value_as_string'
|
82
80
|
|
83
|
-
method_details.operator?('value_as_string').
|
84
|
-
method_details.operator?('blah_as_string').
|
81
|
+
expect(method_details.operator?('value_as_string')).to eq true
|
82
|
+
expect(method_details.operator?('blah_as_string')).to eq false
|
85
83
|
|
86
|
-
method_details.operator_for(:belongs_to).
|
87
|
-
method_details.operator_for(:has_many).
|
84
|
+
expect(method_details.operator_for(:belongs_to)).to eq nil
|
85
|
+
expect(method_details.operator_for(:has_many)).to eq nil
|
88
86
|
end
|
89
87
|
end
|
90
88
|
|
@@ -128,6 +126,25 @@ describe 'Method Dictionary' do
|
|
128
126
|
end
|
129
127
|
|
130
128
|
end
|
129
|
+
|
130
|
+
|
131
|
+
it "should populate method_details on Class for belongs_to" do
|
132
|
+
|
133
|
+
DataShift::MethodDictionary.find_operators( Owner )
|
134
|
+
|
135
|
+
DataShift::MethodDictionary.build_method_details( Owner )
|
136
|
+
|
137
|
+
[:project, 'PROJECT'].each do |format|
|
138
|
+
|
139
|
+
method_details = DataShift::MethodDictionary.find_method_detail( Owner, format )
|
140
|
+
|
141
|
+
expect(method_details.operator_class_name).to eq 'Project'
|
142
|
+
expect(method_details.operator_class).to be_a(Class)
|
143
|
+
expect(method_details.operator_class).to eq Project
|
144
|
+
end
|
145
|
+
|
146
|
+
end
|
147
|
+
|
131
148
|
|
132
149
|
it "should populate belongs_to operator for method details for different forms of a column name" do
|
133
150
|
|
@@ -251,10 +268,6 @@ describe 'Method Dictionary' do
|
|
251
268
|
end
|
252
269
|
|
253
270
|
|
254
|
-
it "should find a set of methods based on a list of column names" do
|
255
|
-
pending("key API - map column headers to set of methods")
|
256
|
-
end
|
257
|
-
|
258
271
|
it "should not by default map setter methods" do
|
259
272
|
DataShift::MethodDictionary.find_operators( Milestone )
|
260
273
|
|
data/spec/method_mapper_spec.rb
CHANGED
@@ -12,8 +12,6 @@ require File.join(File.dirname(__FILE__), 'spec_helper')
|
|
12
12
|
require 'method_mapper'
|
13
13
|
|
14
14
|
describe 'Method Mapper' do
|
15
|
-
|
16
|
-
include_context "ActiveRecordTestModelsConnected"
|
17
15
|
|
18
16
|
before(:each) do
|
19
17
|
DataShift::MethodDictionary.clear
|
@@ -27,7 +25,7 @@ describe 'Method Mapper' do
|
|
27
25
|
|
28
26
|
method_details = @method_mapper.map_inbound_headers_to_methods( Project, headers )
|
29
27
|
|
30
|
-
method_details.
|
28
|
+
expect(method_details.size).to eq 4
|
31
29
|
end
|
32
30
|
|
33
31
|
it "should leave nil in set of methods when no such operator" do
|
@@ -36,7 +34,7 @@ describe 'Method Mapper' do
|
|
36
34
|
|
37
35
|
method_details = @method_mapper.map_inbound_headers_to_methods( Project, headers )
|
38
36
|
|
39
|
-
method_details.
|
37
|
+
expect(method_details.size).to eq 6
|
40
38
|
|
41
39
|
method_details[2].should be_nil
|
42
40
|
method_details[5].should be_nil
|
@@ -53,7 +51,7 @@ describe 'Method Mapper' do
|
|
53
51
|
|
54
52
|
method_details = @method_mapper.map_inbound_headers_to_methods( Project, headers )
|
55
53
|
|
56
|
-
method_details.
|
54
|
+
expect(method_details.size).to eq 4
|
57
55
|
|
58
56
|
method_details[2].should be_nil
|
59
57
|
|
@@ -67,7 +65,7 @@ describe 'Method Mapper' do
|
|
67
65
|
|
68
66
|
method_details = @method_mapper.map_inbound_headers_to_methods( Project, headers )
|
69
67
|
|
70
|
-
method_details.
|
68
|
+
expect(method_details.size).to eq 4
|
71
69
|
|
72
70
|
method_details[0].should be_a DataShift::MethodDetail
|
73
71
|
|
@@ -85,7 +83,7 @@ describe 'Method Mapper' do
|
|
85
83
|
|
86
84
|
method_details = @method_mapper.map_inbound_headers_to_methods( Project, headers )
|
87
85
|
|
88
|
-
method_details.
|
86
|
+
expect(method_details.size).to eq 4
|
89
87
|
|
90
88
|
method_details.should_not include nil
|
91
89
|
|
@@ -0,0 +1,41 @@
|
|
1
|
+
# Copyright:: (c) Autotelik Media Ltd 2015
|
2
|
+
# Author :: Tom Statter
|
3
|
+
# Date :: Aug 2015
|
4
|
+
# License:: MIT
|
5
|
+
#
|
6
|
+
# Details:: Specs for Mapping aspects
|
7
|
+
# Provides automatic mapping between different system's column headings
|
8
|
+
#
|
9
|
+
require File.join(File.dirname(__FILE__), 'spec_helper')
|
10
|
+
|
11
|
+
require 'mapping_generator'
|
12
|
+
|
13
|
+
describe 'ModelMapper' do
|
14
|
+
|
15
|
+
before(:all) do
|
16
|
+
end
|
17
|
+
|
18
|
+
before(:each) do
|
19
|
+
end
|
20
|
+
|
21
|
+
it "should identify the class from a string" do
|
22
|
+
# Similar to const_get_from_string except this version
|
23
|
+
# returns nil if no such class found
|
24
|
+
# Support modules e.g "Spree::Property"
|
25
|
+
#
|
26
|
+
expect(DataShift::ModelMapper.class_from_string( Project)).to be_a Class
|
27
|
+
|
28
|
+
end
|
29
|
+
|
30
|
+
it "should identify the class from a string contianing modules" do
|
31
|
+
# Similar to const_get_from_string except this version
|
32
|
+
# returns nil if no such class found
|
33
|
+
# Support modules e.g "Spree::Property"
|
34
|
+
#
|
35
|
+
expect(DataShift::ModelMapper.class_from_string( DataShift::AClassInAModule )).to be_a Class
|
36
|
+
|
37
|
+
end
|
38
|
+
|
39
|
+
|
40
|
+
|
41
|
+
end
|
@@ -13,9 +13,6 @@ Paperclip.options[:command_path] = "/usr/local/bin/"
|
|
13
13
|
|
14
14
|
describe 'PaperClip Bulk Loader' do
|
15
15
|
|
16
|
-
include_context "ActiveRecordTestModelsConnected"
|
17
|
-
|
18
|
-
include_context "ClearAndPopulateProject"
|
19
16
|
|
20
17
|
include DataShift::Logging
|
21
18
|
|
@@ -38,7 +35,7 @@ describe 'PaperClip Bulk Loader' do
|
|
38
35
|
end
|
39
36
|
|
40
37
|
it "should create a new paperclip loader and define attachment class" do
|
41
|
-
loader = DataShift::Paperclip::AttachmentLoader.new(@attachment_klass,
|
38
|
+
loader = DataShift::Paperclip::AttachmentLoader.new(@attachment_klass, nil, @common_options)
|
42
39
|
|
43
40
|
loader.load_object_class.should == Digital
|
44
41
|
loader.load_object.should be_a Digital
|
@@ -50,7 +47,7 @@ describe 'PaperClip Bulk Loader' do
|
|
50
47
|
|
51
48
|
opts = { :attach_to_klass => Owner }.merge(@common_options)
|
52
49
|
|
53
|
-
loader = DataShift::Paperclip::AttachmentLoader.new(@attachment_klass,
|
50
|
+
loader = DataShift::Paperclip::AttachmentLoader.new(@attachment_klass, nil, opts)
|
54
51
|
|
55
52
|
loader.attach_to_klass.should == Owner
|
56
53
|
end
|
@@ -89,7 +86,7 @@ describe 'PaperClip Bulk Loader' do
|
|
89
86
|
|
90
87
|
loader.process_from_filesystem(@attachment_path, opts)
|
91
88
|
|
92
|
-
Dir.glob("MissingAttachmentRecords/*.jpeg", File::FNM_CASEFOLD).
|
89
|
+
expect(Dir.glob("MissingAttachmentRecords/*.jpeg", File::FNM_CASEFOLD).size).to eq names.size
|
93
90
|
end
|
94
91
|
|
95
92
|
end
|
data/spec/populator_spec.rb
CHANGED
@@ -11,9 +11,6 @@ require 'erb'
|
|
11
11
|
|
12
12
|
describe 'Populator' do
|
13
13
|
|
14
|
-
include_context "ActiveRecordTestModelsConnected"
|
15
|
-
|
16
|
-
include_context "ClearAndPopulateProject"
|
17
14
|
|
18
15
|
before(:each) do
|
19
16
|
@loader = DataShift::LoaderBase.new(Project)
|
@@ -35,7 +32,7 @@ describe 'Populator' do
|
|
35
32
|
|
36
33
|
options = {:populator => 'AnotherPopulator' }
|
37
34
|
|
38
|
-
local_loader = DataShift::LoaderBase.new(Project,
|
35
|
+
local_loader = DataShift::LoaderBase.new(Project, nil, options)
|
39
36
|
|
40
37
|
local_loader.populator.should_not be_nil
|
41
38
|
local_loader.populator.should be_a AnotherPopulator
|
@@ -48,7 +45,7 @@ describe 'Populator' do
|
|
48
45
|
|
49
46
|
options = {:populator => AnotherPopulator }
|
50
47
|
|
51
|
-
local_loader = DataShift::LoaderBase.new(Project,
|
48
|
+
local_loader = DataShift::LoaderBase.new(Project, nil, options)
|
52
49
|
|
53
50
|
local_loader.populator.should_not be_nil
|
54
51
|
local_loader.populator.should be_a AnotherPopulator
|
@@ -61,19 +58,54 @@ describe 'Populator' do
|
|
61
58
|
|
62
59
|
method_detail = DataShift::MethodDictionary.find_method_detail( Project, column_heading )
|
63
60
|
|
64
|
-
method_detail.
|
61
|
+
expect(method_detail).to be_a DataShift::MethodDetail
|
65
62
|
|
66
|
-
|
63
|
+
pop_value, attributes = @populator.prepare_data(method_detail, value)
|
67
64
|
|
68
|
-
|
65
|
+
pop_value.should == value
|
69
66
|
attributes.should be_a Hash
|
70
67
|
attributes.should be_empty
|
71
68
|
|
69
|
+
# check for white space preservation
|
70
|
+
value = 'Another Lazy fox'
|
71
|
+
|
72
|
+
pop_value, attributes = @populator.prepare_data(method_detail, value)
|
73
|
+
|
74
|
+
pop_value.should == value
|
75
|
+
|
72
76
|
end
|
73
77
|
|
74
|
-
it "should process a string
|
78
|
+
it "should process a DSL string into a real hash" do
|
79
|
+
|
80
|
+
str1 = "{:name => 'the_fox' }"
|
81
|
+
|
82
|
+
x = DataShift::Populator::string_to_hash( str1 )
|
83
|
+
|
84
|
+
expect(x).to be_a Hash
|
85
|
+
expect(x.size).to eq 1
|
86
|
+
|
87
|
+
str2 = "{:name => 'the_fox', 'occupation' => 'fantastic', :food => 'duck soup' }"
|
88
|
+
|
89
|
+
x = DataShift::Populator::string_to_hash( str2 )
|
90
|
+
|
91
|
+
expect(x.size).to eq 3
|
92
|
+
expect(x.keys).to include 'food'
|
93
|
+
expect(x['food']).to eq 'duck soup'
|
94
|
+
|
95
|
+
str3 = "{:cost_price => '13.45', :price => 23, :sale_price => 4.23 }"
|
96
|
+
|
97
|
+
x = DataShift::Populator::string_to_hash( str3 )
|
75
98
|
|
76
|
-
|
99
|
+
expect(x.keys).to include 'price'
|
100
|
+
expect(x['cost_price']).to eq '13.45'
|
101
|
+
expect(x['price']).to eq 23
|
102
|
+
expect(x['sale_price']).to eq 4.23
|
103
|
+
|
104
|
+
end
|
105
|
+
|
106
|
+
it "should process a string value against an assigment instance method" do
|
107
|
+
|
108
|
+
value = 'Get up Lazy fox {:name => \'the_fox\' }'
|
77
109
|
|
78
110
|
DataShift::MethodDictionary.find_operators( Milestone, :instance_methods => true )
|
79
111
|
|
@@ -83,11 +115,13 @@ describe 'Populator' do
|
|
83
115
|
|
84
116
|
method_detail.should_not be_nil
|
85
117
|
|
86
|
-
|
118
|
+
pop_value, attrs = @populator.prepare_data(method_detail, value)
|
87
119
|
|
88
|
-
|
89
|
-
|
90
|
-
|
120
|
+
expect(pop_value).to eq 'Get up Lazy fox '
|
121
|
+
expect(attrs).to be_a Hash
|
122
|
+
expect(attrs.size).to eq 1
|
123
|
+
expect(attrs.keys).to include 'name'
|
124
|
+
expect(attrs['name']).to eq 'the_fox'
|
91
125
|
|
92
126
|
end
|
93
127
|
|