github-changelog-generator/spec/unit/parse_file_spec.rb

75 lines
2.8 KiB
Ruby
Raw Permalink Normal View History

# frozen_string_literal: true
2015-09-15 18:38:41 +00:00
describe GitHubChangelogGenerator::ParserFile do
describe ".github_changelog_generator" do
2016-03-19 15:54:13 +00:00
let(:options) { {} }
context "when the well-known default file does not exist" do
2016-03-19 14:22:45 +00:00
let(:parser) { GitHubChangelogGenerator::ParserFile.new(options) }
subject { parser.parse! }
2015-09-15 18:38:41 +00:00
it { is_expected.to be_nil }
end
context "when file is empty" do
2016-03-19 14:22:45 +00:00
let(:parser) { GitHubChangelogGenerator::ParserFile.new(options, StringIO.new("")) }
it "does not change the options" do
2016-03-19 14:22:45 +00:00
expect { parser.parse! }.to_not change { options }
end
2015-09-15 18:38:41 +00:00
end
context "when file is incorrect" do
let(:options_before_change) { options.dup }
2016-03-19 14:20:48 +00:00
let(:file) { StringIO.new("unreleased_label=staging\nunreleased: false") }
2016-03-19 14:22:45 +00:00
let(:parser) do
GitHubChangelogGenerator::ParserFile.new(options, file)
end
2016-03-19 14:22:45 +00:00
it { expect { parser.parse! }.to raise_error(/line #2/) }
2015-09-15 18:38:41 +00:00
end
context "allows empty lines and comments with semi-colon or pound sign" do
let(:file) { StringIO.new("\n \n# Comment on first line\nunreleased_label=staging\n; Comment on third line\nunreleased=false") }
let(:parser) do
2016-03-19 15:54:13 +00:00
GitHubChangelogGenerator::ParserFile.new(options, file)
end
it { expect { parser.parse! }.not_to raise_error }
end
2015-09-15 18:38:41 +00:00
context "when override default values" do
let(:default_options) { GitHubChangelogGenerator::Parser.default_options }
let(:options) { {}.merge(default_options) }
let(:options_before_change) { options.dup }
let(:file) { StringIO.new("unreleased_label=staging\nunreleased=false\nheader==== Changelog ===") }
2016-03-19 14:22:45 +00:00
let(:parser) { GitHubChangelogGenerator::ParserFile.new(options, file) }
it "changes the options" do
2016-03-19 14:22:45 +00:00
expect { parser.parse! }.to change { options }
.from(options_before_change)
.to(options_before_change.merge(unreleased_label: "staging",
unreleased: false,
header: "=== Changelog ==="))
end
2016-02-23 21:24:10 +00:00
context "turns exclude-labels into an Array", bug: "#327" do
let(:file) do
StringIO.new(<<EOF
exclude-labels=73a91042-da6f-11e5-9335-1040f38d7f90,7adf83b4-da6f-11e5-ae18-1040f38d7f90
header_label=# My changelog
EOF
)
2016-02-24 13:02:56 +00:00
end
2016-02-23 21:24:10 +00:00
it "reads exclude_labels into an Array" do
2016-03-19 14:22:45 +00:00
expect { parser.parse! }.to change { options[:exclude_labels] }
.from(default_options[:exclude_labels])
2016-02-24 13:02:56 +00:00
.to(["73a91042-da6f-11e5-9335-1040f38d7f90", "7adf83b4-da6f-11e5-ae18-1040f38d7f90"])
2016-02-23 21:24:10 +00:00
end
2016-03-17 20:38:28 +00:00
it "translates given header_label into the :header option" do
2016-03-19 14:22:45 +00:00
expect { parser.parse! }.to change { options[:header] }
.from(default_options[:header])
2016-03-17 20:38:28 +00:00
.to("# My changelog")
end
2016-02-23 21:24:10 +00:00
end
2015-09-15 18:38:41 +00:00
end
end
end