Update tests to check for touching of caching timestamps

This commit is contained in:
Karina Kwiatek 2023-06-16 18:09:38 +02:00
parent a6f526b9c4
commit 1b05063f4a
5 changed files with 35 additions and 8 deletions

View File

@ -26,6 +26,8 @@ describe Ajax::AnswerController, :ajax_controller, type: :controller do
end end
include_examples "returns the expected response" include_examples "returns the expected response"
include_examples "touches user timestamp", :inbox_updated_at
end end
shared_examples "does not create the answer" do shared_examples "does not create the answer" do

View File

@ -4,6 +4,8 @@
require "rails_helper" require "rails_helper"
describe Ajax::CommentController, :ajax_controller, type: :controller do describe Ajax::CommentController, :ajax_controller, type: :controller do
include ActiveSupport::Testing::TimeHelpers
let(:answer) { FactoryBot.create(:answer, user: FactoryBot.create(:user)) } let(:answer) { FactoryBot.create(:answer, user: FactoryBot.create(:user)) }
describe "#create" do describe "#create" do
@ -23,6 +25,19 @@ describe Ajax::CommentController, :ajax_controller, type: :controller do
expect(answer.reload.comments.ids).to include(Comment.last.id) expect(answer.reload.comments.ids).to include(Comment.last.id)
end end
context "a user is subscribed to the answer" do
let(:subscribed_user) { FactoryBot.create(:user) }
it "updates the notification caching timestamp for a subscribed user" do
Subscription.subscribe(subscribed_user, answer)
travel_to(1.day.from_now) do
expect { subject }.to change { subscribed_user.reload.notifications_updated_at }.to(DateTime.now)
end
end
end
include_examples "returns the expected response" include_examples "returns the expected response"
end end

View File

@ -65,12 +65,7 @@ describe InboxController, type: :controller do
expect { subject }.to change { inbox_entry.reload.new? }.from(true).to(false) expect { subject }.to change { inbox_entry.reload.new? }.from(true).to(false)
end end
it "updates the the timestamp used for caching" do include_examples "touches user timestamp", :inbox_updated_at
user.update(inbox_updated_at: original_inbox_updated_at)
travel 1.second do
expect { subject }.to change { user.reload.inbox_updated_at.floor }.from(original_inbox_updated_at.floor).to(Time.now.utc.floor)
end
end
context "when requested the turbo stream format" do context "when requested the turbo stream format" do
subject { get :show, format: :turbo_stream } subject { get :show, format: :turbo_stream }
@ -280,6 +275,8 @@ describe InboxController, type: :controller do
it "creates an inbox entry" do it "creates an inbox entry" do
expect { subject }.to(change { user.inboxes.count }.by(1)) expect { subject }.to(change { user.inboxes.count }.by(1))
end end
include_examples "touches user timestamp", :inbox_updated_at
end end
end end
end end

View File

@ -17,18 +17,20 @@ describe Settings::ExportController, type: :controller do
end end
context "when user has a new DataExported notification" do context "when user has a new DataExported notification" do
let(:notification) do let!(:notification) do
Notification::DataExported.create( Notification::DataExported.create(
target_id: user.id, target_id: user.id,
target_type: "User::DataExport", target_type: "User::DataExport",
recipient: user, recipient: user,
new: true new: true,
) )
end end
it "marks the notification as read" do it "marks the notification as read" do
expect { subject }.to change { notification.reload.new }.from(true).to(false) expect { subject }.to change { notification.reload.new }.from(true).to(false)
end end
include_examples "touches user timestamp", :notifications_updated_at
end end
end end
end end

View File

@ -0,0 +1,11 @@
# frozen_string_literal: true
RSpec.shared_examples_for "touches user timestamp" do |timestamp_column|
include ActiveSupport::Testing::TimeHelpers
it "touches #{timestamp_column}" do
travel_to(1.day.from_now) do
expect { subject }.to change { user.reload.send(timestamp_column) }.to(DateTime.now)
end
end
end