mirror of
https://github.com/discourse/discourse.git
synced 2025-01-26 14:17:29 +08:00
498481e5be
This commit introduces a new 'dev tools' feature for core, theme and plugin developers. This is enabled by default in development environments, and can be enabled in production by running `enableDevTools()` in the browser console. When enabled, it will load a separate dev-tools JS/CSS bundle, and show a new toolbar on the left of the page. Dev Tools will remain enabled until the 'x' button is clicked, or `disableDevTools()` is run in the console. The toolbar currently has three buttons: - "Toggle safe mode" provides an easy way to toggle all themes/plugins on/off - "Toggle verbose localization" is a toggle for our existing locale debugging feature - "Debug plugin outlets" is inspired by the popular 'plugin outlet locations' theme component. It hooks into core's plugin outlet system, and renders a button into every single outlet. Those buttons have a tooltip which shows more information about the outlet, including all of the outletArg values. To inspect the value further, buttons allow the values to be saved to globals and logged to the console. All of this is implemented under `/static`, and is only async-import()-d when the dev tools are enabled. Therefore, we can continue to add more tools, with zero performance cost to ordinary users of Discourse.
42 lines
1.5 KiB
Ruby
42 lines
1.5 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
describe "Discourse dev tools", type: :system do
|
|
it "works" do
|
|
# Open site and check it loads successfully, with no dev-tools
|
|
visit("/latest")
|
|
expect(page).to have_css("#site-logo")
|
|
expect(page).not_to have_css(".dev-tools-toolbar")
|
|
|
|
# Enable dev tools, and wait for page to reload
|
|
page.evaluate_script("enableDevTools()")
|
|
expect(page).to have_css(".dev-tools-toolbar")
|
|
|
|
# Turn on plugin outlet debugging, and check they appear
|
|
find(".dev-tools-toolbar .toggle-plugin-outlets").click
|
|
expect(page).to have_css(".plugin-outlet-info", minimum: 10)
|
|
|
|
# Open a tooltip
|
|
find(".plugin-outlet-info[data-outlet-name=home-logo-contents__before]").hover
|
|
expect(page).to have_css(".plugin-outlet-info__wrapper")
|
|
|
|
# Check the outletArgs are shown
|
|
expect(page).to have_css(".plugin-outlet-info__wrapper .key", text: "title")
|
|
expect(page).to have_css(
|
|
".plugin-outlet-info__wrapper .value",
|
|
text: "\"#{SiteSetting.title}\"",
|
|
)
|
|
|
|
# Turn off plugin outlet debugging, and check they disappeared
|
|
find(".dev-tools-toolbar .toggle-plugin-outlets").click
|
|
expect(page).not_to have_css(".plugin-outlet-info")
|
|
|
|
# Disable dev tools
|
|
find(".dev-tools-toolbar .disable-dev-tools").click
|
|
|
|
# Check reloaded successfully
|
|
expect(page).not_to have_css(".dev-tools-toolbar")
|
|
expect(page).to have_css("#site-logo")
|
|
expect(page).not_to have_css(".dev-tools-toolbar")
|
|
end
|
|
end
|