DEV: Improve setting of raw-view owner (#18310)

Using the owner of `site` is not perfectly reliable, especially given that `site` is stubbed in tests. Instead, we can fetch the owner of the `context` object itself.

Also, Ember sets the owner of an EmberObject based on the first parameter to `create`. This is preferable to a separate `setOwner` call because it means the owner is available during initialization.

Unfortunately we don't have any way to compile raw templates inline during tests, so testing this behavior in core is very difficult. Given that we aim to remove the raw handlebars system in the not-too-distant future, it doesn't make sense to invest lots of time on tooling here. Regressions of this behavior will be detected by theme CI tests [like this](https://github.com/discourse/discourse-topic-thumbnails/pull/21).
This commit is contained in:
David Taylor 2022-09-21 12:23:28 +01:00 committed by GitHub
parent 0f5a8cc526
commit ae3a5f6bf0
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
1 changed files with 1 additions and 1 deletions

View File

@ -13,8 +13,8 @@ function renderRaw(ctx, template, templateName, params) {
const viewClass = context.registry.resolve(`raw-view:${templateName}`); const viewClass = context.registry.resolve(`raw-view:${templateName}`);
if (viewClass) { if (viewClass) {
setOwner(params, getOwner(context));
params.view = viewClass.create(params, context); params.view = viewClass.create(params, context);
setOwner(params.view, getOwner(context.site));
} }
if (!params.view) { if (!params.view) {