aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--app/models/public_body.rb18
-rw-r--r--spec/fixtures/files/fake-authority-type-with-field-names.csv4
-rw-r--r--spec/models/public_body_spec.rb13
3 files changed, 28 insertions, 7 deletions
diff --git a/app/models/public_body.rb b/app/models/public_body.rb
index 0e32a5164..f1c6582ae 100644
--- a/app/models/public_body.rb
+++ b/app/models/public_body.rb
@@ -313,26 +313,30 @@ class PublicBody < ActiveRecord::Base
def self.import_csv(csv, tag, dry_run, editor)
errors = []
notes = []
-
+
begin
ActiveRecord::Base.transaction do
- existing_bodies = PublicBody.find_by_tag(tag)
-
bodies_by_name = {}
set_of_existing = Set.new()
- for existing_body in existing_bodies
+ for existing_body in PublicBody.find_by_tag(tag)
bodies_by_name[existing_body.name] = existing_body
set_of_existing.add(existing_body.name)
end
set_of_importing = Set.new()
+ field_names = { 'name'=>1, 'email'=>2 } # Default values in case no field list is given
line = 0
-
CSV::Reader.parse(csv) do |row|
+ # Parse the first line as a field list if it starts with '#'
+ if line==0 and row.to_s =~ /^#(.*)$/
+ row.each_with_index {|field, i| field_names[field] = i}
+ next
+ end
+
line = line + 1
- name = row[1]
- email = row[2]
+ name = row[field_names['name']]
+ email = row[field_names['email']]
next if name.nil?
if email.nil?
email = '' # unknown/bad contact is empty string
diff --git a/spec/fixtures/files/fake-authority-type-with-field-names.csv b/spec/fixtures/files/fake-authority-type-with-field-names.csv
new file mode 100644
index 000000000..5032f2783
--- /dev/null
+++ b/spec/fixtures/files/fake-authority-type-with-field-names.csv
@@ -0,0 +1,4 @@
+#id,email,name
+,north_west_foi@localhost,North West Fake Authority
+,scottish_foi@localhost,Scottish Fake Authority
+,ni_foi@localhost,Fake Authority of Northern Ireland
diff --git a/spec/models/public_body_spec.rb b/spec/models/public_body_spec.rb
index 5bbf03d27..e532d0d50 100644
--- a/spec/models/public_body_spec.rb
+++ b/spec/models/public_body_spec.rb
@@ -242,5 +242,18 @@ describe PublicBody, " when loading CSV files" do
end
end
+describe PublicBody, " when loading CSV files with field names and fields out of order" do
+ it "should do a dry run successfully" do
+ original_count = PublicBody.count
+ csv_contents = load_file_fixture("fake-authority-type-with-field-names.csv")
+ errors, notes = PublicBody.import_csv(csv_contents, 'fake', true, 'someadmin') # true means dry run
+ errors.should == []
+ notes.size.should == 3
+ notes.should == ["line 1: new authority 'North West Fake Authority' with email north_west_foi@localhost",
+ "line 2: new authority 'Scottish Fake Authority' with email scottish_foi@localhost",
+ "line 3: new authority 'Fake Authority of Northern Ireland' with email ni_foi@localhost"]
+ PublicBody.count.should == original_count
+ end
+end