diff options
| author | Markus Reiter | 2016-10-15 18:51:11 +0200 |
|---|---|---|
| committer | GitHub | 2016-10-15 18:51:11 +0200 |
| commit | c233cacaf283a42940bdf3f607d82dab07d746a4 (patch) | |
| tree | 2c27248754a6c2b234adc7faae70e28c67ca0d17 /Library/Homebrew/cask/spec | |
| parent | 527a62b64bd8c578af08540166a8b1fd5bce521f (diff) | |
| parent | 581a1245bf2c038a2f35fb10445592c7655108e3 (diff) | |
| download | brew-c233cacaf283a42940bdf3f607d82dab07d746a4.tar.bz2 | |
Merge pull request #1208 from reitermarkus/puts-columns
Refactor `puts_columns` to allow `$stderr.puts_columns`.
Diffstat (limited to 'Library/Homebrew/cask/spec')
| -rw-r--r-- | Library/Homebrew/cask/spec/formatter_spec.rb | 56 |
1 files changed, 56 insertions, 0 deletions
diff --git a/Library/Homebrew/cask/spec/formatter_spec.rb b/Library/Homebrew/cask/spec/formatter_spec.rb new file mode 100644 index 000000000..7e143d933 --- /dev/null +++ b/Library/Homebrew/cask/spec/formatter_spec.rb @@ -0,0 +1,56 @@ +require "spec_helper" +require "utils/formatter" +require "utils/tty" + +describe Formatter do + describe "::columns" do + let(:input) { + [ + 'aa', + 'bbb', + 'ccc', + 'dd' + ] + } + subject { described_class.columns(input) } + + it "doesn't output columns if $stdout is not a TTY." do + allow_any_instance_of(IO).to receive(:tty?).and_return(false) + allow(Tty).to receive(:width).and_return(10) + + expect(subject).to eq( + "aa\n" \ + "bbb\n" \ + "ccc\n" \ + "dd\n" + ) + end + + describe "$stdout is a TTY" do + it "outputs columns" do + allow_any_instance_of(IO).to receive(:tty?).and_return(true) + allow(Tty).to receive(:width).and_return(10) + + expect(subject).to eq( + "aa ccc\n" \ + "bbb dd\n" + ) + end + + it "outputs only one line if everything fits" do + allow_any_instance_of(IO).to receive(:tty?).and_return(true) + allow(Tty).to receive(:width).and_return(20) + + expect(subject).to eq( + "aa bbb ccc dd\n" + ) + end + end + + describe "with empty input" do + let(:input) { [] } + + it { is_expected.to eq("\n") } + end + end +end |
