-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathRakefile
100 lines (83 loc) · 3.82 KB
/
Rakefile
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
# frozen_string_literal: true
# Add your own tasks in files placed in lib/tasks ending in .rake,
# for example lib/tasks/capistrano.rake, and they will automatically be available to Rake.
require_relative "config/application"
Rails.application.load_tasks
namespace :decidim_surveys_patch do
# We need to patch this rake task so that it can work in this installation
desc "PATCH: Migrate data from decidim_surveys tables to decidim_forms tables"
task migrate_data_to_decidim_forms_patch: :environment do
class Answer < ApplicationRecord
self.table_name = :decidim_surveys_survey_answers
end
class AnswerChoice < ApplicationRecord
self.table_name = :decidim_surveys_survey_answer_choices
end
class AnswerOption < ApplicationRecord
self.table_name = :decidim_surveys_survey_answer_options
end
class Question < ApplicationRecord
self.table_name = :decidim_surveys_survey_questions
end
unless [Answer, AnswerChoice, AnswerOption, Question].all? { |model| ActiveRecord::Base.connection.table_exists? model.table_name }
puts "ERROR: There are not all the necessary surveys tables. Have you already migrated the data?"
next
end
ActiveRecord::Base.transaction do
Decidim::Surveys::Survey.find_each do |survey|
puts "Migrating survey #{survey.id}: #{survey.title}..."
questionnaire = Decidim::Forms::Questionnaire.create!(
questionnaire_for: survey,
title: survey.title,
description: survey.description,
tos: survey.tos,
published_at: survey.published_at,
created_at: survey.created_at,
updated_at: survey.updated_at
)
Question.where(decidim_survey_id: survey.id).find_each do |survey_question|
puts "Migrating question #{survey_question.id}..."
question = Decidim::Forms::Question.create!(
questionnaire: questionnaire,
position: survey_question.position,
question_type: survey_question.question_type,
mandatory: survey_question.mandatory,
body: survey_question.body,
description: survey_question.description,
max_choices: survey_question.max_choices,
created_at: survey_question.created_at,
updated_at: survey_question.updated_at
)
# A hash with the old answer_option id as key, and the new form answer option as value
answer_option_mapping = {}
AnswerOption.where(decidim_survey_question_id: survey_question.id).find_each do |survey_answer_option|
answer_option_mapping[survey_answer_option.id] = Decidim::Forms::AnswerOption.create!(
question: question,
body: survey_answer_option.body,
free_text: survey_answer_option.free_text
)
end
Answer.where(decidim_survey_id: survey.id, decidim_survey_question_id: survey_question.id).find_each do |survey_answer|
answer = Decidim::Forms::Answer.new(
questionnaire: questionnaire,
question: question,
decidim_user_id: survey_answer.decidim_user_id,
body: survey_answer.body,
created_at: survey_answer.created_at,
updated_at: survey_answer.updated_at
)
AnswerChoice.where(decidim_survey_answer_id: survey_answer.id).find_each do |survey_answer_choice|
answer.choices.build(
answer_option: answer_option_mapping[survey_answer_choice.decidim_survey_answer_option_id],
body: survey_answer_choice.body,
custom_body: survey_answer_choice.custom_body,
position: survey_answer_choice.position
)
end
answer.save!(validate: false)
end
end
end
end
end
end