From 5daf3cef6e6baab3ee557b0ef864984a4d413796 Mon Sep 17 00:00:00 2001 From: mmeest Date: Mon, 28 Jul 2025 11:07:19 +0300 Subject: [PATCH 1/2] initial --- .../repp/v1/certificates/p12_test.rb | 55 +++++++++++++++++++ 1 file changed, 55 insertions(+) create mode 100644 test/integration/repp/v1/certificates/p12_test.rb diff --git a/test/integration/repp/v1/certificates/p12_test.rb b/test/integration/repp/v1/certificates/p12_test.rb new file mode 100644 index 000000000..8f0e63d34 --- /dev/null +++ b/test/integration/repp/v1/certificates/p12_test.rb @@ -0,0 +1,55 @@ +require 'test_helper' + +class ReppV1CertificatesP12Test < ActionDispatch::IntegrationTest + include ActiveJob::TestHelper + + def setup + @user = users(:api_bestnames) + token = Base64.encode64("#{@user.username}:#{@user.plain_text_password}") + @auth_headers = { 'Authorization' => "Basic #{token}" } + + adapter = ENV['shunter_default_adapter'].constantize.new + adapter&.clear! + end + + def test_enqueues_p12_generation_job_and_returns_success + assert_enqueued_with(job: P12GeneratorJob, args: [@user.id.to_s]) do + post p12_repp_v1_certificates_path, headers: @auth_headers, + params: { p12: { api_user_id: @user.id } } + end + + json = JSON.parse(response.body, symbolize_names: true) + + assert_response :ok + assert_equal 1000, json[:code] + assert_equal 'P12 certificate generation started. Please refresh the page in a few seconds.', + json[:message] + end + + def test_returns_parameter_missing_when_p12_param_absent + post p12_repp_v1_certificates_path, headers: @auth_headers, params: {} + json = JSON.parse(response.body, symbolize_names: true) + + assert_response :bad_request + assert_equal 2003, json[:code] + end + + def test_returns_error_response_if_throttled + ENV['shunter_default_threshold'] = '1' + ENV['shunter_enabled'] = 'true' + + post p12_repp_v1_certificates_path, headers: @auth_headers, + params: { p12: { api_user_id: @user.id } } + post p12_repp_v1_certificates_path, headers: @auth_headers, + params: { p12: { api_user_id: @user.id } } + + json = JSON.parse(response.body, symbolize_names: true) + + assert_response :bad_request + assert_equal 2502, json[:code] + assert response.body.include?(Shunter.default_error_message) + ensure + ENV['shunter_default_threshold'] = '10000' + ENV['shunter_enabled'] = 'false' + end +end \ No newline at end of file From 793407d3e4551e82d3bb11fabde4bbae5a58df71 Mon Sep 17 00:00:00 2001 From: mmeest Date: Mon, 28 Jul 2025 11:13:07 +0300 Subject: [PATCH 2/2] added extra line --- test/integration/repp/v1/certificates/p12_test.rb | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/test/integration/repp/v1/certificates/p12_test.rb b/test/integration/repp/v1/certificates/p12_test.rb index 8f0e63d34..e04d37e40 100644 --- a/test/integration/repp/v1/certificates/p12_test.rb +++ b/test/integration/repp/v1/certificates/p12_test.rb @@ -52,4 +52,4 @@ class ReppV1CertificatesP12Test < ActionDispatch::IntegrationTest ENV['shunter_default_threshold'] = '10000' ENV['shunter_enabled'] = 'false' end -end \ No newline at end of file +end