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.
- checksums.yaml +4 -4
- data/app/assets/javascripts/application/discussions.js +43 -0
- data/app/assets/stylesheets/application/_modules.scss +2 -0
- data/app/assets/stylesheets/application/modules/_checkboxes.scss +21 -8
- data/app/assets/stylesheets/application/modules/_discussion.scss +339 -0
- data/app/assets/stylesheets/application/modules/_pagination.scss +10 -0
- data/app/controllers/application_controller.rb +4 -9
- data/app/controllers/book_discussions_controller.rb +7 -0
- data/app/controllers/chapters_controller.rb +2 -0
- data/app/controllers/discussions_controller.rb +65 -0
- data/app/controllers/discussions_messages_controller.rb +25 -0
- data/app/controllers/exercises_controller.rb +1 -0
- data/app/controllers/guide_container_controller.rb +1 -0
- data/app/controllers/messages_controller.rb +1 -1
- data/app/controllers/users_controller.rb +1 -0
- data/app/helpers/application_helper.rb +7 -0
- data/app/helpers/assignment_result_helper.rb +10 -30
- data/app/helpers/breadcrumbs_helper.rb +7 -3
- data/app/helpers/contextualization_result_helper.rb +31 -0
- data/app/helpers/discussions_helper.rb +163 -0
- data/app/helpers/exercise_input_helper.rb +33 -5
- data/app/helpers/icons_helper.rb +20 -3
- data/app/helpers/messages_helper.rb +4 -0
- data/app/helpers/status_helper.rb +2 -2
- data/app/models/assignment.rb +31 -47
- data/app/models/book.rb +3 -0
- data/app/models/chapter.rb +2 -0
- data/app/models/concerns/contextualization.rb +85 -0
- data/app/models/concerns/submittable/solvable.rb +1 -0
- data/app/models/concerns/with_assignments.rb +1 -1
- data/app/models/concerns/with_discussion_creation.rb +9 -0
- data/app/models/concerns/with_discussion_creation/subscription.rb +33 -0
- data/app/models/concerns/with_discussion_creation/upvote.rb +28 -0
- data/app/models/concerns/with_discussion_status.rb +11 -0
- data/app/models/concerns/with_discussions.rb +23 -0
- data/app/models/concerns/with_randomizations.rb +34 -0
- data/app/models/concerns/with_scoped_queries.rb +47 -0
- data/app/models/concerns/with_scoped_queries/filter.rb +15 -0
- data/app/models/concerns/with_scoped_queries/page.rb +10 -0
- data/app/models/concerns/with_scoped_queries/sort.rb +47 -0
- data/app/models/discussion.rb +128 -0
- data/app/models/exercise.rb +10 -1
- data/app/models/guide.rb +1 -1
- data/app/models/message.rb +24 -3
- data/app/models/organization.rb +4 -0
- data/app/models/submission/confirmation.rb +1 -1
- data/app/models/submission/console_submission.rb +1 -1
- data/app/models/submission/submission.rb +13 -0
- data/app/models/subscription.rb +12 -0
- data/app/models/topic.rb +1 -1
- data/app/models/upvote.rb +4 -0
- data/app/models/user.rb +3 -2
- data/app/views/book_discussions/index.html.erb +23 -0
- data/app/views/chapters/show.html.erb +0 -1
- data/app/views/discussions/_message.html.erb +22 -0
- data/app/views/discussions/_message_container.html.erb +8 -0
- data/app/views/discussions/_new_message.html.erb +19 -0
- data/app/views/discussions/index.html.erb +30 -0
- data/app/views/discussions/show.html.erb +76 -0
- data/app/views/exercise_solutions/_contextualization_results.html.erb +21 -0
- data/app/views/exercise_solutions/_contextualization_results_container.html.erb +4 -0
- data/app/views/exercise_solutions/_expectations.html.erb +9 -3
- data/app/views/exercise_solutions/_kids_results.html.erb +1 -1
- data/app/views/exercise_solutions/_results.html.erb +21 -55
- data/app/views/exercise_solutions/_results_title.html.erb +2 -2
- data/app/views/exercises/_exercise_assignment.html.erb +20 -0
- data/app/views/exercises/_read_only.html.erb +104 -0
- data/app/views/exercises/show.html.erb +4 -20
- data/app/views/layouts/_discussions.html.erb +68 -0
- data/app/views/layouts/_kids.html.erb +9 -6
- data/app/views/layouts/_messages.html.erb +1 -1
- data/app/views/layouts/_result.html.erb +2 -2
- data/app/views/layouts/_test_results.html.erb +6 -6
- data/app/views/layouts/application.html.erb +10 -9
- data/app/views/layouts/exercise_inputs/forms/_form.html.erb +5 -6
- data/app/views/layouts/exercise_inputs/forms/_interactive_form.html.erb +5 -5
- data/app/views/layouts/exercise_inputs/forms/_kids_form.html.erb +9 -17
- data/app/views/layouts/exercise_inputs/forms/_playground_form.html.erb +5 -5
- data/app/views/layouts/exercise_inputs/forms/_problem_form.html.erb +11 -11
- data/app/views/layouts/exercise_inputs/forms/_reading_form.html.erb +1 -1
- data/app/views/layouts/exercise_inputs/layouts/_input_bottom.html.erb +1 -1
- data/app/views/layouts/exercise_inputs/layouts/_input_kids.html.erb +7 -7
- data/app/views/layouts/exercise_inputs/layouts/_input_right.html.erb +1 -1
- data/app/views/layouts/exercise_inputs/read_only_editors/_code.html.erb +3 -0
- data/app/views/layouts/exercise_inputs/read_only_editors/_custom.html.erb +6 -0
- data/app/views/layouts/exercise_inputs/read_only_editors/_multiple_choice.html.erb +8 -0
- data/app/views/layouts/exercise_inputs/read_only_editors/_single_choice.html.erb +8 -0
- data/app/views/layouts/modals/_kids_context.html.erb +2 -2
- data/app/views/layouts/modals/_new_discussion.html.erb +27 -0
- data/app/views/users/show.html.erb +23 -3
- data/config/routes.rb +21 -1
- data/db/migrate/20180504173548_create_discussions.rb +12 -0
- data/db/migrate/20180504185845_add_discussion_id_to_message.rb +5 -0
- data/db/migrate/20180605143727_add_submission_to_discussion.rb +16 -0
- data/db/migrate/20180619182555_create_subscriptions.rb +9 -0
- data/db/migrate/20180702153442_create_upvotes.rb +8 -0
- data/db/migrate/20180702175220_add_upvotes_count_to_discussions.rb +5 -0
- data/db/migrate/20180704150839_rename_assignment_status_to_submission_status.rb +5 -0
- data/lib/mumuki/laboratory.rb +2 -0
- data/lib/mumuki/laboratory/controllers.rb +2 -1
- data/lib/mumuki/laboratory/controllers/content.rb +12 -0
- data/lib/mumuki/laboratory/controllers/notifications.rb +31 -0
- data/lib/mumuki/laboratory/controllers/results_rendering.rb +1 -1
- data/lib/mumuki/laboratory/engine.rb +0 -2
- data/lib/mumuki/laboratory/evaluation/manual.rb +1 -1
- data/lib/mumuki/laboratory/locales/en.yml +37 -1
- data/lib/mumuki/laboratory/locales/es.yml +42 -1
- data/lib/mumuki/laboratory/locales/pt.yml +33 -1
- data/lib/mumuki/laboratory/status.rb +51 -44
- data/lib/mumuki/laboratory/status/discussion/closed.rb +15 -0
- data/lib/mumuki/laboratory/status/discussion/discussion.rb +56 -0
- data/lib/mumuki/laboratory/status/discussion/opened.rb +27 -0
- data/lib/mumuki/laboratory/status/discussion/pending_review.rb +15 -0
- data/lib/mumuki/laboratory/status/discussion/solved.rb +19 -0
- data/lib/mumuki/laboratory/status/submission/aborted.rb +11 -0
- data/lib/mumuki/laboratory/status/submission/errored.rb +15 -0
- data/lib/mumuki/laboratory/status/{failed.rb → submission/failed.rb} +2 -2
- data/lib/mumuki/laboratory/status/submission/manual_evaluation_pending.rb +15 -0
- data/lib/mumuki/laboratory/status/{passed.rb → submission/passed.rb} +2 -2
- data/lib/mumuki/laboratory/status/{passed_with_warnings.rb → submission/passed_with_warnings.rb} +2 -2
- data/lib/mumuki/laboratory/status/submission/pending.rb +11 -0
- data/lib/mumuki/laboratory/status/submission/running.rb +11 -0
- data/lib/mumuki/laboratory/status/submission/submission.rb +49 -0
- data/lib/mumuki/laboratory/status/{unknown.rb → submission/unknown.rb} +2 -2
- data/lib/mumuki/laboratory/version.rb +1 -1
- data/spec/controllers/chapters_controller_spec.rb +17 -0
- data/spec/controllers/discussions_controller_spec.rb +19 -0
- data/spec/dummy/config/environments/development.rb +0 -2
- data/spec/dummy/config/environments/test.rb +0 -2
- data/spec/dummy/db/schema.rb +42 -2
- data/spec/evaluation_helper.rb +1 -1
- data/spec/factories/discussion_factory.rb +8 -0
- data/spec/features/dynamic_exam_spec.rb +1 -1
- data/spec/helpers/exercise_input_helper_spec.rb +25 -0
- data/spec/helpers/test_results_rendering_spec.rb +7 -7
- data/spec/models/assignment_spec.rb +17 -2
- data/spec/models/discussion_spec.rb +153 -0
- metadata +108 -27
- data/app/models/concerns/with_status.rb +0 -43
- data/app/models/status_rendering_verbosity.rb +0 -40
- data/lib/mumuki/laboratory/controllers/messages.rb +0 -9
- data/lib/mumuki/laboratory/status/aborted.rb +0 -7
- data/lib/mumuki/laboratory/status/base.rb +0 -47
- data/lib/mumuki/laboratory/status/errored.rb +0 -15
- data/lib/mumuki/laboratory/status/manual_evaluation_pending.rb +0 -15
- data/lib/mumuki/laboratory/status/pending.rb +0 -11
- data/lib/mumuki/laboratory/status/running.rb +0 -11
- data/spec/models/randomizer_spec.rb +0 -18
- 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,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
|
@@ -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
|
@@ -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
|
@@ -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
|
data/spec/dummy/db/schema.rb
CHANGED
@@ -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:
|
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 "
|
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"
|
data/spec/evaluation_helper.rb
CHANGED
@@ -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: :
|
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
|
4
|
+
describe ContextualizationResultHelper do
|
5
5
|
helper IconsHelper
|
6
|
-
helper
|
6
|
+
helper ContextualizationResultHelper
|
7
7
|
|
8
|
-
let(:html) { render_test_results
|
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(:
|
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(:
|
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(:
|
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(:
|
48
|
+
let(:contextualization) { struct(
|
49
49
|
exercise: struct(hidden?: false),
|
50
50
|
result_html: '<pre>ooops, something went wrong</pre>'.html_safe) }
|
51
51
|
|