mumuki-laboratory 5.5.0 → 5.6.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (149) hide show
  1. checksums.yaml +4 -4
  2. data/app/assets/javascripts/application/discussions.js +43 -0
  3. data/app/assets/stylesheets/application/_modules.scss +2 -0
  4. data/app/assets/stylesheets/application/modules/_checkboxes.scss +21 -8
  5. data/app/assets/stylesheets/application/modules/_discussion.scss +339 -0
  6. data/app/assets/stylesheets/application/modules/_pagination.scss +10 -0
  7. data/app/controllers/application_controller.rb +4 -9
  8. data/app/controllers/book_discussions_controller.rb +7 -0
  9. data/app/controllers/chapters_controller.rb +2 -0
  10. data/app/controllers/discussions_controller.rb +65 -0
  11. data/app/controllers/discussions_messages_controller.rb +25 -0
  12. data/app/controllers/exercises_controller.rb +1 -0
  13. data/app/controllers/guide_container_controller.rb +1 -0
  14. data/app/controllers/messages_controller.rb +1 -1
  15. data/app/controllers/users_controller.rb +1 -0
  16. data/app/helpers/application_helper.rb +7 -0
  17. data/app/helpers/assignment_result_helper.rb +10 -30
  18. data/app/helpers/breadcrumbs_helper.rb +7 -3
  19. data/app/helpers/contextualization_result_helper.rb +31 -0
  20. data/app/helpers/discussions_helper.rb +163 -0
  21. data/app/helpers/exercise_input_helper.rb +33 -5
  22. data/app/helpers/icons_helper.rb +20 -3
  23. data/app/helpers/messages_helper.rb +4 -0
  24. data/app/helpers/status_helper.rb +2 -2
  25. data/app/models/assignment.rb +31 -47
  26. data/app/models/book.rb +3 -0
  27. data/app/models/chapter.rb +2 -0
  28. data/app/models/concerns/contextualization.rb +85 -0
  29. data/app/models/concerns/submittable/solvable.rb +1 -0
  30. data/app/models/concerns/with_assignments.rb +1 -1
  31. data/app/models/concerns/with_discussion_creation.rb +9 -0
  32. data/app/models/concerns/with_discussion_creation/subscription.rb +33 -0
  33. data/app/models/concerns/with_discussion_creation/upvote.rb +28 -0
  34. data/app/models/concerns/with_discussion_status.rb +11 -0
  35. data/app/models/concerns/with_discussions.rb +23 -0
  36. data/app/models/concerns/with_randomizations.rb +34 -0
  37. data/app/models/concerns/with_scoped_queries.rb +47 -0
  38. data/app/models/concerns/with_scoped_queries/filter.rb +15 -0
  39. data/app/models/concerns/with_scoped_queries/page.rb +10 -0
  40. data/app/models/concerns/with_scoped_queries/sort.rb +47 -0
  41. data/app/models/discussion.rb +128 -0
  42. data/app/models/exercise.rb +10 -1
  43. data/app/models/guide.rb +1 -1
  44. data/app/models/message.rb +24 -3
  45. data/app/models/organization.rb +4 -0
  46. data/app/models/submission/confirmation.rb +1 -1
  47. data/app/models/submission/console_submission.rb +1 -1
  48. data/app/models/submission/submission.rb +13 -0
  49. data/app/models/subscription.rb +12 -0
  50. data/app/models/topic.rb +1 -1
  51. data/app/models/upvote.rb +4 -0
  52. data/app/models/user.rb +3 -2
  53. data/app/views/book_discussions/index.html.erb +23 -0
  54. data/app/views/chapters/show.html.erb +0 -1
  55. data/app/views/discussions/_message.html.erb +22 -0
  56. data/app/views/discussions/_message_container.html.erb +8 -0
  57. data/app/views/discussions/_new_message.html.erb +19 -0
  58. data/app/views/discussions/index.html.erb +30 -0
  59. data/app/views/discussions/show.html.erb +76 -0
  60. data/app/views/exercise_solutions/_contextualization_results.html.erb +21 -0
  61. data/app/views/exercise_solutions/_contextualization_results_container.html.erb +4 -0
  62. data/app/views/exercise_solutions/_expectations.html.erb +9 -3
  63. data/app/views/exercise_solutions/_kids_results.html.erb +1 -1
  64. data/app/views/exercise_solutions/_results.html.erb +21 -55
  65. data/app/views/exercise_solutions/_results_title.html.erb +2 -2
  66. data/app/views/exercises/_exercise_assignment.html.erb +20 -0
  67. data/app/views/exercises/_read_only.html.erb +104 -0
  68. data/app/views/exercises/show.html.erb +4 -20
  69. data/app/views/layouts/_discussions.html.erb +68 -0
  70. data/app/views/layouts/_kids.html.erb +9 -6
  71. data/app/views/layouts/_messages.html.erb +1 -1
  72. data/app/views/layouts/_result.html.erb +2 -2
  73. data/app/views/layouts/_test_results.html.erb +6 -6
  74. data/app/views/layouts/application.html.erb +10 -9
  75. data/app/views/layouts/exercise_inputs/forms/_form.html.erb +5 -6
  76. data/app/views/layouts/exercise_inputs/forms/_interactive_form.html.erb +5 -5
  77. data/app/views/layouts/exercise_inputs/forms/_kids_form.html.erb +9 -17
  78. data/app/views/layouts/exercise_inputs/forms/_playground_form.html.erb +5 -5
  79. data/app/views/layouts/exercise_inputs/forms/_problem_form.html.erb +11 -11
  80. data/app/views/layouts/exercise_inputs/forms/_reading_form.html.erb +1 -1
  81. data/app/views/layouts/exercise_inputs/layouts/_input_bottom.html.erb +1 -1
  82. data/app/views/layouts/exercise_inputs/layouts/_input_kids.html.erb +7 -7
  83. data/app/views/layouts/exercise_inputs/layouts/_input_right.html.erb +1 -1
  84. data/app/views/layouts/exercise_inputs/read_only_editors/_code.html.erb +3 -0
  85. data/app/views/layouts/exercise_inputs/read_only_editors/_custom.html.erb +6 -0
  86. data/app/views/layouts/exercise_inputs/read_only_editors/_multiple_choice.html.erb +8 -0
  87. data/app/views/layouts/exercise_inputs/read_only_editors/_single_choice.html.erb +8 -0
  88. data/app/views/layouts/modals/_kids_context.html.erb +2 -2
  89. data/app/views/layouts/modals/_new_discussion.html.erb +27 -0
  90. data/app/views/users/show.html.erb +23 -3
  91. data/config/routes.rb +21 -1
  92. data/db/migrate/20180504173548_create_discussions.rb +12 -0
  93. data/db/migrate/20180504185845_add_discussion_id_to_message.rb +5 -0
  94. data/db/migrate/20180605143727_add_submission_to_discussion.rb +16 -0
  95. data/db/migrate/20180619182555_create_subscriptions.rb +9 -0
  96. data/db/migrate/20180702153442_create_upvotes.rb +8 -0
  97. data/db/migrate/20180702175220_add_upvotes_count_to_discussions.rb +5 -0
  98. data/db/migrate/20180704150839_rename_assignment_status_to_submission_status.rb +5 -0
  99. data/lib/mumuki/laboratory.rb +2 -0
  100. data/lib/mumuki/laboratory/controllers.rb +2 -1
  101. data/lib/mumuki/laboratory/controllers/content.rb +12 -0
  102. data/lib/mumuki/laboratory/controllers/notifications.rb +31 -0
  103. data/lib/mumuki/laboratory/controllers/results_rendering.rb +1 -1
  104. data/lib/mumuki/laboratory/engine.rb +0 -2
  105. data/lib/mumuki/laboratory/evaluation/manual.rb +1 -1
  106. data/lib/mumuki/laboratory/locales/en.yml +37 -1
  107. data/lib/mumuki/laboratory/locales/es.yml +42 -1
  108. data/lib/mumuki/laboratory/locales/pt.yml +33 -1
  109. data/lib/mumuki/laboratory/status.rb +51 -44
  110. data/lib/mumuki/laboratory/status/discussion/closed.rb +15 -0
  111. data/lib/mumuki/laboratory/status/discussion/discussion.rb +56 -0
  112. data/lib/mumuki/laboratory/status/discussion/opened.rb +27 -0
  113. data/lib/mumuki/laboratory/status/discussion/pending_review.rb +15 -0
  114. data/lib/mumuki/laboratory/status/discussion/solved.rb +19 -0
  115. data/lib/mumuki/laboratory/status/submission/aborted.rb +11 -0
  116. data/lib/mumuki/laboratory/status/submission/errored.rb +15 -0
  117. data/lib/mumuki/laboratory/status/{failed.rb → submission/failed.rb} +2 -2
  118. data/lib/mumuki/laboratory/status/submission/manual_evaluation_pending.rb +15 -0
  119. data/lib/mumuki/laboratory/status/{passed.rb → submission/passed.rb} +2 -2
  120. data/lib/mumuki/laboratory/status/{passed_with_warnings.rb → submission/passed_with_warnings.rb} +2 -2
  121. data/lib/mumuki/laboratory/status/submission/pending.rb +11 -0
  122. data/lib/mumuki/laboratory/status/submission/running.rb +11 -0
  123. data/lib/mumuki/laboratory/status/submission/submission.rb +49 -0
  124. data/lib/mumuki/laboratory/status/{unknown.rb → submission/unknown.rb} +2 -2
  125. data/lib/mumuki/laboratory/version.rb +1 -1
  126. data/spec/controllers/chapters_controller_spec.rb +17 -0
  127. data/spec/controllers/discussions_controller_spec.rb +19 -0
  128. data/spec/dummy/config/environments/development.rb +0 -2
  129. data/spec/dummy/config/environments/test.rb +0 -2
  130. data/spec/dummy/db/schema.rb +42 -2
  131. data/spec/evaluation_helper.rb +1 -1
  132. data/spec/factories/discussion_factory.rb +8 -0
  133. data/spec/features/dynamic_exam_spec.rb +1 -1
  134. data/spec/helpers/exercise_input_helper_spec.rb +25 -0
  135. data/spec/helpers/test_results_rendering_spec.rb +7 -7
  136. data/spec/models/assignment_spec.rb +17 -2
  137. data/spec/models/discussion_spec.rb +153 -0
  138. metadata +108 -27
  139. data/app/models/concerns/with_status.rb +0 -43
  140. data/app/models/status_rendering_verbosity.rb +0 -40
  141. data/lib/mumuki/laboratory/controllers/messages.rb +0 -9
  142. data/lib/mumuki/laboratory/status/aborted.rb +0 -7
  143. data/lib/mumuki/laboratory/status/base.rb +0 -47
  144. data/lib/mumuki/laboratory/status/errored.rb +0 -15
  145. data/lib/mumuki/laboratory/status/manual_evaluation_pending.rb +0 -15
  146. data/lib/mumuki/laboratory/status/pending.rb +0 -11
  147. data/lib/mumuki/laboratory/status/running.rb +0 -11
  148. data/spec/models/randomizer_spec.rb +0 -18
  149. data/spec/models/verbosity_spec.rb +0 -24
