From 78d0d8f649c18a8df0a045e50f2210d2ea577fa8 Mon Sep 17 00:00:00 2001 From: Daniela Soares Feitosa Date: Wed, 6 Jan 2016 13:25:57 -0300 Subject: [PATCH] Fix: migration skips softwares without community --- src/noosfero-spb/software_communities/db/migrate/20160104170028_changing_software_statistics_from_block_to_software_info.rb | 24 ++++++++++++++++++++++++ 1 file changed, 24 insertions(+), 0 deletions(-) create mode 100644 src/noosfero-spb/software_communities/db/migrate/20160104170028_changing_software_statistics_from_block_to_software_info.rb diff --git a/src/noosfero-spb/software_communities/db/migrate/20160104170028_changing_software_statistics_from_block_to_software_info.rb b/src/noosfero-spb/software_communities/db/migrate/20160104170028_changing_software_statistics_from_block_to_software_info.rb new file mode 100644 index 0000000..6743839 --- /dev/null +++ b/src/noosfero-spb/software_communities/db/migrate/20160104170028_changing_software_statistics_from_block_to_software_info.rb @@ -0,0 +1,24 @@ +class ChangingSoftwareStatisticsFromBlockToSoftwareInfo < ActiveRecord::Migration + def up + select_all("SELECT * FROM software_infos").each do |software| + benefited_people = 0 + saved_resources = 0 + + if software['community_id'] + select_all("SELECT * FROM tasks WHERE status=3 AND type='CreateOrganizationRatingComment' AND target_id=#{software['community_id']}").each do |task| + settings = YAML.load(task['data']) + organization_rating = select_one("SELECT * FROM organization_ratings WHERE id=#{settings[:organization_rating_id]}") + + benefited_people += organization_rating["people_benefited"].to_i + saved_resources += organization_rating["saved_value"].to_f + end + execute("UPDATE software_infos SET benefited_people=#{benefited_people}, saved_resources=#{saved_resources} WHERE id=#{software['id']}") + end + end + + end + + def down + execute("UPDATE software_infos SET benefited_people=0,saved_resources=0") + end +end -- libgit2 0.21.2