File: user_sends_malformed_strings_spec.rb

package info (click to toggle)
gitlab 17.6.5-19
  • links: PTS, VCS
  • area: main
  • in suites: sid
  • size: 629,368 kB
  • sloc: ruby: 1,915,304; javascript: 557,307; sql: 60,639; xml: 6,509; sh: 4,567; makefile: 1,239; python: 406
file content (28 lines) | stat: -rw-r--r-- 846 bytes parent folder | download
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