Fix migration (Nov 2018) which set a hash value on a boolean Setting

This commit is contained in:
Ryan Lue 2019-04-18 11:04:43 +08:00 committed by Thorsten Eckel
parent 1bdab1c4aa
commit 03b2456dd9
5 changed files with 89 additions and 7 deletions

View file

@ -176,7 +176,7 @@ reload config settings
# convert state into hash to be able to store it as store
def state_check
return true if !state
return true if state.nil? # allow false value
return true if state.try(:key?, :value)
self.state_current = { value: state }

View file

@ -23,9 +23,7 @@ class SettingTicketNumberIgnoreSystemIdSupport < ActiveRecord::Migration[4.2]
},
],
},
state: {
ticket_number_ignore_system_id: false
},
state: false,
preferences: {
permission: ['admin.ticket'],
hidden: true,

View file

@ -0,0 +1,13 @@
class NormalizeSettingTicketNumberIgnoreSystemId < ActiveRecord::Migration[5.1]
def up
return if !Setting.find_by(name: 'system_init_done')
return if !Setting.exists?(name: 'ticket_number_ignore_system_id')
Setting.find_by(name: 'ticket_number_ignore_system_id')
.update(state_initial: { value: false })
return if Setting.get('ticket_number_ignore_system_id') != { 'ticket_number_ignore_system_id' => false }
Setting.set('ticket_number_ignore_system_id', false)
end
end

View file

@ -2086,9 +2086,7 @@ Setting.create_if_not_exists(
},
],
},
state: {
ticket_number_ignore_system_id: false
},
state: false,
preferences: {
permission: ['admin.ticket'],
hidden: true,

View file

@ -0,0 +1,73 @@
require 'rails_helper'
RSpec.describe NormalizeSettingTicketNumberIgnoreSystemId, type: :db_migration do
before do
Setting.find_by(name: 'ticket_number_ignore_system_id')&.destroy
Setting.create(
title: 'Ticket Number ignore system_id',
name: 'ticket_number_ignore_system_id',
area: 'Ticket::Core',
description: '-',
options: {
form: [
{
display: 'Ignore system_id',
null: true,
name: 'ticket_number_ignore_system_id',
tag: 'boolean',
options: {
true => 'yes',
false => 'no',
},
},
],
},
state: {
ticket_number_ignore_system_id: false
},
preferences: {
permission: ['admin.ticket'],
hidden: true,
},
frontend: false
)
end
context 'when previous migration incorrectly sets "ticket_number_ignore_system_id" to hash' do
it 'sets it to false' do
expect { migrate }
.to change { Setting.get('ticket_number_ignore_system_id') }
.to(false)
end
it 'sets #state_initial to { value: false }' do
expect { migrate }
.to change { Setting.find_by(name: 'ticket_number_ignore_system_id').state_initial }
.to({ 'value' => false })
end
end
context 'when "ticket_number_ignore_system_id" Setting is a boolean' do
before { Setting.set('ticket_number_ignore_system_id', true) }
it 'makes no change' do
expect { migrate }
.not_to change { Setting.get('ticket_number_ignore_system_id') }
end
it 'sets #state_initial to { value: false }' do
expect { migrate }
.to change { Setting.find_by(name: 'ticket_number_ignore_system_id').state_initial }
.to({ 'value' => false })
end
end
context 'when no "ticket_number_ignore_system_id" Setting exists (edge case)' do
before { Setting.find_by(name: 'ticket_number_ignore_system_id').destroy }
it 'completes without error' do
expect { migrate }.not_to raise_error
end
end
end