discourse/spec/models/published_page_spec.rb
David Taylor c9dab6fd08
DEV: Automatically require 'rails_helper' in all specs (#16077)
It's very easy to forget to add `require 'rails_helper'` at the top of every core/plugin spec file, and omissions can cause some very confusing/sporadic errors.

By setting this flag in `.rspec`, we can remove the need for `require 'rails_helper'` entirely.
2022-03-01 17:50:50 +00:00

26 lines
956 B
Ruby

# frozen_string_literal: true
RSpec.describe PublishedPage, type: :model do
fab!(:topic) { Fabricate(:topic) }
it "has path and url helpers" do
pp = PublishedPage.create!(topic: topic, slug: 'hello-world')
expect(pp.path).to eq("/pub/hello-world")
expect(pp.url).to eq(Discourse.base_url + "/pub/hello-world")
end
it "validates the slug" do
expect(PublishedPage.new(topic: topic, slug: "this-is-valid")).to be_valid
expect(PublishedPage.new(topic: topic, slug: "10_things_i_hate_about_slugs")).to be_valid
expect(PublishedPage.new(topic: topic, slug: "YELLING")).to be_valid
expect(PublishedPage.new(topic: topic, slug: "how about some space")).not_to be_valid
expect(PublishedPage.new(topic: topic, slug: "slugs are %%%%")).not_to be_valid
expect(PublishedPage.new(topic: topic, slug: "check-slug")).not_to be_valid
expect(PublishedPage.new(topic: topic, slug: "by-topic")).not_to be_valid
end
end