mirror of
https://github.com/edcommonwealth/sqm-dashboards.git
synced 2026-03-07 13:38:18 -08:00
feat: change 'school admin data' to 'school data'
This commit is contained in:
parent
683ece6cf1
commit
90d1419d9c
8 changed files with 89 additions and 89 deletions
|
|
@ -1,9 +1,9 @@
|
|||
require 'rails_helper'
|
||||
require "rails_helper"
|
||||
|
||||
describe MeasurePresenter do
|
||||
let(:academic_year) { create(:academic_year, range: '1989-90') }
|
||||
let(:school) { create(:school, name: 'Best School') }
|
||||
let(:measure) { create(:measure, measure_id: 'measure-id') }
|
||||
let(:academic_year) { create(:academic_year, range: "1989-90") }
|
||||
let(:school) { create(:school, name: "Best School") }
|
||||
let(:measure) { create(:measure, measure_id: "measure-id") }
|
||||
let(:teacher_scale) { create(:teacher_scale, measure:) }
|
||||
let(:student_scale) { create(:student_scale, measure:) }
|
||||
let(:admin_scale) { create(:scale, measure:) }
|
||||
|
|
@ -12,18 +12,18 @@ describe MeasurePresenter do
|
|||
create(:respondent, school:, academic_year:)
|
||||
end
|
||||
|
||||
it 'returns the id of the measure' do
|
||||
expect(measure_presenter.id).to eq 'measure-id'
|
||||
it "returns the id of the measure" do
|
||||
expect(measure_presenter.id).to eq "measure-id"
|
||||
end
|
||||
|
||||
it 'has an id for use in the data item accordions' do
|
||||
expect(measure_presenter.data_item_accordion_id).to eq 'data-item-accordion-measure-id'
|
||||
it "has an id for use in the data item accordions" do
|
||||
expect(measure_presenter.data_item_accordion_id).to eq "data-item-accordion-measure-id"
|
||||
end
|
||||
|
||||
context 'when the measure contains only teacher data' do
|
||||
context "when the measure contains only teacher data" do
|
||||
before :each do
|
||||
survey_item1 = create(:teacher_survey_item, scale: teacher_scale, prompt: 'A teacher survey item prompt')
|
||||
survey_item2 = create(:teacher_survey_item, scale: teacher_scale, prompt: 'Another teacher survey item prompt')
|
||||
survey_item1 = create(:teacher_survey_item, scale: teacher_scale, prompt: "A teacher survey item prompt")
|
||||
survey_item2 = create(:teacher_survey_item, scale: teacher_scale, prompt: "Another teacher survey item prompt")
|
||||
|
||||
create_list(:survey_item_response, SurveyItemResponse::TEACHER_RESPONSE_THRESHOLD, survey_item: survey_item1,
|
||||
academic_year:, school:, likert_score: 1)
|
||||
|
|
@ -31,42 +31,42 @@ describe MeasurePresenter do
|
|||
academic_year:, school:, likert_score: 5)
|
||||
end
|
||||
|
||||
it 'creates a gauge presenter that presents the average likert score' do
|
||||
expect(measure_presenter.gauge_presenter.title).to eq 'Growth'
|
||||
it "creates a gauge presenter that presents the average likert score" do
|
||||
expect(measure_presenter.gauge_presenter.title).to eq "Growth"
|
||||
end
|
||||
|
||||
it 'returns a list of data item presenters that has only one element, and that element has a title of "Teacher survey"' do
|
||||
expect(measure_presenter.data_item_presenters.count).to eq 1
|
||||
expect(measure_presenter.data_item_presenters.first.id).to eq 'teacher-survey-items-measure-id'
|
||||
expect(measure_presenter.data_item_presenters.first.title).to eq 'Teacher survey'
|
||||
expect(measure_presenter.data_item_presenters.first.data_item_accordion_id).to eq 'data-item-accordion-measure-id'
|
||||
expect(measure_presenter.data_item_presenters.first.id).to eq "teacher-survey-items-measure-id"
|
||||
expect(measure_presenter.data_item_presenters.first.title).to eq "Teacher survey"
|
||||
expect(measure_presenter.data_item_presenters.first.data_item_accordion_id).to eq "data-item-accordion-measure-id"
|
||||
end
|
||||
end
|
||||
|
||||
context 'when the measure contains both teacher data and admin data' do
|
||||
context "when the measure contains both teacher data and admin data" do
|
||||
before :each do
|
||||
create(:teacher_survey_item, scale: teacher_scale, prompt: 'A teacher survey item prompt')
|
||||
create(:teacher_survey_item, scale: teacher_scale, prompt: 'Another teacher survey item prompt')
|
||||
create(:admin_data_item, scale: admin_scale, description: 'An admin data item description')
|
||||
create(:admin_data_item, scale: admin_scale, description: 'Another admin data item description')
|
||||
create(:teacher_survey_item, scale: teacher_scale, prompt: "A teacher survey item prompt")
|
||||
create(:teacher_survey_item, scale: teacher_scale, prompt: "Another teacher survey item prompt")
|
||||
create(:admin_data_item, scale: admin_scale, description: "An admin data item description")
|
||||
create(:admin_data_item, scale: admin_scale, description: "Another admin data item description")
|
||||
end
|
||||
|
||||
it 'returns a list of data item presenters with two elements' do
|
||||
it "returns a list of data item presenters with two elements" do
|
||||
expect(measure_presenter.data_item_presenters.count).to eq 2
|
||||
|
||||
first_data_item_presenter = measure_presenter.data_item_presenters[0]
|
||||
expect(first_data_item_presenter.id).to eq 'teacher-survey-items-measure-id'
|
||||
expect(first_data_item_presenter.title).to eq 'Teacher survey'
|
||||
expect(first_data_item_presenter.data_item_accordion_id).to eq 'data-item-accordion-measure-id'
|
||||
expect(first_data_item_presenter.id).to eq "teacher-survey-items-measure-id"
|
||||
expect(first_data_item_presenter.title).to eq "Teacher survey"
|
||||
expect(first_data_item_presenter.data_item_accordion_id).to eq "data-item-accordion-measure-id"
|
||||
|
||||
second_data_item_presenter = measure_presenter.data_item_presenters[1]
|
||||
expect(second_data_item_presenter.id).to eq 'admin-data-items-measure-id'
|
||||
expect(second_data_item_presenter.title).to eq 'School admin data'
|
||||
expect(second_data_item_presenter.data_item_accordion_id).to eq 'data-item-accordion-measure-id'
|
||||
expect(second_data_item_presenter.id).to eq "admin-data-items-measure-id"
|
||||
expect(second_data_item_presenter.title).to eq "School data"
|
||||
expect(second_data_item_presenter.data_item_accordion_id).to eq "data-item-accordion-measure-id"
|
||||
end
|
||||
end
|
||||
|
||||
context 'when the measure has partial data for teachers and students' do
|
||||
context "when the measure has partial data for teachers and students" do
|
||||
before :each do
|
||||
teacher_survey_item = create(:teacher_survey_item, scale: teacher_scale)
|
||||
student_survey_item = create(:student_survey_item, scale: student_scale)
|
||||
|
|
@ -77,38 +77,38 @@ describe MeasurePresenter do
|
|||
survey_item: student_survey_item, academic_year:, school:)
|
||||
end
|
||||
|
||||
it 'tracks which parts of the data are sufficient' do
|
||||
it "tracks which parts of the data are sufficient" do
|
||||
teacher_data_item_presenter = measure_presenter.data_item_presenters.find do |presenter|
|
||||
presenter.title == 'Teacher survey'
|
||||
presenter.title == "Teacher survey"
|
||||
end
|
||||
student_data_item_presenter = measure_presenter.data_item_presenters.find do |presenter|
|
||||
presenter.title == 'Student survey'
|
||||
presenter.title == "Student survey"
|
||||
end
|
||||
expect(teacher_data_item_presenter.sufficient_data?).to be true
|
||||
expect(student_data_item_presenter.sufficient_data?).to be false
|
||||
end
|
||||
end
|
||||
|
||||
context 'when the measure has insufficient admin data and insufficient teacher/student data' do
|
||||
context "when the measure has insufficient admin data and insufficient teacher/student data" do
|
||||
before :each do
|
||||
create(:admin_data_item, scale: admin_scale)
|
||||
create(:teacher_survey_item, scale: teacher_scale)
|
||||
create(:student_survey_item, scale: student_scale)
|
||||
end
|
||||
|
||||
it 'tracks the reason for their insufficiency' do
|
||||
it "tracks the reason for their insufficiency" do
|
||||
teacher_data_item_presenter = measure_presenter.data_item_presenters.find do |presenter|
|
||||
presenter.title == 'Teacher survey'
|
||||
presenter.title == "Teacher survey"
|
||||
end
|
||||
student_data_item_presenter = measure_presenter.data_item_presenters.find do |presenter|
|
||||
presenter.title == 'Student survey'
|
||||
presenter.title == "Student survey"
|
||||
end
|
||||
admin_data_item_presenter = measure_presenter.data_item_presenters.find do |presenter|
|
||||
presenter.title == 'School admin data'
|
||||
presenter.title == "School data"
|
||||
end
|
||||
expect(teacher_data_item_presenter.reason_for_insufficiency).to eq 'low response rate'
|
||||
expect(student_data_item_presenter.reason_for_insufficiency).to eq 'low response rate'
|
||||
expect(admin_data_item_presenter.reason_for_insufficiency).to eq 'limited availability'
|
||||
expect(teacher_data_item_presenter.reason_for_insufficiency).to eq "low response rate"
|
||||
expect(student_data_item_presenter.reason_for_insufficiency).to eq "low response rate"
|
||||
expect(admin_data_item_presenter.reason_for_insufficiency).to eq "limited availability"
|
||||
end
|
||||
end
|
||||
end
|
||||
|
|
|
|||
|
|
@ -8,11 +8,11 @@ describe "overview/index" do
|
|||
measure = create(:measure, name: "Support For Teaching Development & Growth", measure_id: "1")
|
||||
scale = create(:scale, measure:)
|
||||
create(:student_survey_item,
|
||||
scale:,
|
||||
watch_low_benchmark: 1.5,
|
||||
growth_low_benchmark: 2.5,
|
||||
approval_low_benchmark: 3.5,
|
||||
ideal_low_benchmark: 4.5)
|
||||
scale:,
|
||||
watch_low_benchmark: 1.5,
|
||||
growth_low_benchmark: 2.5,
|
||||
approval_low_benchmark: 3.5,
|
||||
ideal_low_benchmark: 4.5)
|
||||
measure
|
||||
end
|
||||
|
||||
|
|
@ -20,11 +20,11 @@ describe "overview/index" do
|
|||
measure = create(:measure, name: "Effective Leadership", measure_id: "2")
|
||||
scale = create(:scale, measure:)
|
||||
create(:teacher_survey_item,
|
||||
scale:,
|
||||
watch_low_benchmark: 1.5,
|
||||
growth_low_benchmark: 2.5,
|
||||
approval_low_benchmark: 3.5,
|
||||
ideal_low_benchmark: 4.5)
|
||||
scale:,
|
||||
watch_low_benchmark: 1.5,
|
||||
growth_low_benchmark: 2.5,
|
||||
approval_low_benchmark: 3.5,
|
||||
ideal_low_benchmark: 4.5)
|
||||
measure
|
||||
end
|
||||
|
||||
|
|
@ -32,11 +32,11 @@ describe "overview/index" do
|
|||
measure = create(:measure, name: "Professional Qualifications", measure_id: "3")
|
||||
scale = create(:scale, measure:)
|
||||
create(:admin_data_item,
|
||||
scale:,
|
||||
watch_low_benchmark: 1.5,
|
||||
growth_low_benchmark: 2.5,
|
||||
approval_low_benchmark: 3.5,
|
||||
ideal_low_benchmark: 4.5)
|
||||
scale:,
|
||||
watch_low_benchmark: 1.5,
|
||||
growth_low_benchmark: 2.5,
|
||||
approval_low_benchmark: 3.5,
|
||||
ideal_low_benchmark: 4.5)
|
||||
measure
|
||||
end
|
||||
|
||||
|
|
@ -48,13 +48,13 @@ describe "overview/index" do
|
|||
@district = create(:district)
|
||||
@school = create(:school)
|
||||
@student_response_rate_presenter = ResponseRatePresenter.new(focus: :student, school: @school,
|
||||
academic_year: @academic_year)
|
||||
academic_year: @academic_year)
|
||||
@teacher_response_rate_presenter = ResponseRatePresenter.new(focus: :teacher, school: @school,
|
||||
academic_year: @academic_year)
|
||||
academic_year: @academic_year)
|
||||
|
||||
Respondent.create!(school: @school, academic_year: @academic_year, total_students: 40, total_teachers: 40)
|
||||
ResponseRate.create!(subcategory: Subcategory.first, school: @school, academic_year: @academic_year,
|
||||
student_response_rate: 100, teacher_response_rate: 100, meets_student_threshold: true, meets_teacher_threshold: true)
|
||||
student_response_rate: 100, teacher_response_rate: 100, meets_student_threshold: true, meets_teacher_threshold: true)
|
||||
|
||||
render
|
||||
end
|
||||
|
|
@ -69,7 +69,7 @@ describe "overview/index" do
|
|||
end
|
||||
|
||||
it "displays a note detailing which measures have insufficient responses for the given school & academic year" do
|
||||
expect(rendered).to match %r{Note: The following measures are not displayed due to limited availability of school admin data and/or low survey response rates: Support For Teaching Development & Growth; Professional Qualifications.}
|
||||
expect(rendered).to match %r{Note: The following measures are not displayed due to limited availability of school data and/or low survey response rates: Support For Teaching Development & Growth; Professional Qualifications.}
|
||||
end
|
||||
|
||||
it "displays a variance row and label only those presenters for which the score is not nil" do
|
||||
|
|
@ -88,19 +88,19 @@ describe "overview/index" do
|
|||
measure = create(:measure, name: "Display Me", measure_id: "display-me")
|
||||
scale = create(:scale, measure:)
|
||||
create(:student_survey_item,
|
||||
scale:,
|
||||
watch_low_benchmark: 1.5,
|
||||
growth_low_benchmark: 2.5,
|
||||
approval_low_benchmark: 3.5,
|
||||
ideal_low_benchmark: 4.5)
|
||||
scale:,
|
||||
watch_low_benchmark: 1.5,
|
||||
growth_low_benchmark: 2.5,
|
||||
approval_low_benchmark: 3.5,
|
||||
ideal_low_benchmark: 4.5)
|
||||
[
|
||||
VarianceChartRowPresenter.new(measure:,
|
||||
score: Score.new(average: rand))
|
||||
score: Score.new(average: rand))
|
||||
]
|
||||
end
|
||||
|
||||
it "does not display a note detailing which measures have insufficient responses for the given school & academic year" do
|
||||
expect(rendered).not_to match %r{Note: The following measures are not displayed due to limited availability of school admin data and/or low survey response rates}
|
||||
expect(rendered).not_to match %r{Note: The following measures are not displayed due to limited availability of school data and/or low survey response rates}
|
||||
end
|
||||
|
||||
it "displays a variance row for each presenter" do
|
||||
|
|
|
|||
|
|
@ -1,14 +1,14 @@
|
|||
require 'rails_helper'
|
||||
require "rails_helper"
|
||||
include VarianceHelper
|
||||
|
||||
describe 'overview/_variance_chart.html.erb' do
|
||||
describe "overview/_variance_chart.html.erb" do
|
||||
before do
|
||||
@academic_year = create(:academic_year)
|
||||
@district = create(:district)
|
||||
@school = create(:school)
|
||||
end
|
||||
|
||||
context 'When there are scores to show' do
|
||||
context "When there are scores to show" do
|
||||
subject { Nokogiri::HTML(rendered) }
|
||||
|
||||
let(:survey_items1) { [create(:student_survey_item)] }
|
||||
|
|
@ -31,24 +31,24 @@ describe 'overview/_variance_chart.html.erb' do
|
|||
VarianceChartRowPresenter.new(measure: higher_scoring_measure, score: Score.new(average: 5))
|
||||
]
|
||||
|
||||
render partial: 'variance_chart', locals: { presenters: }
|
||||
render partial: "variance_chart", locals: { presenters: }
|
||||
end
|
||||
|
||||
it 'displays higher scoring measures above lower scoring measures' do
|
||||
measure_row_bars = subject.css('rect.measure-row-bar')
|
||||
it "displays higher scoring measures above lower scoring measures" do
|
||||
measure_row_bars = subject.css("rect.measure-row-bar")
|
||||
|
||||
higher_scoring_measure_index = measure_row_bars.find_index do |bar|
|
||||
bar['data-for-measure-id'] == higher_scoring_measure.measure_id
|
||||
bar["data-for-measure-id"] == higher_scoring_measure.measure_id
|
||||
end
|
||||
lower_scoring_measure_index = measure_row_bars.find_index do |bar|
|
||||
bar['data-for-measure-id'] == lower_scoring_measure.measure_id
|
||||
bar["data-for-measure-id"] == lower_scoring_measure.measure_id
|
||||
end
|
||||
|
||||
expect(higher_scoring_measure_index).to be < lower_scoring_measure_index
|
||||
end
|
||||
end
|
||||
|
||||
context 'When there are no scores to show for any measures' do
|
||||
context "When there are no scores to show for any measures" do
|
||||
before :each do
|
||||
measure_lacking_score = create(:measure)
|
||||
another_measure_lacking_score = create(:measure)
|
||||
|
|
@ -57,15 +57,15 @@ describe 'overview/_variance_chart.html.erb' do
|
|||
VarianceChartRowPresenter.new(measure: another_measure_lacking_score, score: Score.new(average: nil))
|
||||
]
|
||||
|
||||
render partial: 'variance_chart', locals: { presenters: }
|
||||
render partial: "variance_chart", locals: { presenters: }
|
||||
end
|
||||
|
||||
it "displays the text 'insufficient data' for an empty dataset" do
|
||||
expect(rendered).to have_text 'Insufficient data'
|
||||
expect(rendered).to have_text "Insufficient data"
|
||||
end
|
||||
|
||||
it "does not display the partial data text: 'The following measures are not displayed due to limited availability of school admin data and/or low survey response rates:' " do
|
||||
expect(rendered).not_to have_text 'The following measures are not displayed due to limited availability of school admin data and/or low survey response rates:'
|
||||
it "does not display the partial data text: 'The following measures are not displayed due to limited availability of school data and/or low survey response rates:' " do
|
||||
expect(rendered).not_to have_text "The following measures are not displayed due to limited availability of school data and/or low survey response rates:"
|
||||
end
|
||||
end
|
||||
end
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue