Options: add error class, refactor
- improve readability of specs - extract methods
This commit is contained in:
		
							parent
							
								
									70aaba9aa2
								
							
						
					
					
						commit
						c1f6fce86c
					
				| @ -2,6 +2,8 @@ | ||||
| require 'delegate' | ||||
| module GitHubChangelogGenerator | ||||
|   class Options < SimpleDelegator | ||||
|     UnsupportedOptionError = Class.new(ArgumentError) | ||||
| 
 | ||||
|     KNOWN_OPTIONS = [ | ||||
|       :add_issues_wo_labels, | ||||
|       :add_pr_wo_labels, | ||||
| @ -56,9 +58,12 @@ module GitHubChangelogGenerator | ||||
| 
 | ||||
|     def initialize(values) | ||||
|       super(values) | ||||
|       if unsupported_options.any? | ||||
|         raise ArgumentError, "Unsupported options #{unsupported_options}" | ||||
|       unsupported_options.any? && raise(UnsupportedOptionError, unsupported_options.inspect) | ||||
|     end | ||||
| 
 | ||||
|     def []=(key, val) | ||||
|       supported_option?(key) || raise(UnsupportedOptionError, key.inspect) | ||||
|       values[key] = val | ||||
|     end | ||||
| 
 | ||||
|     def to_hash | ||||
| @ -72,7 +77,15 @@ module GitHubChangelogGenerator | ||||
|     end | ||||
| 
 | ||||
|     def unsupported_options | ||||
|       values.keys - (KNOWN_OPTIONS + THESE_ARE_DIFFERENT) | ||||
|       values.keys - supported_options | ||||
|     end | ||||
| 
 | ||||
|     def supported_option?(key) | ||||
|       supported_options.include?(key) | ||||
|     end | ||||
| 
 | ||||
|     def supported_options | ||||
|       KNOWN_OPTIONS + THESE_ARE_DIFFERENT | ||||
|     end | ||||
|   end | ||||
| end | ||||
|  | ||||
| @ -1,16 +1,42 @@ | ||||
| # frozen_string_literal: true | ||||
| describe GitHubChangelogGenerator::Options do | ||||
|   it 'can be instantiated with defaults' do | ||||
|     expect(described_class.new(user: 'olle')[:user]).to eq('olle') | ||||
| RSpec.describe GitHubChangelogGenerator::Options do | ||||
|   describe "#initialize" do | ||||
|     context "with known options" do | ||||
|       it "instantiates successfully" do | ||||
|         expect(described_class.new(user: "olle")[:user]).to eq("olle") | ||||
|       end | ||||
|     end | ||||
| 
 | ||||
|   it 'disallows unknown option names' do | ||||
|     context "with unknown options" do | ||||
|       it "raises an error" do | ||||
|         expect { | ||||
|           described_class.new( | ||||
|         git_remote: 'origin', | ||||
|         strength: 'super-strength', | ||||
|         wisdom: 'deep' | ||||
|             git_remote: "origin", | ||||
|             strength: "super-strength", | ||||
|             wisdom: "deep" | ||||
|           ) | ||||
|     }.to raise_error(ArgumentError, "Unsupported options [:strength, :wisdom]") | ||||
|         }.to raise_error("[:strength, :wisdom]") | ||||
|       end | ||||
|     end | ||||
|   end | ||||
| 
 | ||||
|   describe "#[]=(key, value)" do | ||||
|     let(:options) { described_class.new(git_remote: "origin") } | ||||
| 
 | ||||
|     context "with known options" do | ||||
|       it "sets the option value" do | ||||
|         expect { | ||||
|           options[:git_remote] = "in the cloud" | ||||
|         }.to change { options[:git_remote] }.to "in the cloud" | ||||
|       end | ||||
|     end | ||||
| 
 | ||||
|     context "with unknown options" do | ||||
|       it "raises an error" do | ||||
|         expect { | ||||
|           options[:charisma] = 8 | ||||
|         }.to raise_error(":charisma") | ||||
|       end | ||||
|     end | ||||
|   end | ||||
| end | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user
	 Olle Jonsson
						Olle Jonsson