Instance variables might lead to hard-to-detect issues, since using a nonexistent instance variable will return `nil` instead of raising an error.
41 lines
1.1 KiB
Ruby
41 lines
1.1 KiB
Ruby
require "rails_helper"
|
|
|
|
describe "rake sitemap:create", type: :feature do
|
|
let(:file) { Rails.root.join("public", "sitemap.xml") }
|
|
|
|
before do
|
|
File.delete(file) if File.exist?(file)
|
|
|
|
Rake::Task["sitemap:create"].reenable
|
|
Rake.application.invoke_task("sitemap:create")
|
|
end
|
|
|
|
it "generates a sitemap" do
|
|
expect(file).to exist
|
|
end
|
|
|
|
it "generates a valid sitemap" do
|
|
sitemap = Nokogiri::XML(File.open(file))
|
|
expect(sitemap.errors).to be_empty
|
|
end
|
|
|
|
it "generates a sitemap with expected and valid URLs" do
|
|
sitemap = File.read(file)
|
|
|
|
# Static pages
|
|
expect(sitemap).to include(faq_path)
|
|
expect(sitemap).to include(help_path)
|
|
expect(sitemap).to include(how_to_use_path)
|
|
|
|
# Dynamic URLs
|
|
expect(sitemap).to include(polls_path)
|
|
expect(sitemap).to include(budgets_path)
|
|
expect(sitemap).to include(debates_path)
|
|
expect(sitemap).to include(proposals_path)
|
|
expect(sitemap).to include(legislation_processes_path)
|
|
|
|
expect(sitemap).to have_content("0.7", count: 5)
|
|
expect(sitemap).to have_content("daily", count: 5)
|
|
end
|
|
end
|