mirror of
https://github.com/discourse/discourse.git
synced 2025-06-24 19:01:33 +08:00
merge master
This commit is contained in:
@ -1,4 +1,4 @@
|
||||
require 'spec_helper'
|
||||
require 'rails_helper'
|
||||
|
||||
describe Admin::SiteTextsController do
|
||||
|
||||
@ -11,17 +11,74 @@ describe Admin::SiteTextsController do
|
||||
@user = log_in(:admin)
|
||||
end
|
||||
|
||||
context '.show' do
|
||||
let(:text_type) { SiteText.text_types.first.text_type }
|
||||
|
||||
it 'returns success' do
|
||||
xhr :get, :show, id: text_type
|
||||
context '.index' do
|
||||
it 'returns json' do
|
||||
xhr :get, :index, q: 'title'
|
||||
expect(response).to be_success
|
||||
expect(::JSON.parse(response.body)).to be_present
|
||||
end
|
||||
end
|
||||
|
||||
context '.show' do
|
||||
it 'returns a site text for a key that exists' do
|
||||
xhr :get, :show, id: 'title'
|
||||
expect(response).to be_success
|
||||
|
||||
json = ::JSON.parse(response.body)
|
||||
expect(json).to be_present
|
||||
|
||||
site_text = json['site_text']
|
||||
expect(site_text).to be_present
|
||||
|
||||
expect(site_text['id']).to eq('title')
|
||||
expect(site_text['value']).to eq(I18n.t(:title))
|
||||
end
|
||||
|
||||
it 'returns JSON' do
|
||||
xhr :get, :show, id: text_type
|
||||
expect(::JSON.parse(response.body)).to be_present
|
||||
it 'returns not found for missing keys' do
|
||||
xhr :get, :show, id: 'made_up_no_key_exists'
|
||||
expect(response).not_to be_success
|
||||
end
|
||||
end
|
||||
|
||||
context '.update and .revert' do
|
||||
it 'updates and reverts the key' do
|
||||
orig_title = I18n.t(:title)
|
||||
|
||||
xhr :put, :update, id: 'title', site_text: {value: 'hello'}
|
||||
expect(response).to be_success
|
||||
|
||||
json = ::JSON.parse(response.body)
|
||||
expect(json).to be_present
|
||||
|
||||
site_text = json['site_text']
|
||||
expect(site_text).to be_present
|
||||
|
||||
expect(site_text['id']).to eq('title')
|
||||
expect(site_text['value']).to eq('hello')
|
||||
|
||||
|
||||
# Revert
|
||||
xhr :put, :revert, id: 'title'
|
||||
expect(response).to be_success
|
||||
|
||||
json = ::JSON.parse(response.body)
|
||||
expect(json).to be_present
|
||||
|
||||
site_text = json['site_text']
|
||||
expect(site_text).to be_present
|
||||
|
||||
expect(site_text['id']).to eq('title')
|
||||
expect(site_text['value']).to eq(orig_title)
|
||||
end
|
||||
|
||||
it 'returns not found for missing keys' do
|
||||
xhr :put, :update, id: 'made_up_no_key_exists', site_text: {value: 'hello'}
|
||||
expect(response).not_to be_success
|
||||
end
|
||||
|
||||
it 'logs the change' do
|
||||
StaffActionLogger.any_instance.expects(:log_site_text_change).once
|
||||
xhr :put, :update, id: 'title', site_text: {value: 'hello'}
|
||||
end
|
||||
end
|
||||
end
|
||||
|
Reference in New Issue
Block a user