require 'spec_helper' describe Gitlab::RouteMap, lib: true do describe '#initialize' do context 'when the data is not YAML' do it 'raises an error' do expect { described_class.new('"') }. to raise_error(Gitlab::RouteMap::FormatError, /valid YAML/) end end context 'when the data is not a YAML array' do it 'raises an error' do expect { described_class.new(YAML.dump('foo')) }. to raise_error(Gitlab::RouteMap::FormatError, /an array/) end end context 'when an entry is not a hash' do it 'raises an error' do expect { described_class.new(YAML.dump(['foo'])) }. to raise_error(Gitlab::RouteMap::FormatError, /a hash/) end end context 'when an entry does not have a source key' do it 'raises an error' do expect { described_class.new(YAML.dump([{ 'public' => 'index.html' }])) }. to raise_error(Gitlab::RouteMap::FormatError, /source key/) end end context 'when an entry does not have a public key' do it 'raises an error' do expect { described_class.new(YAML.dump([{ 'source' => '/index\.html/' }])) }. to raise_error(Gitlab::RouteMap::FormatError, /public key/) end end context 'when an entry source does not start and end with a slash' do it 'raises an error' do expect { described_class.new(YAML.dump([{ 'source' => 'index.html', 'public' => 'index.html' }])) }. to raise_error(Gitlab::RouteMap::FormatError, /a slash/) end end context 'when an entry source is not a valid regex' do it 'raises an error' do expect { described_class.new(YAML.dump([{ 'source' => '/[/', 'public' => 'index.html' }])) }. to raise_error(Gitlab::RouteMap::FormatError, /regular expression/) end end context 'when all is good' do it 'returns a route map' do route_map = described_class.new(YAML.dump([{ 'source' => '/index\.html/', 'public' => 'index.html' }])) expect(route_map.map).to eq([{ source: /^index\.html$/, public: 'index.html' }]) end end end describe '#public_path_for_source_path' do subject do described_class.new(<<-'MAP'.strip_heredoc) # Blogposts - source: /source/posts/([0-9]{4})-([0-9]{2})-([0-9]{2})-(.+?)\..*/ # source/posts/2017-01-30-around-the-world-in-6-releases.html.md.erb public: '\1/\2/\3/\4/' # 2017/01/30/around-the-world-in-6-releases/ # HTML files - source: /source/(.+?\.html).*/ # source/index.html.haml public: '\1' # index.html # Other files - source: /source/(.*)/ # source/images/blogimages/around-the-world-in-6-releases-cover.png public: '\1' # images/blogimages/around-the-world-in-6-releases-cover.png MAP end it 'returns the public path for a provided source path' do expect(subject.public_path_for_source_path('source/posts/2017-01-30-around-the-world-in-6-releases.html.md.erb')).to eq('2017/01/30/around-the-world-in-6-releases/') expect(subject.public_path_for_source_path('source/index.html.haml')).to eq('index.html') expect(subject.public_path_for_source_path('source/images/blogimages/around-the-world-in-6-releases-cover.png')).to eq('images/blogimages/around-the-world-in-6-releases-cover.png') expect(subject.public_path_for_source_path('.gitlab/route-map.yml')).to be_nil end end end