@@ -0,0 +1,27 @@
1
+ module Mumuki::Laboratory::Status::Discussion::Opened
2
+ extend Mumuki::Laboratory::Status::Discussion
3
+
4
+ def self.opened?
5
+ true
6
+ end
7
+
8
+ def self.reachable_statuses_for_initiator(discussion)
9
+ if discussion.has_responses?
10
+ [Mumuki::Laboratory::Status::Discussion::PendingReview]
11
+ else
12
+ [Mumuki::Laboratory::Status::Discussion::Closed]
13
+ end
14
+ end
15
+
16
+ def self.reachable_statuses_for_moderator(_)
17
+ [Mumuki::Laboratory::Status::Discussion::Closed, Mumuki::Laboratory::Status::Discussion::Solved]
18
+ end
19
+
20
+ def self.iconize
21
+ {class: :warning, type: 'question-circle'}
22
+ end
23
+
24
+ def self.should_be_shown?(*)
25
+ true
26
+ end
27
+ end
@@ -0,0 +1,15 @@
1
+ module Mumuki::Laboratory::Status::Discussion::PendingReview
2
+ extend Mumuki::Laboratory::Status::Discussion
3
+
4
+ def self.pending_review?
5
+ true
6
+ end
7
+
8
+ def self.reachable_statuses_for_moderator(*)
9
+ [Mumuki::Laboratory::Status::Discussion::Closed, Mumuki::Laboratory::Status::Discussion::Solved]
10
+ end
11
+
12
+ def self.iconize
13
+ {class: :info, type: 'hourglass'}
14
+ end
15
+ end
@@ -0,0 +1,19 @@
1
+ module Mumuki::Laboratory::Status::Discussion::Solved
2
+ extend Mumuki::Laboratory::Status::Discussion
3
+
4
+ def self.solved?
5
+ true
6
+ end
7
+
8
+ def self.reachable_statuses_for_moderator(*)
9
+ [Mumuki::Laboratory::Status::Discussion::Closed]
10
+ end
11
+
12
+ def self.iconize
13
+ {class: :success, type: 'check-circle'}
14
+ end
15
+
16
+ def self.should_be_shown?(*)
17
+ true
18
+ end
19
+ end
@@ -0,0 +1,11 @@
1
+ module Mumuki::Laboratory::Status::Submission::Aborted
2
+ extend Mumuki::Laboratory::Status::Submission
3
+
4
+ def self.group
5
+ Mumuki::Laboratory::Status::Submission::Failed
6
+ end
7
+
8
+ def aborted?
9
+ true
10
+ end
11
+ end
@@ -0,0 +1,15 @@
1
+ module Mumuki::Laboratory::Status::Submission::Errored
2
+ extend Mumuki::Laboratory::Status::Submission
3
+
4
+ def self.errored?
5
+ true
6
+ end
7
+
8
+ def self.group
9
+ Mumuki::Laboratory::Status::Submission::Failed
10
+ end
11
+
12
+ def self.iconize
13
+ {class: :broken, type: 'minus-circle'}
14
+ end
15
+ end
@@ -1,5 +1,5 @@
1
- module Mumuki::Laboratory::Status::Failed
2
- extend Mumuki::Laboratory::Status::Base
1
+ module Mumuki::Laboratory::Status::Submission::Failed
2
+ extend Mumuki::Laboratory::Status::Submission
3
3
 
