X-Git-Url: https://git.cworth.org/git?a=blobdiff_plain;f=test;h=f117234e66ff98b78aec86f9746c7c2b856089c8;hb=3d164c48d0b979afdd83f58af9bb47e7c89c1877;hp=667d6ac380346619c4c1a6d7e38499f5a48bce7b;hpb=1c822aaccac6e77568f813d628fe0721b80284ad;p=empires-server diff --git a/test b/test index 667d6ac..f117234 100755 --- a/test +++ b/test @@ -460,6 +460,11 @@ empathy_submit_prompt() curl_post $empathy_game_path/prompts "{ \"items\": $2, \"prompt\": \"$3\"}" "-b $1" } +TEST "Huge numbers are rejected" +result=$(empathy_submit_prompt $alice 10000 "10,000 Maniacs") +test "$result" = '{"valid":false,"message":"Maximum number of items is 20"}' +TEST_END + TEST "Submit a category" prompt_id=$(empathy_submit_prompt $alice 4 "4 things on a beach" | jq .id) test "$prompt_id" = "1" @@ -493,7 +498,7 @@ empathy_answer() TEST_SUBSECTION "Submitting answers" TEST "Submit from a non-player fails" -result=$(empathy_answer bogus $prompt_id '"sun", "sand", "water", "people"') +result=$(empathy_answer bogus $prompt_id '"Sun", "Sand", "Water", "People"') test "$result" = '{"valid":false,"message":"Player not found"}' TEST_END @@ -503,23 +508,48 @@ test "$result" = '{"valid":true}' TEST_END TEST "Submit from bob succeeds" -result=$(empathy_answer $bob $prompt_id '"sand", "sands", "sunlight", "towels"') +result=$(empathy_answer $bob $prompt_id '"sand", "sands", "SunLight", "towels"') test "$result" = '{"valid":true}' TEST_END TEST "Submit from charlie succeeds" -result=$(empathy_answer $charlie $prompt_id '"sunshine", "grains of sand", "wafer", "people"') +result=$(empathy_answer $charlie $prompt_id '"SunShine", "Grains of Sand", "wafer", "people"') test "$result" = '{"valid":true}' TEST_END -empathy_judging() +TEST_SUBSECTION "Transition from answering to judging" + +empathy_ambiguities() { - curl_post $empathy_game_path/judging/$2 "{ \"word_groups\": $3}" "-b $1" + curl_get_event $empathy_game_path/events game-state "-b $1" \ + | jq .ambiguities +} + +TEST "Judging has not yet started" +result=$(echo $(empathy_ambiguities $alice)) +test "$result" = "null" +TEST_END + +empathy_end_answers() +{ + curl_post $empathy_game_path/end-answers/$2 "" "-b $1" } +TEST "Players vote to start judging" +empathy_end_answers $alice $prompt_id +empathy_end_answers $bob $prompt_id +empathy_end_answers $charlie $prompt_id +test "$?" = "0" +TEST_END + +TEST "Judging has now started" +result=$(echo $(empathy_ambiguities $alice)) +test "$result" != "null" +TEST_END + TEST_SUBSECTION "Judging answers" -empathy_ambiguities() +empathy_ambiguities_list() { curl_get_event $empathy_game_path/events game-state "-b $1" \ | jq .ambiguities[] @@ -527,12 +557,17 @@ empathy_ambiguities() TEST "Received all unique words" # echo here is to strip newlines -result=$(echo $(empathy_ambiguities $alice)) -test "$result" = '"sun" "sand" "water" "people" "sands" "sunlight" "towels" "sunshine" "grains of sand" "wafer"' +result=$(echo $(empathy_ambiguities_list $alice)) +test "$result" = '"Grains of Sand" "people" "sand" "sands" "sun" "SunLight" "SunShine" "towels" "wafer" "water"' TEST_END +empathy_judging() +{ + curl_post $empathy_game_path/judging/$2 "{ \"word_groups\": $3}" "-b $1" +} + TEST "Submit word groups from alice" -result=$(empathy_judging $alice $prompt_id '[["sun","sunlight","sunshine"],["sand","sands","grains of sand"],["water","wafer"]]') +result=$(empathy_judging $alice $prompt_id '[["sun","SunLight","SunShine"],["sand","sands","Grains of Sand"],["water","wafer"]]') test "$result" = '{"valid":true}' TEST_END @@ -542,11 +577,41 @@ test "$result" = '{"valid":true}' TEST_END TEST "Submit word groups from charlie" -result=$(empathy_judging $charlie $prompt_id '[["sunlight","sunshine"],["sand","grains of sand"]]') +result=$(empathy_judging $charlie $prompt_id '[["SunLight","SunShine"],["sand","Grains of Sand"]]') test "$result" = '{"valid":true}' TEST_END +TEST_SUBSECTION "Transition from judging to scoring" + empathy_scores() +{ + curl_get_event $empathy_game_path/events game-state "-b $1" \ + | jq .scores +} + +TEST "Scoring has not yet started" +result=$(echo $(empathy_scores $alice)) +test "$result" = "null" +TEST_END + +empathy_end_judging() +{ + curl_post $empathy_game_path/end-judging/$2 "" "-b $1" +} + +TEST "Players vote to start scoring" +empathy_end_judging $alice $prompt_id +empathy_end_judging $bob $prompt_id +empathy_end_judging $charlie $prompt_id +test "$?" = "0" +TEST_END + +TEST "Scoring has now started" +result=$(echo $(empathy_scores $alice)) +test "$result" != "null" +TEST_END + +empathy_scores_names_numbers() { curl_get_event $empathy_game_path/events game-state "-b $1" \ | jq '.scores.scores[]|.player,.score' @@ -556,8 +621,20 @@ TEST_SUBSECTION "Scoring" TEST "Verify final scores as expected" # echo here is to strip newlines -result=$(echo $(empathy_scores $alice)) +result=$(echo $(empathy_scores_names_numbers $alice)) test "$result" = '"charlie" 9 "alice" 8 "bob" 6' TEST_END +empathy_words_submitted() +{ + curl_get_event $empathy_game_path/events game-state "-b $1" \ + | jq '.scores.words[].word' +} + +TEST "Verify final list of words submitted" +# echo here is to strip newlines +result=$(echo $(empathy_words_submitted $alice)) +test "$result" = '"Grains of Sand/sand/sands" "SunLight/SunShine" "wafer/water" "people" "sun" "towels"' +TEST_END + TEST_REPORT