2019-04-30 08:27:42 +08:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
2015-10-11 17:41:23 +08:00
|
|
|
require 'rails_helper'
|
2013-02-11 08:02:57 +08:00
|
|
|
|
2017-08-31 12:06:56 +08:00
|
|
|
RSpec.describe RobotsTxtController do
|
2018-04-17 03:43:20 +08:00
|
|
|
describe '#builder' do
|
|
|
|
it "returns json information for building a robots.txt" do
|
|
|
|
get "/robots-builder.json"
|
|
|
|
json = ::JSON.parse(response.body)
|
|
|
|
expect(json).to be_present
|
|
|
|
expect(json['header']).to be_present
|
|
|
|
expect(json['agents']).to be_present
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2017-08-31 12:06:56 +08:00
|
|
|
describe '#index' do
|
2018-04-06 08:15:23 +08:00
|
|
|
|
2018-04-12 04:05:02 +08:00
|
|
|
context 'subfolder' do
|
|
|
|
it 'prefixes the rules with the directory' do
|
|
|
|
Discourse.stubs(:base_uri).returns('/forum')
|
|
|
|
get '/robots.txt'
|
|
|
|
expect(response.body).to include("\nDisallow: /forum/admin")
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2018-04-06 08:15:23 +08:00
|
|
|
context 'crawl delay' do
|
|
|
|
it 'allows you to set crawl delay on particular bots' do
|
|
|
|
SiteSetting.allow_index_in_robots_txt = true
|
|
|
|
SiteSetting.slow_down_crawler_rate = 17
|
|
|
|
SiteSetting.slow_down_crawler_user_agents = 'bingbot|googlebot'
|
|
|
|
get '/robots.txt'
|
|
|
|
expect(response.body).to include("\nUser-agent: bingbot\nCrawl-delay: 17")
|
|
|
|
expect(response.body).to include("\nUser-agent: googlebot\nCrawl-delay: 17")
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2018-03-16 05:10:45 +08:00
|
|
|
context 'allow_index_in_robots_txt is true' do
|
|
|
|
|
|
|
|
def expect_allowed_and_disallowed_sections(allow_index, disallow_index)
|
|
|
|
expect(allow_index).to be_present
|
|
|
|
expect(disallow_index).to be_present
|
|
|
|
|
|
|
|
allow_section = allow_index < disallow_index ?
|
|
|
|
response.body[allow_index...disallow_index] : response.body[allow_index..-1]
|
|
|
|
|
|
|
|
expect(allow_section).to include('Disallow: /u/')
|
|
|
|
expect(allow_section).to_not include("Disallow: /\n")
|
|
|
|
|
|
|
|
disallowed_section = allow_index < disallow_index ?
|
|
|
|
response.body[disallow_index..-1] : response.body[disallow_index...allow_index]
|
|
|
|
expect(disallowed_section).to include("Disallow: /\n")
|
|
|
|
end
|
|
|
|
|
|
|
|
it "returns index when indexing is allowed" do
|
|
|
|
SiteSetting.allow_index_in_robots_txt = true
|
|
|
|
get '/robots.txt'
|
|
|
|
|
|
|
|
i = response.body.index('User-agent: *')
|
|
|
|
expect(i).to be_present
|
|
|
|
expect(response.body[i..-1]).to include("Disallow: /u/")
|
|
|
|
end
|
|
|
|
|
|
|
|
it "can whitelist user agents" do
|
|
|
|
SiteSetting.whitelisted_crawler_user_agents = "Googlebot|Twitterbot"
|
|
|
|
get '/robots.txt'
|
|
|
|
expect(response.body).to include('User-agent: Googlebot')
|
|
|
|
expect(response.body).to include('User-agent: Twitterbot')
|
|
|
|
|
|
|
|
allowed_index = [response.body.index('User-agent: Googlebot'), response.body.index('User-agent: Twitterbot')].min
|
|
|
|
disallow_all_index = response.body.index('User-agent: *')
|
|
|
|
|
|
|
|
expect_allowed_and_disallowed_sections(allowed_index, disallow_all_index)
|
|
|
|
end
|
|
|
|
|
|
|
|
it "can blacklist user agents" do
|
|
|
|
SiteSetting.blacklisted_crawler_user_agents = "Googlebot|Twitterbot"
|
|
|
|
get '/robots.txt'
|
|
|
|
expect(response.body).to include('User-agent: Googlebot')
|
|
|
|
expect(response.body).to include('User-agent: Twitterbot')
|
|
|
|
|
|
|
|
disallow_index = [response.body.index('User-agent: Googlebot'), response.body.index('User-agent: Twitterbot')].min
|
|
|
|
allow_index = response.body.index('User-agent: *')
|
|
|
|
|
|
|
|
expect_allowed_and_disallowed_sections(allow_index, disallow_index)
|
|
|
|
end
|
2017-08-31 12:06:56 +08:00
|
|
|
|
2018-03-16 05:10:45 +08:00
|
|
|
it "ignores blacklist if whitelist is set" do
|
|
|
|
SiteSetting.whitelisted_crawler_user_agents = "Googlebot|Twitterbot"
|
|
|
|
SiteSetting.blacklisted_crawler_user_agents = "Bananabot"
|
|
|
|
get '/robots.txt'
|
|
|
|
expect(response.body).to_not include('Bananabot')
|
|
|
|
expect(response.body).to include('User-agent: Googlebot')
|
|
|
|
expect(response.body).to include('User-agent: Twitterbot')
|
|
|
|
end
|
2013-02-11 08:02:57 +08:00
|
|
|
end
|
|
|
|
|
2013-02-26 23:42:49 +08:00
|
|
|
it "returns noindex when indexing is disallowed" do
|
2015-06-03 18:14:00 +08:00
|
|
|
SiteSetting.allow_index_in_robots_txt = false
|
2017-08-31 12:06:56 +08:00
|
|
|
get '/robots.txt'
|
2013-02-26 00:42:20 +08:00
|
|
|
|
2017-08-31 12:06:56 +08:00
|
|
|
expect(response.body).to_not include("Disallow: /u/")
|
|
|
|
end
|
2013-02-11 08:02:57 +08:00
|
|
|
end
|
|
|
|
end
|