diff options
author | Rémy Coutable <remy@rymai.me> | 2016-11-02 13:25:47 +0000 |
---|---|---|
committer | Rémy Coutable <remy@rymai.me> | 2016-11-02 13:25:47 +0000 |
commit | daca93c4b1b7163f3104397ea666865815232dba (patch) | |
tree | 072d021e25e84d6f10ddb3b968c31f51051a03a1 /spec | |
parent | 65b4f17bff971f5f0a4107ad7fe47b54f310d894 (diff) | |
parent | 5acb3230efce11148c55dce9a53cd2a85e7d120a (diff) | |
download | gitlab-ce-daca93c4b1b7163f3104397ea666865815232dba.tar.gz |
Merge branch 'rs-bin-changelog' into 'master'
Add a bin/changelog script and changelog documentation
See merge request !7098
Diffstat (limited to 'spec')
-rw-r--r-- | spec/bin/changelog_spec.rb | 65 |
1 files changed, 65 insertions, 0 deletions
diff --git a/spec/bin/changelog_spec.rb b/spec/bin/changelog_spec.rb new file mode 100644 index 00000000000..da167dc570f --- /dev/null +++ b/spec/bin/changelog_spec.rb @@ -0,0 +1,65 @@ +require 'spec_helper' + +load File.expand_path('../../bin/changelog', __dir__) + +describe 'bin/changelog' do + describe ChangelogOptionParser do + it 'parses --ammend' do + options = described_class.parse(%w[foo bar --amend]) + + expect(options.amend).to eq true + end + + it 'parses --merge-request' do + options = described_class.parse(%w[foo --merge-request 1234 bar]) + + expect(options.merge_request).to eq 1234 + end + + it 'parses -m' do + options = described_class.parse(%w[foo -m 4321 bar]) + + expect(options.merge_request).to eq 4321 + end + + it 'parses --dry-run' do + options = described_class.parse(%w[foo --dry-run bar]) + + expect(options.dry_run).to eq true + end + + it 'parses -n' do + options = described_class.parse(%w[foo -n bar]) + + expect(options.dry_run).to eq true + end + + it 'parses --git-username' do + allow(described_class).to receive(:git_user_name).and_return('Jane Doe') + options = described_class.parse(%w[foo --git-username bar]) + + expect(options.author).to eq 'Jane Doe' + end + + it 'parses -u' do + allow(described_class).to receive(:git_user_name).and_return('John Smith') + options = described_class.parse(%w[foo -u bar]) + + expect(options.author).to eq 'John Smith' + end + + it 'parses -h' do + expect do + $stdout = StringIO.new + + described_class.parse(%w[foo -h bar]) + end.to raise_error(SystemExit) + end + + it 'assigns title' do + options = described_class.parse(%W[foo -m 1 bar\n -u baz\r\n --amend]) + + expect(options.title).to eq 'foo bar baz' + end + end +end |