summaryrefslogtreecommitdiff
path: root/spec/requests/user_sends_malformed_strings_spec.rb
blob: 4c131bfe452fba17eb51b3b2face2654c716bb8d (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
# frozen_string_literal: true

require 'spec_helper'

RSpec.describe 'User sends malformed strings', feature_category: :user_management do
  include GitHttpHelpers

  let(:null_byte) { "\u0000" }
  let(:invalid_string) { "mal\xC0formed" }

  it 'raises a 400 error with a null byte' do
    post '/nonexistent', params: { a: "A #{null_byte} nasty string" }

    expect(response).to have_gitlab_http_status(:bad_request)
  end

  it 'raises a 400 error with an invalid string' do
    post '/nonexistent', params: { a: "A #{invalid_string} nasty string" }

    expect(response).to have_gitlab_http_status(:bad_request)
  end

  it 'raises a 400 error with null bytes in the auth headers' do
    clone_get("project/path", user: "hello#{null_byte}", password: "nothing to see")

    expect(response).to have_gitlab_http_status(:bad_request)
  end
end