From f8496edcc4ea5d26043f2538313eb9e4312b5e28 Mon Sep 17 00:00:00 2001 From: Valtteri Kantanen Date: Thu, 24 Oct 2024 13:28:56 +0300 Subject: [PATCH] [Class statistics] Fix a bug where change in filtered students didn't trigger a new request for course stats Also added two tests for this scenario --- cypress/e2e/Population_statistics.js | 40 +++++++++++++++++++ .../PopulationCourses/index.jsx | 14 +++++-- 2 files changed, 51 insertions(+), 3 deletions(-) diff --git a/cypress/e2e/Population_statistics.js b/cypress/e2e/Population_statistics.js index 9a19fac272..7e2770558e 100644 --- a/cypress/e2e/Population_statistics.js +++ b/cypress/e2e/Population_statistics.js @@ -96,6 +96,46 @@ describe('Population Statistics tests', () => { cy.get('[data-cy=toggle-group-module-MAT-tyo]').should('not.exist') }) + it('New fetch of courses data is done when curriculum is changed', () => { + cy.visit(pathToMathBSc2020) + cy.contains('Courses of class').click() + cy.intercept('/api/v2/populationstatistics/courses').as('courseData') + cy.get('[data-cy=curriculum-picker]').click().contains('2020 - 2023').click() + cy.wait('@courseData').then(({ response }) => { + expect(response.body).to.have.property('allStudents') + expect(response.body).to.have.property('coursestatistics') + expect(response.body.allStudents).to.equal(27) + expect(response.body.coursestatistics.some(stat => stat.course.code === 'DIGI-100')).to.be.true + }) + cy.get('[data-cy=curriculum-picker]').click().contains('2023 - 2026').click() + cy.wait('@courseData').then(({ response }) => { + expect(response.body).to.have.property('allStudents') + expect(response.body).to.have.property('coursestatistics') + expect(response.body.allStudents).to.equal(27) + expect(response.body.coursestatistics.some(stat => stat.course.code === 'DIGI-100')).to.be.not.true + }) + }) + + it('New fetch of courses data is done when filtered students change', () => { + cy.visit(pathToMathBSc2020) + cy.contains('Courses of class').click() + cy.intercept('/api/v2/populationstatistics/courses').as('courseData') + cy.wait('@courseData').then(({ response }) => { + expect(response.body).to.have.property('allStudents') + expect(response.body).to.have.property('coursestatistics') + expect(response.body.allStudents).to.equal(27) + }) + cy.get('[data-cy=GraduatedFromProgramme-filter-card]').within(() => { + cy.get('[data-cy=GraduatedFromProgramme-header]').click() + cy.get('[data-cy=option-graduated-true]').click() + cy.wait('@courseData').then(({ response }) => { + expect(response.body).to.have.property('allStudents') + expect(response.body).to.have.property('coursestatistics') + expect(response.body.allStudents).to.equal(16) + }) + }) + }) + it("Empty 'tags' tab has a link to the page where tags can be created", { retries: 2 }, () => { cy.visit(pathToMathBSc2020) cy.contains('Students (27)') diff --git a/services/frontend/src/components/PopulationDetails/PopulationCourses/index.jsx b/services/frontend/src/components/PopulationDetails/PopulationCourses/index.jsx index 550c162492..38916ff0cb 100644 --- a/services/frontend/src/components/PopulationDetails/PopulationCourses/index.jsx +++ b/services/frontend/src/components/PopulationDetails/PopulationCourses/index.jsx @@ -53,13 +53,21 @@ export const PopulationCourses = ({ }, [mandatoryCourses]) useEffect(() => { + if (programmeCodesToFetch == null || populationSelectedStudentCourses?.query == null) { + return + } + const { courses, selectedStudents } = populationSelectedStudentCourses.query if ( - programmeCodesToFetch != null && - !isEqual(programmeCodesToFetch, populationSelectedStudentCourses.query.courses) + !isEqual(programmeCodesToFetch, courses) || + selectedStudents.length !== filteredStudents.length || + !isEqual( + selectedStudents, + filteredStudents.map(({ studentNumber }) => studentNumber) + ) ) { fetch(programmeCodesToFetch) } - }, [programmeCodesToFetch]) + }, [programmeCodesToFetch, filteredStudents]) const pending = populationSelectedStudentCourses.pending || !mandatoryCourses