mirror of
https://github.com/discourse/discourse.git
synced 2025-02-25 18:55:32 -06:00
FEATURE: Allow customization of robots.txt (#7884)
* FEATURE: Allow customization of robots.txt This allows admins to customize/override the content of the robots.txt file at /admin/customize/robots. That page is not linked to anywhere in the UI -- admins have to manually type the URL to access that page. * use Ember.computed.not * Jeff feedback * Feedback * Remove unused import
This commit is contained in:
91
spec/requests/admin/robots_txt_controller_spec.rb
Normal file
91
spec/requests/admin/robots_txt_controller_spec.rb
Normal file
@@ -0,0 +1,91 @@
|
||||
# frozen_string_literal: true
|
||||
|
||||
require 'rails_helper'
|
||||
|
||||
describe Admin::RobotsTxtController do
|
||||
it "is a subclass of AdminController" do
|
||||
expect(described_class < Admin::AdminController).to eq(true)
|
||||
end
|
||||
|
||||
fab!(:admin) { Fabricate(:admin) }
|
||||
fab!(:user) { Fabricate(:user) }
|
||||
|
||||
describe "non-admin users" do
|
||||
before { sign_in(user) }
|
||||
|
||||
it "can't see #show" do
|
||||
get "/admin/customize/robots.json"
|
||||
expect(response.status).to eq(404)
|
||||
end
|
||||
|
||||
it "can't perform #update" do
|
||||
put "/admin/customize/robots.json", params: { robots_txt: "adasdasd" }
|
||||
expect(response.status).to eq(404)
|
||||
expect(SiteSetting.overridden_robots_txt).to eq("")
|
||||
end
|
||||
|
||||
it "can't perform #reset" do
|
||||
SiteSetting.overridden_robots_txt = "overridden_content"
|
||||
delete "/admin/customize/robots.json"
|
||||
expect(response.status).to eq(404)
|
||||
expect(SiteSetting.overridden_robots_txt).to eq("overridden_content")
|
||||
end
|
||||
end
|
||||
|
||||
describe "#show" do
|
||||
before { sign_in(admin) }
|
||||
|
||||
it "returns default content if there are no overrides" do
|
||||
get "/admin/customize/robots.json"
|
||||
expect(response.status).to eq(200)
|
||||
json = JSON.parse(response.body)
|
||||
expect(json["robots_txt"]).to be_present
|
||||
expect(json["overridden"]).to eq(false)
|
||||
end
|
||||
|
||||
it "returns overridden content if there are overrides" do
|
||||
SiteSetting.overridden_robots_txt = "something"
|
||||
get "/admin/customize/robots.json"
|
||||
expect(response.status).to eq(200)
|
||||
json = JSON.parse(response.body)
|
||||
expect(json["robots_txt"]).to eq("something")
|
||||
expect(json["overridden"]).to eq(true)
|
||||
end
|
||||
end
|
||||
|
||||
describe "#update" do
|
||||
before { sign_in(admin) }
|
||||
|
||||
it "overrides the site's default robots.txt" do
|
||||
put "/admin/customize/robots.json", params: { robots_txt: "new_content" }
|
||||
expect(response.status).to eq(200)
|
||||
json = JSON.parse(response.body)
|
||||
expect(json["robots_txt"]).to eq("new_content")
|
||||
expect(json["overridden"]).to eq(true)
|
||||
expect(SiteSetting.overridden_robots_txt).to eq("new_content")
|
||||
|
||||
get "/robots.txt"
|
||||
expect(response.body).to include("new_content")
|
||||
end
|
||||
|
||||
it "requires `robots_txt` param to be present" do
|
||||
SiteSetting.overridden_robots_txt = "overridden_content"
|
||||
put "/admin/customize/robots.json", params: { robots_txt: "" }
|
||||
expect(response.status).to eq(400)
|
||||
end
|
||||
end
|
||||
|
||||
describe "#reset" do
|
||||
before { sign_in(admin) }
|
||||
|
||||
it "resets robots.txt file to the default version" do
|
||||
SiteSetting.overridden_robots_txt = "overridden_content"
|
||||
delete "/admin/customize/robots.json"
|
||||
expect(response.status).to eq(200)
|
||||
json = JSON.parse(response.body)
|
||||
expect(json["robots_txt"]).not_to include("overridden_content")
|
||||
expect(json["overridden"]).to eq(false)
|
||||
expect(SiteSetting.overridden_robots_txt).to eq("")
|
||||
end
|
||||
end
|
||||
end
|
||||
@@ -11,10 +11,42 @@ RSpec.describe RobotsTxtController do
|
||||
expect(json['header']).to be_present
|
||||
expect(json['agents']).to be_present
|
||||
end
|
||||
|
||||
it "includes overridden content if robots.txt is is overridden" do
|
||||
SiteSetting.overridden_robots_txt = "something"
|
||||
|
||||
get "/robots-builder.json"
|
||||
expect(response.status).to eq(200)
|
||||
json = ::JSON.parse(response.body)
|
||||
expect(json['header']).to be_present
|
||||
expect(json['agents']).to be_present
|
||||
expect(json['overridden']).to eq("something")
|
||||
end
|
||||
end
|
||||
|
||||
describe '#index' do
|
||||
|
||||
context "header for when the content is overridden" do
|
||||
it "is not prepended if there are no overrides" do
|
||||
sign_in(Fabricate(:admin))
|
||||
get '/robots.txt'
|
||||
expect(response.body).not_to start_with(RobotsTxtController::OVERRIDDEN_HEADER)
|
||||
end
|
||||
|
||||
it "is prepended if there are overrides and the user is admin" do
|
||||
SiteSetting.overridden_robots_txt = "overridden_content"
|
||||
sign_in(Fabricate(:admin))
|
||||
get '/robots.txt'
|
||||
expect(response.body).to start_with(RobotsTxtController::OVERRIDDEN_HEADER)
|
||||
end
|
||||
|
||||
it "is not prepended if the user is not admin" do
|
||||
SiteSetting.overridden_robots_txt = "overridden_content"
|
||||
get '/robots.txt'
|
||||
expect(response.body).not_to start_with(RobotsTxtController::OVERRIDDEN_HEADER)
|
||||
end
|
||||
end
|
||||
|
||||
context 'subfolder' do
|
||||
it 'prefixes the rules with the directory' do
|
||||
Discourse.stubs(:base_uri).returns('/forum')
|
||||
@@ -101,5 +133,12 @@ RSpec.describe RobotsTxtController do
|
||||
|
||||
expect(response.body).to_not include("Disallow: /u/")
|
||||
end
|
||||
|
||||
it "returns overridden robots.txt if the file is overridden" do
|
||||
SiteSetting.overridden_robots_txt = "blah whatever"
|
||||
get '/robots.txt'
|
||||
expect(response.status).to eq(200)
|
||||
expect(response.body).to eq(SiteSetting.overridden_robots_txt)
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
Reference in New Issue
Block a user