Commit 968f1e9a authored by peterhegman's avatar peterhegman

DRY up RSpec shared example

Per reviewer feedback
parent 7953fb39
...@@ -15,10 +15,7 @@ RSpec.shared_examples 'manage applications' do ...@@ -15,10 +15,7 @@ RSpec.shared_examples 'manage applications' do
check :doorkeeper_application_scopes_read_user check :doorkeeper_application_scopes_read_user
click_on 'Save application' click_on 'Save application'
expect(page).to have_content application_name validate_application(application_name, 'Yes')
expect(page).to have_content 'Application ID'
expect(page).to have_content 'Secret'
expect(page).to have_content 'Confidential Yes'
application = Doorkeeper::Application.find_by(name: application_name) application = Doorkeeper::Application.find_by(name: application_name)
expect(page).to have_css("button[title=\"Copy secret\"][data-clipboard-text=\"#{application.secret}\"]", text: 'Copy') expect(page).to have_css("button[title=\"Copy secret\"][data-clipboard-text=\"#{application.secret}\"]", text: 'Copy')
...@@ -31,10 +28,7 @@ RSpec.shared_examples 'manage applications' do ...@@ -31,10 +28,7 @@ RSpec.shared_examples 'manage applications' do
uncheck :doorkeeper_application_confidential uncheck :doorkeeper_application_confidential
click_on 'Save application' click_on 'Save application'
expect(page).to have_content application_name_changed validate_application(application_name_changed, 'No')
expect(page).to have_content 'Application ID'
expect(page).to have_content 'Secret'
expect(page).to have_content 'Confidential No'
visit_applications_path visit_applications_path
...@@ -61,4 +55,13 @@ RSpec.shared_examples 'manage applications' do ...@@ -61,4 +55,13 @@ RSpec.shared_examples 'manage applications' do
def visit_applications_path def visit_applications_path
visit defined?(applications_path) ? applications_path : new_application_path visit defined?(applications_path) ? applications_path : new_application_path
end end
def validate_application(name, confidential)
aggregate_failures do
expect(page).to have_content name
expect(page).to have_content 'Application ID'
expect(page).to have_content 'Secret'
expect(page).to have_content "Confidential #{confidential}"
end
end
end end
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment