123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136 |
- # Copyright (C) 2012-2025 Zammad Foundation, https://zammad-foundation.org/
- require 'rails_helper'
- RSpec.describe 'System setup process', authenticated_as: false, required_envs: %w[MAIL_ADDRESS MAIL_PASS], set_up: false, type: :system do
- before do
- # Import mail server CA certificate into the trust store.
- SSLCertificate.create!(certificate: Rails.root.join('spec/fixtures/files/imap/ca.crt').read)
- end
- def fqdn
- match_data = %r{://(.+?)(:.+?|/.+?|)$}.match(app_host)
- return match_data.captures.first if match_data.present?
- raise "Unable to get fqdn based on #{app_host}"
- end
- it 'Setting up a new system' do
- mailbox_user = ENV['MAIL_ADDRESS']
- mailbox_password = ENV['MAIL_PASS']
- visit '/'
- expect(page).to have_css('.setup.wizard', text: 'Set up a new system')
- # choose setup (over migration)
- click_on('Set up a new system')
- # admin user form
- expect(page).to have_css('.js-admin h2', text: 'Administrator Account')
- within('.js-admin') do
- fill_in 'firstname', with: 'Test Admin'
- fill_in 'lastname', with: 'Agent'
- fill_in 'email', with: 'admin@example.com'
- fill_in 'password', with: 'TEst1234äöüß'
- fill_in 'password_confirm', with: 'TEst1234äöüß'
- click_on('Create')
- end
- # configure Organization
- expect(page).to have_css('.js-base h2', text: 'Organization')
- within('.js-base') do
- fill_in 'organization', with: 'Some Organization'
- # fill in wrong URL
- fill_in 'url', with: 'some host'
- click_on('Next')
- expect(page).to have_css('.alert', text: 'Please include a valid url.')
- # fill in valild/current URL
- fill_in 'url', with: app_host
- click_on('Next')
- end
- # configure Email Notification
- expect(page).to have_css('.js-outbound h2', text: 'Email Notification')
- expect_current_route 'getting_started/email_notification'
- click_on('Continue')
- # create email account
- expect(page).to have_css('.js-channel h2', text: 'Connect Channels')
- expect_current_route 'getting_started/channel'
- click('.js-channel .btn.email')
- within('.js-intro') do
- fill_in 'realname', with: 'Some Realname'
- fill_in 'email', with: mailbox_user
- fill_in 'password', with: mailbox_password
- page.element.click_on('Connect')
- end
- # wait for verification process to start
- expect(page).to have_css('body', text: 'Verify sending and receiving')
- # wait for verification process to finish
- expect(page).to have_css('.js-agent h2', text: 'Invite Colleagues', wait: 2.minutes)
- expect_current_route 'getting_started/agents'
- # invite agent1
- within('.js-agent') do
- fill_in 'firstname', with: 'Agent 1'
- fill_in 'lastname', with: 'Test'
- fill_in 'email', with: 'agent12@example.com'
- click_on('Invite')
- end
- expect(page).to have_css('body', text: 'Invitation sent!')
- # expect to still be on the same page
- expect_current_route 'getting_started/agents'
- within('.js-agent') do
- click_on('Continue')
- end
- # expect Dashboard of a fresh system
- expect(page).to have_css('body', text: 'My Stats')
- expect_current_route 'clues'
- find(:clues_close).in_fixed_position.click
- # verify organization and fqdn
- click(:manage)
- within(:active_content) do
- click(:href, '#settings/branding')
- expect(page).to have_field('organization', with: 'Some Organization')
- click(:href, '#settings/system')
- expect(page).to have_field('fqdn', with: fqdn)
- end
- end
- # https://github.com/zammad/zammad/issues/3106
- it 'Shows an error message if too weak password is filled in' do
- visit '/'
- click_on('Set up a new system')
- within('.js-admin') do
- fill_in 'firstname', with: 'Test Admin'
- fill_in 'lastname', with: 'Agent'
- fill_in 'email', with: 'admin@example.com'
- fill_in 'password', with: 'asd'
- fill_in 'password_confirm', with: 'asd'
- click_on('Create')
- expect(page).to have_text 'Invalid password'
- end
- end
- end
|