Получение

лизовал Оптимистическую блокировку для состояния гонки. Для этого я добавил дополнительный столбецlock_version в продукте. Метод:recalculate звонит в приватmethod_1 потом спасает (save!) продукт. Я не могу использоватьsave! наединеmethod_1потому что это потерпит неудачу с другими вещами. Я не хочу перестраивать бизнес-логику.

#Product: Model's new field:
    #  lock_version                       :integer(4)      default(0), not null

def recalculate
  method_1
  self.save!
end

private
def method_1
    begin
      ####
      ####
      if self.lock_version == Product.find(self.id).lock_version
         Product.where(:id => self.id).update_all(attributes)
      else
         raise ActiveRecord::StaleObjectError.new(self, "test")
      end
    rescue ActiveRecord::StaleObjectError => e
        if tries < 3
           tries += 1
           sleep(1 + tries)
           self.reload
           retry
        else
           raise Exception.new(timeout.inspect)
        end
    end
end

Контрольный пример Rspec:

  it 'if car is updated then ActiveRecord::StaleObjectError should be raised' do
    prod_v1 =Product.find(@prod.id)
    prod_v2 = Car.find(@prod.id)
    prod_v1.recalculate
    prod_v1.reload  # will make lock_version of prod_v1 to 1

    prod_v2.recalculate # howvever lock_version of prod_v2 is still 0.

    expect(car_v2).to receive(:method1).and_raise(ActiveRecord::StaleObjectError)
  end

Когда я пытаюсь написать выше контрольного примера, то это должно вызвать исключениеActiveRecord::StaleObjectError, Тем не менее, я получаю сообщение об ошибке, как

 Failure/Error: expect(car_v2).to receive(:set_total_and_buckets_used).and_raise(ActiveRecord::StaleObjectError)
 ArgumentError:
   wrong number of arguments (0 for 2)

Ответы на вопрос(1)

Ваш ответ на вопрос