4
4
  def self.failed?
5
5
  true
@@ -0,0 +1,15 @@
1
+ module Mumuki::Laboratory::Status::Submission::ManualEvaluationPending
2
+ extend Mumuki::Laboratory::Status::Submission
3
+
4
+ def self.passed?
5
+ true
6
+ end
7
+
8
+ def self.group
9
+ Mumuki::Laboratory::Status::Submission::Passed
10
+ end
11
+
12
+ def self.iconize
13
+ {class: :info, type: 'clock-o'}
14
+ end
15
+ end
@@ -1,5 +1,5 @@
1
- module Mumuki::Laboratory::Status::Passed
2
- extend Mumuki::Laboratory::Status::Base
1
+ module Mumuki::Laboratory::Status::Submission::Passed
2
+ extend Mumuki::Laboratory::Status::Submission
3
3
 
4
4
  def self.passed?
5
5
  true
@@ -1,5 +1,5 @@
1
- module Mumuki::Laboratory::Status::PassedWithWarnings
2
- extend Mumuki::Laboratory::Status::Base
1
+ module Mumuki::Laboratory::Status::Submission::PassedWithWarnings
2
+ extend Mumuki::Laboratory::Status::Submission
3
3
 
4
4
  def self.passed?
5
5
  true
@@ -0,0 +1,11 @@
1
+ module Mumuki::Laboratory::Status::Submission::Pending
2
+ extend Mumuki::Laboratory::Status::Submission
3
+
4
+ def self.group
5
+ Mumuki::Laboratory::Status::Submission::Unknown
6
+ end
7
+
8
+ def self.iconize
9
+ {class: :info, type: 'clock-o'}
10
+ end
11
+ end
@@ -0,0 +1,11 @@
1
+ module Mumuki::Laboratory::Status::Submission::Running
2
+ extend Mumuki::Laboratory::Status::Submission
3
+
4
+ def self.group
5
+ Mumuki::Laboratory::Status::Submission::Unknown
6
+ end
7
+
8
+ def self.iconize
9
+ {class: :info, type: :circle}
10
+ end
11
+ end
@@ -0,0 +1,49 @@
1
+ module Mumuki::Laboratory::Status::Submission
2
+ include Mumuki::Laboratory::Status
3
+ end
4
+
5
+ require_relative './unknown'
6
+ require_relative './pending'
7
+ require_relative './running'
8
+ require_relative './passed'
9
+ require_relative './failed'
10
+ require_relative './errored'
11
+ require_relative './aborted'
12
+ require_relative './passed_with_warnings'
13
+ require_relative './manual_evaluation_pending'
14
+
15
+ module Mumuki::Laboratory::Status::Submission
16
+ STATUSES = [Pending, Running, Passed, Failed, Errored, Aborted, PassedWithWarnings, ManualEvaluationPending]
17
+
18
+ def group
19
+ self
20
+ end
21
+
22
+ def passed?
23
+ false
24
+ end
25
+
26
+ def failed?
27
+ false
28
+ end
29
+
30
+ def errored?
31
+ false
32
+ end
33
+
34
+ def aborted?
35
+ false
36
+ end
37
+
38
+ def should_retry?
39
+ true
40
+ end
41
+
42
+ def iconize
43
+ group.iconize
44
+ end
45
+
46
+ def as_json(_options={})
47
+ to_s
48
+ end
49
+ end
@@ -1,5 +1,5 @@
1
- module Mumuki::Laboratory::Status::Unknown
2
- extend Mumuki::Laboratory::Status::Base
1
+ module Mumuki::Laboratory::Status::Submission::Unknown
2
+ extend Mumuki::Laboratory::Status::Submission
3
3
 
