require 'spec_helper' require 'pact/configuration' describe Pact do before do Pact.clear_configuration end describe "configure" do KEY_VALUE_PAIRS = {pact_dir: 'a path', log_dir: 'a dir', logger: 'a logger'} KEY_VALUE_PAIRS.each do | key, value | it "should allow configuration of #{key}" do Pact.configure do | config | config.send("#{key}=".to_sym, value) end expect(Pact.configuration.send(key)).to eql(value) end end end describe Pact::Configuration do let(:configuration) { Pact::Configuration.new } describe "log_dir" do it "sets the location of the logs" do expect(Logger).to receive(:new).with("./tmp/logs/pact.log").and_call_original Pact.configure do | config | config.log_dir = "./tmp/logs" end Pact.configuration.logger end end describe "logger" do it "sets the location of the logs to log_dir by default" do expect(Logger).to receive(:new).with(File.expand_path("./log/pact.log")).and_call_original Pact.configuration.logger end it "defaults to DEBUG" do expect(Pact.configuration.logger.level).to eq Logger::DEBUG end end describe "doc_dir" do it "defaults to ./doc/pacts" do expect(Pact.configuration.doc_dir).to eq File.expand_path("./doc/pacts") end it "can be changed" do Pact.configuration.doc_dir = "newdir" expect(Pact.configuration.doc_dir).to eq "newdir" end end describe "doc_generator" do context "with a symbol" do it "allows configuration of a doc_generator" do Pact.configuration.doc_generator = :markdown expect(Pact.configuration.doc_generators).to eq [Pact::Doc::Markdown::Generator] end end context "with anything that responds to 'call'" do it "allows configuration of a doc_generator" do Pact.configuration.doc_generator = lambda { | pact_dir, doc_dir | "doc" } expect(Pact.configuration.doc_generators.size).to be 1 expect(Pact.configuration.doc_generators.first.call('doc','pacts')).to eq ("doc") end end context "with something that does not respond to call and doesn't have a matching doc_generator" do it "raises an error" do expect { Pact.configuration.doc_generator = Object.new }.to raise_error "Pact.configuration.doc_generator needs to respond to call, or be in the preconfigured list: [:markdown]" end end end describe "#diff_formatter_for_content_type" do let(:subject) { Pact::Configuration.new } it "returns the Pact::Matchers::UnixDiffFormatter by default" do expect(subject.diff_formatter_for_content_type 'anything').to eq(Pact::Matchers::UnixDiffFormatter) end Pact::Configuration::DIFF_FORMATTERS.each_pair do | key, diff_formatter | context "when set to :#{key}" do before do subject.diff_formatter = key end it "sets the diff_formatter to #{diff_formatter}" do expect(subject.diff_formatter_for_content_type nil).to be diff_formatter end end end context "when set to an object that responds to call" do let(:diff_formatter) { lambda{ | diff| } } before do subject.diff_formatter = diff_formatter end it "sets the diff_formatter to the object" do expect(subject.diff_formatter_for_content_type nil).to be diff_formatter end end context "when set to an object that does not respond to call and isn't a known default option" do it "raises an error" do expect { subject.diff_formatter = Object.new }.to raise_error "Pact diff_formatter needs to respond to call, or be in the preconfigured list: [:embedded, :unix, :list]" expect { subject.diff_formatter = Object.new }.to raise_error "Pact diff_formatter needs to respond to call, or be in the preconfigured list: [:embedded, :unix, :list]" end end end describe "diff_formatter_for_content_type" do let(:diff_formatter) { lambda { |expected, actual| }} context "with the default configuration" do context "when the content type is nil" do it "returns the UnixDiffFormatter" do expect(Pact.configuration.diff_formatter_for_content_type nil).to eq Pact::Matchers::UnixDiffFormatter end end context "when the content type is application/json" do it "returns the UnixDiffFormatter" do expect(Pact.configuration.diff_formatter_for_content_type nil).to eq Pact::Matchers::UnixDiffFormatter end end context "when the content type is text/plain" do it "returns the UnixDiffFormatter" do expect(Pact.configuration.diff_formatter_for_content_type nil).to eq Pact::Matchers::UnixDiffFormatter end end end context "with a custom diff_formatter registered for nil content type" do context "when the content_type is nil" do it "returns the custom diff_formatter" do Pact.configuration.register_diff_formatter nil, diff_formatter expect(Pact.configuration.diff_formatter_for_content_type nil).to eq diff_formatter end end end context "with a custom diff_formatter registered for json content type" do context "when the content_type is application/json" do it "returns the custom diff_formatter" do Pact.configuration.register_diff_formatter /json/, diff_formatter expect(Pact.configuration.diff_formatter_for_content_type 'application/json').to eq diff_formatter end end end end describe "register_body_differ" do let(:differ) { lambda{ |expected, actual| } } context "with a string for a content type" do it "configures the differ for the given content type" do Pact.configure do | config | config.register_body_differ 'application/xml', differ end expect(Pact.configuration.body_differ_for_content_type 'application/xml').to be differ end end context "with a regexp for a content type" do it "returns a matching differ" do Pact.configuration.register_body_differ /application\/.*xml/, differ expect(Pact.configuration.body_differ_for_content_type 'application/hal+xml').to be differ end end context "when a non string or regexp is used to register a differ" do it "raises an error" do expect { Pact.configuration.register_body_differ 1, differ }.to raise_error /Invalid/ end end context "when something that does not respond to call is sumbitted as a differ" do it "raises an error" do expect { Pact.configuration.register_body_differ 'thing', Object.new }.to raise_error /responds to call/ end end context "when a nil content type is registered for responses without a content type header" do it "returns that differ if the differ for a nil content type is requested" do Pact.configuration.register_body_differ nil, differ expect(Pact.configuration.body_differ_for_content_type(nil)).to be differ end end end describe "body_differ_for_content_type" do let(:differ) { lambda { |expected, actual| }} context "when 2 potentially matching content types have a differ registered" do let(:differ_1) { lambda{ |expected, actual| } } let(:differ_2) { lambda{ |expected, actual| } } it "returns the differ that was configured first" do Pact.configuration.register_body_differ /application\/.*xml/, differ_2 Pact.configuration.register_body_differ /application\/hal\+xml/, differ_1 expect(Pact.configuration.body_differ_for_content_type 'application/hal+xml').to be differ_2 end end context "when a nil content type is given" do it "returns the text differ" do expect(Pact.configuration.body_differ_for_content_type nil).to be Pact::TextDiffer end end context "when no matching content type is found" do it "returns the text differ" do expect(Pact.configuration.body_differ_for_content_type 'blah').to be Pact::TextDiffer end end context "when the nil content type has a custom differ configured" do it "returns the custom differ" do Pact.configuration.register_body_differ nil, differ expect(Pact.configuration.body_differ_for_content_type(nil)).to be differ end end context "when a custom differ is registered for a content type that has a default differ" do it "returns the custom differ" do Pact.configuration.register_body_differ /application\/json/, differ expect(Pact.configuration.body_differ_for_content_type 'application/json').to be differ end end end describe "pactfile_write_mode" do context "when @pactfile_write_mode is :overwrite" do it 'returns :overwrite' do configuration.pactfile_write_mode = :overwrite expect(configuration.pactfile_write_mode).to eq :overwrite end end context "when @pactfile_write_mode is :update" do it 'returns :overwrite' do configuration.pactfile_write_mode = :update expect(configuration.pactfile_write_mode).to eq :update end end context "when @pactfile_write_mode is :smart" do before do configuration.pactfile_write_mode = :smart expect(configuration).to receive(:is_rake_running?).and_return(is_rake_running) end context "when rake is running" do let(:is_rake_running) { true } it "returns :overwrite" do expect(configuration.pactfile_write_mode).to eq :overwrite end end context "when rake is not running" do let(:is_rake_running) { false } it "returns :update" do expect(configuration.pactfile_write_mode).to eq :update end end end end end describe "default_configuration" do it "should have a default pact_dir" do expect(Pact.configuration.pact_dir).to eql File.expand_path('./spec/pacts') end it "should have a default log_dir" do expect(Pact.configuration.log_dir).to eql File.expand_path('./log') end it "should have a default logger configured" do expect(Pact.configuration.logger).to be_instance_of Logger end end end