From 37b34031d740c4332d8bf4ef21eacb8002901ea1 Mon Sep 17 00:00:00 2001 From: "David A. Wheeler" Date: Tue, 4 Feb 2025 11:36:37 -0500 Subject: [PATCH 1/2] Minor wordsmithing about academic use Signed-off-by: David A. Wheeler --- docs/labs/create_checker.md | 10 ++++++---- 1 file changed, 6 insertions(+), 4 deletions(-) diff --git a/docs/labs/create_checker.md b/docs/labs/create_checker.md index 086bcd2e..5f314429 100644 --- a/docs/labs/create_checker.md +++ b/docs/labs/create_checker.md @@ -769,11 +769,13 @@ The "give up" button has a timer, so people can't load the page and *immediately* give up to see the answer. When a lab is completed, that is clearly indicated at the bottom. In English this stamp has the word "Completed" at the bottom. -After that, it has a datetime of the completion time, followed +After that, it has a precise datetime of the completion time, followed by a random unique value (a UUID). -That is followed by `(GA)` if the learner gave up in this session. -If two learners have the same random value, then a single lab -session being claimed by more than one learner (thus, there was cheating). +The random value is followed by `(GA)` if the learner gave up in this session. +If two learners submit labs with the same datetime and random value, +then a single lab +session is being claimed by more than one learner (in other words, +there was cheating). This doesn't detect all cheating, but it does provide a way to detect some kinds of cheating. From ca0699b4a63b8823f1142c0e113cc220893c8cd1 Mon Sep 17 00:00:00 2001 From: "David A. Wheeler" Date: Tue, 4 Feb 2025 11:41:01 -0500 Subject: [PATCH 2/2] Further tweak explanation Signed-off-by: David A. Wheeler --- docs/labs/create_checker.md | 13 ++++++++----- 1 file changed, 8 insertions(+), 5 deletions(-) diff --git a/docs/labs/create_checker.md b/docs/labs/create_checker.md index 5f314429..406f6a8a 100644 --- a/docs/labs/create_checker.md +++ b/docs/labs/create_checker.md @@ -763,21 +763,24 @@ and answers are visible to those who look at its source. In addition, some learners may be unable to figure out the answer, so we provide a "give up" button. -However, cheating is fundamentally a lazy approach, and we take steps to +However, cheating is fundamentally a lazy approach, and we take some steps to address this. The "give up" button has a timer, so people can't load the page and *immediately* give up to see the answer. When a lab is completed, that is clearly indicated at the bottom. In English this stamp has the word "Completed" at the bottom. After that, it has a precise datetime of the completion time, followed -by a random unique value (a UUID). -The random value is followed by `(GA)` if the learner gave up in this session. +by a random unique value (a UUID), and a hash value computed from the +datetime stamp and random value. +All of this is followed by `(GA)` if the learner gave up in this session. If two learners submit labs with the same datetime and random value, then a single lab session is being claimed by more than one learner (in other words, there was cheating). -This doesn't detect all cheating, but it does provide a way to detect -some kinds of cheating. +Changing the datetime or UUID, without fixing the hash, can also be used +to detect an invalid lab submission. +This doesn't detect all cheating, but these mechanisms +do provide a way to detect some kinds of cheating. ## Potential future directions