require_relative '../spec_helper' require_relative '../../lib/puppet-check/cli' describe PuppetCheck::CLI do context '.run' do it 'raises an error if no paths were specified' do expect { PuppetCheck::CLI.run(%w[-s -f]) }.to raise_error(RuntimeError, 'puppet-check: no paths specified; try using --help') end end context '.parse' do it 'raises an error if an invalid option was specified' do expect { PuppetCheck::CLI.parse(%w[-s -f -asdf foo]) }.to raise_error(OptionParser::InvalidOption) end it 'allows future parser, fail on warnings, style, smoke, and regression checks to be enabled' do PuppetCheck.settings[:future_parser] = false PuppetCheck.settings[:fail_on_warnings] = false PuppetCheck.settings[:style_check] = false PuppetCheck.settings[:smoke_check] = false PuppetCheck.settings[:regression_check] = false PuppetCheck::CLI.parse(%w[-f --fail-on-warnings -s -r --smoke foo]) expect(PuppetCheck.settings[:future_parser]).to eql(true) expect(PuppetCheck.settings[:fail_on_warnings]).to eql(true) expect(PuppetCheck.settings[:style_check]).to eql(true) expect(PuppetCheck.settings[:smoke_check]).to eql(true) expect(PuppetCheck.settings[:regression_check]).to eql(true) end it 'correctly parses a formatting option' do PuppetCheck.settings[:output_format] = '' PuppetCheck::CLI.parse(%w[-o text]) expect(PuppetCheck.settings[:output_format]).to eql('text') end it 'correctly parses octocatalog-diff options' do PuppetCheck.settings[:octoconfig] = '' PuppetCheck.settings[:octonodes] = [] PuppetCheck::CLI.parse(%w[--octoconfig config.cfg.rb --octonodes server1,server2]) expect(PuppetCheck.settings[:octoconfig]).to eql('config.cfg.rb') expect(PuppetCheck.settings[:octonodes]).to eql(%w[server1 server2]) end it 'correctly parses PuppetLint arguments' do PuppetCheck.settings[:puppetlint_args] = [] PuppetCheck::CLI.parse(%w[--puppet-lint puppetlint-arg-one,puppetlint-arg-two foo]) expect(PuppetCheck.settings[:puppetlint_args]).to eql(['--puppetlint-arg-one', '--puppetlint-arg-two']) end it 'correctly loads a .puppet-lint.rc' do PuppetCheck.settings[:puppetlint_args] = [] PuppetCheck::CLI.parse(%W[-c #{fixtures_dir}/manifests/.puppet-lint.rc]) expect(PuppetCheck.settings[:puppetlint_args]).to eql(['--puppetlint-arg-one', '--puppetlint-arg-two']) end it 'correctly parses Rubocop arguments' do PuppetCheck.settings[:rubocop_args] = [] PuppetCheck::CLI.parse(%w[--rubocop rubocop-arg-one,rubocop-arg-two foo]) expect(PuppetCheck.settings[:rubocop_args]).to eql(['--except', 'rubocop-arg-one,rubocop-arg-two']) end it 'correctly parses multiple sets of arguments' do PuppetCheck.settings[:future_parser] = false PuppetCheck.settings[:style_check] = false PuppetCheck.settings[:puppetlint_args] = [] PuppetCheck.settings[:rubocop_args] = [] PuppetCheck::CLI.parse(%w[-s -f --puppet-lint puppetlint-arg-one,puppetlint-arg-two --rubocop rubocop-arg-one,rubocop-arg-two foo]) expect(PuppetCheck.settings[:future_parser]).to eql(true) expect(PuppetCheck.settings[:style_check]).to eql(true) expect(PuppetCheck.settings[:puppetlint_args]).to eql(['--puppetlint-arg-one', '--puppetlint-arg-two']) expect(PuppetCheck.settings[:rubocop_args]).to eql(['--except', 'rubocop-arg-one,rubocop-arg-two']) end end end