Commit 70e75a41 authored by Ethan Urie's avatar Ethan Urie

Add spec to test #interceptors is called

parent 51e4d80d
...@@ -27,22 +27,18 @@ module Gitlab ...@@ -27,22 +27,18 @@ module Gitlab
# connect with Spamcheck # connect with Spamcheck
@endpoint_url = @endpoint_url.gsub(%r(^grpc:\/\/), '') @endpoint_url = @endpoint_url.gsub(%r(^grpc:\/\/), '')
creds = @creds =
if Rails.env.development? || Rails.env.test? if Rails.env.development? || Rails.env.test?
:this_channel_is_insecure :this_channel_is_insecure
else else
GRPC::Core::ChannelCredentials.new GRPC::Core::ChannelCredentials.new
end end
@stub = ::Spamcheck::SpamcheckService::Stub.new(@endpoint_url, creds,
interceptors: interceptors,
timeout: DEFAULT_TIMEOUT_SECS)
end end
def issue_spam?(spam_issue:, user:, context: {}) def issue_spam?(spam_issue:, user:, context: {})
issue = build_issue_protobuf(issue: spam_issue, user: user, context: context) issue = build_issue_protobuf(issue: spam_issue, user: user, context: context)
response = @stub.check_for_spam_issue(issue, response = grpc_client.check_for_spam_issue(issue,
metadata: { 'authorization' => metadata: { 'authorization' =>
Gitlab::CurrentSettings.spam_check_api_key }) Gitlab::CurrentSettings.spam_check_api_key })
verdict = convert_verdict_to_gitlab_constant(response.verdict) verdict = convert_verdict_to_gitlab_constant(response.verdict)
...@@ -102,6 +98,12 @@ module Gitlab ...@@ -102,6 +98,12 @@ module Gitlab
nanos: ar_timestamp.to_time.nsec) nanos: ar_timestamp.to_time.nsec)
end end
def grpc_client
@grpc_client ||= ::Spamcheck::SpamcheckService::Stub.new(@endpoint_url, @creds,
interceptors: interceptors,
timeout: DEFAULT_TIMEOUT_SECS)
end
def interceptors def interceptors
[Labkit::Correlation::GRPC::ClientInterceptor.instance] [Labkit::Correlation::GRPC::ClientInterceptor.instance]
end end
......
...@@ -7,7 +7,7 @@ RSpec.describe Gitlab::Spamcheck::Client do ...@@ -7,7 +7,7 @@ RSpec.describe Gitlab::Spamcheck::Client do
let(:endpoint) { 'grpc://grpc.test.url' } let(:endpoint) { 'grpc://grpc.test.url' }
let_it_be(:user) { create(:user, organization: 'GitLab') } let_it_be(:user) { create(:user, organization: 'GitLab') }
let(:verdict_value) { nil } let(:verdict_value) { ::Spamcheck::SpamVerdict::Verdict::ALLOW }
let(:error_value) { "" } let(:error_value) { "" }
let(:attribs_value) do let(:attribs_value) do
...@@ -56,6 +56,13 @@ RSpec.describe Gitlab::Spamcheck::Client do ...@@ -56,6 +56,13 @@ RSpec.describe Gitlab::Spamcheck::Client do
expect(subject).to eq([expected, { "monitorMode" => "false" }, ""]) expect(subject).to eq([expected, { "monitorMode" => "false" }, ""])
end end
end end
it 'includes interceptors' do
expect_next_instance_of(::Gitlab::Spamcheck::Client) do |client|
expect(client).to receive(:interceptors).and_call_original
end
subject
end
end end
describe "#build_issue_protobuf", :aggregate_failures do describe "#build_issue_protobuf", :aggregate_failures do
......
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