Fix flaky tests dependent on exercise.reload for files

This commit is contained in:
Sebastian Serth
2023-09-16 16:57:59 +02:00
parent 1102db9f02
commit e767cff309
3 changed files with 17 additions and 13 deletions

View File

@ -63,20 +63,21 @@ describe CodeOcean::FilesController do
end
describe 'DELETE #destroy' do
let(:exercise) { create(:fibonacci) }
let(:perform_request) { proc { delete :destroy, params: {id: exercise.files.first.id} } }
let!(:exercise) { create(:fibonacci) }
let(:perform_request) { proc { delete :destroy, params: {id: exercise.files.reject(&:main_file?).first.id} } }
before { perform_request.call }
context 'with request performed' do
before { perform_request.call }
expect_assigns(file: CodeOcean::File)
expect_assigns(file: CodeOcean::File)
it 'destroys the file' do
create(:fibonacci)
expect { perform_request.call }.to change(CodeOcean::File, :count).by(-1)
it 'redirects to exercise path' do
expect(controller).to redirect_to(exercise)
end
end
it 'redirects to exercise path' do
expect(controller).to redirect_to(exercise)
it 'destroys the file' do
expect { perform_request.call }.to change(CodeOcean::File, :count).by(-1)
end
end
end