spec/unit/repositories/route_event_repository_spec.rb
require 'spec_helper'
module VCAP::CloudController
module Repositories
RSpec.describe RouteEventRepository do
let(:user) { User.make }
let(:route) { Route.make }
let(:request_attrs) { { 'host' => 'dora', 'domain_guid' => route.domain.guid, 'space_guid' => route.space.guid } }
let(:user_email) { 'some@email.com' }
let(:user_name) { 'some-user' }
let(:actor_audit_info) { UserAuditInfo.new(user_guid: user.guid, user_name: user_name, user_email: user_email) }
subject(:route_event_repository) { RouteEventRepository.new }
describe '#record_route_create' do
it 'records event correctly' do
event = route_event_repository.record_route_create(route, actor_audit_info, request_attrs)
event.reload
expect(event.space).to eq(route.space)
expect(event.type).to eq('audit.route.create')
expect(event.actee).to eq(route.guid)
expect(event.actee_type).to eq('route')
expect(event.actee_name).to eq(route.host)
expect(event.actor).to eq(user.guid)
expect(event.actor_type).to eq('user')
expect(event.actor_name).to eq(user_email)
expect(event.actor_username).to eq(user_name)
expect(event.metadata).to eq({ 'request' => request_attrs })
end
context 'when the event recording is manifest triggered' do
it 'tags the event as manifest triggered' do
event = route_event_repository.record_route_create(route, actor_audit_info, request_attrs, manifest_triggered: true)
event.reload
expect(event.metadata['manifest_triggered']).to be(true)
end
end
end
describe '#record_route_update' do
it 'records event correctly' do
event = route_event_repository.record_route_update(route, actor_audit_info, request_attrs)
event.reload
expect(event.space).to eq(route.space)
expect(event.type).to eq('audit.route.update')
expect(event.actee).to eq(route.guid)
expect(event.actee_type).to eq('route')
expect(event.actee_name).to eq(route.host)
expect(event.actor).to eq(user.guid)
expect(event.actor_type).to eq('user')
expect(event.actor_name).to eq(user_email)
expect(event.actor_username).to eq(user_name)
expect(event.metadata).to eq({ 'request' => request_attrs })
end
end
describe '#record_route_share' do
let(:target_space_guids) { %w[space-guid another-guid] }
it 'records event correctly' do
event = route_event_repository.record_route_share(route, actor_audit_info, target_space_guids)
event.reload
expect(event.space).to eq(route.space)
expect(event.type).to eq('audit.route.share')
expect(event.actee).to eq(route.guid)
expect(event.actee_type).to eq('route')
expect(event.actee_name).to eq(route.host)
expect(event.actor).to eq(user.guid)
expect(event.actor_type).to eq('user')
expect(event.actor_name).to eq(user_email)
expect(event.actor_username).to eq(user_name)
expect(event.space_guid).to eq(route.space.guid)
expect(event.metadata['target_space_guids']).to eq(target_space_guids)
end
end
describe '#record_route_unshare' do
let(:target_space_guid) { 'space-guid' }
it 'records event correctly' do
event = route_event_repository.record_route_unshare(route, actor_audit_info, target_space_guid)
event.reload
expect(event.space).to eq(route.space)
expect(event.type).to eq('audit.route.unshare')
expect(event.actee).to eq(route.guid)
expect(event.actee_type).to eq('route')
expect(event.actee_name).to eq(route.host)
expect(event.actor).to eq(user.guid)
expect(event.actor_type).to eq('user')
expect(event.actor_name).to eq(user_email)
expect(event.actor_username).to eq(user_name)
expect(event.space_guid).to eq(route.space.guid)
expect(event.metadata['target_space_guid']).to eq(target_space_guid)
end
end
describe '#record_route_delete' do
let(:recursive) { true }
before do
TestConfig.override(kubernetes: {})
route.destroy
end
it 'records event correctly' do
event = route_event_repository.record_route_delete_request(route, actor_audit_info, recursive)
event.reload
expect(event.space).to eq(route.space)
expect(event.type).to eq('audit.route.delete-request')
expect(event.actee).to eq(route.guid)
expect(event.actee_type).to eq('route')
expect(event.actee_name).to eq(route.host)
expect(event.actor).to eq(user.guid)
expect(event.actor_type).to eq('user')
expect(event.actor_name).to eq(user_email)
expect(event.actor_username).to eq(user_name)
expect(event.metadata).to eq({ 'request' => { 'recursive' => true } })
end
end
describe '#record_route_map' do
let(:app) { AppModel.make(space: route.space) }
context 'when route mapping has no weight' do
let(:route_mapping) { RouteMappingModel.make(app: app, route: route, process_type: 'web', app_port: 8080) }
it 'records event correctly' do
event = route_event_repository.record_route_map(route_mapping, actor_audit_info)
event.reload
expect(event.type).to eq('audit.app.map-route')
expect(event.actor).to eq(user.guid)
expect(event.actor_type).to eq('user')
expect(event.actor_name).to eq(user_email)
expect(event.actor_username).to eq(user_name)
expect(event.actee).to eq(app.guid)
expect(event.actee_type).to eq('app')
expect(event.actee_name).to eq(app.name)
expect(event.space_guid).to eq(app.space.guid)
expect(event.organization_guid).to eq(app.space.organization_guid)
expect(event.metadata).to eq({
'route_guid' => route.guid,
'app_port' => 8080,
'destination_guid' => route_mapping.guid,
'process_type' => 'web',
'weight' => route_mapping.weight
})
end
end
context 'when route mapping has weight' do
let(:route_mapping) { RouteMappingModel.make(app: app, route: route, process_type: 'web', app_port: 8080, weight: 100) }
it 'records event correctly' do
event = route_event_repository.record_route_map(route_mapping, actor_audit_info)
event.reload
expect(event.type).to eq('audit.app.map-route')
expect(event.actor).to eq(user.guid)
expect(event.actor_type).to eq('user')
expect(event.actor_name).to eq(user_email)
expect(event.actor_username).to eq(user_name)
expect(event.actee).to eq(app.guid)
expect(event.actee_type).to eq('app')
expect(event.actee_name).to eq(app.name)
expect(event.space_guid).to eq(app.space.guid)
expect(event.organization_guid).to eq(app.space.organization_guid)
expect(event.metadata).to eq({
'route_guid' => route.guid,
'app_port' => 8080,
'destination_guid' => route_mapping.guid,
'process_type' => 'web',
'weight' => route_mapping.weight
})
end
end
end
describe '#record_route_unmap' do
let(:app) { AppModel.make(space: route.space) }
context 'when route mapping has no weight' do
let(:route_mapping) { RouteMappingModel.make(app: app, route: route, process_type: 'web', app_port: 8080) }
it 'records event correctly' do
event = route_event_repository.record_route_unmap(route_mapping, actor_audit_info)
event.reload
expect(event.type).to eq('audit.app.unmap-route')
expect(event.actor).to eq(user.guid)
expect(event.actor_type).to eq('user')
expect(event.actor_name).to eq(user_email)
expect(event.actor_username).to eq(user_name)
expect(event.actee).to eq(app.guid)
expect(event.actee_type).to eq('app')
expect(event.actee_name).to eq(app.name)
expect(event.space_guid).to eq(app.space.guid)
expect(event.organization_guid).to eq(app.space.organization_guid)
expect(event.metadata).to eq({
'route_guid' => route.guid,
'app_port' => 8080,
'destination_guid' => route_mapping.guid,
'process_type' => 'web',
'weight' => route_mapping.weight
})
end
end
context 'when route mapping has weight' do
let(:route_mapping) { RouteMappingModel.make(app: app, route: route, process_type: 'web', app_port: 8080, weight: 100) }
it 'records event correctly' do
event = route_event_repository.record_route_unmap(route_mapping, actor_audit_info)
event.reload
expect(event.type).to eq('audit.app.unmap-route')
expect(event.actor).to eq(user.guid)
expect(event.actor_type).to eq('user')
expect(event.actor_name).to eq(user_email)
expect(event.actor_username).to eq(user_name)
expect(event.actee).to eq(app.guid)
expect(event.actee_type).to eq('app')
expect(event.actee_name).to eq(app.name)
expect(event.space_guid).to eq(app.space.guid)
expect(event.organization_guid).to eq(app.space.organization_guid)
expect(event.metadata).to eq({
'route_guid' => route.guid,
'app_port' => 8080,
'destination_guid' => route_mapping.guid,
'process_type' => 'web',
'weight' => route_mapping.weight
})
end
end
end
end
end
end