Skip to content
Snippets Groups Projects
Commit 8bbf122d authored by Julia Friesel's avatar Julia Friesel
Browse files

Ignore 0 -> 1 mucus shift

parent 6ac642b9
No related branches found
No related tags found
No related merge requests found
export default function (cycleDays, tempEvalEndIndex) {
const notDetected = { detected: false}
const mucusDays = cycleDays.filter(day => day.mucus && !day.mucus.exclude)
let currentBestQuality = 0
......@@ -9,6 +10,9 @@ export default function (cycleDays, tempEvalEndIndex) {
currentBestQuality = day.mucus.value
}
// if mucus only changes from dry to nothing, it doesn't constitute a shift
if (currentBestQuality < 2) continue
if (day.mucus.value !== currentBestQuality) continue
// the three following days must be of lower quality
......@@ -40,6 +44,6 @@ export default function (cycleDays, tempEvalEndIndex) {
}
}
return { detected: false }
return notDetected
}
......@@ -14,7 +14,7 @@ describe('sympto', () => {
describe('detect mucus shift', () => {
describe('regular rule', () => {
it('detects mucus shift correctly', function () {
const values = [0, 0, 0, 1, 1, 2, 2, 2, 3, 3, 3, 2, 2, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0]
const values = [0,0,0,1,1,2,2,2,3,3,3,2,2,0,1,1,1,1,0,0,0,0,0]
.map(turnIntoCycleDayObject)
const status = getMucusStatus(values, 12)
expect(status).to.eql({
......@@ -38,7 +38,10 @@ describe('sympto', () => {
})
it('detects no mucus shift when there are no mucus values', function () {
const status = getMucusStatus(Array(10).fill({date: 1, temperature: { value: 35}}))
const status = getMucusStatus(Array(10).fill({
date: 1,
temperature: { value: 35 }
}))
expect(status).to.eql({ detected: false })
})
......@@ -48,6 +51,30 @@ describe('sympto', () => {
const status = getMucusStatus(values, 30)
expect(status).to.eql({ detected: false })
})
it('detects no mucus shift when mucus only changes from dry to nothing', function () {
const values = [0,0,0,1,0,0,0,0,0,0,0]
.map(turnIntoCycleDayObject)
const status = getMucusStatus(values, 30)
expect(status).to.eql({ detected: false })
})
it('ignores an early seeming shift from 0 to 1', function () {
const values = [0,0,0,1,0,0,0,2,3,3,3,2,2,0,1,1,1,1,0,0,0,0,0]
.map(turnIntoCycleDayObject)
const status = getMucusStatus(values, 12)
expect(status).to.eql({
detected: true,
mucusPeak: {
date: 10,
mucus: { value: 3 }
},
evaluationCompleteDay: {
date: 13,
mucus: { value: 0 }
}
})
})
})
})
})
\ No newline at end of file
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment