Spiegel von
https://github.com/paviliondev/discourse-custom-wizard.git
synchronisiert 2024-11-22 17:30:29 +01:00
ceef3f4bc9
* Re structure builder logic to allow for step conditionality Concerns - Performance. Look at whether the additional build in the steps controller can be reduced - Does not work if applied to the last step. - Certain conditions will not work with the first step(?) - How should this be scoped to known functionality? * Add indexes and conditions to steps and fields * Complete and add spec * Complete backend * Complete step conditionality and field indexing * Fix failing spec * Update coverage * Apply rubocop * Apply prettier * Apply prettier to wizard js * Fix schema issues created in merge * Remove setting label for force_final * Improve client wizard cache naming * Improve steps controller and spec conditionality * Improve final step attribute naming * Fix failing spec * Linting * Add one more final step test * Linting * Fix eslint issues * Apply prettier * Linting, syntax, merge and copy cleanups * Update wizard-admin.scss * Fix template linting * Rubocop fixes
67 Zeilen
2 KiB
Ruby
67 Zeilen
2 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
require_relative '../../plugin_helper'
|
|
|
|
describe CustomWizard::StepSerializer do
|
|
fab!(:user) { Fabricate(:user) }
|
|
|
|
let(:wizard_template) {
|
|
JSON.parse(
|
|
File.open(
|
|
"#{Rails.root}/plugins/discourse-custom-wizard/spec/fixtures/wizard.json"
|
|
).read
|
|
)
|
|
}
|
|
|
|
let(:required_data_json) {
|
|
JSON.parse(
|
|
File.open(
|
|
"#{Rails.root}/plugins/discourse-custom-wizard/spec/fixtures/step/required_data.json"
|
|
).read
|
|
)
|
|
}
|
|
|
|
before do
|
|
CustomWizard::Template.save(wizard_template, skip_jobs: true)
|
|
@wizard = CustomWizard::Builder.new("super_mega_fun_wizard", user).build
|
|
end
|
|
|
|
it 'should return basic step attributes' do
|
|
json_array = ActiveModel::ArraySerializer.new(
|
|
@wizard.steps,
|
|
each_serializer: described_class,
|
|
scope: Guardian.new(user)
|
|
).as_json
|
|
expect(json_array[0][:title]).to eq("<p>Text</p>")
|
|
expect(json_array[0][:description]).to eq("<p>Text inputs!</p>")
|
|
expect(json_array[1][:index]).to eq(1)
|
|
end
|
|
|
|
it 'should return fields' do
|
|
json_array = ActiveModel::ArraySerializer.new(
|
|
@wizard.steps,
|
|
each_serializer: described_class,
|
|
scope: Guardian.new(user)
|
|
).as_json
|
|
expect(json_array[0][:fields].length).to eq(4)
|
|
end
|
|
|
|
context 'with required data' do
|
|
before do
|
|
wizard_template['steps'][0]['required_data'] = required_data_json['required_data']
|
|
wizard_template['steps'][0]['required_data_message'] = required_data_json['required_data_message']
|
|
CustomWizard::Template.save(wizard_template)
|
|
@wizard = CustomWizard::Builder.new("super_mega_fun_wizard", user).build
|
|
end
|
|
|
|
it 'should return permitted attributes' do
|
|
json_array = ActiveModel::ArraySerializer.new(
|
|
@wizard.steps,
|
|
each_serializer: described_class,
|
|
scope: Guardian.new(user)
|
|
).as_json
|
|
expect(json_array[0][:permitted]).to eq(false)
|
|
expect(json_array[0][:permitted_message]).to eq("Missing required data")
|
|
end
|
|
end
|
|
end
|