hensei-api/spec/services/processors/base_processor_spec.rb
Justin Edmund 15729ec7a8 Updates for weapon series
- Change to new series numbers
- Add static method for querying whether the weapon's element is changeable
- Add a new method to return a text slug for the weapon's series
2025-02-17 20:33:48 -08:00

45 lines
1.2 KiB
Ruby

# frozen_string_literal: true
require 'rails_helper'
require 'rails_helper'
module Processors
class DummyBaseProcessor < BaseProcessor
# A dummy implementation of process.
def process
"processed"
end
# Expose the protected log method as public for testing.
def public_log(message)
log(message)
end
end
end
RSpec.describe Processors::DummyBaseProcessor, type: :model do
# Note: BaseProcessor.new expects (party, data, options = {})
let(:dummy_party) { nil }
let(:dummy_data) { {} }
let(:processor) { described_class.new(dummy_party, dummy_data) }
describe '#process' do
it 'returns the dummy processed value' do
expect(processor.process).to eq("processed")
end
end
describe '#public_log' do
it 'logs a message containing the processor class name' do
message = "Test log message"
expect(Rails.logger).to receive(:info).with(a_string_including("DummyBaseProcessor", message))
processor.public_log(message)
end
end
after(:each) do |example|
if example.exception
puts "\nDEBUG [DummyBaseProcessor]: #{example.full_description} failed with error: #{example.exception.message}"
end
end
end