From 331cbe078814e9c661e87ec5902315a8b65a0191 Mon Sep 17 00:00:00 2001 From: Florian Lentsch Date: Fri, 19 Apr 2024 09:33:10 +0200 Subject: [PATCH] On #8: Adapted article version unit tests --- spec/models/article_version_spec.rb | 31 +++++++++++++++++++++-------- 1 file changed, 23 insertions(+), 8 deletions(-) diff --git a/spec/models/article_version_spec.rb b/spec/models/article_version_spec.rb index 7efa5867..6a9f302e 100644 --- a/spec/models/article_version_spec.rb +++ b/spec/models/article_version_spec.rb @@ -11,21 +11,36 @@ let(:article_version) { order.order_articles.first.article_version } let(:article) { article_version.article } - it 'updates the name of articles in open orders in place' do - article.update(latest_article_version_attributes: { name: 'new name', id: article_version.id }) + it 'updates the properties of article versions in open orders in place' do + original_version_id = article_version.id - expect(order.order_articles.first.article_version.name).to eq 'new name' + new_version = create(:article_version) + new_attributes = new_version.attributes.except('updated_at', 'created_at', 'id', 'article_id') + + article.update(latest_article_version_attributes: new_attributes.merge(id: article_version.id)) + + new_attributes.each do |key, value| + expect(order.order_articles.first.article_version[key]).to eq value + end + expect(original_version_id).to eq article.latest_article_version.id end - it 'keeps the names of articles in closed orders' do - original_name = article_version.name + it 'keeps the properties of article versions in closed orders' do + original_version_id = article_version.id + original_version = article_version.dup + + new_version = create(:article_version) + new_attributes = new_version.attributes.except('updated_at', 'created_at', 'id', 'article_id') order.finish!(admin) - article.update(latest_article_version_attributes: { name: 'new name', id: article_version.id }) + article.update(latest_article_version_attributes: new_attributes.merge(id: article_version.id)) - expect(article.latest_article_version.name).to eq 'new name' - expect(order.order_articles.first.article_version.name).to eq original_name + new_attributes.each do |key, value| + expect(article.latest_article_version[key]).to eq value + expect(order.order_articles.first.article_version[key]).to eq original_version[key] + end + expect(original_version_id).not_to eq article.latest_article_version.id end end