discourse/spec/system/user_tips_spec.rb
Jarek Radosz 6a9af7c82f
FIX: Show the last rendered user-tip (#29346)
…or a tip with the highest priority.

This regressed in 597ef11195 where we got rid of `next()` calls, so we'd render the first tip we encounter.

The commit also adds a test and updates existing ones.
2024-10-22 22:41:29 +02:00

79 lines
2.1 KiB
Ruby

# frozen_string_literal: true
describe "User tips", type: :system do
fab!(:admin)
fab!(:user)
fab!(:topics) { Fabricate.times(2, :post).map(&:topic) }
fab!(:posts) { Fabricate.times(3, :post, topic: topics[0]) }
let(:discovery) { PageObjects::Pages::Discovery.new }
let(:tooltip) { PageObjects::Components::Tooltips.new("user-tip") }
context "when user tips are disabled" do
before { SiteSetting.enable_user_tips = false }
it "does not show the 'first notification' tip to the user when disabled" do
sign_in(user)
visit("/")
expect(tooltip).to be_not_present
end
it "does not show the boostrapping tip to an admin user" do
SiteSetting.bootstrap_mode_enabled = true
sign_in(admin)
visit("/")
expect(tooltip).to be_not_present
end
end
context "when user tips are enabled" do
before { SiteSetting.enable_user_tips = true }
it "shows the 'first notification' tip to the user when enabled" do
sign_in(user)
expect(user.user_option.seen_popups).to eq(nil)
visit("/")
expect(tooltip).to be_present(text: "Your first notification!")
# Find an element with no action to simulate clicking outside the user tip
find("th.topic-list-data span", text: "Topic").click
expect(tooltip).to be_not_present
end
it "shows a second notification once first is dismissed and user visits a topic" do
sign_in(user)
visit("/")
find(".fk-d-tooltip__content .user-tip__buttons .btn-primary").click
expect(tooltip).to be_not_present
discovery.topic_list.visit_topic(topics[0])
expect(tooltip).to be_present(text: "Topic timeline")
tooltip.find(".user-tip__buttons .btn-primary").click
expect(tooltip).to be_present(text: "Keep reading!")
end
it "can skip all tips" do
sign_in(user)
visit("/")
tooltip.find(".user-tip__buttons .btn", text: "Skip tips").click
expect(tooltip).to be_not_present
discovery.topic_list.visit_topic(topics[0])
expect(tooltip).to be_not_present
end
end
end