summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--test/models/score_test.rb20
-rw-r--r--test/services/tartiflette_scoring_service.rb42
2 files changed, 54 insertions, 8 deletions
diff --git a/test/models/score_test.rb b/test/models/score_test.rb
index a895158..ecf5558 100644
--- a/test/models/score_test.rb
+++ b/test/models/score_test.rb
@@ -11,31 +11,39 @@ class ScoreTest < ActiveSupport::TestCase
test "should have associated tartiflette" do
@score.tartiflette = nil
- assert_not @score.valid?, "Score has no associated tartiflette."
+ assert_not @score.valid?, "Score should not be valid without an associated tartiflette."
end
test "should have associated scoring_criterium" do
@score.scoring_criterium = nil
- assert_not @score.valid?, "Score has no associated scoring_criterium."
+ assert_not @score.valid?, "Score should not be valid without an associated scoring criterium."
end
test "should have value" do
@score.value = nil
- assert_not @score.valid?, "Score has no value."
+ assert_not @score.valid?, "Score should not be valid without a value."
end
test "value should be between 1 and 5" do
@score.value = 3
- assert @score.valid?, "Score value is invalid."
+ assert @score.valid?, "Score with a value of 3 should be valid."
end
test "value should be greater than or equal to 1" do
@score.value = 0
- assert_not @score.valid?, "Score is less than 1."
+ assert_not @score.valid?, "Score should not be valid with a value less than 1."
end
test "value should be less than or equal to 5" do
@score.value = 6
- assert_not @score.valid?, "Score is greater than 5."
+ assert_not @score.valid?, "Score should not be valid with a value greater than 5."
end
+
+ test "should have a session_id" do
+ @score.session_id = nil
+ assert_not @score.valid?, "Score should not be valid without a session_id."
+ assert_includes @score.errors[:session_id], "can't be blank"
+ end
+
+
end
diff --git a/test/services/tartiflette_scoring_service.rb b/test/services/tartiflette_scoring_service.rb
index 6796342..0a66d5b 100644
--- a/test/services/tartiflette_scoring_service.rb
+++ b/test/services/tartiflette_scoring_service.rb
@@ -2,8 +2,9 @@ require "test_helper"
class TartifletteScoringServiceTest < ActiveSupport::TestCase
setup do
- @tartiflette = Tartiflette.new(scoring_id: 1)
- @session = {}
+ @tartiflette = tartiflettes(:one)
+ @existing_score = scores(:one)
+ @session = { id: @existing_score.session_id }
end
test "should check if tartiflette is already scored" do
@@ -16,6 +17,43 @@ class TartifletteScoringServiceTest < ActiveSupport::TestCase
assert_includes @session[:scored_tartiflettes], @tartiflette.id
end
+ test "should process scores for tartiflette" do
+ scores = {
+ "1" => { value: 4, id: nil }, # New score for criterium_id 1
+ "2" => { value: 5, id: @existing_score.id } # Update existing score
+ }
+
+ assert_nothing_raised do
+ TartifletteScoringService.process_scores(@tartiflette, scores, @session)
+ end
+
+ # Assertions for new score
+ new_score = Score.find_by(scoring_criterium_id: 1, tartiflette: @tartiflette)
+ assert_equal 4, new_score.value
+ assert_equal @session[:id], new_score.session_id
+
+ # Assertions for updated score
+ @existing_score.reload
+ assert_equal 5, @existing_score.value
+ end
+
+ test "should raise error for invalid data" do
+ scores = {
+ "1" => { value: nil, id: nil }, # Missing value
+ "2" => { value: 5, id: nil } # Valid score
+ }
+
+ assert_raises(StandardError, /Failed to process scores/) do
+ TartifletteScoringService.process_scores(@tartiflette, scores, @session)
+ end
+ end
+
+ test "should mark tartiflette as scored in session" do
+ session = { scored_tartiflettes: [] }
+ TartifletteScoringService.mark_as_scored(@tartiflette, session)
+ assert_includes session[:scored_tartiflettes], @tartiflette.id
+ end
+
test "should calculate average of all scores for a tartiflette" do
Score.create!(tartiflette: @tartiflette,
scoring_criterium: scoring_criteria(:one),
Copyright 2019--2025 Marius PETER