FIX: Set `auto_update` to false for non-git themes/components (#15157)
Related to: 20f736aa11
.
`auto_update` is true by default at the database level, but it doesn't make sense for `auto_update` to be true on themes that are not imported from a Git repository.
This commit is contained in:
parent
20f736aa11
commit
1d69261bc0
|
@ -59,7 +59,7 @@ class Admin::ThemesController < Admin::AdminController
|
||||||
json = JSON::parse(params[:theme].read)
|
json = JSON::parse(params[:theme].read)
|
||||||
theme = json['theme']
|
theme = json['theme']
|
||||||
|
|
||||||
@theme = Theme.new(name: theme["name"], user_id: theme_user.id)
|
@theme = Theme.new(name: theme["name"], user_id: theme_user.id, auto_update: false)
|
||||||
theme["theme_fields"]&.each do |field|
|
theme["theme_fields"]&.each do |field|
|
||||||
|
|
||||||
if field["raw_upload"]
|
if field["raw_upload"]
|
||||||
|
@ -116,7 +116,14 @@ class Admin::ThemesController < Admin::AdminController
|
||||||
update_components = params[:components]
|
update_components = params[:components]
|
||||||
match_theme_by_name = !!params[:bundle] && !params.key?(:theme_id) # Old theme CLI behavior, match by name. Remove Jan 2020
|
match_theme_by_name = !!params[:bundle] && !params.key?(:theme_id) # Old theme CLI behavior, match by name. Remove Jan 2020
|
||||||
begin
|
begin
|
||||||
@theme = RemoteTheme.update_zipped_theme(bundle.path, bundle.original_filename, match_theme: match_theme_by_name, user: theme_user, theme_id: theme_id, update_components: update_components)
|
@theme = RemoteTheme.update_zipped_theme(
|
||||||
|
bundle.path,
|
||||||
|
bundle.original_filename,
|
||||||
|
match_theme: match_theme_by_name,
|
||||||
|
user: theme_user,
|
||||||
|
theme_id: theme_id,
|
||||||
|
update_components: update_components
|
||||||
|
)
|
||||||
log_theme_change(nil, @theme)
|
log_theme_change(nil, @theme)
|
||||||
render json: @theme, status: :created
|
render json: @theme, status: :created
|
||||||
rescue RemoteTheme::ImportError => e
|
rescue RemoteTheme::ImportError => e
|
||||||
|
|
|
@ -40,7 +40,7 @@ class RemoteTheme < ActiveRecord::Base
|
||||||
|
|
||||||
existing = true
|
existing = true
|
||||||
if theme.blank?
|
if theme.blank?
|
||||||
theme = Theme.new(user_id: user&.id || -1, name: theme_info["name"])
|
theme = Theme.new(user_id: user&.id || -1, name: theme_info["name"], auto_update: false)
|
||||||
existing = false
|
existing = false
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
|
@ -149,6 +149,7 @@ describe Admin::ThemesController do
|
||||||
|
|
||||||
expect(json["theme"]["name"]).to eq("Sam's Simple Theme")
|
expect(json["theme"]["name"]).to eq("Sam's Simple Theme")
|
||||||
expect(json["theme"]["theme_fields"].length).to eq(2)
|
expect(json["theme"]["theme_fields"].length).to eq(2)
|
||||||
|
expect(json["theme"]["auto_update"]).to eq(false)
|
||||||
expect(UserHistory.where(action: UserHistory.actions[:change_theme]).count).to eq(1)
|
expect(UserHistory.where(action: UserHistory.actions[:change_theme]).count).to eq(1)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -163,6 +164,7 @@ describe Admin::ThemesController do
|
||||||
|
|
||||||
expect(json["theme"]["name"]).to eq("Header Icons")
|
expect(json["theme"]["name"]).to eq("Header Icons")
|
||||||
expect(json["theme"]["theme_fields"].length).to eq(5)
|
expect(json["theme"]["theme_fields"].length).to eq(5)
|
||||||
|
expect(json["theme"]["auto_update"]).to eq(false)
|
||||||
expect(UserHistory.where(action: UserHistory.actions[:change_theme]).count).to eq(1)
|
expect(UserHistory.where(action: UserHistory.actions[:change_theme]).count).to eq(1)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -219,6 +221,7 @@ describe Admin::ThemesController do
|
||||||
expect(json["theme"]["name"]).to eq("Header Icons")
|
expect(json["theme"]["name"]).to eq("Header Icons")
|
||||||
expect(json["theme"]["id"]).not_to eq(existing_theme.id)
|
expect(json["theme"]["id"]).not_to eq(existing_theme.id)
|
||||||
expect(json["theme"]["theme_fields"].length).to eq(5)
|
expect(json["theme"]["theme_fields"].length).to eq(5)
|
||||||
|
expect(json["theme"]["auto_update"]).to eq(false)
|
||||||
expect(UserHistory.where(action: UserHistory.actions[:change_theme]).count).to eq(1)
|
expect(UserHistory.where(action: UserHistory.actions[:change_theme]).count).to eq(1)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
Loading…
Reference in New Issue