X-Git-Url: https://git.cworth.org/git?a=blobdiff_plain;f=test;h=646cdcabc0654af15ecbe90b1d5870c7e9846b29;hb=678fbabe0f69470625606f59b84e87ae1d60c110;hp=f5f5eeb91e9b06869e96fb69438b388bdc40c6b2;hpb=13f2a95476240fd9049008d1a5a5f8711b39c3fd;p=lmno-server diff --git a/test b/test index f5f5eeb..646cdca 100755 --- a/test +++ b/test @@ -481,6 +481,15 @@ empathy_player_activate() empathy_players+=($player) } +empathy_player_reactivate() +{ + player="$1" + player_pid=${player}_pid + + empathy_get $player events >/dev/null 2>&1 & + eval ${player_pid}=$! +} + # Usage: empathy_player_deactivate empathy_player_deactivate() { @@ -681,7 +690,7 @@ TEST_END # Usage: empathy_scores_names_numbers empathy_scores_names_numbers() { - empathy_get_event $1 game-state | jq '.scores.scores[]|.player,.score' + empathy_get_event $1 game-state | jq '.scores.scores[]|.players[],.score' } TEST_SUBSECTION "Scoring" @@ -847,6 +856,16 @@ result=$(echo $(empathy_scores alice)) test "$result" = "null" TEST_END +TEST "Submit word groups from a non-answering player" +result=$(empathy_judged dale $prompt_id '[]') +test "$result" = '{"valid":true}' +TEST_END + +TEST "Scoring still hasn't started" +result=$(echo $(empathy_scores alice)) +test "$result" = "null" +TEST_END + TEST "Submit word groups from last answering player" result=$(empathy_judged charlie $prompt_id '[]') test "$result" = '{"valid":true}' @@ -881,7 +900,7 @@ TEST_END TEST "Verify the match passed the vote" # echo here is to strip newlines result=$(echo $(empathy_scores_names_numbers alice)) -test "$result" = '"alice" 2 "bob" 2 "charlie" 0 "dale" 0 "eric" 0 "fred" 0' +test "$result" = '"alice" "bob" 2 "charlie" "dale" "eric" "fred" 0' TEST_END echo "" @@ -920,7 +939,7 @@ TEST_END TEST "Verify scores don't include inactive players" # echo here is to strip newlines result=$(echo $(empathy_scores_names_numbers alice)) -test "$result" = '"alice" 1 "bob" 1 "charlie" 0' +test "$result" = '"alice" "bob" 1 "charlie" 0' TEST_END TEST_SUBSECTION "Deactivated players don't block future game phase advances" @@ -970,4 +989,40 @@ result=$(echo $(empathy_scores alice)) test "$result" != "null" TEST_END +TEST_SUBSECTION "Reactivated player is fully active" + +TEST "The dale player is currently deactivated" +test "$dale_pid" = "" +TEST_END + +TEST "Reactivate dale" +empathy_player_reactivate dale +test "$dale_pid" != "" +TEST_END + +TEST "New 4-player game, 3 submit right away" +empathy_reset +prompt_id=$(empathy_submit_prompt alice 1 "favorite letter" | jq .id) +empathy_start alice $prompt_id +empathy_answer alice $prompt_id '"A"' >/dev/null +empathy_answer bob $prompt_id '"B"' >/dev/null +empathy_answer charlie $prompt_id '"C"' >/dev/null +test "$?" = "0" +TEST_END + +TEST "Judging hasn't started with player unsubmitted" +result=$(echo $(empathy_ambiguities alice)) +test "$result" = "null" +TEST_END + +TEST "Final active player submits" +result=$(empathy_answer dale $prompt_id '"D"') +test "$result" = '{"valid":true}' +TEST_END + +TEST "Judging has started now" +result=$(echo $(empathy_ambiguities alice)) +test "$result" != "null" +TEST_END + cleanup_and_report