2022-04-12 09:33:59 -04:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
|
|
|
require 'rails_helper'
|
|
|
|
|
2022-07-27 22:27:38 -04:00
|
|
|
RSpec.describe Sitemap do
|
2022-04-12 09:33:59 -04:00
|
|
|
describe '.regenerate_sitemaps' do
|
|
|
|
fab!(:topic) { Fabricate(:topic) }
|
|
|
|
|
|
|
|
it 'always create the news and recent sitemaps' do
|
|
|
|
described_class.regenerate_sitemaps
|
|
|
|
|
|
|
|
sitemaps = Sitemap.where(name: [Sitemap::NEWS_SITEMAP_NAME, Sitemap::RECENT_SITEMAP_NAME], enabled: true)
|
|
|
|
|
|
|
|
expect(sitemaps.exists?).to eq(true)
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'bumps existing sitemaps last_posted_at attribute' do
|
|
|
|
news = Sitemap.create!(name: Sitemap::NEWS_SITEMAP_NAME, enabled: true, last_posted_at: 10.days.ago)
|
|
|
|
|
|
|
|
described_class.regenerate_sitemaps
|
|
|
|
|
|
|
|
expect(news.reload.last_posted_at).to eq_time(topic.updated_at)
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'creates the sitemap first page when there is a topic' do
|
|
|
|
described_class.regenerate_sitemaps
|
|
|
|
first_page = Sitemap.find_by(name: '1')
|
|
|
|
|
|
|
|
expect(first_page.enabled).to eq(true)
|
|
|
|
end
|
|
|
|
|
|
|
|
it "only counts topics from unrestricted categories" do
|
|
|
|
restricted_category = Fabricate(:category, read_restricted: true)
|
|
|
|
topic.update!(category: restricted_category)
|
|
|
|
Category.update_stats
|
|
|
|
|
|
|
|
described_class.regenerate_sitemaps
|
|
|
|
first_page = Sitemap.find_by(name: '1')
|
|
|
|
|
|
|
|
expect(first_page).to be_nil
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'disable empty pages' do
|
|
|
|
unused_page = Sitemap.touch('10')
|
|
|
|
|
|
|
|
described_class.regenerate_sitemaps
|
|
|
|
|
|
|
|
expect(unused_page.reload.enabled).to eq(false)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe '#topics' do
|
|
|
|
shared_examples 'Excludes hidden and restricted topics' do
|
|
|
|
it "doesn't include topics from restricted categories" do
|
|
|
|
restricted_category = Fabricate(:category, read_restricted: true)
|
|
|
|
Fabricate(:topic, category: restricted_category)
|
|
|
|
|
|
|
|
topics_data = sitemap.topics
|
|
|
|
|
|
|
|
expect(topics_data).to be_empty
|
|
|
|
end
|
|
|
|
|
|
|
|
it "doesn't include hidden topics" do
|
|
|
|
Fabricate(:topic, visible: false)
|
|
|
|
|
|
|
|
topics_data = sitemap.topics
|
|
|
|
|
|
|
|
expect(topics_data).to be_empty
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when the sitemap corresponds to a page' do
|
|
|
|
let(:sitemap) { described_class.new(enabled: true, last_posted_at: 1.minute.ago, name: '1') }
|
|
|
|
|
|
|
|
it 'returns an empty array if there no topics' do
|
|
|
|
expect(sitemap.topics).to be_empty
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'returns all the neccessary topic attributes to render a sitemap URL' do
|
|
|
|
topic = Fabricate(:topic)
|
|
|
|
|
|
|
|
topics_data = sitemap.topics.first
|
|
|
|
|
|
|
|
expect(topics_data[0]).to eq(topic.id)
|
|
|
|
expect(topics_data[1]).to eq(topic.slug)
|
|
|
|
expect(topics_data[2]).to eq_time(topic.bumped_at)
|
|
|
|
expect(topics_data[3]).to eq_time(topic.updated_at)
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'returns empty when the page is empty because the previous page is not full' do
|
|
|
|
Fabricate(:topic)
|
|
|
|
sitemap.name = '2'
|
|
|
|
|
|
|
|
topics_data = sitemap.topics
|
|
|
|
|
|
|
|
expect(topics_data).to be_empty
|
|
|
|
end
|
|
|
|
|
|
|
|
it "order topics by bumped_at asc" do
|
|
|
|
topic_1 = Fabricate(:topic, bumped_at: 3.minute.ago)
|
|
|
|
topic_2 = Fabricate(:topic, bumped_at: 1.minutes.ago)
|
|
|
|
topic_3 = Fabricate(:topic, bumped_at: 20.minutes.ago)
|
|
|
|
|
|
|
|
topic_ids = sitemap.topics.map { |td| td[0] }
|
|
|
|
|
|
|
|
expect(topic_ids).to contain_exactly(topic_2.id, topic_1.id, topic_3.id)
|
|
|
|
end
|
|
|
|
|
|
|
|
it_behaves_like 'Excludes hidden and restricted topics'
|
|
|
|
end
|
|
|
|
|
2022-07-27 12:14:14 -04:00
|
|
|
context 'with sitemap for recent topics' do
|
2022-04-12 09:33:59 -04:00
|
|
|
let(:sitemap) do
|
|
|
|
described_class.new(
|
|
|
|
enabled: true, last_posted_at: 1.minute.ago, name: described_class::RECENT_SITEMAP_NAME
|
|
|
|
)
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'return topics that were bumped less than three days ago' do
|
|
|
|
Fabricate(:topic, bumped_at: 4.days.ago)
|
|
|
|
recent_topic = Fabricate(:topic, bumped_at: 2.days.ago, posts_count: 3)
|
|
|
|
|
|
|
|
topics_data = sitemap.topics
|
|
|
|
|
|
|
|
expect(topics_data.length).to eq(1)
|
|
|
|
recent_topic_data = topics_data.first
|
|
|
|
expect(recent_topic_data[0]).to eq(recent_topic.id)
|
|
|
|
expect(recent_topic_data[1]).to eq(recent_topic.slug)
|
|
|
|
expect(recent_topic_data[2]).to eq_time(recent_topic.bumped_at)
|
|
|
|
expect(recent_topic_data[3]).to eq_time(recent_topic.updated_at)
|
|
|
|
expect(recent_topic_data[4]).to eq(recent_topic.posts_count)
|
|
|
|
end
|
|
|
|
|
|
|
|
it_behaves_like 'Excludes hidden and restricted topics'
|
|
|
|
end
|
|
|
|
|
2022-07-27 12:14:14 -04:00
|
|
|
context 'with news sitemap' do
|
2022-04-12 09:33:59 -04:00
|
|
|
let(:sitemap) do
|
|
|
|
described_class.new(
|
|
|
|
enabled: true, last_posted_at: 1.minute.ago, name: described_class::NEWS_SITEMAP_NAME
|
|
|
|
)
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'returns topics that were bumped in the last 72 hours' do
|
|
|
|
Fabricate(:topic, bumped_at: 73.hours.ago)
|
|
|
|
recent_topic = Fabricate(:topic, bumped_at: 71.hours.ago)
|
|
|
|
|
|
|
|
topics_data = sitemap.topics
|
|
|
|
|
|
|
|
expect(topics_data.length).to eq(1)
|
|
|
|
recent_topic_data = topics_data.first
|
|
|
|
expect(recent_topic_data[0]).to eq(recent_topic.id)
|
|
|
|
expect(recent_topic_data[1]).to eq(recent_topic.title)
|
|
|
|
expect(recent_topic_data[2]).to eq(recent_topic.slug)
|
|
|
|
expect(recent_topic_data[3]).to eq_time(recent_topic.updated_at)
|
|
|
|
end
|
|
|
|
|
|
|
|
it_behaves_like 'Excludes hidden and restricted topics'
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|