4
4
  def self.to_i
5
5
  raise 'unknown status'
@@ -1,5 +1,5 @@
1
1
  module Mumuki
2
2
  module Laboratory
3
- VERSION = '5.5.0'
3
+ VERSION = '5.6.0'
4
4
  end
5
5
  end
@@ -0,0 +1,17 @@
1
+ require 'spec_helper'
2
+
3
+ describe ChaptersController, type: :controller, organization_workspace: :test do
4
+ describe 'when chapter does not exist' do
5
+ before { get :show, params: {id: 0} }
6
+
7
+ it { expect(response.status).to eq 404 }
8
+ end
9
+
10
+ describe 'when chapter exists' do
11
+ let!(:chapter) { create(:chapter) }
12
+
13
+ before { get :show, params: {id: chapter.id} }
14
+
15
+ it { expect(response.status).to eq 200 }
16
+ end
17
+ end
@@ -0,0 +1,19 @@
1
+ require 'spec_helper'
2
+
3
+ describe DiscussionsController, organization_workspace: :test do
4
+ let(:user) { create(:user) }
5
+ let(:exercise) { create(:exercise) }
6
+ let(:exercise_params) { {debatable_class: 'Exercise', exercise_id: exercise.id} }
7
+
8
+ before { set_current_user! user }
9
+
10
+ describe 'post' do
11
+ before { allow_any_instance_of(DiscussionsController).to receive(:discussion_params).and_return title: 'A title' }
12
+ before { post :create, params: exercise_params }
13
+
14
+ it { expect(response.status).to eq 302 }
15
+ it { expect(exercise.discussions.size).to eq 1 }
16
+ it { expect(user.discussions.size).to eq 1 }
17
+ it { expect(user.watched_discussions.size).to eq 1 }
18
+ end
19
+ end
@@ -52,6 +52,4 @@ Rails.application.configure do
52
52
  # Use an evented file watcher to asynchronously detect changes in source code,
