96 lines
3.5 KiB
Ruby
96 lines
3.5 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
#
|
|
# Copyright (C) 2011 - present Instructure, Inc.
|
|
#
|
|
# This file is part of Canvas.
|
|
#
|
|
# Canvas is free software: you can redistribute it and/or modify it under
|
|
# the terms of the GNU Affero General Public License as published by the Free
|
|
# Software Foundation, version 3 of the License.
|
|
#
|
|
# Canvas is distributed in the hope that it will be useful, but WITHOUT ANY
|
|
# WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR
|
|
# A PARTICULAR PURPOSE. See the GNU Affero General Public License for more
|
|
# details.
|
|
#
|
|
# You should have received a copy of the GNU Affero General Public License along
|
|
# with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
#
|
|
|
|
require "nokogiri"
|
|
|
|
describe "user asset accesses" do
|
|
before do
|
|
Setting.set("enable_page_views", "db")
|
|
|
|
username = "nobody@example.com"
|
|
password = "asdfasdf"
|
|
u = user_with_pseudonym(active_user: true,
|
|
username:,
|
|
password:)
|
|
u.save!
|
|
@e = course_with_teacher active_course: true,
|
|
user: u,
|
|
active_enrollment: true
|
|
@e.save!
|
|
@teacher = u
|
|
user_session(@user, @pseudonym)
|
|
|
|
user_model
|
|
@student = @user
|
|
@course.enroll_student(@student).accept
|
|
end
|
|
|
|
include ApplicationHelper
|
|
|
|
it "records and show user asset accesses" do
|
|
now = Time.now.utc
|
|
allow(Time).to receive(:now).and_return(now)
|
|
|
|
assignment = @course.assignments.create(title: "Assignment 1")
|
|
assignment.workflow_state = "active"
|
|
assignment.save!
|
|
|
|
user_session(@student)
|
|
get "/courses/#{@course.id}/assignments/#{assignment.id}"
|
|
expect(response).to be_successful
|
|
|
|
user_session(@teacher)
|
|
get "/courses/#{@course.id}/users/#{@student.id}/usage"
|
|
expect(response).to be_successful
|
|
html = Nokogiri::HTML5(response.body)
|
|
expect(html.css("#usage_report .access.assignment").length).to eq 1
|
|
expect(html.css("#usage_report .access.assignment .readable_name").text.strip).to eq "Assignment 1"
|
|
expect(html.css("#usage_report .access.assignment .view_score").text.strip).to eq "1"
|
|
expect(html.css("#usage_report .access.assignment .last_viewed").text.strip).to eq datetime_string(now)
|
|
expect(AssetUserAccess.where(user_id: @student).first.last_access.to_i).to eq now.to_i
|
|
|
|
now2 = now + 1.hour
|
|
allow(Time).to receive(:now).and_return(now2)
|
|
|
|
# make sure that we're not using the uodated_at time as the time of the access
|
|
AssetUserAccess.where(user_id: @student).update_all(updated_at: now2 + 5.hours)
|
|
|
|
user_session(@student)
|
|
get "/courses/#{@course.id}/assignments/#{assignment.id}"
|
|
expect(response).to be_successful
|
|
|
|
user_session(@teacher)
|
|
get "/courses/#{@course.id}/users/#{@student.id}/usage"
|
|
expect(response).to be_successful
|
|
html = Nokogiri::HTML5(response.body)
|
|
expect(html.css("#usage_report .access.assignment").length).to eq 1
|
|
expect(html.css("#usage_report .access.assignment .readable_name").text.strip).to eq "Assignment 1"
|
|
expect(html.css("#usage_report .access.assignment .view_score").text.strip).to eq "2"
|
|
expect(html.css("#usage_report .access.assignment .last_viewed").text.strip).to eq datetime_string(now2)
|
|
expect(AssetUserAccess.where(user_id: @student).first.last_access.to_i).to eq now2.to_i
|
|
end
|
|
|
|
it "records user names when viewing profiles" do
|
|
user_session(@student)
|
|
get "/courses/#{@course.id}/users/#{@teacher.id}"
|
|
expect(AssetUserAccess.where(user_id: @student).first.display_name).to eq @teacher.name
|
|
end
|
|
end
|