Skip to content

Commit

Permalink
Merge pull request #18409 from kbrock/tag_name_updates
Browse files Browse the repository at this point in the history
Allow tag names to be updated
  • Loading branch information
gtanzillo authored Jan 30, 2019
2 parents 055e562 + 90051e4 commit 6752229
Show file tree
Hide file tree
Showing 3 changed files with 46 additions and 11 deletions.
6 changes: 5 additions & 1 deletion app/models/classification.rb
Original file line number Diff line number Diff line change
Expand Up @@ -529,7 +529,11 @@ def find_tag

def save_tag
tag_name = Classification.name2tag(name, parent_id, ns)
self.tag = Tag.in_region(region_id).find_or_create_by(:name => tag_name)
if tag_id.present? || tag.present?
tag.update_attributes(:name => tag_name) unless tag.name == tag_name
else
self.tag = Tag.in_region(region_id).find_or_create_by(:name => tag_name)
end
end

def delete_all_entries
Expand Down
16 changes: 6 additions & 10 deletions spec/factories/classification.rb
Original file line number Diff line number Diff line change
Expand Up @@ -29,20 +29,16 @@
#

factory :classification_cost_center_with_tags, :parent => :classification_cost_center do
children do
[
FactoryBot.create(:classification_tag, :name => "001", :description => "Cost Center 001"),
]
after(:create) do |c|
FactoryBot.create(:classification_tag, :name => "001", :description => "Cost Center 001", :parent => c)
end
end

factory :classification_department_with_tags, :parent => :classification_department do
children do
[
FactoryBot.create(:classification_tag, :name => "accounting", :description => "Accounting"),
FactoryBot.create(:classification_tag, :name => "finance", :description => "Financial Services"),
FactoryBot.create(:classification_tag, :name => "hr", :description => "Human Resources"),
]
after(:create) do |c|
FactoryBot.create(:classification_tag, :parent => c, :name => "accounting", :description => "Accounting")
FactoryBot.create(:classification_tag, :parent => c, :name => "finance", :description => "Financial Services")
FactoryBot.create(:classification_tag, :parent => c, :name => "hr", :description => "Human Resources")
end
end
end
35 changes: 35 additions & 0 deletions spec/models/classification_spec.rb
Original file line number Diff line number Diff line change
Expand Up @@ -571,6 +571,41 @@
end
end

describe '#save' do
let(:new_name) { "new_tag_name" }
let(:category) { FactoryBot.create(:classification, :name => "category") }

context "editing existing classification" do
let(:classification) { FactoryBot.create(:classification_tag, :parent => category, :name => "some_tag_name") }
it "doesn't assign new tag " do
tag = classification.tag
classification.update_attributes!(:name => new_name)
classification.reload
expect(tag.id).to eq classification.tag.id
expect(classification.name).to eq(new_name)
expect(classification.tag.name).to eq(Classification.name2tag(new_name, category))
end
end

context "saving new classification" do
it "creates new tag" do
classification = Classification.create(:description => new_name, :parent => category, :name => new_name)
expect(classification.tag).to be_present
expect(classification.name).to eq(new_name)
expect(classification.tag.name).to eq(Classification.name2tag(new_name, category))
end
end
end

describe '.create' do
it "assigns proper tags" do
FactoryBot.create(:classification_department_with_tags)
Tag.all.each do |tag|
expect(tag.name).to eq(Classification.name2tag(tag.classification.name, tag.classification.parent_id))
end
end
end

def all_tagged_with(target, all, category = nil)
tagged_with(target, :all => all, :cat => category)
end
Expand Down

0 comments on commit 6752229

Please sign in to comment.