mirror of
https://github.com/discourse/discourse.git
synced 2024-11-24 21:16:08 +08:00
c9dab6fd08
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.
26 lines
956 B
Ruby
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
|