From f5d0e07296b8bdf6461edca4fafefd522cd57b2d Mon Sep 17 00:00:00 2001 From: Jim O'Donnell Date: Thu, 7 Nov 2024 09:25:20 +0000 Subject: [PATCH] test(lib-classifier): test classification timestamps - [x] Add tests for classification `started_at` and `finished_at` timestamps. - [ ] fix the failing test for classification start times. --- .../Classification/ClassificationMetadata.js | 7 +-- .../src/store/ClassificationStore.spec.js | 48 +++++++++++++++++++ 2 files changed, 52 insertions(+), 3 deletions(-) diff --git a/packages/lib-classifier/src/store/Classification/ClassificationMetadata.js b/packages/lib-classifier/src/store/Classification/ClassificationMetadata.js index 4cbaeb6596d..84e3a485352 100644 --- a/packages/lib-classifier/src/store/Classification/ClassificationMetadata.js +++ b/packages/lib-classifier/src/store/Classification/ClassificationMetadata.js @@ -36,9 +36,10 @@ const ClassificationMetadata = types.model('ClassificationMetadata', { .actions(self => ({ afterAttach() { function _onLocaleChange() { - self.update({ - userLanguage: getRoot(self)?.locale - }) + const userLanguage = getRoot(self)?.locale + if (userLanguage) { + self.update({ userLanguage }) + } } addDisposer(self, autorun(_onLocaleChange)) }, diff --git a/packages/lib-classifier/src/store/ClassificationStore.spec.js b/packages/lib-classifier/src/store/ClassificationStore.spec.js index 346714d9a80..fdd77dea430 100644 --- a/packages/lib-classifier/src/store/ClassificationStore.spec.js +++ b/packages/lib-classifier/src/store/ClassificationStore.spec.js @@ -65,6 +65,7 @@ describe('Model > ClassificationStore', function () { describe('when a subject advances', function () { let classifications let rootStore + beforeEach(function () { rootStore = setupStores({ dataVisAnnotating: {}, @@ -106,6 +107,53 @@ describe('Model > ClassificationStore', function () { }) describe('on complete classification', function () { + describe('submitted classifications', function () { + let classifications + let rootStore + let clock + let submittedClassification + + before(function () { + clock = sinon.useFakeTimers(new Date('2024-11-06T13:00:00Z')) + rootStore = setupStores({ + dataVisAnnotating: {}, + drawing: {}, + feedback: {}, + fieldGuide: {}, + subjectViewer: {}, + tutorials: {}, + workflowSteps: {}, + userProjectPreferences: {} + }) + + classifications = rootStore.classifications + classifications.setOnComplete(snapshot => { + console.log(snapshot) + submittedClassification = snapshot + }) + const taskSnapshot = Object.assign({}, singleChoiceTaskSnapshot, { taskKey: singleChoiceAnnotationSnapshot.task }) + taskSnapshot.createAnnotation = () => SingleChoiceAnnotation.create(singleChoiceAnnotationSnapshot) + clock.tick(1 * 60 * 60 * 1000) // wait for one hour before starting the classification. + classifications.addAnnotation(taskSnapshot, singleChoiceAnnotationSnapshot.value) + clock.tick(30 * 1000) // wait for 30 seconds before finishing the classification. + classifications.completeClassification() + }) + + after(function () { + clock.restore() + }) + + it('should record the started at time', function () { + const startedAt = submittedClassification.metadata.started_at + expect(startedAt).to.equal('2024-11-06T14:00:00.000Z') + }) + + it('should record the finished at time', function () { + const finishedAt = submittedClassification.metadata.finished_at + expect(finishedAt).to.equal('2024-11-06T14:00:30.000Z') + }) + }) + describe('with invalid feedback', function () { let classifications let rootStore