DEV: adds a tooltip system spec component (#28275)

Usage:

```
tooltip = PageObjects::Components::Tooltips.new(identifier)
expect(tooltip).to be_present(text: "Welcome")
expect(tooltip).to be_not_present(text: "Welcome")
tooltip.find(".my-button).click
```
This commit is contained in:
Joffrey JAFFEUX 2024-08-08 14:02:00 +02:00 committed by GitHub
parent e79a50d7a9
commit 2fdee7849c
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
2 changed files with 56 additions and 28 deletions

View File

@ -0,0 +1,27 @@
# frozen_string_literal: true
module PageObjects
module Components
class Tooltips < PageObjects::Components::Base
SELECTOR = ".fk-d-tooltip__content"
attr_reader :identifier
def initialize(identifier)
@identifier = identifier
end
def find(selector, **kwargs)
page.find("#{SELECTOR}[data-identifier='#{identifier}'] #{selector}", **kwargs)
end
def present?(**kwargs)
page.has_selector?("#{SELECTOR}[data-identifier='#{identifier}']", **kwargs)
end
def not_present?(**kwargs)
page.has_no_selector?("#{SELECTOR}[data-identifier='#{identifier}']", **kwargs)
end
end
end
end

View File

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