You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
docuseal/spec/system/storage_settings_spec.rb

246 lines
9.1 KiB

# frozen_string_literal: true
RSpec.describe 'Storage Settings' do
let!(:account) { create(:account) }
let!(:user) { create(:user, account:) }
before do
sign_in(user)
end
context 'when storage settings are not set' do
before do
visit settings_storage_index_path
end
context 'when Disk is selected' do
it 'shows default storage settings page' do
expect(page).to have_content('Storage')
expect(page).to have_content('Store all files on disk')
expect(page).to have_content('No configs are needed but make sure your disk is persistent')
expect(page).to have_checked_field('Disk')
end
end
context 'when AWS S3 is selected' do
it 'setups AWS S3 storage settings' do
choose 'AWS'
fill_in 'Access key ID', with: 'access_key_id'
fill_in 'Secret access key', with: 'secret_access_key'
fill_in 'Region', with: 'us-west-1'
fill_in 'Bucket', with: 'bucket'
fill_in 'Endpoint', with: 'https://s3.us-west-1.amazonaws.com'
expect do
click_button 'Save'
end.to change(EncryptedConfig, :count).by(1)
encrypted_config = EncryptedConfig.find_by(account:, key: EncryptedConfig::FILES_STORAGE_KEY)
configs = encrypted_config.value['configs']
expect(encrypted_config.value['service']).to eq('aws_s3')
expect(configs['access_key_id']).to eq('access_key_id')
expect(configs['secret_access_key']).to eq('secret_access_key')
expect(configs['region']).to eq('us-west-1')
expect(configs['bucket']).to eq('bucket')
expect(configs['endpoint']).to eq('https://s3.us-west-1.amazonaws.com')
end
end
context 'when Google Cloud Storage is selected' do
it 'setups Google Cloud Storage settings' do
choose 'GCP'
fill_in 'Project', with: 'project_id'
fill_in 'Bucket', with: 'bucket'
fill_in 'Credentials (JSON key content)', with: '{ "type": "service_account", "project_id": "project_id" }'
expect do
click_button 'Save'
end.to change(EncryptedConfig, :count).by(1)
encrypted_config = EncryptedConfig.find_by(account:, key: EncryptedConfig::FILES_STORAGE_KEY)
configs = encrypted_config.value['configs']
expect(encrypted_config.value['service']).to eq('google')
expect(configs['project']).to eq('project_id')
expect(configs['bucket']).to eq('bucket')
expect(configs['credentials']).to eq('{ "type": "service_account", "project_id": "project_id" }')
end
end
context 'when Azure is selected' do
it 'setup Azure storage settings' do
choose 'Azure'
fill_in 'Storage Account Name', with: 'storage_account_name'
fill_in 'Container', with: 'container'
fill_in 'Storage Access Key', with: 'storage_access_key'
expect do
click_button 'Save'
end.to change(EncryptedConfig, :count).by(1)
encrypted_config = EncryptedConfig.find_by(account:, key: EncryptedConfig::FILES_STORAGE_KEY)
configs = encrypted_config.value['configs']
expect(encrypted_config.value['service']).to eq('azure')
expect(configs['storage_account_name']).to eq('storage_account_name')
expect(configs['container']).to eq('container')
expect(configs['storage_access_key']).to eq('storage_access_key')
end
end
end
context 'when storage settings are set' do
context 'when updates the same storage settings' do
context 'when AWS S3' do
let!(:encrypted_config) do
create(:encrypted_config, account:, key: EncryptedConfig::FILES_STORAGE_KEY, value: {
service: 'aws_s3',
configs: {
access_key_id: 'access_key_id',
secret_access_key: 'secret_access_key',
region: 'us-west-1',
bucket: 'bucket',
endpoint: 'https://s3.us-west-1.amazonaws.com'
}
})
end
it 'updates AWS S3 storage settings' do
visit settings_storage_index_path
fill_in 'Access key ID', with: 'new_access_key_id'
fill_in 'Secret access key', with: 'new_secret_access_key'
fill_in 'Region', with: 'us-west-2'
fill_in 'Bucket', with: 'new_bucket'
fill_in 'Endpoint', with: 'https://s3.us-west-2.amazonaws.com'
expect do
click_button 'Save'
end.not_to(change(EncryptedConfig, :count))
encrypted_config.reload
configs = encrypted_config.value['configs']
expect(encrypted_config.value['service']).to eq('aws_s3')
expect(configs['access_key_id']).to eq('new_access_key_id')
expect(configs['secret_access_key']).to eq('new_secret_access_key')
expect(configs['region']).to eq('us-west-2')
expect(configs['bucket']).to eq('new_bucket')
expect(configs['endpoint']).to eq('https://s3.us-west-2.amazonaws.com')
end
end
context 'when Google Cloud Storage' do
let!(:encrypted_config) do
create(:encrypted_config, account:, key: EncryptedConfig::FILES_STORAGE_KEY, value: {
service: 'google',
configs: {
project: 'project_id',
bucket: 'bucket',
credentials: '{ "type": "service_account", "project_id": "project_id" }'
}
})
end
it 'updates Google Cloud Storage settings' do
visit settings_storage_index_path
fill_in 'Project', with: 'new_project_id'
fill_in 'Bucket', with: 'new_bucket'
fill_in 'Credentials (JSON key content)',
with: '{ "type": "new_service_account", "project_id": "new_project_id" }'
expect do
click_button 'Save'
end.not_to(change(EncryptedConfig, :count))
encrypted_config.reload
configs = encrypted_config.value['configs']
expect(encrypted_config.value['service']).to eq('google')
expect(configs['project']).to eq('new_project_id')
expect(configs['bucket']).to eq('new_bucket')
expect(configs['credentials']).to eq('{ "type": "new_service_account", "project_id": "new_project_id" }')
end
end
context 'when Azure' do
let!(:encrypted_config) do
create(:encrypted_config, account:, key: EncryptedConfig::FILES_STORAGE_KEY, value: {
service: 'azure',
configs: {
storage_account_name: 'storage_account_name',
container: 'container',
storage_access_key: 'storage_access_key'
}
})
end
it 'updates Azure storage settings' do
visit settings_storage_index_path
fill_in 'Storage Account Name', with: 'new_storage_account_name'
fill_in 'Container', with: 'new_container'
fill_in 'Storage Access Key', with: 'new_storage_access_key'
expect do
click_button 'Save'
end.not_to(change(EncryptedConfig, :count))
encrypted_config.reload
configs = encrypted_config.value['configs']
expect(encrypted_config.value['service']).to eq('azure')
expect(configs['storage_account_name']).to eq('new_storage_account_name')
expect(configs['container']).to eq('new_container')
expect(configs['storage_access_key']).to eq('new_storage_access_key')
end
end
end
context 'when switches to another storage settings' do
context 'when Google Cloud Storage' do
let!(:encrypted_config) do
create(:encrypted_config, account:, key: EncryptedConfig::FILES_STORAGE_KEY, value: {
service: 'google',
configs: {
project: 'project_id',
bucket: 'bucket',
credentials: '{ "type": "service_account", "project_id": "project_id" }'
}
})
end
it 'switches to AWS S3' do
visit settings_storage_index_path
choose 'AWS'
fill_in 'Access key ID', with: 'access_key_id'
fill_in 'Secret access key', with: 'secret_access_key'
fill_in 'Region', with: 'us-west-1'
fill_in 'Bucket', with: 'bucket'
fill_in 'Endpoint', with: 'https://s3.us-west-1.amazonaws.com'
expect do
click_button 'Save'
end.not_to(change(EncryptedConfig, :count))
encrypted_config.reload
configs = encrypted_config.value['configs']
expect(encrypted_config.value['service']).to eq('aws_s3')
expect(configs['access_key_id']).to eq('access_key_id')
expect(configs['secret_access_key']).to eq('secret_access_key')
expect(configs['region']).to eq('us-west-1')
expect(configs['bucket']).to eq('bucket')
expect(configs['endpoint']).to eq('https://s3.us-west-1.amazonaws.com')
end
end
end
end
end