diff --git a/.eslintignore b/.eslintignore index 3956d17380d..68b8560b4a8 100644 --- a/.eslintignore +++ b/.eslintignore @@ -12,7 +12,7 @@ lib/highlight_js/ plugins/**/lib/javascripts/locale public/ vendor/ -app/assets/javascripts/discourse/tests/test-boot-rails.js +app/assets/javascripts/discourse/tests/test_helper.js app/assets/javascripts/discourse/tests/fixtures node_modules/ dist/ diff --git a/.prettierignore b/.prettierignore index 217c164e17c..3884169675c 100644 --- a/.prettierignore +++ b/.prettierignore @@ -20,7 +20,7 @@ lib/highlight_js/ plugins/**/lib/javascripts/locale public/ vendor/ -app/assets/javascripts/discourse/tests/test-boot-rails.js +app/assets/javascripts/discourse/tests/test_helper.js app/assets/javascripts/discourse/tests/fixtures node_modules/ dist/ diff --git a/app/assets/javascripts/discourse-common/addon/lib/debounce.js b/app/assets/javascripts/discourse-common/addon/lib/debounce.js index dcd2693b78c..5e30864574f 100644 --- a/app/assets/javascripts/discourse-common/addon/lib/debounce.js +++ b/app/assets/javascripts/discourse-common/addon/lib/debounce.js @@ -11,9 +11,7 @@ let testingFunc = isLegacyEmber() ? run : next; export default function () { if (isTesting()) { - // Don't include the time argument (in ms) - let args = [].slice.call(arguments, 0, -1); - return testingFunc.apply(void 0, args); + return testingFunc(...arguments); } else { return debounce(...arguments); } diff --git a/app/assets/javascripts/discourse/ember-cli-build.js b/app/assets/javascripts/discourse/ember-cli-build.js index 602f51f189b..5125e7e08e5 100644 --- a/app/assets/javascripts/discourse/ember-cli-build.js +++ b/app/assets/javascripts/discourse/ember-cli-build.js @@ -37,66 +37,8 @@ module.exports = function (defaults) { // We don't use SRI in Rails. Disable here to match: enabled: false, }, - - "ember-cli-terser": { - enabled: true, - exclude: [ - "**/test-*.js", - "**/core-tests*.js", - "**/highlightjs/*", - "**/javascripts/*", - ], - }, - - // We need to build tests in prod for theme tests - tests: true, }); - // Patching a private method is not great, but there's no other way for us to tell - // Ember CLI that we want the tests alone in a package without helpers/fixtures, since - // we re-use those in the theme tests. - app._defaultPackager.packageApplicationTests = function (tree) { - let appTestTrees = [] - .concat( - this.packageEmberCliInternalFiles(), - this.packageTestApplicationConfig(), - tree - ) - .filter(Boolean); - - appTestTrees = mergeTrees(appTestTrees, { - overwrite: true, - annotation: "TreeMerger (appTestTrees)", - }); - - let tests = concat(appTestTrees, { - inputFiles: [ - "**/tests/acceptance/*.js", - "**/tests/integration/*.js", - "**tests/unit/*.js", - ], - headerFiles: ["vendor/ember-cli/tests-prefix.js"], - footerFiles: ["vendor/ember-cli/app-config.js"], - outputFile: "/assets/core-tests.js", - annotation: "Concat: Core Tests", - sourceMapConfig: false, - }); - - let testHelpers = concat(appTestTrees, { - inputFiles: [ - "**/tests/test-boot-ember-cli.js", - "**/tests/helpers/**/*.js", - "**/tests/fixtures/**/*.js", - "**/tests/setup-tests.js", - ], - outputFile: "/assets/test-helpers.js", - annotation: "Concat: Test Helpers", - sourceMapConfig: false, - }); - - return mergeTrees([tests, testHelpers]); - }; - // WARNING: We should only import scripts here if they are not in NPM. // For example: our very specific version of bootstrap-modal. app.import(vendorJs + "bootbox.js"); diff --git a/app/assets/javascripts/discourse/package.json b/app/assets/javascripts/discourse/package.json index 056a33e0880..32b109253a9 100644 --- a/app/assets/javascripts/discourse/package.json +++ b/app/assets/javascripts/discourse/package.json @@ -34,7 +34,7 @@ "discourse-common": "^1.0.0", "discourse-hbr": "^1.0.0", "discourse-widget-hbs": "^1.0.0", - "ember-auto-import": "^1.12.0", + "ember-auto-import": "^1.10.1", "ember-buffered-proxy": "^2.0.0-beta.0", "ember-cli": "~3.25.3", "ember-cli-app-version": "^4.0.0", diff --git a/app/assets/javascripts/discourse/public/assets/scripts/discourse-test-listen-boot.js b/app/assets/javascripts/discourse/public/assets/scripts/discourse-test-listen-boot.js deleted file mode 100644 index 8f46890eb42..00000000000 --- a/app/assets/javascripts/discourse/public/assets/scripts/discourse-test-listen-boot.js +++ /dev/null @@ -1,4 +0,0 @@ -document.write( - "" -); -require('discourse/tests/test-boot-ember-cli'); diff --git a/app/assets/javascripts/discourse/tests/core-tests.js b/app/assets/javascripts/discourse/tests/core_plugins_tests.js similarity index 75% rename from app/assets/javascripts/discourse/tests/core-tests.js rename to app/assets/javascripts/discourse/tests/core_plugins_tests.js index 1890b65888e..f9c99ce034e 100644 --- a/app/assets/javascripts/discourse/tests/core-tests.js +++ b/app/assets/javascripts/discourse/tests/core_plugins_tests.js @@ -1,3 +1,4 @@ //= require_tree ./acceptance //= require_tree ./integration //= require_tree ./unit +//= require ./plugin_tests diff --git a/app/assets/javascripts/discourse/tests/index.html b/app/assets/javascripts/discourse/tests/index.html index 1c9ac2bb559..34c33c48e40 100644 --- a/app/assets/javascripts/discourse/tests/index.html +++ b/app/assets/javascripts/discourse/tests/index.html @@ -50,14 +50,9 @@ - + - - - - + {{content-for "body-footer"}} diff --git a/app/assets/javascripts/discourse/tests/plugin-tests.js.erb b/app/assets/javascripts/discourse/tests/plugin-tests.js.erb deleted file mode 100644 index f2b38319a4a..00000000000 --- a/app/assets/javascripts/discourse/tests/plugin-tests.js.erb +++ /dev/null @@ -1,10 +0,0 @@ -<% - Discourse.plugins.each do |p| - root_path = "#{File.dirname(p.path)}/test/javascripts" - - to_glob = [root_path + '/**/**.es6'] - to_glob << (root_path + '/**/**.js') if p.transpile_js - - Dir.glob(to_glob) { |f| require_asset(f) } - end -%> diff --git a/app/assets/javascripts/discourse/tests/active-plugins.js.erb b/app/assets/javascripts/discourse/tests/plugin_tests.js.erb similarity index 53% rename from app/assets/javascripts/discourse/tests/active-plugins.js.erb rename to app/assets/javascripts/discourse/tests/plugin_tests.js.erb index 6b2958541e9..0bb267961df 100644 --- a/app/assets/javascripts/discourse/tests/active-plugins.js.erb +++ b/app/assets/javascripts/discourse/tests/plugin_tests.js.erb @@ -8,4 +8,13 @@ require_asset(f) end end + + Discourse.plugins.each do |p| + root_path = "#{File.dirname(p.path)}/test/javascripts" + + to_glob = [root_path + '/**/**.es6'] + to_glob << (root_path + '/**/**.js') if p.transpile_js + + Dir.glob(to_glob) { |f| require_asset(f) } + end %> diff --git a/app/assets/javascripts/discourse/tests/test-boot-ember-cli.js b/app/assets/javascripts/discourse/tests/test-helper.js similarity index 96% rename from app/assets/javascripts/discourse/tests/test-boot-ember-cli.js rename to app/assets/javascripts/discourse/tests/test-helper.js index cfbc0b9ff8c..ffb266b9724 100644 --- a/app/assets/javascripts/discourse/tests/test-boot-ember-cli.js +++ b/app/assets/javascripts/discourse/tests/test-helper.js @@ -34,4 +34,3 @@ document.addEventListener("discourse-booted", () => { setupEmberOnerrorValidation: !skippingCore, }); }); -window.EmberENV.TESTS_FILE_LOADED = true; diff --git a/app/assets/javascripts/discourse/tests/test_helper.js b/app/assets/javascripts/discourse/tests/test_helper.js new file mode 100644 index 00000000000..028f3a5167f --- /dev/null +++ b/app/assets/javascripts/discourse/tests/test_helper.js @@ -0,0 +1,38 @@ +// discourse-skip-module + +//= require env +//= require jquery.debug +//= require jquery.ui.widget +//= require ember.debug +//= require message-bus +//= require qunit +//= require ember-qunit +//= require fake_xml_http_request +//= require route-recognizer +//= require pretender +//= require locales/i18n +//= require locales/en +//= require discourse-loader + +// Our base application +//= require vendor +//= require discourse-shims +//= require markdown-it-bundle +//= require application +//= require admin + +// These are not loaded in prod or development +// But we need them for testing handlebars templates in qunit +//= require handlebars +//= require ember-template-compiler + +// Test helpers +//= require sinon +//= require_tree ./helpers +//= require break_string + +//= require_tree ./fixtures + +//= require ./setup-tests +//= require test-shims +//= require jquery.magnific-popup.min.js diff --git a/app/assets/javascripts/discourse/tests/test-helpers-rails.js b/app/assets/javascripts/discourse/tests/theme_qunit_helper.js similarity index 82% rename from app/assets/javascripts/discourse/tests/test-helpers-rails.js rename to app/assets/javascripts/discourse/tests/theme_qunit_helper.js index 71bb2c44530..a9c60c90f9e 100644 --- a/app/assets/javascripts/discourse/tests/test-helpers-rails.js +++ b/app/assets/javascripts/discourse/tests/theme_qunit_helper.js @@ -3,3 +3,4 @@ //= require_tree ./helpers //= require_tree ./fixtures //= require ./setup-tests +//= require test-shims diff --git a/app/assets/javascripts/discourse/tests/test-support-rails.js b/app/assets/javascripts/discourse/tests/theme_qunit_tests_vendor.js similarity index 69% rename from app/assets/javascripts/discourse/tests/test-support-rails.js rename to app/assets/javascripts/discourse/tests/theme_qunit_tests_vendor.js index 4f916572efc..3c6865b1e04 100644 --- a/app/assets/javascripts/discourse/tests/test-support-rails.js +++ b/app/assets/javascripts/discourse/tests/theme_qunit_tests_vendor.js @@ -5,10 +5,11 @@ //= require fake_xml_http_request //= require route-recognizer //= require pretender -//= require sinon -//= require break_string -//= require test-shims -//= require jquery.magnific-popup.min.js + +// These are not loaded in prod or development +// But we need them for testing handlebars templates in qunit //= require handlebars //= require ember-template-compiler -//= require markdown-it-bundle + +//= require sinon +//= require break_string diff --git a/app/assets/javascripts/discourse/tests/theme_qunit_vendor.js b/app/assets/javascripts/discourse/tests/theme_qunit_vendor.js new file mode 100644 index 00000000000..9eb492b917d --- /dev/null +++ b/app/assets/javascripts/discourse/tests/theme_qunit_vendor.js @@ -0,0 +1,30 @@ +// This bundle contains the same dependencies as app/assets/javascripts/vendor.js +// minus ember_jquery. +// ember_jquery doesn't work with theme tests in production because it +// contains production builds of Ember and jQuery, so we have a separate bundle +// caled theme_qunit_ember_jquery which contains a debug build for Ember and jQuery. +// We don't put theme_qunit_ember_jquery in this bundle because it would make the +// bundle too big and cause OOM exceptions during rebuilds for self-hosters on +// low-end machines. + +//= require logster + +//= require template_include.js + +//= require message-bus +//= require jquery.ui.widget.js +//= require Markdown.Converter.js +//= require bootbox.js +//= require popper.js +//= require bootstrap-modal.js +//= require caret_position +//= require jquery.sortable.js +//= require lodash.js +//= require itsatrap.js +//= require rsvp.js +//= require uppy.js +//= require buffered-proxy +//= require virtual-dom +//= require virtual-dom-amd +//= require discourse-shims +//= require pretty-text-bundle diff --git a/app/assets/javascripts/yarn.lock b/app/assets/javascripts/yarn.lock index 80a80588c24..691b5eea85e 100644 --- a/app/assets/javascripts/yarn.lock +++ b/app/assets/javascripts/yarn.lock @@ -4810,41 +4810,6 @@ ember-auto-import@^1.10.1, ember-auto-import@^1.5.3: walk-sync "^0.3.3" webpack "^4.43.0" -ember-auto-import@^1.12.0: - version "1.12.0" - resolved "https://registry.yarnpkg.com/ember-auto-import/-/ember-auto-import-1.12.0.tgz#52246b04891090e2608244e65c4c6af7710df12b" - integrity sha512-fzMGnyHGfUNFHchpLbJ98Vs/c5H2wZBMR9r/XwW+WOWPisZDGLUPPyhJQsSREPoUQ+o8GvyLaD/rkrKqW8bmgw== - dependencies: - "@babel/core" "^7.1.6" - "@babel/preset-env" "^7.10.2" - "@babel/traverse" "^7.1.6" - "@babel/types" "^7.1.6" - "@embroider/core" "^0.33.0" - babel-core "^6.26.3" - babel-loader "^8.0.6" - babel-plugin-syntax-dynamic-import "^6.18.0" - babylon "^6.18.0" - broccoli-debug "^0.6.4" - broccoli-node-api "^1.7.0" - broccoli-plugin "^4.0.0" - broccoli-source "^3.0.0" - debug "^3.1.0" - ember-cli-babel "^7.0.0" - enhanced-resolve "^4.0.0" - fs-extra "^6.0.1" - fs-tree-diff "^2.0.0" - handlebars "^4.3.1" - js-string-escape "^1.0.1" - lodash "^4.17.19" - mkdirp "^0.5.1" - resolve-package-path "^3.1.0" - rimraf "^2.6.2" - semver "^7.3.4" - symlink-or-copy "^1.2.0" - typescript-memoize "^1.0.0-alpha.3" - walk-sync "^0.3.3" - webpack "^4.43.0" - ember-buffered-proxy@^2.0.0-beta.0: version "2.0.0-beta.0" resolved "https://registry.yarnpkg.com/ember-buffered-proxy/-/ember-buffered-proxy-2.0.0-beta.0.tgz#65be4e2d0dcf40a5a2dab548c84a21aa332555a2" diff --git a/app/controllers/bootstrap_controller.rb b/app/controllers/bootstrap_controller.rb index af3919e8285..811058d7526 100644 --- a/app/controllers/bootstrap_controller.rb +++ b/app/controllers/bootstrap_controller.rb @@ -69,7 +69,7 @@ class BootstrapController < ApplicationController locale_script: locale, stylesheets: @stylesheets, plugin_js: plugin_js, - plugin_test_js: [script_asset_path("plugin-tests")], + plugin_test_js: [script_asset_path("plugin_tests")], setup_data: client_side_setup_data, preloaded: @preloaded, html: create_html, diff --git a/app/controllers/qunit_controller.rb b/app/controllers/qunit_controller.rb index 7e196d72369..309d2af8b20 100644 --- a/app/controllers/qunit_controller.rb +++ b/app/controllers/qunit_controller.rb @@ -8,28 +8,15 @@ class QunitController < ApplicationController } layout false - def is_ember_cli_proxy? - request.headers["HTTP_X_DISCOURSE_EMBER_CLI"] == "true" - end - # only used in test / dev def index - raise Discourse::NotFound.new if is_ember_cli_proxy? + raise Discourse::NotFound.new if request.headers["HTTP_X_DISCOURSE_EMBER_CLI"] == "true" raise Discourse::InvalidAccess.new if Rails.env.production? end def theme raise Discourse::NotFound.new if !can_see_theme_qunit? - @is_proxied = is_ember_cli_proxy? - @legacy_ember = Rails.env.development? && !@is_proxied - - # In production mode all bundles use `application` - @app_bundle = "application" - if Rails.env.development? && @is_proxied - @app_bundle = "discourse" - end - param_key = nil @suggested_themes = nil if (id = get_param(:id)).present? diff --git a/app/helpers/application_helper.rb b/app/helpers/application_helper.rb index f232bd5b7e5..c5a96271231 100644 --- a/app/helpers/application_helper.rb +++ b/app/helpers/application_helper.rb @@ -13,11 +13,9 @@ module ApplicationHelper @extra_body_classes ||= Set.new end - def discourse_config_environment(testing: false) - + def discourse_config_environment # TODO: Can this come from Ember CLI somehow? - config = { - modulePrefix: "discourse", + { modulePrefix: "discourse", environment: Rails.env, rootURL: Discourse.base_path, locationType: "auto", @@ -34,16 +32,7 @@ module ApplicationHelper version: "#{Discourse::VERSION::STRING} #{Discourse.git_version}", exportApplicationGlobal: true } - } - - if testing - config[:environment] = "test" - config[:locationType] = "none" - config[:APP][:autoboot] = false - config[:APP][:rootElement] = '#ember-testing' - end - - config.to_json + }.to_json end def google_universal_analytics_json(ua_domain_name = nil) diff --git a/app/helpers/qunit_helper.rb b/app/helpers/qunit_helper.rb index 029c4d04c97..e0376a1ad26 100644 --- a/app/helpers/qunit_helper.rb +++ b/app/helpers/qunit_helper.rb @@ -1,33 +1,6 @@ # frozen_string_literal: true module QunitHelper - - def support_bundles - result = [] - if Rails.env.production? || @legacy_ember - result << preload_script("discourse/tests/test-support-rails") - result << preload_script("discourse/tests/test-helpers-rails") - else - result << preload_script("test-support") - result << preload_script("test-helpers") - end - result.join("\n").html_safe - end - - def boot_bundles - result = [] - if @legacy_ember - result << preload_script("discourse/tests/test_starter") - elsif @is_proxied - result << preload_script("scripts/discourse-test-listen-boot") - result << preload_script("scripts/discourse-boot") - else - result << preload_script("discourse-test-listen-boot") - result << preload_script("discourse-boot") - end - result.join("\n").html_safe - end - def theme_tests theme = Theme.find_by(id: request.env[:resolved_theme_id]) return "" if theme.blank? diff --git a/app/views/qunit/index.html.erb b/app/views/qunit/index.html.erb index 9912387a2d7..830e3d8bb50 100644 --- a/app/views/qunit/index.html.erb +++ b/app/views/qunit/index.html.erb @@ -5,15 +5,8 @@ <%= discourse_color_scheme_stylesheets %> <%= discourse_stylesheet_link_tag(:desktop, theme_id: nil) %> <%= discourse_stylesheet_link_tag(:test_helper, theme_id: nil) %> - <%= preload_script "locales/#{I18n.locale}" %> - <%= preload_script "vendor" %> - <%= preload_script "application" %> - <%= preload_script "admin" %> - <%= preload_script "discourse/tests/test-support-rails" %> - <%= preload_script "discourse/tests/test-helpers-rails" %> - <%= preload_script "discourse/tests/active-plugins" %> - <%= preload_script "discourse/tests/core-tests" %> - <%= preload_script "discourse/tests/plugin-tests" %> + <%= preload_script "discourse/tests/test_helper" %> + <%= preload_script "discourse/tests/core_plugins_tests" %> <%= preload_script "discourse/tests/test_starter" %> <%= csrf_meta_tags %> diff --git a/app/views/qunit/theme.html.erb b/app/views/qunit/theme.html.erb index 23db6bf4513..53752cc9a29 100644 --- a/app/views/qunit/theme.html.erb +++ b/app/views/qunit/theme.html.erb @@ -6,12 +6,17 @@ <%- if !@suggested_themes %> <%= discourse_stylesheet_link_tag(:desktop, theme_id: nil) %> <%= discourse_stylesheet_link_tag(:test_helper, theme_id: nil) %> - <%= preload_script "locales/#{I18n.locale}" %> - <%= preload_script "vendor" %> - <%= preload_script @app_bundle %> + <%= preload_script "locales/en" %> + <%= preload_script "discourse/tests/theme_qunit_ember_jquery" %> + <%= preload_script "discourse/tests/theme_qunit_vendor" %> + <%= preload_script "discourse/tests/theme_qunit_tests_vendor" %> + <%= preload_script "markdown-it-bundle" %> + <%= preload_script "application" %> + <%- Discourse.find_plugin_js_assets(include_official: allow_plugins?, include_unofficial: allow_third_party_plugins?, request: request).each do |file| %> + <%= preload_script file %> + <%- end %> <%= preload_script "admin" %> - <%= preload_script "discourse/tests/active-plugins" %> - <%= support_bundles %> + <%= preload_script "discourse/tests/theme_qunit_helper" %> <%= theme_translations_lookup %> <%= theme_js_lookup %> <%= theme_lookup("head_tag") %> @@ -19,7 +24,7 @@ <%= tag.meta id: 'data-discourse-setup', data: client_side_setup_data %> - + <%= preload_script "discourse/tests/test_starter" %> <%- else %>