Spiegel von
https://github.com/paviliondev/discourse-custom-wizard.git
synchronisiert 2024-11-22 09:20:29 +01:00
Complete builder.rb spec
Dieser Commit ist enthalten in:
Ursprung
be83350b72
Commit
8e5d6b779c
4 geänderte Dateien mit 183 neuen und 60 gelöschten Zeilen
|
@ -161,7 +161,7 @@ class CustomWizard::Builder
|
||||||
submission = @submissions.last
|
submission = @submissions.last
|
||||||
data = submission.merge(data)
|
data = submission.merge(data)
|
||||||
end
|
end
|
||||||
|
|
||||||
if step_template['actions'] && step_template['actions'].length && data
|
if step_template['actions'] && step_template['actions'].length && data
|
||||||
step_template['actions'].each do |action|
|
step_template['actions'].each do |action|
|
||||||
self.send(action['type'].to_sym, user, action, data)
|
self.send(action['type'].to_sym, user, action, data)
|
||||||
|
@ -364,7 +364,7 @@ class CustomWizard::Builder
|
||||||
else
|
else
|
||||||
title = data[action['title']]
|
title = data[action['title']]
|
||||||
end
|
end
|
||||||
|
|
||||||
if action['post_builder']
|
if action['post_builder']
|
||||||
post = CustomWizard::Builder.fill_placeholders(action['post_template'], user, data)
|
post = CustomWizard::Builder.fill_placeholders(action['post_template'], user, data)
|
||||||
else
|
else
|
||||||
|
|
|
@ -13,6 +13,8 @@ class CustomWizard::StepUpdater
|
||||||
end
|
end
|
||||||
|
|
||||||
def update
|
def update
|
||||||
|
return false if !SiteSetting.custom_wizard_enabled
|
||||||
|
|
||||||
@step.updater.call(self) if @step.present? && @step.updater.present?
|
@step.updater.call(self) if @step.present? && @step.updater.present?
|
||||||
|
|
||||||
if success?
|
if success?
|
||||||
|
|
|
@ -3,8 +3,9 @@
|
||||||
require 'rails_helper'
|
require 'rails_helper'
|
||||||
|
|
||||||
describe CustomWizard::Builder do
|
describe CustomWizard::Builder do
|
||||||
fab!(:user) { Fabricate(:user) }
|
fab!(:user) { Fabricate(:user, username: 'angus') }
|
||||||
fab!(:trusted_user) { Fabricate(:user, trust_level: 3)}
|
fab!(:trusted_user) { Fabricate(:user, trust_level: 3) }
|
||||||
|
fab!(:group) { Fabricate(:group) }
|
||||||
|
|
||||||
let!(:template) do
|
let!(:template) do
|
||||||
JSON.parse(File.open(
|
JSON.parse(File.open(
|
||||||
|
@ -21,8 +22,8 @@ describe CustomWizard::Builder do
|
||||||
let(:tag_field) {{"id": "tag","type": "tag","label": "Tag","limit": "2"}}
|
let(:tag_field) {{"id": "tag","type": "tag","label": "Tag","limit": "2"}}
|
||||||
let(:category_field) {{"id": "category","type": "category","limit": "1","label": "Category"}}
|
let(:category_field) {{"id": "category","type": "category","limit": "1","label": "Category"}}
|
||||||
let(:image_field) {{"id": "image","type": "image","label": "Image"}}
|
let(:image_field) {{"id": "image","type": "image","label": "Image"}}
|
||||||
let(:text_field) {{"id": "text","type": "text","min_length": "12","label": "Text"}}
|
let(:text_field) {{"id": "text","type": "text","label": "Text"}}
|
||||||
let(:textarea_field) {{"id": "textarea","type": "textarea","min_length": "40","label": "Textarea"}}
|
let(:textarea_field) {{"id": "textarea","type": "textarea","label": "Textarea"}}
|
||||||
let(:text_only_field) {{"id": "text_only","type": "text-only","label": "Text only"}}
|
let(:text_only_field) {{"id": "text_only","type": "text-only","label": "Text only"}}
|
||||||
let(:upload_field) {{"id": "upload","type": "upload","file_types": ".jpg,.png,.pdf","label": "Upload"}}
|
let(:upload_field) {{"id": "upload","type": "upload","file_types": ".jpg,.png,.pdf","label": "Upload"}}
|
||||||
let(:user_selector_field) {{"id": "user_selector","type": "user-selector","label": "User selector"}}
|
let(:user_selector_field) {{"id": "user_selector","type": "user-selector","label": "User selector"}}
|
||||||
|
@ -31,6 +32,11 @@ describe CustomWizard::Builder do
|
||||||
let(:dropdown_custom_field) {{"id": "dropdown_custom","type": "dropdown","choices_type": "custom","choices": [{"key": "option_1","value": "Option 1"},{"key": "option_2","value": "Option 2"}]}}
|
let(:dropdown_custom_field) {{"id": "dropdown_custom","type": "dropdown","choices_type": "custom","choices": [{"key": "option_1","value": "Option 1"},{"key": "option_2","value": "Option 2"}]}}
|
||||||
let(:dropdown_translation_field) {{"id": "dropdown_translation","type": "dropdown","choices_type": "translation","choices_key": "key1.key2"}}
|
let(:dropdown_translation_field) {{"id": "dropdown_translation","type": "dropdown","choices_type": "translation","choices_key": "key1.key2"}}
|
||||||
let(:dropdown_categories_filtered_field) {{"id": "dropdown_categories_filtered_field","type": "dropdown","choices_type": "preset","choices_preset": "categories","choices_filters": [{"key": "slug","value": "staff"}]}}
|
let(:dropdown_categories_filtered_field) {{"id": "dropdown_categories_filtered_field","type": "dropdown","choices_type": "preset","choices_preset": "categories","choices_filters": [{"key": "slug","value": "staff"}]}}
|
||||||
|
let(:create_topic_action) {{"id":"create_topic","type":"create_topic","title":"text","post":"textarea"}}
|
||||||
|
let(:send_message_action) {{"id":"send_message","type":"send_message","title":"text","post":"textarea","username":"angus"}}
|
||||||
|
let(:route_to_action) {{"id":"route_to","type":"route_to","url":"https://google.com"}}
|
||||||
|
let(:open_composer_action) {{"id":"open_composer","type":"open_composer","title":"text","post":"textarea"}}
|
||||||
|
let(:add_to_group_action) {{"id":"add_to_group","type":"add_to_group","group_id":"dropdown_groups"}}
|
||||||
|
|
||||||
def build_wizard(t = template, u = user, build_opts = {}, params = {})
|
def build_wizard(t = template, u = user, build_opts = {}, params = {})
|
||||||
CustomWizard::Wizard.add_wizard(t)
|
CustomWizard::Wizard.add_wizard(t)
|
||||||
|
@ -48,11 +54,44 @@ describe CustomWizard::Builder do
|
||||||
PluginStore.get("welcome_submissions", user.id)
|
PluginStore.get("welcome_submissions", user.id)
|
||||||
end
|
end
|
||||||
|
|
||||||
it "returns no steps when disabled" do
|
def run_update(t = template, step_id = nil, data = {})
|
||||||
SiteSetting.custom_wizard_enabled = false
|
wizard = build_wizard(t)
|
||||||
wizard = build_wizard
|
updater = wizard.create_updater(step_id || t['steps'][0]['id'], data)
|
||||||
expect(wizard.steps.length).to eq(0)
|
updater.update
|
||||||
expect(wizard.name).to eq('Welcome')
|
updater
|
||||||
|
end
|
||||||
|
|
||||||
|
def send_message(extra_field = nil, extra_action_opts = {})
|
||||||
|
fields = [text_field, textarea_field]
|
||||||
|
|
||||||
|
if extra_field
|
||||||
|
fields.push(extra_field)
|
||||||
|
end
|
||||||
|
|
||||||
|
template['steps'][0]['fields'] = fields
|
||||||
|
template['steps'][0]["actions"] = [send_message_action.merge(extra_action_opts)]
|
||||||
|
|
||||||
|
run_update(template, nil,
|
||||||
|
text: "Message Title",
|
||||||
|
textarea: "message body"
|
||||||
|
)
|
||||||
|
end
|
||||||
|
|
||||||
|
context 'disabled' do
|
||||||
|
before do
|
||||||
|
SiteSetting.custom_wizard_enabled = false
|
||||||
|
end
|
||||||
|
|
||||||
|
it "returns no steps" do
|
||||||
|
wizard = build_wizard
|
||||||
|
expect(wizard.steps.length).to eq(0)
|
||||||
|
expect(wizard.name).to eq('Welcome')
|
||||||
|
end
|
||||||
|
|
||||||
|
it "doesn't save submissions" do
|
||||||
|
run_update(template, nil, name: 'Angus')
|
||||||
|
expect(get_submission_data.blank?).to eq(true)
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
context 'enabled' do
|
context 'enabled' do
|
||||||
|
@ -152,12 +191,15 @@ describe CustomWizard::Builder do
|
||||||
end
|
end
|
||||||
|
|
||||||
context 'on update' do
|
context 'on update' do
|
||||||
|
it 'saves submissions' do
|
||||||
|
run_update(template, nil, name: 'Angus')
|
||||||
|
expect(get_submission_data.first['name']).to eq('Angus')
|
||||||
|
end
|
||||||
|
|
||||||
context 'validation' do
|
context 'validation' do
|
||||||
it 'applies min length' do
|
it 'applies min length' do
|
||||||
template['steps'][0]['fields'][0]['min_length'] = 10
|
template['steps'][0]['fields'][0]['min_length'] = 10
|
||||||
wizard = build_wizard(template, user)
|
updater = run_update(template, nil, name: 'short')
|
||||||
updater = wizard.create_updater(template['steps'][0]['id'], name: 'short')
|
|
||||||
updater.update
|
|
||||||
expect(updater.errors.messages[:name].first).to eq(
|
expect(updater.errors.messages[:name].first).to eq(
|
||||||
I18n.t('wizard.field.too_short', label: 'Name', min: 10)
|
I18n.t('wizard.field.too_short', label: 'Name', min: 10)
|
||||||
)
|
)
|
||||||
|
@ -165,78 +207,162 @@ describe CustomWizard::Builder do
|
||||||
|
|
||||||
it 'standardises boolean entries' do
|
it 'standardises boolean entries' do
|
||||||
template['steps'][0]['fields'][0] = checkbox_field
|
template['steps'][0]['fields'][0] = checkbox_field
|
||||||
wizard = build_wizard(template, user)
|
run_update(template, nil, checkbox: 'false')
|
||||||
updater = wizard.create_updater(template['steps'][0]['id'], checkbox: 'false')
|
expect(get_submission_data.first['checkbox']).to eq(false)
|
||||||
updater.update
|
|
||||||
submissions = get_submission_data
|
|
||||||
expect(submissions.first['checkbox']).to eq(false)
|
|
||||||
end
|
end
|
||||||
|
|
||||||
it 'requires required fields' do
|
it 'requires required fields' do
|
||||||
wizard = build_wizard
|
template['steps'][0]['fields'][0]['required'] = true
|
||||||
updater = wizard.create_updater(template['steps'][0]['id'], other_field: 'other')
|
expect(run_update(template).errors.messages[:name].first).to eq(
|
||||||
updater.update
|
|
||||||
expect(updater.errors.messages[:name].first).to eq(
|
|
||||||
I18n.t('wizard.field.required', label: 'Name')
|
I18n.t('wizard.field.required', label: 'Name')
|
||||||
)
|
)
|
||||||
end
|
end
|
||||||
|
|
||||||
context 'submisisons' do
|
|
||||||
it 'saves submissions' do
|
|
||||||
|
|
||||||
end
|
|
||||||
|
|
||||||
it "doesn't save submissions if disabled" do
|
|
||||||
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
context 'custom_step_handlers' do
|
|
||||||
it 'runs custom step handlers' do
|
|
||||||
|
|
||||||
end
|
|
||||||
end
|
end
|
||||||
|
|
||||||
context 'actions' do
|
context 'actions' do
|
||||||
it 'runs all actions attached to a step' do
|
it 'runs actions attached to a step' do
|
||||||
|
run_update(template, template['steps'][1]['id'], name: "Gus")
|
||||||
|
expect(user.name).to eq('Gus')
|
||||||
end
|
end
|
||||||
|
|
||||||
it 'interpolates wizard and user data correctly' do
|
it 'interpolates user data correctly' do
|
||||||
|
user.name = "Angus"
|
||||||
|
user.save!
|
||||||
|
|
||||||
|
expect(
|
||||||
|
CustomWizard::Builder.fill_placeholders(
|
||||||
|
"My name is u{name}",
|
||||||
|
user,
|
||||||
|
{}
|
||||||
|
)
|
||||||
|
).to eq('My name is Angus')
|
||||||
end
|
end
|
||||||
|
|
||||||
it 'creates a topic' do
|
it 'creates a topic' do
|
||||||
|
template['steps'][0]['fields'] = [text_field, textarea_field]
|
||||||
|
template['steps'][0]["actions"] = [create_topic_action]
|
||||||
|
updater = run_update(template, nil,
|
||||||
|
text: "Topic Title",
|
||||||
|
textarea: "topic body"
|
||||||
|
)
|
||||||
|
topic = Topic.where(title: "Topic Title")
|
||||||
|
|
||||||
|
expect(topic.exists?).to eq(true)
|
||||||
|
expect(Post.where(
|
||||||
|
topic_id: topic.pluck(:id),
|
||||||
|
raw: "topic body"
|
||||||
|
).exists?).to eq(true)
|
||||||
|
end
|
||||||
|
|
||||||
|
it 'creates a topic with a custom title' do
|
||||||
|
user.name = "Angus"
|
||||||
|
user.save!
|
||||||
|
|
||||||
|
template['steps'][0]['fields'] = [text_field, textarea_field]
|
||||||
|
|
||||||
|
create_topic_action['custom_title_enabled'] = true
|
||||||
|
create_topic_action['custom_title'] = "u{name}' Topic Title"
|
||||||
|
template['steps'][0]["actions"] = [create_topic_action]
|
||||||
|
|
||||||
|
run_update(template, nil, textarea: "topic body")
|
||||||
|
|
||||||
|
topic = Topic.where(title: "Angus' Topic Title")
|
||||||
|
|
||||||
|
expect(topic.exists?).to eq(true)
|
||||||
|
expect(Post.where(
|
||||||
|
topic_id: topic.pluck(:id),
|
||||||
|
raw: "topic body"
|
||||||
|
).exists?).to eq(true)
|
||||||
|
end
|
||||||
|
|
||||||
|
it 'creates a topic with a custom post' do
|
||||||
|
user.name = "Angus"
|
||||||
|
user.save!
|
||||||
|
|
||||||
|
template['steps'][0]['fields'] = [text_field, textarea_field]
|
||||||
|
|
||||||
|
create_topic_action['post_builder'] = true
|
||||||
|
create_topic_action['post_template'] = "u{name}' w{textarea}"
|
||||||
|
template['steps'][0]["actions"] = [create_topic_action]
|
||||||
|
|
||||||
|
run_update(template, nil,
|
||||||
|
text: "Topic Title",
|
||||||
|
textarea: "topic body"
|
||||||
|
)
|
||||||
|
|
||||||
|
topic = Topic.where(title: "Topic Title")
|
||||||
|
|
||||||
|
expect(topic.exists?).to eq(true)
|
||||||
|
expect(Post.where(
|
||||||
|
topic_id: topic.pluck(:id),
|
||||||
|
raw: "Angus' topic body"
|
||||||
|
).exists?).to eq(true)
|
||||||
end
|
end
|
||||||
|
|
||||||
it 'sends a message' do
|
it 'sends a message' do
|
||||||
|
send_message
|
||||||
|
|
||||||
|
topic = Topic.where(
|
||||||
|
archetype: Archetype.private_message,
|
||||||
|
title: "Message Title"
|
||||||
|
)
|
||||||
|
|
||||||
|
expect(topic.exists?).to eq(true)
|
||||||
|
expect(
|
||||||
|
topic.first.topic_allowed_users.first.user.username
|
||||||
|
).to eq('angus')
|
||||||
|
expect(Post.where(
|
||||||
|
topic_id: topic.pluck(:id),
|
||||||
|
raw: "message body"
|
||||||
|
).exists?).to eq(true)
|
||||||
end
|
end
|
||||||
|
|
||||||
it 'doesnt sent a message if the required data is not present' do
|
it 'doesnt sent a message if the required data is not present' do
|
||||||
|
send_message(user_selector_field, required: "user_selector")
|
||||||
|
topic = Topic.where(
|
||||||
|
archetype: Archetype.private_message,
|
||||||
|
title: "Message Title"
|
||||||
|
)
|
||||||
|
expect(topic.exists?).to eq(false)
|
||||||
end
|
end
|
||||||
|
|
||||||
it 'updates a profile' do
|
it 'updates a profile' do
|
||||||
|
run_update(template, template['steps'][1]['id'], name: "Sally")
|
||||||
end
|
expect(user.name).to eq('Sally')
|
||||||
|
|
||||||
it 'calls an api' do
|
|
||||||
|
|
||||||
end
|
end
|
||||||
|
|
||||||
it 'opens a composer' do
|
it 'opens a composer' do
|
||||||
|
template['steps'][0]['fields'] = [text_field, textarea_field]
|
||||||
|
template['steps'][0]["actions"] = [open_composer_action]
|
||||||
|
|
||||||
|
updater = run_update(template, nil,
|
||||||
|
text: "Topic Title",
|
||||||
|
textarea: "topic body"
|
||||||
|
)
|
||||||
|
|
||||||
|
expect(updater.result.blank?).to eq(true)
|
||||||
|
|
||||||
|
updater = run_update(template, template['steps'][1]['id'])
|
||||||
|
|
||||||
|
expect(updater.result[:redirect_on_complete]).to eq(
|
||||||
|
"/new-topic?title=Topic%20Title&body=topic%20body"
|
||||||
|
)
|
||||||
end
|
end
|
||||||
|
|
||||||
it 'adds a user to a group' do
|
it 'adds a user to a group' do
|
||||||
|
template['steps'][0]['fields'] = [dropdown_groups_field]
|
||||||
|
template['steps'][0]["actions"] = [add_to_group_action]
|
||||||
|
|
||||||
|
updater = run_update(template, nil, dropdown_groups: group.id)
|
||||||
|
expect(group.users.first.username).to eq('angus')
|
||||||
end
|
end
|
||||||
|
|
||||||
it 're-routes a user' do
|
it 're-routes a user' do
|
||||||
|
template['steps'][0]["actions"] = [route_to_action]
|
||||||
|
updater = run_update(template, nil, {})
|
||||||
|
expect(updater.result[:redirect_on_next]).to eq(
|
||||||
|
"https://google.com"
|
||||||
|
)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
7
spec/fixtures/wizard.json
gevendort
7
spec/fixtures/wizard.json
gevendort
|
@ -16,8 +16,7 @@
|
||||||
{
|
{
|
||||||
"id": "name",
|
"id": "name",
|
||||||
"type": "text",
|
"type": "text",
|
||||||
"label": "Name",
|
"label": "Name"
|
||||||
"required": true
|
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
},
|
},
|
||||||
|
@ -41,10 +40,6 @@
|
||||||
{
|
{
|
||||||
"key": "name",
|
"key": "name",
|
||||||
"value": "name"
|
"value": "name"
|
||||||
},
|
|
||||||
{
|
|
||||||
"key": "website",
|
|
||||||
"value": "website"
|
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
|
|
Laden …
In neuem Issue referenzieren