# frozen_string_literal: true require 'spec_helper' RSpec.describe Packages::Go::Module, type: :model do before do stub_feature_flags(go_proxy_disable_gomod_validation: false) end describe '#path_valid?' do context 'with root path' do let_it_be(:package) { create(:go_module) } context 'with major version 0' do it('returns true') { expect(package.path_valid?(0)).to eq(true) } end context 'with major version 1' do it('returns true') { expect(package.path_valid?(1)).to eq(true) } end context 'with major version 2' do it('returns false') { expect(package.path_valid?(2)).to eq(false) } end end context 'with path ./v2' do let_it_be(:package) { create(:go_module, path: '/v2') } context 'with major version 0' do it('returns false') { expect(package.path_valid?(0)).to eq(false) } end context 'with major version 1' do it('returns false') { expect(package.path_valid?(1)).to eq(false) } end context 'with major version 2' do it('returns true') { expect(package.path_valid?(2)).to eq(true) } end end end describe '#gomod_valid?' do let_it_be(:package) { create(:go_module) } context 'with good gomod' do it('returns true') { expect(package.gomod_valid?("module #{package.name}")).to eq(true) } end context 'with bad gomod' do it('returns false') { expect(package.gomod_valid?("module #{package.name}/v2")).to eq(false) } end context 'with empty gomod' do it('returns false') { expect(package.gomod_valid?("")).to eq(false) } end end end