
- It was suggested in https://github.com/Homebrew/brew/issues/ 16733 that `brew desc <formula_or_cask>` should work like `brew info <formula_or_cask>` and print the description of the package without needing `--eval-all`. - Looking at the code, it seems like it's only searching that needs `--eval-all`, so limit the check to that. Before: ```shell $ brew desc hello Error: `brew desc` needs `--eval-all` passed or `HOMEBREW_EVAL_ALL` set! ``` After: ```shell $ brew desc hello hello: Program providing model for GNU coding standards and practices $ brew desc --search hello Error: Invalid usage: `brew desc --search` needs `--eval-all` passed or `HOMEBREW_EVAL_ALL` set! $ brew desc --search --eval-all hello ==> Formulae dsh: Dancer's shell, or distributed shell hello: Program providing model for GNU coding standards and practices ```
34 lines
987 B
Ruby
34 lines
987 B
Ruby
# frozen_string_literal: true
|
|
|
|
require "cmd/desc"
|
|
require "cmd/shared_examples/args_parse"
|
|
|
|
RSpec.describe Homebrew::Cmd::Desc do
|
|
it_behaves_like "parseable arguments"
|
|
|
|
it "shows a given Formula's description", :integration_test do
|
|
setup_test_formula "testball"
|
|
|
|
expect { brew "desc", "testball" }
|
|
.to output("testball: Some test\n").to_stdout
|
|
.and not_to_output.to_stderr
|
|
.and be_a_success
|
|
end
|
|
|
|
it "errors when searching without --eval-all", :integration_test do
|
|
setup_test_formula "testball"
|
|
|
|
expect { brew "desc", "--search", "testball" }
|
|
.to output(/`brew desc --search` needs `--eval-all` passed or `HOMEBREW_EVAL_ALL` set!/).to_stderr
|
|
.and be_a_failure
|
|
end
|
|
|
|
it "successfully searches with --search --eval-all", :integration_test do
|
|
setup_test_formula "testball"
|
|
|
|
expect { brew "desc", "--search", "--eval-all", "ball" }
|
|
.to output(/testball: Some test/).to_stdout
|
|
.and not_to_output.to_stderr
|
|
end
|
|
end
|