You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
sqm-dashboards/spec/models/report/subcategory_spec.rb

96 lines
3.5 KiB

require "rails_helper"
RSpec.describe Report::Subcategory, type: :model do
let(:school) { create(:school, name: "Milford High", slug: "milford-high") }
let(:academic_year) { create(:academic_year, range: "2018-2019") }
let(:subcategory) { create(:subcategory, subcategory_id: "1A") }
let(:respondent) { create(:respondent, school:, academic_year:) }
before :each do
school
academic_year
subcategory
respondent
end
let(:measure) { create(:measure, subcategory:) }
let(:scale) { create(:scale, measure:) }
let(:survey_item) { create(:student_survey_item, scale:) }
context "when creating a report for a subcategory" do
before :each do
create_list(:survey_item_response, 10, survey_item:, school:, academic_year:)
end
it "creates a report for subcategories with the correct headers" do
report = Report::Subcategory.create_report
csv = CSV.parse(report, headers: true)
headers = csv.headers
expect(headers).to be_a(Array)
expect(headers).to eq(["District", "School", "School Code", "Academic Year", "Recorded Date Range", "Grades", "Subcategory", "Student Score",
"Student Zone", "Teacher Score", "Teacher Zone", "Admin Score", "Admin Zone", "All Score (Average)", "All Score Zone"])
end
it "Adds information about the first school and first academic year to the report" do
report = Report::Subcategory.create_report
csv = CSV.parse(report, headers: true)
csv.first in [district, school_name, school_code, academic_year, recorded_date_range, grades, subcategory_id, *]
expect(school_name).to eq("Milford High")
expect(academic_year).to eq("2018-2019")
expect(subcategory_id).to eq("1A")
end
end
describe ".create_report" do
before do
allow(Report::Subcategory).to receive(:write_csv)
end
it "generates a CSV report" do
expect(FileUtils).to receive(:mkdir_p).with(Rails.root.join("tmp", "reports"))
Report::Subcategory.create_report
expect(Report::Subcategory).to have_received(:write_csv)
end
end
describe ".write_csv" do
it "writes the data to a CSV file" do
data = [["School", "Academic Year", "Subcategory"], ["School A", "2022-2023", "Category A"]]
csv = CSV.generate do |csv|
data.each do |row|
csv << row
end
end
filepath = Rails.root.join("tmp", "spec", "reports", "subcategories.csv")
FileUtils.mkdir_p Rails.root.join("tmp", "spec", "reports")
Report::Subcategory.write_csv(csv:, filepath:)
csv_data = File.read(filepath)
expect(csv_data).to include("School,Academic Year,Subcategory")
expect(csv_data).to include("School A,2022-2023,Category A")
end
end
describe ".student_score" do
let(:response_rate) { create(:response_rate, subcategory:, school:, academic_year:) }
let(:row) { [response_rate, subcategory, school, academic_year] }
it "returns student score if response rate meets student threshold" do
allow(subcategory).to receive(:student_score).and_return(80)
allow(response_rate).to receive(:meets_student_threshold?).and_return(true)
score = Report::Subcategory.student_score(row:)
expect(score).to eq(80)
end
it 'returns "N/A" if response rate does not meet student threshold' do
allow(response_rate).to receive(:meets_student_threshold?).and_return(false)
score = Report::Subcategory.student_score(row:)
expect(score).to eq("N/A")
end
end
end