decidim-forms 0.27.7 → 0.28.0.rc4
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/README.md +1 -1
- data/app/cells/decidim/forms/answer_readonly/show.erb +1 -1
- data/app/cells/decidim/forms/matrix_readonly/show.erb +1 -1
- data/app/cells/decidim/forms/question_readonly/show.erb +8 -8
- data/app/cells/decidim/forms/question_readonly/title_and_description.erb +8 -0
- data/app/cells/decidim/forms/question_readonly_cell.rb +7 -0
- data/app/cells/decidim/forms/step_navigation/show.erb +13 -26
- data/app/cells/decidim/forms/step_navigation_cell.rb +7 -0
- data/app/commands/decidim/forms/answer_questionnaire.rb +31 -11
- data/app/controllers/decidim/forms/admin/concerns/has_questionnaire.rb +4 -4
- data/app/controllers/decidim/forms/admin/concerns/has_questionnaire_answers.rb +1 -1
- data/app/controllers/decidim/forms/concerns/has_questionnaire.rb +3 -3
- data/app/forms/decidim/forms/answer_form.rb +7 -3
- data/app/forms/decidim/forms/questionnaire_form.rb +1 -1
- data/app/helpers/decidim/forms/admin/application_helper.rb +1 -1
- data/app/helpers/decidim/forms/admin/concerns/has_questionnaire_answers_url_helper.rb +2 -2
- data/app/models/decidim/forms/answer.rb +1 -1
- data/app/models/decidim/forms/display_condition.rb +2 -2
- data/app/models/decidim/forms/question.rb +0 -4
- data/app/models/decidim/forms/questionnaire.rb +1 -1
- data/app/packs/entrypoints/decidim_forms.js +4 -0
- data/app/packs/src/decidim/forms/admin/collapsible_questions.js +12 -6
- data/app/packs/src/decidim/forms/admin/forms.js +7 -7
- data/app/packs/src/decidim/forms/display_conditions.component.js +3 -3
- data/app/packs/src/decidim/forms/forms.js +15 -9
- data/app/packs/src/decidim/forms/option_attached_inputs.component.js +1 -1
- data/app/packs/stylesheets/decidim/forms/forms.scss +82 -52
- data/app/packs/stylesheets/decidim/forms/questionnaire-answers-pdf.scss +13 -13
- data/app/presenters/decidim/forms/admin/questionnaire_participant_presenter.rb +2 -2
- data/app/presenters/decidim/forms/admin_log/questionnaire_presenter.rb +2 -2
- data/app/presenters/decidim/forms/answer_option_presenter.rb +1 -1
- data/app/queries/decidim/forms/questionnaire_participants.rb +1 -1
- data/app/views/decidim/forms/admin/questionnaires/_answer_option.html.erb +1 -1
- data/app/views/decidim/forms/admin/questionnaires/_answer_option_template.html.erb +1 -1
- data/app/views/decidim/forms/admin/questionnaires/_display_condition.html.erb +2 -2
- data/app/views/decidim/forms/admin/questionnaires/_display_condition_template.html.erb +1 -1
- data/app/views/decidim/forms/admin/questionnaires/_form.html.erb +52 -74
- data/app/views/decidim/forms/admin/questionnaires/_matrix_row.html.erb +1 -1
- data/app/views/decidim/forms/admin/questionnaires/_matrix_row_template.html.erb +1 -1
- data/app/views/decidim/forms/admin/questionnaires/_question.html.erb +147 -135
- data/app/views/decidim/forms/admin/questionnaires/_separator.html.erb +15 -13
- data/app/views/decidim/forms/admin/questionnaires/_title_and_description.html.erb +69 -63
- data/app/views/decidim/forms/admin/questionnaires/answers/export/_answer.html.erb +4 -4
- data/app/views/decidim/forms/admin/questionnaires/answers/export/pdf.html.erb +1 -1
- data/app/views/decidim/forms/admin/questionnaires/answers/index.html.erb +41 -45
- data/app/views/decidim/forms/admin/questionnaires/answers/show.html.erb +13 -18
- data/app/views/decidim/forms/admin/questionnaires/edit.html.erb +33 -6
- data/app/views/decidim/forms/questionnaires/_answer.html.erb +31 -27
- data/app/views/decidim/forms/questionnaires/_questionnaire.html.erb +78 -0
- data/app/views/decidim/forms/questionnaires/_questionnaire_readonly.html.erb +11 -0
- data/app/views/decidim/forms/questionnaires/answers/_files.html.erb +1 -1
- data/app/views/decidim/forms/questionnaires/answers/_long_answer.html.erb +3 -1
- data/app/views/decidim/forms/questionnaires/answers/_matrix_multiple.html.erb +44 -41
- data/app/views/decidim/forms/questionnaires/answers/_matrix_single.html.erb +44 -41
- data/app/views/decidim/forms/questionnaires/answers/_multiple_option.html.erb +7 -6
- data/app/views/decidim/forms/questionnaires/answers/_separator.html.erb +1 -1
- data/app/views/decidim/forms/questionnaires/answers/_short_answer.html.erb +3 -1
- data/app/views/decidim/forms/questionnaires/answers/_single_option.html.erb +13 -12
- data/app/views/decidim/forms/questionnaires/answers/_sorting.html.erb +9 -12
- data/app/views/decidim/forms/questionnaires/answers/_title_and_description.html.erb +1 -1
- data/app/views/decidim/forms/questionnaires/show.html.erb +35 -144
- data/config/initializers/wicked_pdf.rb +1 -1
- data/config/locales/ar.yml +0 -6
- data/config/locales/bg.yml +0 -177
- data/config/locales/ca.yml +7 -2
- data/config/locales/cs.yml +8 -3
- data/config/locales/de.yml +9 -4
- data/config/locales/el.yml +7 -2
- data/config/locales/en.yml +8 -3
- data/config/locales/es-MX.yml +7 -2
- data/config/locales/es-PY.yml +7 -2
- data/config/locales/es.yml +7 -2
- data/config/locales/eu.yml +8 -3
- data/config/locales/fi-plain.yml +7 -2
- data/config/locales/fi.yml +7 -2
- data/config/locales/fr-CA.yml +8 -3
- data/config/locales/fr.yml +8 -3
- data/config/locales/gl.yml +0 -4
- data/config/locales/hu.yml +3 -9
- data/config/locales/id-ID.yml +0 -4
- data/config/locales/it.yml +0 -6
- data/config/locales/ja.yml +6 -1
- data/config/locales/lb.yml +0 -6
- data/config/locales/lt.yml +7 -2
- data/config/locales/lv.yml +0 -6
- data/config/locales/nl.yml +0 -6
- data/config/locales/no.yml +0 -6
- data/config/locales/pl.yml +6 -8
- data/config/locales/pt-BR.yml +0 -25
- data/config/locales/pt.yml +0 -6
- data/config/locales/ro-RO.yml +19 -14
- data/config/locales/ru.yml +0 -3
- data/config/locales/sk.yml +0 -6
- data/config/locales/sv.yml +3 -6
- data/config/locales/tr-TR.yml +0 -6
- data/config/locales/zh-CN.yml +0 -6
- data/config/locales/zh-TW.yml +7 -2
- data/lib/decidim/forms/engine.rb +8 -0
- data/lib/decidim/forms/test/factories.rb +37 -51
- data/lib/decidim/forms/test/shared_examples/has_questionnaire.rb +129 -239
- data/lib/decidim/forms/test/shared_examples/manage_questionnaire_answers.rb +18 -18
- data/lib/decidim/forms/test/shared_examples/manage_questionnaires/add_display_conditions.rb +14 -14
- data/lib/decidim/forms/test/shared_examples/manage_questionnaires/add_questions.rb +60 -78
- data/lib/decidim/forms/test/shared_examples/manage_questionnaires/update_display_conditions.rb +6 -6
- data/lib/decidim/forms/test/shared_examples/manage_questionnaires/update_questions.rb +25 -25
- data/lib/decidim/forms/test/shared_examples/manage_questionnaires.rb +9 -9
- data/lib/decidim/forms/user_answers_serializer.rb +1 -1
- data/lib/decidim/forms/version.rb +1 -1
- metadata +23 -18
- data/app/packs/src/decidim/forms/autosortable_checkboxes.component.js +0 -83
- data/config/locales/he-IL.yml +0 -1
- data/decidim-forms.gemspec +0 -34
@@ -7,16 +7,14 @@ shared_examples_for "has questionnaire" do
|
|
7
7
|
it "does not allow answering the questionnaire" do
|
8
8
|
visit questionnaire_public_path
|
9
9
|
|
10
|
-
expect(page).to have_i18n_content(questionnaire.title
|
11
|
-
expect(page).to have_i18n_content(questionnaire.description
|
10
|
+
expect(page).to have_i18n_content(questionnaire.title)
|
11
|
+
expect(page).to have_i18n_content(questionnaire.description)
|
12
12
|
|
13
13
|
expect(page).not_to have_css(".form.answer-questionnaire")
|
14
14
|
|
15
|
-
within "
|
15
|
+
within "[data-question-readonly]" do
|
16
16
|
expect(page).to have_i18n_content(question.body)
|
17
17
|
end
|
18
|
-
|
19
|
-
expect(page).to have_content("Sign in with your account or sign up to answer the form.")
|
20
18
|
end
|
21
19
|
end
|
22
20
|
|
@@ -28,8 +26,8 @@ shared_examples_for "has questionnaire" do
|
|
28
26
|
it "allows answering the questionnaire" do
|
29
27
|
visit questionnaire_public_path
|
30
28
|
|
31
|
-
expect(page).to have_i18n_content(questionnaire.title
|
32
|
-
expect(page).to have_i18n_content(questionnaire.description
|
29
|
+
expect(page).to have_i18n_content(questionnaire.title)
|
30
|
+
expect(page).to have_i18n_content(questionnaire.description)
|
33
31
|
|
34
32
|
fill_in question.body["en"], with: "My first answer"
|
35
33
|
|
@@ -39,9 +37,7 @@ shared_examples_for "has questionnaire" do
|
|
39
37
|
click_button "Submit"
|
40
38
|
end
|
41
39
|
|
42
|
-
|
43
|
-
expect(page).to have_content("successfully")
|
44
|
-
end
|
40
|
+
expect(page).to have_admin_callout(callout_success)
|
45
41
|
|
46
42
|
visit questionnaire_public_path
|
47
43
|
|
@@ -50,31 +46,31 @@ shared_examples_for "has questionnaire" do
|
|
50
46
|
end
|
51
47
|
|
52
48
|
context "with multiple steps" do
|
53
|
-
let!(:separator) { create(:questionnaire_question, questionnaire
|
54
|
-
let!(:question2) { create(:questionnaire_question, questionnaire
|
49
|
+
let!(:separator) { create(:questionnaire_question, questionnaire:, position: 1, question_type: :separator) }
|
50
|
+
let!(:question2) { create(:questionnaire_question, questionnaire:, position: 2) }
|
55
51
|
|
56
52
|
before do
|
57
53
|
visit questionnaire_public_path
|
58
54
|
end
|
59
55
|
|
60
56
|
it "allows answering the first questionnaire" do
|
61
|
-
expect(page).to have_content("
|
57
|
+
expect(page).to have_content("Step 1 of 2")
|
62
58
|
|
63
|
-
within ".answer-questionnaire__submit" do
|
64
|
-
expect(page).
|
59
|
+
within ".answer-questionnaire__submit", match: :first do
|
60
|
+
expect(page).not_to have_content("Back")
|
65
61
|
end
|
66
62
|
|
67
63
|
answer_first_questionnaire
|
68
64
|
|
69
|
-
expect(page).
|
65
|
+
expect(page).not_to have_selector(".success.flash")
|
70
66
|
end
|
71
67
|
|
72
68
|
it "allows revisiting previously-answered questionnaires with my answers" do
|
73
69
|
answer_first_questionnaire
|
74
70
|
|
75
|
-
|
71
|
+
click_button "Back"
|
76
72
|
|
77
|
-
expect(page).to have_content("
|
73
|
+
expect(page).to have_content("Step 1 of 2")
|
78
74
|
expect(page).to have_field("questionnaire_responses_0", with: "My first answer")
|
79
75
|
end
|
80
76
|
|
@@ -84,9 +80,7 @@ shared_examples_for "has questionnaire" do
|
|
84
80
|
check "questionnaire_tos_agreement"
|
85
81
|
accept_confirm { click_button "Submit" }
|
86
82
|
|
87
|
-
|
88
|
-
expect(page).to have_content("successfully")
|
89
|
-
end
|
83
|
+
expect(page).to have_admin_callout(callout_success)
|
90
84
|
|
91
85
|
visit questionnaire_public_path
|
92
86
|
|
@@ -94,13 +88,13 @@ shared_examples_for "has questionnaire" do
|
|
94
88
|
end
|
95
89
|
|
96
90
|
def answer_first_questionnaire
|
97
|
-
|
91
|
+
within "#step-0" do
|
92
|
+
expect(page).not_to have_selector("#questionnaire_tos_agreement")
|
98
93
|
|
99
|
-
|
100
|
-
|
101
|
-
click_link "Continue"
|
94
|
+
fill_in question.body["en"], with: "My first answer"
|
95
|
+
click_button "Continue"
|
102
96
|
end
|
103
|
-
expect(page).to have_content("
|
97
|
+
expect(page).to have_content("Step 2 of 2")
|
104
98
|
end
|
105
99
|
end
|
106
100
|
|
@@ -110,7 +104,7 @@ shared_examples_for "has questionnaire" do
|
|
110
104
|
fill_in question.body["en"], with: "My first answer"
|
111
105
|
|
112
106
|
dismiss_page_unload do
|
113
|
-
page.find(".
|
107
|
+
page.find(".main-bar__logo a").click
|
114
108
|
end
|
115
109
|
|
116
110
|
expect(page).to have_current_path questionnaire_public_path
|
@@ -120,7 +114,7 @@ shared_examples_for "has questionnaire" do
|
|
120
114
|
let!(:question) do
|
121
115
|
create(
|
122
116
|
:questionnaire_question,
|
123
|
-
questionnaire
|
117
|
+
questionnaire:,
|
124
118
|
question_type: "single_option",
|
125
119
|
position: 0,
|
126
120
|
options: [
|
@@ -131,7 +125,7 @@ shared_examples_for "has questionnaire" do
|
|
131
125
|
end
|
132
126
|
|
133
127
|
before do
|
134
|
-
answer = create(:answer, id: 1, questionnaire
|
128
|
+
answer = create(:answer, id: 1, questionnaire:, question:)
|
135
129
|
|
136
130
|
answer.choices.create!(
|
137
131
|
answer_option: Decidim::Forms::AnswerOption.first,
|
@@ -142,21 +136,24 @@ shared_examples_for "has questionnaire" do
|
|
142
136
|
it "does not leak defaults from other answers" do
|
143
137
|
visit questionnaire_public_path
|
144
138
|
|
145
|
-
expect(page).
|
139
|
+
expect(page).not_to have_field(type: "radio", checked: true)
|
146
140
|
end
|
147
141
|
end
|
148
142
|
|
149
143
|
shared_examples_for "a correctly ordered questionnaire" do
|
150
144
|
it "displays the questions ordered by position starting with one" do
|
151
|
-
form_fields = all(".answer-
|
145
|
+
form_fields = all(".answer-questionnaire__question")
|
152
146
|
|
153
|
-
expect(form_fields[0]).to have_i18n_content(question.body)
|
154
|
-
expect(form_fields[1]).to have_i18n_content(other_question.body)
|
147
|
+
expect(form_fields[0]).to have_i18n_content(question.body)
|
148
|
+
expect(form_fields[1]).to have_i18n_content(other_question.body)
|
149
|
+
2.times do |index|
|
150
|
+
expect(form_fields[index]).to have_css("[data-answer-idx='#{index + 1}']")
|
151
|
+
end
|
155
152
|
end
|
156
153
|
end
|
157
154
|
|
158
155
|
context "and submitting a fresh form" do
|
159
|
-
let!(:other_question) { create(:questionnaire_question, questionnaire
|
156
|
+
let!(:other_question) { create(:questionnaire_question, questionnaire:, position: 1) }
|
160
157
|
|
161
158
|
before do
|
162
159
|
visit questionnaire_public_path
|
@@ -166,7 +163,7 @@ shared_examples_for "has questionnaire" do
|
|
166
163
|
end
|
167
164
|
|
168
165
|
context "and rendering a form after errors" do
|
169
|
-
let!(:other_question) { create(:questionnaire_question, questionnaire
|
166
|
+
let!(:other_question) { create(:questionnaire_question, questionnaire:, position: 1) }
|
170
167
|
|
171
168
|
before do
|
172
169
|
visit questionnaire_public_path
|
@@ -180,7 +177,7 @@ shared_examples_for "has questionnaire" do
|
|
180
177
|
let!(:question) do
|
181
178
|
create(
|
182
179
|
:questionnaire_question,
|
183
|
-
questionnaire
|
180
|
+
questionnaire:,
|
184
181
|
question_type: "short_answer",
|
185
182
|
position: 0,
|
186
183
|
mandatory: true
|
@@ -208,7 +205,7 @@ shared_examples_for "has questionnaire" do
|
|
208
205
|
context "when max_characters value is 0" do
|
209
206
|
let(:max_characters) { 0 }
|
210
207
|
|
211
|
-
it "
|
208
|
+
it "does not show message indicating number of characters left" do
|
212
209
|
visit questionnaire_public_path
|
213
210
|
|
214
211
|
expect(page).not_to have_content("characters left")
|
@@ -224,11 +221,8 @@ shared_examples_for "has questionnaire" do
|
|
224
221
|
end
|
225
222
|
|
226
223
|
it "submits the form and shows errors" do
|
227
|
-
|
228
|
-
|
229
|
-
end
|
230
|
-
|
231
|
-
expect(page).to have_content("can't be blank")
|
224
|
+
expect(page).to have_admin_callout(callout_failure)
|
225
|
+
expect(page).to have_content("cannot be blank")
|
232
226
|
end
|
233
227
|
end
|
234
228
|
|
@@ -240,12 +234,12 @@ shared_examples_for "has questionnaire" do
|
|
240
234
|
end
|
241
235
|
|
242
236
|
it "shows errors without submitting the form" do
|
243
|
-
expect(page).
|
237
|
+
expect(page).not_to have_selector ".alert.flash"
|
244
238
|
different_error = I18n.t("decidim.forms.questionnaires.answer.max_choices_alert")
|
245
239
|
expect(different_error).to eq("There are too many choices selected")
|
246
240
|
expect(page).not_to have_content(different_error)
|
247
241
|
|
248
|
-
expect(page).to have_content("
|
242
|
+
expect(page).to have_content("cannot be blank")
|
249
243
|
end
|
250
244
|
end
|
251
245
|
|
@@ -253,7 +247,7 @@ shared_examples_for "has questionnaire" do
|
|
253
247
|
let!(:question) do
|
254
248
|
create(
|
255
249
|
:questionnaire_question,
|
256
|
-
questionnaire
|
250
|
+
questionnaire:,
|
257
251
|
question_type: "single_option",
|
258
252
|
position: 0,
|
259
253
|
mandatory: true,
|
@@ -273,16 +267,13 @@ shared_examples_for "has questionnaire" do
|
|
273
267
|
end
|
274
268
|
|
275
269
|
it "submits the form and shows errors" do
|
276
|
-
|
277
|
-
|
278
|
-
end
|
279
|
-
|
280
|
-
expect(page).to have_content("can't be blank")
|
270
|
+
expect(page).to have_admin_callout(callout_failure)
|
271
|
+
expect(page).to have_content("cannot be blank")
|
281
272
|
end
|
282
273
|
end
|
283
274
|
|
284
275
|
context "when a question has a rich text description" do
|
285
|
-
let!(:question) { create(:questionnaire_question, questionnaire
|
276
|
+
let!(:question) { create(:questionnaire_question, questionnaire:, position: 0, description: { en: "<b>This question is important</b>" }) }
|
286
277
|
|
287
278
|
it "properly interprets HTML descriptions" do
|
288
279
|
visit questionnaire_public_path
|
@@ -297,9 +288,9 @@ shared_examples_for "has questionnaire" do
|
|
297
288
|
let!(:question) do
|
298
289
|
create(
|
299
290
|
:questionnaire_question,
|
300
|
-
questionnaire
|
301
|
-
question_type
|
302
|
-
max_characters
|
291
|
+
questionnaire:,
|
292
|
+
question_type:,
|
293
|
+
max_characters:,
|
303
294
|
position: 1,
|
304
295
|
options: [
|
305
296
|
{ "body" => answer_option_bodies[0] },
|
@@ -312,7 +303,7 @@ shared_examples_for "has questionnaire" do
|
|
312
303
|
let!(:other_question) do
|
313
304
|
create(
|
314
305
|
:questionnaire_question,
|
315
|
-
questionnaire
|
306
|
+
questionnaire:,
|
316
307
|
question_type: "multiple_option",
|
317
308
|
max_choices: 2,
|
318
309
|
position: 2,
|
@@ -332,7 +323,7 @@ shared_examples_for "has questionnaire" do
|
|
332
323
|
let(:question_type) { "single_option" }
|
333
324
|
|
334
325
|
it "renders them as radio buttons with attached text fields disabled by default" do
|
335
|
-
expect(page).to have_selector(".radio-button-collection input[type=radio]", count: 3)
|
326
|
+
expect(page).to have_selector(".js-radio-button-collection input[type=radio]", count: 3)
|
336
327
|
|
337
328
|
expect(page).to have_field("questionnaire_responses_0_choices_2_custom_body", disabled: true, count: 1)
|
338
329
|
|
@@ -348,10 +339,7 @@ shared_examples_for "has questionnaire" do
|
|
348
339
|
check "questionnaire_tos_agreement"
|
349
340
|
accept_confirm { click_button "Submit" }
|
350
341
|
|
351
|
-
|
352
|
-
expect(page).to have_content("successfully")
|
353
|
-
end
|
354
|
-
|
342
|
+
expect(page).to have_admin_callout(callout_success)
|
355
343
|
expect(Decidim::Forms::Answer.first.choices.first.custom_body).to eq("Cacatua")
|
356
344
|
end
|
357
345
|
|
@@ -366,10 +354,7 @@ shared_examples_for "has questionnaire" do
|
|
366
354
|
check "questionnaire_tos_agreement"
|
367
355
|
accept_confirm { click_button "Submit" }
|
368
356
|
|
369
|
-
|
370
|
-
expect(page).to have_content("There was a problem answering")
|
371
|
-
end
|
372
|
-
|
357
|
+
expect(page).to have_admin_callout("There was a problem answering")
|
373
358
|
expect(page).to have_field("questionnaire_responses_0_choices_2_custom_body", with: "Cacatua")
|
374
359
|
end
|
375
360
|
|
@@ -380,7 +365,7 @@ shared_examples_for "has questionnaire" do
|
|
380
365
|
let(:question_type) { "multiple_option" }
|
381
366
|
|
382
367
|
it "renders them as check boxes with attached text fields disabled by default" do
|
383
|
-
expect(page.first(".check-box-collection")).to
|
368
|
+
expect(page.first(".js-check-box-collection")).to have_field(type: "checkbox", count: 3)
|
384
369
|
|
385
370
|
expect(page).to have_field("questionnaire_responses_0_choices_2_custom_body", disabled: true, count: 1)
|
386
371
|
|
@@ -396,10 +381,7 @@ shared_examples_for "has questionnaire" do
|
|
396
381
|
check "questionnaire_tos_agreement"
|
397
382
|
accept_confirm { click_button "Submit" }
|
398
383
|
|
399
|
-
|
400
|
-
expect(page).to have_content("successfully")
|
401
|
-
end
|
402
|
-
|
384
|
+
expect(page).to have_admin_callout(callout_success)
|
403
385
|
expect(Decidim::Forms::Answer.first.choices.first.custom_body).to eq("Cacatua")
|
404
386
|
end
|
405
387
|
|
@@ -414,10 +396,7 @@ shared_examples_for "has questionnaire" do
|
|
414
396
|
check "questionnaire_tos_agreement"
|
415
397
|
accept_confirm { click_button "Submit" }
|
416
398
|
|
417
|
-
|
418
|
-
expect(page).to have_content("There was a problem answering")
|
419
|
-
end
|
420
|
-
|
399
|
+
expect(page).to have_admin_callout("There was a problem answering")
|
421
400
|
expect(page).to have_field("questionnaire_responses_0_choices_2_custom_body", with: "Cacatua")
|
422
401
|
end
|
423
402
|
|
@@ -427,7 +406,7 @@ shared_examples_for "has questionnaire" do
|
|
427
406
|
|
428
407
|
context "when question type is long answer" do
|
429
408
|
let(:max_characters) { 0 }
|
430
|
-
let!(:question) { create(:questionnaire_question, questionnaire
|
409
|
+
let!(:question) { create(:questionnaire_question, questionnaire:, question_type: "long_answer", max_characters:) }
|
431
410
|
|
432
411
|
it "renders the answer as a textarea" do
|
433
412
|
visit questionnaire_public_path
|
@@ -440,12 +419,12 @@ shared_examples_for "has questionnaire" do
|
|
440
419
|
|
441
420
|
context "when question type is short answer" do
|
442
421
|
let(:max_characters) { 0 }
|
443
|
-
let!(:question) { create(:questionnaire_question, questionnaire
|
422
|
+
let!(:question) { create(:questionnaire_question, questionnaire:, question_type: "short_answer", max_characters:) }
|
444
423
|
|
445
424
|
it "renders the answer as a text field" do
|
446
425
|
visit questionnaire_public_path
|
447
426
|
|
448
|
-
expect(page).to
|
427
|
+
expect(page).to have_field(id: "questionnaire_responses_0")
|
449
428
|
end
|
450
429
|
|
451
430
|
it_behaves_like "question has a character limit"
|
@@ -453,12 +432,12 @@ shared_examples_for "has questionnaire" do
|
|
453
432
|
|
454
433
|
context "when question type is single option" do
|
455
434
|
let(:answer_options) { Array.new(2) { { "body" => Decidim::Faker::Localized.sentence } } }
|
456
|
-
let!(:question) { create(:questionnaire_question, questionnaire
|
435
|
+
let!(:question) { create(:questionnaire_question, questionnaire:, question_type: "single_option", options: answer_options) }
|
457
436
|
|
458
437
|
it "renders answers as a collection of radio buttons" do
|
459
438
|
visit questionnaire_public_path
|
460
439
|
|
461
|
-
expect(page).to have_selector(".radio-button-collection input[type=radio]", count: 2)
|
440
|
+
expect(page).to have_selector(".js-radio-button-collection input[type=radio]", count: 2)
|
462
441
|
|
463
442
|
choose answer_options[0]["body"][:en]
|
464
443
|
|
@@ -466,9 +445,7 @@ shared_examples_for "has questionnaire" do
|
|
466
445
|
|
467
446
|
accept_confirm { click_button "Submit" }
|
468
447
|
|
469
|
-
|
470
|
-
expect(page).to have_content("successfully")
|
471
|
-
end
|
448
|
+
expect(page).to have_admin_callout(callout_success)
|
472
449
|
|
473
450
|
visit questionnaire_public_path
|
474
451
|
|
@@ -479,14 +456,14 @@ shared_examples_for "has questionnaire" do
|
|
479
456
|
|
480
457
|
context "when question type is multiple option" do
|
481
458
|
let(:answer_options) { Array.new(3) { { "body" => Decidim::Faker::Localized.sentence } } }
|
482
|
-
let!(:question) { create(:questionnaire_question, questionnaire
|
459
|
+
let!(:question) { create(:questionnaire_question, questionnaire:, question_type: "multiple_option", options: answer_options) }
|
483
460
|
|
484
461
|
it "renders answers as a collection of radio buttons" do
|
485
462
|
visit questionnaire_public_path
|
486
463
|
|
487
|
-
expect(page).to have_selector(".check-box-collection input[type=checkbox]", count: 3)
|
464
|
+
expect(page).to have_selector(".js-check-box-collection input[type=checkbox]", count: 3)
|
488
465
|
|
489
|
-
expect(page).
|
466
|
+
expect(page).not_to have_content("Max choices:")
|
490
467
|
|
491
468
|
check answer_options[0]["body"][:en]
|
492
469
|
check answer_options[1]["body"][:en]
|
@@ -495,9 +472,7 @@ shared_examples_for "has questionnaire" do
|
|
495
472
|
|
496
473
|
accept_confirm { click_button "Submit" }
|
497
474
|
|
498
|
-
|
499
|
-
expect(page).to have_content("successfully")
|
500
|
-
end
|
475
|
+
expect(page).to have_admin_callout(callout_success)
|
501
476
|
|
502
477
|
visit questionnaire_public_path
|
503
478
|
|
@@ -522,29 +497,23 @@ shared_examples_for "has questionnaire" do
|
|
522
497
|
|
523
498
|
accept_confirm { click_button "Submit" }
|
524
499
|
|
525
|
-
|
526
|
-
expect(page).to have_content("There was a problem answering")
|
527
|
-
end
|
528
|
-
|
500
|
+
expect(page).to have_admin_callout("There was a problem answering")
|
529
501
|
expect(page).to have_content("are too many")
|
530
502
|
|
531
503
|
uncheck answer_options[2]["body"][:en]
|
532
504
|
|
533
505
|
accept_confirm { click_button "Submit" }
|
534
506
|
|
535
|
-
|
536
|
-
expect(page).to have_content("successfully")
|
537
|
-
end
|
507
|
+
expect(page).to have_admin_callout(callout_success)
|
538
508
|
end
|
539
509
|
end
|
540
510
|
|
541
|
-
context "when question type is sorting
|
511
|
+
context "when question type is sorting" do
|
542
512
|
let!(:question) do
|
543
513
|
create(
|
544
514
|
:questionnaire_question,
|
545
|
-
questionnaire
|
515
|
+
questionnaire:,
|
546
516
|
question_type: "sorting",
|
547
|
-
mandatory: true,
|
548
517
|
options: [
|
549
518
|
{ "body" => { "en" => "chocolate" } },
|
550
519
|
{ "body" => { "en" => "like" } },
|
@@ -555,90 +524,32 @@ shared_examples_for "has questionnaire" do
|
|
555
524
|
)
|
556
525
|
end
|
557
526
|
|
558
|
-
it "renders the question answers as a collection of
|
527
|
+
it "renders the question answers as a collection of divs sortable on drag and drop" do
|
559
528
|
visit questionnaire_public_path
|
560
529
|
|
561
|
-
expect(page).to have_selector(".
|
562
|
-
|
563
|
-
expect(page).to have_content("chocolate\nlike\nWe\ndark\nall")
|
530
|
+
expect(page).to have_selector("div.answer-questionnaire__sorting.js-collection-input", count: 5)
|
564
531
|
|
565
|
-
|
566
|
-
|
567
|
-
|
568
|
-
check "dark"
|
569
|
-
check "chocolate"
|
570
|
-
|
571
|
-
expect(page).to have_content("1. We\n2. all\n3. like\n4. dark\n5. chocolate")
|
532
|
+
%w(We all like dark chocolate).each do |term|
|
533
|
+
expect(page).to have_content(term)
|
534
|
+
end
|
572
535
|
end
|
573
536
|
|
574
537
|
it "properly saves valid sortings" do
|
575
538
|
visit questionnaire_public_path
|
576
539
|
|
577
|
-
|
578
|
-
|
579
|
-
|
580
|
-
check "dark"
|
581
|
-
check "chocolate"
|
540
|
+
%w(We all like dark chocolate).reverse.each do |text|
|
541
|
+
find("div.answer-questionnaire__sorting", text:).drag_to(find("div.answer-questionnaire__sorting", match: :first))
|
542
|
+
end
|
582
543
|
|
583
544
|
check "questionnaire_tos_agreement"
|
584
545
|
|
585
546
|
accept_confirm { click_button "Submit" }
|
586
547
|
|
587
|
-
|
588
|
-
expect(page).to have_content("successfully")
|
589
|
-
end
|
590
|
-
|
548
|
+
expect(page).to have_admin_callout(callout_success)
|
591
549
|
expect(Decidim::Forms::Answer.first.choices.pluck(:position, :body)).to eq(
|
592
550
|
[[0, "We"], [1, "all"], [2, "like"], [3, "dark"], [4, "chocolate"]]
|
593
551
|
)
|
594
552
|
end
|
595
|
-
|
596
|
-
it "displays errors on incomplete sortings" do
|
597
|
-
visit questionnaire_public_path
|
598
|
-
|
599
|
-
check "We"
|
600
|
-
|
601
|
-
accept_confirm { click_button "Submit" }
|
602
|
-
|
603
|
-
within ".alert.flash" do
|
604
|
-
expect(page).to have_content("problem")
|
605
|
-
end
|
606
|
-
|
607
|
-
expect(page).to have_content("are not complete")
|
608
|
-
end
|
609
|
-
|
610
|
-
it "displays maintains sorting order if errors" do
|
611
|
-
visit questionnaire_public_path
|
612
|
-
|
613
|
-
check "We"
|
614
|
-
check "dark"
|
615
|
-
check "chocolate"
|
616
|
-
|
617
|
-
accept_confirm { click_button "Submit" }
|
618
|
-
|
619
|
-
within ".alert.flash" do
|
620
|
-
expect(page).to have_content("problem")
|
621
|
-
end
|
622
|
-
|
623
|
-
# Check the next round to ensure a re-submission conserves status
|
624
|
-
expect(page).to have_content("are not complete")
|
625
|
-
expect(page).to have_content("1. We\n2. dark\n3. chocolate\nlike\nall")
|
626
|
-
|
627
|
-
checkboxes = page.all("input[type=checkbox]")
|
628
|
-
|
629
|
-
checkboxes[0].uncheck
|
630
|
-
check "We"
|
631
|
-
check "all"
|
632
|
-
|
633
|
-
accept_confirm { click_button "Submit" }
|
634
|
-
|
635
|
-
within ".alert.flash" do
|
636
|
-
expect(page).to have_content("problem")
|
637
|
-
end
|
638
|
-
|
639
|
-
expect(page).to have_content("are not complete")
|
640
|
-
expect(page).to have_content("1. dark\n2. chocolate\n3. We\n4. all\nlike")
|
641
|
-
end
|
642
553
|
end
|
643
554
|
|
644
555
|
context "when question type is matrix_single" do
|
@@ -649,23 +560,23 @@ shared_examples_for "has questionnaire" do
|
|
649
560
|
let!(:question) do
|
650
561
|
create(
|
651
562
|
:questionnaire_question,
|
652
|
-
questionnaire
|
563
|
+
questionnaire:,
|
653
564
|
question_type: "matrix_single",
|
654
565
|
rows: matrix_rows,
|
655
566
|
options: answer_options,
|
656
|
-
mandatory:
|
567
|
+
mandatory:
|
657
568
|
)
|
658
569
|
end
|
659
570
|
|
660
571
|
it "renders the question answers as a collection of radio buttons" do
|
661
572
|
visit questionnaire_public_path
|
662
573
|
|
663
|
-
expect(page).to have_selector(".radio-button-collection input[type=radio]", count: 4)
|
574
|
+
expect(page).to have_selector(".js-radio-button-collection input[type=radio]", count: 4)
|
664
575
|
|
665
576
|
expect(page).to have_content(matrix_rows.map { |row| row["body"]["en"] }.join("\n"))
|
666
577
|
expect(page).to have_content(answer_options.map { |option| option["body"]["en"] }.join(" "))
|
667
578
|
|
668
|
-
radio_buttons = page.all(".radio-button-collection input[type=radio]")
|
579
|
+
radio_buttons = page.all(".js-radio-button-collection input[type=radio]")
|
669
580
|
|
670
581
|
choose radio_buttons.first[:id]
|
671
582
|
choose radio_buttons.last[:id]
|
@@ -674,9 +585,7 @@ shared_examples_for "has questionnaire" do
|
|
674
585
|
|
675
586
|
accept_confirm { click_button "Submit" }
|
676
587
|
|
677
|
-
|
678
|
-
expect(page).to have_content("successfully")
|
679
|
-
end
|
588
|
+
expect(page).to have_admin_callout(callout_success)
|
680
589
|
|
681
590
|
visit questionnaire_public_path
|
682
591
|
|
@@ -692,16 +601,14 @@ shared_examples_for "has questionnaire" do
|
|
692
601
|
it "preserves the chosen answers if submission not correct" do
|
693
602
|
visit questionnaire_public_path
|
694
603
|
|
695
|
-
radio_buttons = page.all(".radio-button-collection input[type=radio]")
|
604
|
+
radio_buttons = page.all(".js-radio-button-collection input[type=radio]")
|
696
605
|
choose radio_buttons[1][:id]
|
697
606
|
|
698
607
|
accept_confirm { click_button "Submit" }
|
699
608
|
|
700
|
-
|
701
|
-
expect(page).to have_content("There was a problem answering")
|
702
|
-
end
|
609
|
+
expect(page).to have_admin_callout("There was a problem answering")
|
703
610
|
|
704
|
-
radio_buttons = page.all(".radio-button-collection input[type=radio]")
|
611
|
+
radio_buttons = page.all(".js-radio-button-collection input[type=radio]")
|
705
612
|
expect(radio_buttons.pluck(:checked)).to eq([nil, "true", nil, nil])
|
706
613
|
end
|
707
614
|
|
@@ -711,16 +618,13 @@ shared_examples_for "has questionnaire" do
|
|
711
618
|
it "shows an error if the question is mandatory and the answer is not complete" do
|
712
619
|
visit questionnaire_public_path
|
713
620
|
|
714
|
-
radio_buttons = page.all(".radio-button-collection input[type=radio]")
|
621
|
+
radio_buttons = page.all(".js-radio-button-collection input[type=radio]")
|
715
622
|
choose radio_buttons[0][:id]
|
716
623
|
|
717
624
|
check "questionnaire_tos_agreement"
|
718
625
|
accept_confirm { click_button "Submit" }
|
719
626
|
|
720
|
-
|
721
|
-
expect(page).to have_content("There was a problem answering")
|
722
|
-
end
|
723
|
-
|
627
|
+
expect(page).to have_admin_callout("There was a problem answering")
|
724
628
|
expect(page).to have_content("Choices are not complete")
|
725
629
|
end
|
726
630
|
end
|
@@ -735,24 +639,24 @@ shared_examples_for "has questionnaire" do
|
|
735
639
|
let!(:question) do
|
736
640
|
create(
|
737
641
|
:questionnaire_question,
|
738
|
-
questionnaire
|
642
|
+
questionnaire:,
|
739
643
|
question_type: "matrix_multiple",
|
740
644
|
rows: matrix_rows,
|
741
645
|
options: answer_options,
|
742
|
-
max_choices
|
743
|
-
mandatory:
|
646
|
+
max_choices:,
|
647
|
+
mandatory:
|
744
648
|
)
|
745
649
|
end
|
746
650
|
|
747
651
|
it "renders the question answers as a collection of check boxes" do
|
748
652
|
visit questionnaire_public_path
|
749
653
|
|
750
|
-
expect(page).to have_selector(".check-box-collection input[type=checkbox]", count: 6)
|
654
|
+
expect(page).to have_selector(".js-check-box-collection input[type=checkbox]", count: 6)
|
751
655
|
|
752
656
|
expect(page).to have_content(matrix_rows.map { |row| row["body"]["en"] }.join("\n"))
|
753
657
|
expect(page).to have_content(answer_options.map { |option| option["body"]["en"] }.join(" "))
|
754
658
|
|
755
|
-
checkboxes = page.all(".check-box-collection input[type=checkbox]")
|
659
|
+
checkboxes = page.all(".js-check-box-collection input[type=checkbox]")
|
756
660
|
|
757
661
|
check checkboxes[0][:id]
|
758
662
|
check checkboxes[1][:id]
|
@@ -762,9 +666,7 @@ shared_examples_for "has questionnaire" do
|
|
762
666
|
|
763
667
|
accept_confirm { click_button "Submit" }
|
764
668
|
|
765
|
-
|
766
|
-
expect(page).to have_content("successfully")
|
767
|
-
end
|
669
|
+
expect(page).to have_admin_callout(callout_success)
|
768
670
|
|
769
671
|
visit questionnaire_public_path
|
770
672
|
|
@@ -786,7 +688,7 @@ shared_examples_for "has questionnaire" do
|
|
786
688
|
|
787
689
|
expect(page).to have_content("Max choices: 2")
|
788
690
|
|
789
|
-
checkboxes = page.all(".check-box-collection input[type=checkbox]")
|
691
|
+
checkboxes = page.all(".js-check-box-collection input[type=checkbox]")
|
790
692
|
|
791
693
|
check checkboxes[0][:id]
|
792
694
|
check checkboxes[1][:id]
|
@@ -809,21 +711,16 @@ shared_examples_for "has questionnaire" do
|
|
809
711
|
|
810
712
|
accept_confirm { click_button "Submit" }
|
811
713
|
|
812
|
-
|
813
|
-
expect(page).to have_content("There was a problem answering")
|
814
|
-
end
|
815
|
-
|
714
|
+
expect(page).to have_admin_callout("There was a problem answering")
|
816
715
|
expect(page).to have_content("are too many")
|
817
716
|
|
818
|
-
checkboxes = page.all(".check-box-collection input[type=checkbox]")
|
717
|
+
checkboxes = page.all(".js-check-box-collection input[type=checkbox]")
|
819
718
|
|
820
719
|
uncheck checkboxes[5][:id]
|
821
720
|
|
822
721
|
accept_confirm { click_button "Submit" }
|
823
722
|
|
824
|
-
|
825
|
-
expect(page).to have_content("successfully")
|
826
|
-
end
|
723
|
+
expect(page).to have_admin_callout(callout_success)
|
827
724
|
end
|
828
725
|
end
|
829
726
|
|
@@ -833,16 +730,13 @@ shared_examples_for "has questionnaire" do
|
|
833
730
|
it "shows an error" do
|
834
731
|
visit questionnaire_public_path
|
835
732
|
|
836
|
-
checkboxes = page.all(".check-box-collection input[type=checkbox]")
|
733
|
+
checkboxes = page.all(".js-check-box-collection input[type=checkbox]")
|
837
734
|
check checkboxes[0][:id]
|
838
735
|
|
839
736
|
check "questionnaire_tos_agreement"
|
840
737
|
accept_confirm { click_button "Submit" }
|
841
738
|
|
842
|
-
|
843
|
-
expect(page).to have_content("There was a problem answering")
|
844
|
-
end
|
845
|
-
|
739
|
+
expect(page).to have_admin_callout("There was a problem answering")
|
846
740
|
expect(page).to have_content("Choices are not complete")
|
847
741
|
end
|
848
742
|
end
|
@@ -853,7 +747,7 @@ shared_examples_for "has questionnaire" do
|
|
853
747
|
it "preserves the chosen answers" do
|
854
748
|
visit questionnaire_public_path
|
855
749
|
|
856
|
-
checkboxes = page.all(".check-box-collection input[type=checkbox]")
|
750
|
+
checkboxes = page.all(".js-check-box-collection input[type=checkbox]")
|
857
751
|
check checkboxes[0][:id]
|
858
752
|
check checkboxes[1][:id]
|
859
753
|
check checkboxes[2][:id]
|
@@ -862,11 +756,9 @@ shared_examples_for "has questionnaire" do
|
|
862
756
|
check "questionnaire_tos_agreement"
|
863
757
|
accept_confirm { click_button "Submit" }
|
864
758
|
|
865
|
-
|
866
|
-
expect(page).to have_content("There was a problem answering")
|
867
|
-
end
|
759
|
+
expect(page).to have_admin_callout("There was a problem answering")
|
868
760
|
|
869
|
-
checkboxes = page.all(".check-box-collection input[type=checkbox]")
|
761
|
+
checkboxes = page.all(".js-check-box-collection input[type=checkbox]")
|
870
762
|
expect(checkboxes.pluck(:checked)).to eq(["true", "true", "true", nil, nil, "true"])
|
871
763
|
end
|
872
764
|
end
|
@@ -882,11 +774,11 @@ shared_examples_for "has questionnaire" do
|
|
882
774
|
end
|
883
775
|
end
|
884
776
|
let(:condition_question_options) { [] }
|
885
|
-
let!(:question) { create(:questionnaire_question, questionnaire
|
777
|
+
let!(:question) { create(:questionnaire_question, questionnaire:, position: 2) }
|
886
778
|
let!(:conditioned_question_id) { "#questionnaire_responses_1" }
|
887
779
|
let!(:condition_question) do
|
888
780
|
create(:questionnaire_question,
|
889
|
-
questionnaire
|
781
|
+
questionnaire:,
|
890
782
|
question_type: condition_question_type,
|
891
783
|
position: 1,
|
892
784
|
options: condition_question_options)
|
@@ -897,8 +789,8 @@ shared_examples_for "has questionnaire" do
|
|
897
789
|
let!(:display_condition) do
|
898
790
|
create(:display_condition,
|
899
791
|
condition_type: "answered",
|
900
|
-
question
|
901
|
-
condition_question:
|
792
|
+
question:,
|
793
|
+
condition_question:)
|
902
794
|
end
|
903
795
|
|
904
796
|
before do
|
@@ -989,8 +881,8 @@ shared_examples_for "has questionnaire" do
|
|
989
881
|
let!(:display_condition) do
|
990
882
|
create(:display_condition,
|
991
883
|
condition_type: "not_answered",
|
992
|
-
question
|
993
|
-
condition_question:
|
884
|
+
question:,
|
885
|
+
condition_question:)
|
994
886
|
end
|
995
887
|
|
996
888
|
before do
|
@@ -1069,8 +961,8 @@ shared_examples_for "has questionnaire" do
|
|
1069
961
|
let!(:display_condition) do
|
1070
962
|
create(:display_condition,
|
1071
963
|
condition_type: "equal",
|
1072
|
-
question
|
1073
|
-
condition_question
|
964
|
+
question:,
|
965
|
+
condition_question:,
|
1074
966
|
answer_option: condition_question.answer_options.first)
|
1075
967
|
end
|
1076
968
|
|
@@ -1125,8 +1017,8 @@ shared_examples_for "has questionnaire" do
|
|
1125
1017
|
let!(:display_condition) do
|
1126
1018
|
create(:display_condition,
|
1127
1019
|
condition_type: "not_equal",
|
1128
|
-
question
|
1129
|
-
condition_question
|
1020
|
+
question:,
|
1021
|
+
condition_question:,
|
1130
1022
|
answer_option: condition_question.answer_options.first)
|
1131
1023
|
end
|
1132
1024
|
|
@@ -1182,9 +1074,9 @@ shared_examples_for "has questionnaire" do
|
|
1182
1074
|
let!(:display_condition) do
|
1183
1075
|
create(:display_condition,
|
1184
1076
|
condition_type: "match",
|
1185
|
-
question
|
1186
|
-
condition_question
|
1187
|
-
condition_value:
|
1077
|
+
question:,
|
1078
|
+
condition_question:,
|
1079
|
+
condition_value:)
|
1188
1080
|
end
|
1189
1081
|
|
1190
1082
|
before do
|
@@ -1197,7 +1089,7 @@ shared_examples_for "has questionnaire" do
|
|
1197
1089
|
it "shows the question only if the condition is fulfilled" do
|
1198
1090
|
expect_question_to_be_visible(false)
|
1199
1091
|
|
1200
|
-
fill_in "questionnaire_responses_0", with: "
|
1092
|
+
fill_in "questionnaire_responses_0", with: "Are not we all expecting #{condition_value[:en]}?"
|
1201
1093
|
change_focus
|
1202
1094
|
|
1203
1095
|
expect_question_to_be_visible(true)
|
@@ -1220,7 +1112,7 @@ shared_examples_for "has questionnaire" do
|
|
1220
1112
|
it "shows the question only if the condition is fulfilled" do
|
1221
1113
|
expect_question_to_be_visible(false)
|
1222
1114
|
|
1223
|
-
fill_in "questionnaire_responses_0", with: "
|
1115
|
+
fill_in "questionnaire_responses_0", with: "Are not we all expecting #{condition_value[:en]}?"
|
1224
1116
|
change_focus
|
1225
1117
|
|
1226
1118
|
expect_question_to_be_visible(true)
|
@@ -1318,13 +1210,13 @@ shared_examples_for "has questionnaire" do
|
|
1318
1210
|
[
|
1319
1211
|
create(:display_condition,
|
1320
1212
|
condition_type: "answered",
|
1321
|
-
question
|
1322
|
-
condition_question
|
1213
|
+
question:,
|
1214
|
+
condition_question:,
|
1323
1215
|
mandatory: true),
|
1324
1216
|
create(:display_condition,
|
1325
1217
|
condition_type: "not_equal",
|
1326
|
-
question
|
1327
|
-
condition_question
|
1218
|
+
question:,
|
1219
|
+
condition_question:,
|
1328
1220
|
mandatory: true,
|
1329
1221
|
answer_option: condition_question.answer_options.second)
|
1330
1222
|
]
|
@@ -1350,14 +1242,14 @@ shared_examples_for "has questionnaire" do
|
|
1350
1242
|
[
|
1351
1243
|
create(:display_condition,
|
1352
1244
|
condition_type: "equal",
|
1353
|
-
question
|
1354
|
-
condition_question
|
1245
|
+
question:,
|
1246
|
+
condition_question:,
|
1355
1247
|
mandatory: false,
|
1356
1248
|
answer_option: condition_question.answer_options.first),
|
1357
1249
|
create(:display_condition,
|
1358
1250
|
condition_type: "not_equal",
|
1359
|
-
question
|
1360
|
-
condition_question
|
1251
|
+
question:,
|
1252
|
+
condition_question:,
|
1361
1253
|
mandatory: false,
|
1362
1254
|
answer_option: condition_question.answer_options.third)
|
1363
1255
|
]
|
@@ -1383,19 +1275,19 @@ shared_examples_for "has questionnaire" do
|
|
1383
1275
|
|
1384
1276
|
context "when a mandatory question has conditions that have not been fulfilled" do
|
1385
1277
|
let!(:condition_question_type) { "short_answer" }
|
1386
|
-
let!(:question) { create(:questionnaire_question, questionnaire
|
1278
|
+
let!(:question) { create(:questionnaire_question, questionnaire:, position: 2, mandatory: true) }
|
1387
1279
|
let!(:display_conditions) do
|
1388
1280
|
[
|
1389
1281
|
create(:display_condition,
|
1390
1282
|
condition_type: "match",
|
1391
|
-
question
|
1392
|
-
condition_question
|
1283
|
+
question:,
|
1284
|
+
condition_question:,
|
1393
1285
|
condition_value: { en: "hey", es: "ey", ca: "ei" },
|
1394
1286
|
mandatory: true)
|
1395
1287
|
]
|
1396
1288
|
end
|
1397
1289
|
|
1398
|
-
it "
|
1290
|
+
it "does not throw error" do
|
1399
1291
|
visit questionnaire_public_path
|
1400
1292
|
|
1401
1293
|
fill_in condition_question.body["en"], with: "My first answer"
|
@@ -1404,9 +1296,7 @@ shared_examples_for "has questionnaire" do
|
|
1404
1296
|
|
1405
1297
|
accept_confirm { click_button "Submit" }
|
1406
1298
|
|
1407
|
-
|
1408
|
-
expect(page).to have_content("successfully")
|
1409
|
-
end
|
1299
|
+
expect(page).to have_admin_callout(callout_success)
|
1410
1300
|
end
|
1411
1301
|
end
|
1412
1302
|
end
|
@@ -1415,7 +1305,7 @@ shared_examples_for "has questionnaire" do
|
|
1415
1305
|
private
|
1416
1306
|
|
1417
1307
|
def expect_question_to_be_visible(visible)
|
1418
|
-
expect(page).to have_css(conditioned_question_id, visible:
|
1308
|
+
expect(page).to have_css(conditioned_question_id, visible:)
|
1419
1309
|
end
|
1420
1310
|
|
1421
1311
|
def change_focus
|