53
53
  # routes, locales, etc. This feature depends on the listen gem.
54
54
  # config.file_watcher = ActiveSupport::EventedFileUpdateChecker
55
-
56
- config.status_rendering_verbosity = :verbose
57
55
  end
@@ -42,8 +42,6 @@ Rails.application.configure do
42
42
 
43
43
  config.i18n.default_locale = :en
44
44
 
45
- config.status_rendering_verbosity = :standard
46
-
47
45
  OmniAuth.config.test_mode = true
48
46
  OmniAuth.config.mock_auth[:developer] =
49
47
  OmniAuth::AuthHash.new provider: 'developer',
@@ -10,7 +10,7 @@
10
10
  #
11
11
  # It's strongly recommended that you check this file into your version control system.
12
12
 
13
- ActiveRecord::Schema.define(version: 20180611190239) do
13
+ ActiveRecord::Schema.define(version: 20180704150839) do
14
14
 
15
15
  # These are extensions that must be enabled in order to support this database
16
16
  enable_extension "plpgsql"
@@ -27,7 +27,7 @@ ActiveRecord::Schema.define(version: 20180611190239) do
27
27
  create_table "assignments", id: :serial, force: :cascade do |t|
28
28
  t.text "solution"
29
29
  t.integer "exercise_id"
