summaryrefslogtreecommitdiff
path: root/spec/lib/api/validations/validators/git_ref_spec.rb
blob: 0d2d9e8f39a6a6baaa4e627d76536b29017f45bf (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
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
# frozen_string_literal: true

require 'spec_helper'

RSpec.describe API::Validations::Validators::GitRef do
  include ApiValidatorsHelpers

  subject do
    described_class.new(['test'], {}, false, scope.new)
  end

  context 'valid revision param' do
    it 'does not raise a validation error' do
      expect_no_validation_error('test' => '4e963fe')
      expect_no_validation_error('test' => 'foo/bar/baz')
      expect_no_validation_error('test' => "heads/fu\303\237")
      expect_no_validation_error('test' => 'a' * 1024)
    end
  end

  context "revision param contains invalid chars" do
    it 'raises a validation error' do
      expect_validation_error('test' => '-4e963fe')
      expect_validation_error('test' => '4e963fe..ed4ef')
      expect_validation_error('test' => '4e96\3fe')
      expect_validation_error('test' => '4e96@3fe')
      expect_validation_error('test' => '4e9@{63fe')
      expect_validation_error('test' => '4e963 fe')
      expect_validation_error('test' => '4e96~3fe')
      expect_validation_error('test' => '^4e963fe')
      expect_validation_error('test' => '4:e963fe')
      expect_validation_error('test' => '4e963fe.')
      expect_validation_error('test' => 'heads/foo..bar')
      expect_validation_error('test' => 'foo/bar/.')
      expect_validation_error('test' => 'heads/v@{ation')
      expect_validation_error('test' => 'refs/heads/foo.')
      expect_validation_error('test' => 'heads/foo\bar')
      expect_validation_error('test' => 'heads/f[/bar')
      expect_validation_error('test' => "heads/foo\t")
      expect_validation_error('test' => "heads/foo\177")
      expect_validation_error('test' => "#{'a' * 1025}")
      expect_validation_error('test' => nil)
      expect_validation_error('test' => '')
    end
  end
end