Improve spec for Geo::RepositorySyncWorker

parent 67a6ab0f
require 'spec_helper' require 'spec_helper'
describe Geo::RepositorySyncWorker do describe Geo::RepositorySyncWorker do
let!(:primary) { create(:geo_node, :primary, host: 'primary-geo-node') } let!(:primary) { create(:geo_node, :primary, host: 'primary-geo-node') }
let!(:secondary) { create(:geo_node, :current) } let!(:secondary) { create(:geo_node, :current) }
let(:group) { create(:group) } let(:synced_group) { create(:group) }
let!(:project_1) { create(:project, group: group) } let!(:project_in_synced_group) { create(:project, group: synced_group) }
let!(:project_2) { create(:project) } let!(:unsynced_project) { create(:project) }
subject { described_class.new } subject { described_class.new }
...@@ -22,8 +22,8 @@ describe Geo::RepositorySyncWorker do ...@@ -22,8 +22,8 @@ describe Geo::RepositorySyncWorker do
end end
it 'performs Geo::ProjectSyncWorker for projects where last attempt to sync failed' do it 'performs Geo::ProjectSyncWorker for projects where last attempt to sync failed' do
create(:geo_project_registry, :sync_failed, project: project_1) create(:geo_project_registry, :sync_failed, project: project_in_synced_group)
create(:geo_project_registry, :synced, project: project_2) create(:geo_project_registry, :synced, project: unsynced_project)
expect(Geo::ProjectSyncWorker).to receive(:perform_in).once.and_return(spy) expect(Geo::ProjectSyncWorker).to receive(:perform_in).once.and_return(spy)
...@@ -31,8 +31,8 @@ describe Geo::RepositorySyncWorker do ...@@ -31,8 +31,8 @@ describe Geo::RepositorySyncWorker do
end end
it 'performs Geo::ProjectSyncWorker for synced projects updated recently' do it 'performs Geo::ProjectSyncWorker for synced projects updated recently' do
create(:geo_project_registry, :synced, :repository_dirty, project: project_1) create(:geo_project_registry, :synced, :repository_dirty, project: project_in_synced_group)
create(:geo_project_registry, :synced, project: project_2) create(:geo_project_registry, :synced, project: unsynced_project)
create(:geo_project_registry, :synced, :wiki_dirty) create(:geo_project_registry, :synced, :wiki_dirty)
expect(Geo::ProjectSyncWorker).to receive(:perform_in).twice.and_return(spy) expect(Geo::ProjectSyncWorker).to receive(:perform_in).twice.and_return(spy)
...@@ -66,20 +66,26 @@ describe Geo::RepositorySyncWorker do ...@@ -66,20 +66,26 @@ describe Geo::RepositorySyncWorker do
context 'when node has namespace restrictions' do context 'when node has namespace restrictions' do
before do before do
secondary.update_attribute(:namespaces, [group]) secondary.update_attribute(:namespaces, [synced_group])
end end
it 'does not perform Geo::ProjectSyncWorker for projects that do not belong to selected namespaces to replicate' do it 'does not perform Geo::ProjectSyncWorker for projects that do not belong to selected namespaces to replicate' do
expect(Geo::ProjectSyncWorker).to receive(:perform_in).once.and_return(spy) expect(Geo::ProjectSyncWorker).to receive(:perform_in)
.with(300, project_in_synced_group.id, within(1.minute).of(Time.now))
.once
.and_return(spy)
subject.perform subject.perform
end end
it 'does not perform Geo::ProjectSyncWorker for synced projects updated recently that do not belong to selected namespaces to replicate' do it 'does not perform Geo::ProjectSyncWorker for synced projects updated recently that do not belong to selected namespaces to replicate' do
create(:geo_project_registry, :synced, :repository_dirty, project: project_1) create(:geo_project_registry, :synced, :repository_dirty, project: project_in_synced_group)
create(:geo_project_registry, :synced, :repository_dirty, project: project_2) create(:geo_project_registry, :synced, :repository_dirty, project: unsynced_project)
expect(Geo::ProjectSyncWorker).to receive(:perform_in).once.and_return(spy) expect(Geo::ProjectSyncWorker).to receive(:perform_in)
.with(300, project_in_synced_group.id, within(1.minute).of(Time.now))
.once
.and_return(spy)
subject.perform subject.perform
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