mirror of
https://github.com/discourse/discourse.git
synced 2024-12-05 07:43:39 +08:00
6e161d3e75
The most common thing that we do with fab! is: fab!(:thing) { Fabricate(:thing) } This commit adds a shorthand for this which is just simply: fab!(:thing) i.e. If you omit the block, then, by default, you'll get a `Fabricate`d object using the fabricator of the same name.
174 lines
5.4 KiB
Ruby
174 lines
5.4 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
RSpec.describe Admin::FormTemplatesController do
|
|
fab!(:admin)
|
|
fab!(:user)
|
|
|
|
before { SiteSetting.experimental_form_templates = true }
|
|
|
|
describe "#index" do
|
|
fab!(:form_template)
|
|
|
|
context "when logged in as an admin" do
|
|
before { sign_in(admin) }
|
|
|
|
it "should work if you are an admin" do
|
|
get "/admin/customize/form-templates.json"
|
|
expect(response.status).to eq(200)
|
|
|
|
json = response.parsed_body
|
|
expect(json["form_templates"]).to be_present
|
|
end
|
|
end
|
|
|
|
context "when logged in as a non-admin user" do
|
|
before { sign_in(user) }
|
|
|
|
it "should not work if you are not an admin" do
|
|
get "/admin/customize/form-templates.json"
|
|
|
|
expect(response.status).to eq(404)
|
|
end
|
|
end
|
|
|
|
context "when experimental form templates is disabled" do
|
|
before do
|
|
sign_in(admin)
|
|
SiteSetting.experimental_form_templates = false
|
|
end
|
|
|
|
it "should not work if you are an admin" do
|
|
get "/admin/customize/form-templates.json"
|
|
|
|
expect(response.status).to eq(403)
|
|
end
|
|
end
|
|
end
|
|
|
|
describe "#show" do
|
|
fab!(:form_template)
|
|
|
|
context "when logged in as an admin" do
|
|
before { sign_in(admin) }
|
|
|
|
it "should work if you are an admin" do
|
|
get "/admin/customize/form-templates/#{form_template.id}.json"
|
|
expect(response.status).to eq(200)
|
|
|
|
json = response.parsed_body
|
|
current_template = json["form_template"]
|
|
expect(current_template["id"]).to eq(form_template.id)
|
|
expect(current_template["name"]).to eq(form_template.name)
|
|
expect(current_template["template"]).to eq(form_template.template)
|
|
end
|
|
end
|
|
end
|
|
|
|
describe "#create" do
|
|
context "when logged in as an admin" do
|
|
before { sign_in(admin) }
|
|
|
|
it "creates a form template" do
|
|
expect {
|
|
post "/admin/customize/form-templates.json",
|
|
params: {
|
|
name: "Bug Reports",
|
|
template:
|
|
"- type: input\n id: website\n attributes:\n label: Website or apps\n description: |\n Which website or app were you using when the bug happened?\n placeholder: |\n e.g. website URL, name of the app\n validations:\n required: true",
|
|
}
|
|
|
|
expect(response.status).to eq(200)
|
|
}.to change(FormTemplate, :count).by(1)
|
|
end
|
|
end
|
|
|
|
context "when logged in as a non-admin user" do
|
|
before { sign_in(user) }
|
|
|
|
it "prevents creation with a 404 response" do
|
|
expect do
|
|
post "/admin/customize/form-templates.json",
|
|
params: {
|
|
name: "Feature Requests",
|
|
template:
|
|
" type: checkbox\n choices:\n - \"Option 1\"\n - \"Option 2\"\n - \"Option 3\"\n attributes:\n label: \"Enter question here\"\n description: \"Enter description here\"\n validations:\n required: true\n- type: input\n attributes:\n label: \"Enter input label here\"\n description: \"Enter input description here\"\n placeholder: \"Enter input placeholder here\"\n validations:\n required: true",
|
|
}
|
|
end.not_to change { FormTemplate.count }
|
|
|
|
expect(response.status).to eq(404)
|
|
expect(response.parsed_body["errors"]).to include(I18n.t("not_found"))
|
|
end
|
|
end
|
|
end
|
|
|
|
describe "#update" do
|
|
fab!(:form_template)
|
|
|
|
context "when logged in as an admin" do
|
|
before { sign_in(admin) }
|
|
|
|
it "updates a form template" do
|
|
put "/admin/customize/form-templates/#{form_template.id}.json",
|
|
params: {
|
|
id: form_template.id,
|
|
name: "Updated Template",
|
|
template: "- type: checkbox\n id: checkbox",
|
|
}
|
|
|
|
expect(response.status).to eq(200)
|
|
form_template.reload
|
|
expect(form_template.name).to eq("Updated Template")
|
|
expect(form_template.template).to eq("- type: checkbox\n id: checkbox")
|
|
end
|
|
end
|
|
|
|
context "when logged in as a non-admin user" do
|
|
before { sign_in(user) }
|
|
|
|
it "prevents update with a 404 response" do
|
|
form_template.reload
|
|
original_name = form_template.name
|
|
|
|
put "/admin/customize/form-templates/#{form_template.id}.json",
|
|
params: {
|
|
name: "Updated Template",
|
|
template: "New yaml: true",
|
|
}
|
|
|
|
expect(response.status).to eq(404)
|
|
expect(response.parsed_body["errors"]).to include(I18n.t("not_found"))
|
|
|
|
form_template.reload
|
|
expect(form_template.name).to eq(original_name)
|
|
end
|
|
end
|
|
end
|
|
|
|
describe "#destroy" do
|
|
fab!(:form_template)
|
|
|
|
context "when logged in as an admin" do
|
|
before { sign_in(admin) }
|
|
|
|
it "deletes a form template" do
|
|
expect {
|
|
delete "/admin/customize/form-templates/#{form_template.id}.json"
|
|
expect(response.status).to eq(200)
|
|
}.to change(FormTemplate, :count).by(-1)
|
|
end
|
|
end
|
|
|
|
context "when logged in as a non-admin user" do
|
|
before { sign_in(user) }
|
|
it "prevents deletion with a 404 response" do
|
|
expect do
|
|
delete "/admin/customize/form-templates/#{form_template.id}.json"
|
|
end.not_to change { FormTemplate.count }
|
|
|
|
expect(response.status).to eq(404)
|
|
expect(response.parsed_body["errors"]).to include(I18n.t("not_found"))
|
|
end
|
|
end
|
|
end
|
|
end
|