summaryrefslogtreecommitdiff
path: root/spec/lib/gitlab/ci/parsers/sbom/source/dependency_scanning_spec.rb
blob: 7222ebc3cb8d938512e7d005999c043a1ffc1c33 (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
# frozen_string_literal: true

require 'fast_spec_helper'

RSpec.describe Gitlab::Ci::Parsers::Sbom::Source::DependencyScanning do
  subject { described_class.source(property_data) }

  context 'when all property data is present' do
    let(:property_data) do
      {
        'category' => 'development',
        'input_file' => { 'path' => 'package-lock.json' },
        'source_file' => { 'path' => 'package.json' },
        'package_manager' => { 'name' => 'npm' },
        'language' => { 'name' => 'JavaScript' }
      }
    end

    it 'returns expected source data' do
      is_expected.to have_attributes(
        source_type: :dependency_scanning,
        data: property_data,
        fingerprint: '4dbcb747e6f0fb3ed4f48d96b777f1d64acdf43e459fdfefad404e55c004a188'
      )
    end
  end

  context 'when required properties are missing' do
    let(:property_data) do
      {
        'category' => 'development',
        'source_file' => { 'path' => 'package.json' },
        'package_manager' => { 'name' => 'npm' },
        'language' => { 'name' => 'JavaScript' }
      }
    end

    it { is_expected.to be_nil }
  end
end