30
- t.integer "status", default: 0
30
+ t.integer "submission_status", default: 0
31
31
  t.text "result"
32
32
  t.integer "submitter_id"
33
33
  t.text "expectation_results"
@@ -86,6 +86,30 @@ ActiveRecord::Schema.define(version: 20180611190239) do
86
86
  t.datetime "updated_at", null: false
87
87
  end
88
88
 
89
+ create_table "discussions", force: :cascade do |t|
90
+ t.integer "status", default: 0
91
+ t.string "title"
92
+ t.text "description"
93
+ t.bigint "initiator_id"
94
+ t.string "item_type"
95
+ t.bigint "item_id"
96
+ t.datetime "created_at", null: false
97
+ t.datetime "updated_at", null: false
98
+ t.text "solution"
99
+ t.integer "submission_status", default: 0
100
+ t.text "result"
101
+ t.text "expectation_results"
102
+ t.text "feedback"
103
+ t.text "test_results"
104
+ t.string "submission_id"
105
+ t.string "queries", default: [], array: true
106
+ t.text "query_results"
107
+ t.text "manual_evaluation_comment"
108
+ t.integer "upvotes_count"
109
+ t.index ["initiator_id"], name: "index_discussions_on_initiator_id"
110
+ t.index ["item_type", "item_id"], name: "index_discussions_on_item_type_and_item_id"
111
+ end
112
+
89
113
  create_table "exam_authorizations", force: :cascade do |t|
90
114
  t.integer "exam_id"
91
115
  t.integer "user_id"
@@ -210,6 +234,7 @@ ActiveRecord::Schema.define(version: 20180611190239) do
210
234
  t.datetime "created_at"
211
235
  t.datetime "updated_at"
212
236
  t.boolean "read", default: false
237
+ t.integer "discussion_id"
213
238
  end
214
239
 
215
240
  create_table "organizations", id: :serial, force: :cascade do |t|
@@ -232,6 +257,14 @@ ActiveRecord::Schema.define(version: 20180611190239) do
232
257
  t.index ["language_id"], name: "index_paths_on_language_id"
233
258
  end
234
259
 
260
+ create_table "subscriptions", force: :cascade do |t|
261
+ t.bigint "user_id"
262
+ t.bigint "discussion_id"
263
+ t.boolean "read", default: true
264
+ t.index ["discussion_id"], name: "index_subscriptions_on_discussion_id"
265
+ t.index ["user_id"], name: "index_subscriptions_on_user_id"
266
+ end
267
+
235
268
  create_table "topics", id: :serial, force: :cascade do |t|
236
269
  t.string "name"
237
270
  t.string "locale"
@@ -243,6 +276,13 @@ ActiveRecord::Schema.define(version: 20180611190239) do
243
276
  t.index ["slug"], name: "index_topics_on_slug", unique: true
244
277
  end
245
278
 
279
+ create_table "upvotes", force: :cascade do |t|
280
+ t.bigint "user_id"
281
+ t.bigint "discussion_id"
282
+ t.index ["discussion_id"], name: "index_upvotes_on_discussion_id"
283
+ t.index ["user_id"], name: "index_upvotes_on_user_id"
284
+ end
285
+
246
286
  create_table "usages", id: :serial, force: :cascade do |t|
247
287
  t.integer "organization_id"
248
288
  t.string "slug"
@@ -1,6 +1,6 @@
1
1
  Language.class_eval do
2
2
  def test_only_fake_response
3
- {status: Mumuki::Laboratory::Status::Failed, result: 'noop result'}
3
+ {status: Mumuki::Laboratory::Status::Submission::Failed, result: 'noop result'}
4
4
  end
5
5
 
6
6
  def run_tests!(*)
@@ -0,0 +1,8 @@
1
+ FactoryBot.define do
2
+ factory :discussion do
3
+ title 'A discussion'
4
+ description 'A discussion description'
5
+ initiator { create(:user) }
6
+ item { create(:exercise) }
7
+ end
8
+ end
@@ -4,7 +4,7 @@ feature 'Dynamic Exam', organization_workspace: :test do
4
4
  let(:user) { create(:user, id: 1) }
