From f2b34b14e5fe73a6ad4a19b9006545e76c823f62 Mon Sep 17 00:00:00 2001 From: gromdimon Date: Mon, 25 Sep 2023 11:10:42 +0200 Subject: [PATCH] tests --- frontend/src/api/__tests__/acmgSeqVar.spec.ts | 270 -------- frontend/src/components/HeaderDetailPage.vue | 2 +- .../components/VariantDetails/AcmgRating.vue | 46 +- .../VariantDetails/FreqsAutosomal.vue | 2 +- .../VariantDetails/FreqsMitochondrial.vue | 2 +- .../VariantDetails/VariantConservation.vue | 2 +- .../VariantDetails/VariantFreqs.vue | 2 +- .../VariantDetails/VariantTools.vue | 2 +- .../components/__tests__/AcmgRating.spec.ts | 2 +- frontend/src/lib/__tests__/acmgSeqVar.spec.ts | 621 ++++++++++++++++++ .../src/{api => lib}/__tests__/utils.spec.ts | 0 frontend/src/{api => lib}/acmgSeqVar.ts | 39 ++ frontend/src/{api => lib}/utils.ts | 2 +- .../__tests__/variantAcmgRating.spec.ts | 2 +- frontend/src/stores/variantAcmgRating.ts | 2 +- frontend/src/stores/variantInfo.ts | 2 +- frontend/src/views/GeneDetailView.vue | 2 +- frontend/src/views/HomeView.vue | 2 +- .../views/__tests__/VariantDetailView.spec.ts | 2 +- 19 files changed, 678 insertions(+), 326 deletions(-) delete mode 100644 frontend/src/api/__tests__/acmgSeqVar.spec.ts create mode 100644 frontend/src/lib/__tests__/acmgSeqVar.spec.ts rename frontend/src/{api => lib}/__tests__/utils.spec.ts (100%) rename frontend/src/{api => lib}/acmgSeqVar.ts (93%) rename frontend/src/{api => lib}/utils.ts (98%) diff --git a/frontend/src/api/__tests__/acmgSeqVar.spec.ts b/frontend/src/api/__tests__/acmgSeqVar.spec.ts deleted file mode 100644 index 274f537b..00000000 --- a/frontend/src/api/__tests__/acmgSeqVar.spec.ts +++ /dev/null @@ -1,270 +0,0 @@ -import { describe, it, expect } from 'vitest' -import { - MultiSourceAcmgCriteriaState, - StateSource, - Presence, - AcmgCriteria, - AcmgEvidenceLevel -} from '../acmgSeqVar' - -describe.concurrent('MultiSourceAcmgCriteriaState', () => { - it('should have correct default values', () => { - const AcmgCriteriaState = new MultiSourceAcmgCriteriaState() - // Check keys of AcmgCriteriaState.criteriaStates - expect(Object.keys(AcmgCriteriaState.criteriaStates).length).toEqual(3) - expect(AcmgCriteriaState.criteriaStates).toHaveProperty(StateSource.Default) - expect(AcmgCriteriaState.criteriaStates).toHaveProperty(StateSource.InterVar) - expect(AcmgCriteriaState.criteriaStates).toHaveProperty(StateSource.User) - - // Check keys of AcmgCriteriaState.criteriaStates[StateSource.Default] - expect(Object.keys(AcmgCriteriaState.criteriaStates[StateSource.Default]).length).toEqual(28) - expect(AcmgCriteriaState.criteriaStates[StateSource.Default]).toHaveProperty(AcmgCriteria.Pvs1) - - // Check keys of AcmgCriteriaState.criteriaStates[StateSource.InterVar] - expect(Object.keys(AcmgCriteriaState.criteriaStates[StateSource.InterVar]).length).toEqual(28) - expect(AcmgCriteriaState.criteriaStates[StateSource.InterVar]).toHaveProperty(AcmgCriteria.Pvs1) - - // Check keys of AcmgCriteriaState.criteriaStates[StateSource.User] - expect(Object.keys(AcmgCriteriaState.criteriaStates[StateSource.User]).length).toEqual(28) - expect(AcmgCriteriaState.criteriaStates[StateSource.User]).toHaveProperty(AcmgCriteria.Pvs1) - }) - - it('should correctly get criteria state', () => { - const AcmgCriteriaState = new MultiSourceAcmgCriteriaState() - expect(AcmgCriteriaState.getCriteriaState(AcmgCriteria.Pvs1)).toEqual( - AcmgCriteriaState.criteriaStates[StateSource.Default][AcmgCriteria.Pvs1] - ) - }) - - it('should correctly get criteria state from interVar', () => { - const AcmgCriteriaState = new MultiSourceAcmgCriteriaState() - const criteriaState = { - criteria: AcmgCriteria.Pvs1, - presence: Presence.Present, - evidenceLevel: AcmgEvidenceLevel.PathogenicVeryStrong - } - AcmgCriteriaState.setPresence(StateSource.InterVar, AcmgCriteria.Pvs1, Presence.Present) - expect(AcmgCriteriaState.getCriteriaState(AcmgCriteria.Pvs1)).toStrictEqual(criteriaState) - }) - - it('should correctly get criteria state with invalid request', () => { - const AcmgCriteriaState = new MultiSourceAcmgCriteriaState() - const criteriaState = { - criteria: 'invalid' as AcmgCriteria, - presence: Presence.Unknown, - evidenceLevel: AcmgEvidenceLevel.NotSet - } - expect(AcmgCriteriaState.getCriteriaState('invalid' as AcmgCriteria)).toStrictEqual( - criteriaState - ) - }) - - it('should correctly get criteria state from default source', () => { - const AcmgCriteriaState = new MultiSourceAcmgCriteriaState() - const criteriaState = { - criteria: AcmgCriteria.Pvs1, - presence: Presence.Unknown, - evidenceLevel: AcmgEvidenceLevel.PathogenicVeryStrong - } - expect( - AcmgCriteriaState.getCriteriaStateFromSource(AcmgCriteria.Pvs1, StateSource.Default) - ).toStrictEqual(criteriaState) - }) - - it('should correctly get criteria state from interVar source', () => { - const AcmgCriteriaState = new MultiSourceAcmgCriteriaState() - const criteriaState = { - criteria: AcmgCriteria.Pvs1, - presence: Presence.Present, - evidenceLevel: AcmgEvidenceLevel.NotSet - } - AcmgCriteriaState.setPresence(StateSource.InterVar, AcmgCriteria.Pvs1, Presence.Present) - expect( - AcmgCriteriaState.getCriteriaStateFromSource(AcmgCriteria.Pvs1, StateSource.InterVar) - ).toStrictEqual(criteriaState) - }) - - it('should correctly get criteria state from user source', () => { - const AcmgCriteriaState = new MultiSourceAcmgCriteriaState() - const criteriaState = { - criteria: AcmgCriteria.Pvs1, - presence: Presence.Present, - evidenceLevel: AcmgEvidenceLevel.NotSet - } - AcmgCriteriaState.setPresence(StateSource.User, AcmgCriteria.Pvs1, Presence.Present) - expect( - AcmgCriteriaState.getCriteriaStateFromSource(AcmgCriteria.Pvs1, StateSource.User) - ).toStrictEqual(criteriaState) - }) - - it('should throw error if getting invalid criteria from source', () => { - const AcmgCriteriaState = new MultiSourceAcmgCriteriaState() - expect(() => - AcmgCriteriaState.getCriteriaStateFromSource('invalid' as AcmgCriteria, StateSource.User) - ).toThrowError() - }) - - it('should correctly set presence for InterVar', () => { - const AcmgCriteriaState = new MultiSourceAcmgCriteriaState() - AcmgCriteriaState.setPresence(StateSource.InterVar, AcmgCriteria.Pvs1, Presence.Present) - expect( - AcmgCriteriaState.criteriaStates[StateSource.InterVar][AcmgCriteria.Pvs1].presence - ).toEqual(Presence.Present) - // Check that other sources are not affected - expect( - AcmgCriteriaState.criteriaStates[StateSource.Default][AcmgCriteria.Pvs1].presence - ).toEqual(Presence.Unknown) - expect(AcmgCriteriaState.criteriaStates[StateSource.User][AcmgCriteria.Pvs1].presence).toEqual( - Presence.Unknown - ) - }) - - it('should correctly set presence for User', () => { - const AcmgCriteriaState = new MultiSourceAcmgCriteriaState() - AcmgCriteriaState.setPresence(StateSource.User, AcmgCriteria.Pvs1, Presence.Present) - expect(AcmgCriteriaState.criteriaStates[StateSource.User][AcmgCriteria.Pvs1].presence).toEqual( - Presence.Present - ) - // Check that other sources are not affected - expect( - AcmgCriteriaState.criteriaStates[StateSource.Default][AcmgCriteria.Pvs1].presence - ).toEqual(Presence.Unknown) - expect( - AcmgCriteriaState.criteriaStates[StateSource.InterVar][AcmgCriteria.Pvs1].presence - ).toEqual(Presence.Unknown) - }) - - it('should raise error for setting present for Default', () => { - const AcmgCriteriaState = new MultiSourceAcmgCriteriaState() - expect(() => - AcmgCriteriaState.setPresence(StateSource.Default, AcmgCriteria.Pvs1, Presence.Present) - ).toThrowError() - }) - - it('should correctly set absent presence for User', () => { - const AcmgCriteriaState = new MultiSourceAcmgCriteriaState() - AcmgCriteriaState.setPresence(StateSource.User, AcmgCriteria.Pvs1, Presence.Absent) - expect(AcmgCriteriaState.criteriaStates[StateSource.User][AcmgCriteria.Pvs1].presence).toEqual( - Presence.Absent - ) - // Set presence to absent - AcmgCriteriaState.setUserPresenceAbsent() - expect(AcmgCriteriaState.criteriaStates[StateSource.User][AcmgCriteria.Pvs1].presence).toEqual( - Presence.Absent - ) - }) - - it('should correctly set interVar presence for User', () => { - const AcmgCriteriaState = new MultiSourceAcmgCriteriaState() - AcmgCriteriaState.setPresence(StateSource.User, AcmgCriteria.Pvs1, Presence.Absent) - AcmgCriteriaState.setPresence(StateSource.InterVar, AcmgCriteria.Pvs1, Presence.Present) - expect(AcmgCriteriaState.criteriaStates[StateSource.User][AcmgCriteria.Pvs1].presence).toEqual( - Presence.Absent - ) - // Set presence to unknown - AcmgCriteriaState.setUserPresenceInterVar() - expect(AcmgCriteriaState.criteriaStates[StateSource.User][AcmgCriteria.Pvs1].presence).toEqual( - Presence.Present - ) - }) - - it('should correctly set evidence level for user', () => { - const AcmgCriteriaState = new MultiSourceAcmgCriteriaState() - AcmgCriteriaState.setEvidenceLevel( - StateSource.User, - AcmgCriteria.Pvs1, - AcmgEvidenceLevel.PathogenicModerate - ) - expect( - AcmgCriteriaState.criteriaStates[StateSource.User][AcmgCriteria.Pvs1].evidenceLevel - ).toEqual(AcmgEvidenceLevel.PathogenicModerate) - // Check that other sources are not affected - expect( - AcmgCriteriaState.criteriaStates[StateSource.Default][AcmgCriteria.Pvs1].evidenceLevel - ).toEqual(AcmgEvidenceLevel.PathogenicVeryStrong) - expect( - AcmgCriteriaState.criteriaStates[StateSource.InterVar][AcmgCriteria.Pvs1].evidenceLevel - ).toEqual(AcmgEvidenceLevel.NotSet) - }) - - it('should correctly set evidence level for interVar', () => { - const AcmgCriteriaState = new MultiSourceAcmgCriteriaState() - AcmgCriteriaState.setEvidenceLevel( - StateSource.InterVar, - AcmgCriteria.Pvs1, - AcmgEvidenceLevel.PathogenicModerate - ) - expect( - AcmgCriteriaState.criteriaStates[StateSource.InterVar][AcmgCriteria.Pvs1].evidenceLevel - ).toEqual(AcmgEvidenceLevel.PathogenicModerate) - // Check that other sources are not affected - expect( - AcmgCriteriaState.criteriaStates[StateSource.Default][AcmgCriteria.Pvs1].evidenceLevel - ).toEqual(AcmgEvidenceLevel.PathogenicVeryStrong) - expect( - AcmgCriteriaState.criteriaStates[StateSource.User][AcmgCriteria.Pvs1].evidenceLevel - ).toEqual(AcmgEvidenceLevel.NotSet) - }) - - it('should raise error for setting evidence level for Default', () => { - const AcmgCriteriaState = new MultiSourceAcmgCriteriaState() - expect(() => - AcmgCriteriaState.setEvidenceLevel( - StateSource.Default, - AcmgCriteria.Pvs1, - AcmgEvidenceLevel.PathogenicModerate - ) - ).toThrowError() - }) - - it('should correctly get States', () => { - const AcmgCriteriaState = new MultiSourceAcmgCriteriaState() - - const criteriaStates = AcmgCriteriaState.getStates() - // Check keys of AcmgCriteriaState.criteriaStates - expect(Object.keys(criteriaStates).length).toEqual(3) - expect(criteriaStates).toHaveProperty(StateSource.Default) - expect(criteriaStates).toHaveProperty(StateSource.InterVar) - expect(criteriaStates).toHaveProperty(StateSource.User) - - // Check keys of AcmgCriteriaState.criteriaStates[StateSource.Default] - expect(Object.keys(criteriaStates[StateSource.Default]).length).toEqual(28) - expect(criteriaStates[StateSource.Default]).toHaveProperty(AcmgCriteria.Pvs1) - - // Check keys of AcmgCriteriaState.criteriaStates[StateSource.InterVar] - expect(Object.keys(criteriaStates[StateSource.InterVar]).length).toEqual(28) - expect(criteriaStates[StateSource.InterVar]).toHaveProperty(AcmgCriteria.Pvs1) - - // Check keys of AcmgCriteriaState.criteriaStates[StateSource.User] - expect(Object.keys(criteriaStates[StateSource.User]).length).toEqual(28) - expect(criteriaStates[StateSource.User]).toHaveProperty(AcmgCriteria.Pvs1) - }) - - it('should correctly get evidence counts', () => { - const AcmgCriteriaState = new MultiSourceAcmgCriteriaState() - AcmgCriteriaState.setPresence(StateSource.InterVar, AcmgCriteria.Pvs1, Presence.Present) - AcmgCriteriaState.setPresence(StateSource.InterVar, AcmgCriteria.Ps1, Presence.Present) - AcmgCriteriaState.setPresence(StateSource.InterVar, AcmgCriteria.Pm1, Presence.Present) - AcmgCriteriaState.setPresence(StateSource.InterVar, AcmgCriteria.Pm2, Presence.Present) - AcmgCriteriaState.setPresence(StateSource.InterVar, AcmgCriteria.Pp1, Presence.Present) - AcmgCriteriaState.setPresence(StateSource.InterVar, AcmgCriteria.Pp4, Presence.Present) - AcmgCriteriaState.setPresence(StateSource.InterVar, AcmgCriteria.Ba1, Presence.Present) - AcmgCriteriaState.setPresence(StateSource.InterVar, AcmgCriteria.Bp1, Presence.Present) - AcmgCriteriaState.setPresence(StateSource.InterVar, AcmgCriteria.Bs1, Presence.Present) - AcmgCriteriaState.setPresence(StateSource.InterVar, AcmgCriteria.Bs2, Presence.Present) - AcmgCriteriaState.setPresence(StateSource.InterVar, AcmgCriteria.Bs3, Presence.Present) - - expect( - AcmgCriteriaState.getActiveEvidenceCounts(AcmgEvidenceLevel.PathogenicVeryStrong) - ).toEqual(1) - expect(AcmgCriteriaState.getActiveEvidenceCounts(AcmgEvidenceLevel.PathogenicStrong)).toEqual(1) - expect(AcmgCriteriaState.getActiveEvidenceCounts(AcmgEvidenceLevel.PathogenicModerate)).toEqual( - 2 - ) - expect( - AcmgCriteriaState.getActiveEvidenceCounts(AcmgEvidenceLevel.PathogenicSupporting) - ).toEqual(2) - expect(AcmgCriteriaState.getActiveEvidenceCounts(AcmgEvidenceLevel.BenignSupporting)).toEqual(1) - expect(AcmgCriteriaState.getActiveEvidenceCounts(AcmgEvidenceLevel.BenignStrong)).toEqual(3) - }) -}) diff --git a/frontend/src/components/HeaderDetailPage.vue b/frontend/src/components/HeaderDetailPage.vue index 166b8188..e339d149 100644 --- a/frontend/src/components/HeaderDetailPage.vue +++ b/frontend/src/components/HeaderDetailPage.vue @@ -3,7 +3,7 @@ import { watch, ref } from 'vue' import { useRouter } from 'vue-router' import SearchBar from '@/components/SearchBar.vue' -import { search } from '@/api/utils' +import { search } from '@/lib/utils' export interface Props { searchTerm?: string diff --git a/frontend/src/components/VariantDetails/AcmgRating.vue b/frontend/src/components/VariantDetails/AcmgRating.vue index 5ec3515b..d1d22194 100644 --- a/frontend/src/components/VariantDetails/AcmgRating.vue +++ b/frontend/src/components/VariantDetails/AcmgRating.vue @@ -5,14 +5,13 @@ import { StoreState } from '@/stores/misc' import { useVariantAcmgRatingStore } from '@/stores/variantAcmgRating' import { AcmgCriteria, - AcmgEvidenceLevel, StateSource, Presence, ALL_ACMG_CRITERIA, ACMG_EVIDENCE_LEVELS_PATHOGENIC, ACMG_EVIDENCE_LEVELS_BENIGN, ACMG_CRITERIA_DEFS -} from '@/api/acmgSeqVar' +} from '@/lib/acmgSeqVar' const props = defineProps({ smallVariant: Object @@ -37,51 +36,14 @@ const updateAcmgConflicting = (isConflicting: boolean) => { } const calculateAcmgRating = computed((): string => { - const pvs = acmgRatingStore.acmgRating.getActiveEvidenceCounts( - AcmgEvidenceLevel.PathogenicVeryStrong - ) - const ps = acmgRatingStore.acmgRating.getActiveEvidenceCounts(AcmgEvidenceLevel.PathogenicStrong) - const pm = acmgRatingStore.acmgRating.getActiveEvidenceCounts( - AcmgEvidenceLevel.PathogenicModerate - ) - const pp = acmgRatingStore.acmgRating.getActiveEvidenceCounts( - AcmgEvidenceLevel.PathogenicSupporting - ) - const ba = acmgRatingStore.acmgRating.getActiveEvidenceCounts(AcmgEvidenceLevel.BenignStandalone) - const bs = acmgRatingStore.acmgRating.getActiveEvidenceCounts(AcmgEvidenceLevel.BenignStrong) - const bp = acmgRatingStore.acmgRating.getActiveEvidenceCounts(AcmgEvidenceLevel.BenignSupporting) - const isPathogenic = - (pvs === 1 && (ps >= 1 || pm >= 2 || (pm === 1 && pp === 1) || pp >= 2)) || - ps >= 2 || - (ps === 1 && (pm >= 3 || (pm === 2 && pp >= 2) || (pm === 1 && pp >= 4))) - const isLikelyPathogenic = - (pvs === 1 && pm === 1) || - (ps === 1 && pm >= 1 && pm <= 2) || - (ps === 1 && pp >= 2) || - pm >= 3 || - (pm === 2 && pp >= 2) || - (pm === 1 && pp >= 4) - const isBenign = ba > 0 || bs >= 2 - const isLikelyBenign = (bs === 1 && bp === 1) || bp >= 2 - const isConflicting = (isPathogenic || isLikelyPathogenic) && (isBenign || isLikelyBenign) - - let computedClass = 'Uncertain significance' - if (isPathogenic) { - computedClass = 'Pathogenic' - } else if (isLikelyPathogenic) { - computedClass = 'Likely pathogenic' - } else if (isBenign) { - computedClass = 'Benign' - } else if (isLikelyBenign) { - computedClass = 'Likely benign' - } + let [acmgClass, isConflicting] = acmgRatingStore.acmgRating.getAcmgClass() if (isConflicting) { - computedClass = 'Uncertain significance' + acmgClass = 'Uncertain significance' updateAcmgConflicting(true) } else { updateAcmgConflicting(false) } - return computedClass + return acmgClass }) const switchCriteria = (criteria: AcmgCriteria, presence: Presence) => { diff --git a/frontend/src/components/VariantDetails/FreqsAutosomal.vue b/frontend/src/components/VariantDetails/FreqsAutosomal.vue index 529263c8..d970501e 100644 --- a/frontend/src/components/VariantDetails/FreqsAutosomal.vue +++ b/frontend/src/components/VariantDetails/FreqsAutosomal.vue @@ -1,7 +1,7 @@