DEV: Improve performance of system test `sign_in` helper (#19579)

Previously, calling `sign_in` would cause the browser to be redirected to `/`, and would cause the Ember app to boot. We would then call `visit()`, causing the app to boot for a second time.

This commit adds a `redirect=false` option to the `/session/username/become` route. This avoids the unnecessary boot of the app, and leads to significantly faster system spec run times.

In local testing, this takes the full system-spec suite for chat from ~6min to ~4min.
This commit is contained in:
David Taylor 2022-12-22 16:03:27 +00:00 committed by GitHub
parent b11e7fb901
commit b1b53da71d
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
7 changed files with 13 additions and 2 deletions

View File

@ -113,9 +113,14 @@ class SessionController < ApplicationController
raise "User #{params[:session_id]} not found" if user.blank?
log_on_user(user)
if params[:redirect] == "false"
render plain: "Signed in to #{params[:session_id]} successfully"
else
redirect_to path("/")
end
end
end
def sso_login
raise Discourse::NotFound unless SiteSetting.enable_discourse_connect

View File

@ -9,6 +9,7 @@ RSpec.describe "Channel selector modal", type: :system, js: true do
before do
chat_system_bootstrap
sign_in(current_user)
visit("/")
end
KEY_MODIFIER = RUBY_PLATFORM =~ /darwin/i ? :meta : :control

View File

@ -19,6 +19,8 @@ RSpec.describe "Navigation", type: :system, js: true do
context "when clicking chat icon and drawer is viewing channel" do
it "navigates to index" do
visit("/")
chat_page.open_from_header
chat_drawer_page.open_channel(category_channel_2)
chat_page.open_from_header

View File

@ -158,6 +158,7 @@ RSpec.describe "Sidebar navigation menu", type: :system, js: true do
end
it "displays all participants names" do
visit("/")
expect(
page.find(
".sidebar-section-chat-dms a.sidebar-section-link:nth-child(1) .sidebar-section-link-content-text",

View File

@ -16,6 +16,7 @@ RSpec.describe "Unfollow dm channel", type: :system, js: true do
context "when receiving a message after unfollowing" do
it "correctly shows the channel" do
visit("/")
find(".channel-#{dm_channel_1.id}").hover
find(".channel-#{dm_channel_1.id} .sidebar-section-link-hover").click

View File

@ -175,6 +175,7 @@ RSpec.describe "User menu notifications | sidebar", type: :system, js: true do
using_session(:user_1) do
sign_in(other_user)
visit("/")
find(".header-dropdown-toggle.current-user").click
expect(find("#user-menu-button-chat-notifications")).to have_content(1)

View File

@ -12,7 +12,7 @@ module SystemHelpers
end
def sign_in(user)
visit "/session/#{user.encoded_username}/become"
visit "/session/#{user.encoded_username}/become.json?redirect=false"
end
def sign_out