5
5
  let(:user2) { create(:user, id: 2) }
6
6
 
7
- let!(:problem) { build(:problem, description: 'do f = $someVariable', randomizations: { someVariable: { type: :oneOf, value: %w(some_string some_other_string)} }) }
7
+ let!(:problem) { build(:problem, description: 'do f = $someVariable', randomizations: { someVariable: { type: :one_of, value: %w(some_string some_other_string)} }) }
8
8
 
9
9
  let!(:chapter) {
10
10
  create(:chapter, lessons: [
@@ -24,6 +24,31 @@ describe ApplicationHelper, organization_workspace: :test do
24
24
  end
25
25
  end
26
26
 
27
+ describe 'should_render_need_help_dropdown?' do
28
+ let(:assignment) { create(:assignment) }
29
+
30
+ context 'when the orga has a community link' do
31
+ let(:organization) { create(:organization, name: 'myorg', community_link: 'com_link') }
32
+ it { expect(should_render_need_help_dropdown? assignment, organization).to be true }
33
+ end
34
+ context 'when report issue enabled' do
35
+ let(:organization) { create(:organization, name: 'myorg', report_issue_enabled: true) }
36
+ it { expect(should_render_need_help_dropdown? assignment, organization).to be true }
37
+ end
38
+ context 'when forum enabled' do
39
+ let(:organization) { create(:organization, name: 'myorg', forum_enabled: true) }
40
+ it { expect(should_render_need_help_dropdown? assignment, organization).to be true }
41
+ end
42
+ context 'when ask for help is not enabled' do
43
+ it { expect(should_render_need_help_dropdown? assignment).to be false }
44
+ end
45
+ context 'when assignment passed' do
46
+ let(:organization) { create(:organization, name: 'myorg', forum_enabled: true) }
47
+ let(:assignment) { create(:assignment, status: :passed) }
48
+ it { expect(should_render_need_help_dropdown? assignment, organization).to be false }
49
+ end
50
+ end
51
+
27
52
  describe 'should_render_problem_tabs?' do
28
53
  let(:student) { create(:user) }
29
54
 
@@ -1,15 +1,15 @@
1
1
  require 'spec_helper'
2
2
  require 'ostruct'
3
3
 
4
- describe AssignmentResultHelper do
4
+ describe ContextualizationResultHelper do
5
5
  helper IconsHelper
6
- helper AssignmentResultHelper
6
+ helper ContextualizationResultHelper
7
7
 
8
- let(:html) { render_test_results assignment }
8
+ let(:html) { render_test_results contextualization }
9
9
 
10
10
  context 'structured results' do
11
11
  context 'when single passed submission' do
12
- let(:assignment) { struct(
12
+ let(:contextualization) { struct(
13
13
  exercise: struct(hidden?: false),
14
14
  test_results: [{title: '2 is 2', status: :passed, result: ''}],
15
15
  output_content_type: Mumukit::ContentType::Plain) }
@@ -21,7 +21,7 @@ describe AssignmentResultHelper do
21
21
 
22
22
  context 'when single failed submission' do
23
23
  context 'when plain results' do
24
- let(:assignment) { struct(
24
+ let(:contextualization) { struct(
25
25
  exercise: struct(hidden?: false),
26
26
  test_results: [{title: '2 is 2', status: :failed, result: 'something _went_ wrong'}],
27
27
  output_content_type: Mumukit::ContentType::Plain) }
@@ -32,7 +32,7 @@ describe AssignmentResultHelper do
32
32
  end
33
33
 
34
34
  context 'when markdown results' do
35
- let(:assignment) { struct(
35
+ let(:contextualization) { struct(
36
36
  exercise: struct(hidden?: false),
37
37
  test_results: [{title: '2 is 2', status: :failed, result: 'something went _really_ wrong'}],
38
38
  output_content_type: Mumukit::ContentType::Markdown) }
@@ -45,7 +45,7 @@ describe AssignmentResultHelper do
45
45
  end
46
46
 
47
47
  context 'unstructured results' do
48
- let(:assignment) { struct(
48
+ let(:contextualization) { struct(
49
49
  exercise: struct(hidden?: false),
50
50
  result_html: '<pre>ooops, something went wrong</pre>'.html_safe) }
51
51