Skip to content
GitLab
Explore
Sign in
Register
Primary navigation
Search or go to…
Project
B
brew
Manage
Activity
Members
Labels
Plan
Issues
Issue boards
Milestones
Wiki
Requirements
Code
Merge requests
Repository
Branches
Commits
Tags
Repository graph
Compare revisions
Snippets
Locked files
Build
Pipelines
Jobs
Pipeline schedules
Test cases
Artifacts
Deploy
Releases
Package Registry
Container Registry
Model registry
Operate
Environments
Terraform modules
Monitor
Incidents
Service Desk
Analyze
Value stream analytics
Contributor analytics
CI/CD analytics
Repository analytics
Code review analytics
Issue analytics
Insights
Model experiments
Help
Help
Support
GitLab documentation
Compare GitLab plans
Community forum
Contribute to JiHu GitLab
Provide feedback
Keyboard shortcuts
?
Snippets
Groups
Projects
Show more breadcrumbs
KMSCAKKSCFKA AKFACAMADCAS
brew
Commits
917b9f44
Commit
917b9f44
authored
8 years ago
by
Vítor Galvão
Committed by
GitHub
8 years ago
Browse files
Options
Downloads
Plain Diff
Merge pull request #1908 from reitermarkus/cleanup-cask-doctor
Simplify `brew cask doctor`.
parents
73df5045
d02a4d9e
No related branches found
Branches containing commit
No related tags found
Tags containing commit
No related merge requests found
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
Library/Homebrew/cask/lib/hbc/cli/doctor.rb
+51
-124
51 additions, 124 deletions
Library/Homebrew/cask/lib/hbc/cli/doctor.rb
Library/Homebrew/cask/spec/cask/cli/doctor_spec.rb
+1
-1
1 addition, 1 deletion
Library/Homebrew/cask/spec/cask/cli/doctor_spec.rb
with
52 additions
and
125 deletions
Library/Homebrew/cask/lib/hbc/cli/doctor.rb
+
51
−
124
View file @
917b9f44
...
...
@@ -2,116 +2,39 @@ module Hbc
class
CLI
class
Doctor
<
Base
def
self
.
run
ohai
"macOS Release:"
,
render_with_none_as_error
(
MacOS
.
full_version
)
ohai
"Hardware Architecture:"
,
render_with_none_as_error
(
"
#{
Hardware
::
CPU
.
type
}
-
#{
Hardware
::
CPU
.
bits
}
"
)
ohai
"Ruby Version:"
,
render_with_none_as_error
(
"
#{
RUBY_VERSION
}
-p
#{
RUBY_PATCHLEVEL
}
"
)
ohai
"Ruby Path:"
,
render_with_none_as_error
(
RbConfig
.
ruby
)
# TODO: consider removing most Homebrew constants from doctor output
ohai
"Homebrew Version:"
,
render_with_none_as_error
(
homebrew_version
)
ohai
"Homebrew Executable Path:"
,
render_with_none_as_error
(
HOMEBREW_BREW_FILE
)
ohai
"Homebrew Cellar Path:"
,
render_with_none_as_error
(
homebrew_cellar
)
ohai
"Homebrew Repository Path:"
,
render_with_none_as_error
(
HOMEBREW_REPOSITORY
)
ohai
"Homebrew Origin:"
,
render_with_none_as_error
(
homebrew_origin
)
ohai
"Homebrew-Cask Version:"
,
render_with_none_as_error
(
Hbc
.
full_version
)
ohai
"Homebrew-Cask Install Location:"
,
render_install_location
ohai
"Homebrew-Cask Staging Location:"
,
render_staging_location
(
Hbc
.
caskroom
)
ohai
"Homebrew-Cask Cached Downloads:"
,
render_cached_downloads
ohai
"Homebrew-Cask Default Tap Path:"
,
render_tap_paths
(
Hbc
.
default_tap
.
path
)
ohai
"Homebrew-Cask Alternate Cask Taps:"
,
render_tap_paths
(
alt_taps
)
ohai
"Homebrew-Cask Default Tap Cask Count:"
,
render_with_none_as_error
(
default_cask_count
)
ohai
"Contents of $LOAD_PATH:"
,
render_load_path
(
$LOAD_PATH
)
ohai
"Contents of $RUBYLIB Environment Variable:"
,
render_env_var
(
"RUBYLIB"
)
ohai
"Contents of $RUBYOPT Environment Variable:"
,
render_env_var
(
"RUBYOPT"
)
ohai
"Contents of $RUBYPATH Environment Variable:"
,
render_env_var
(
"RUBYPATH"
)
ohai
"Contents of $RBENV_VERSION Environment Variable:"
,
render_env_var
(
"RBENV_VERSION"
)
ohai
"Contents of $CHRUBY_VERSION Environment Variable:"
,
render_env_var
(
"CHRUBY_VERSION"
)
ohai
"Contents of $GEM_HOME Environment Variable:"
,
render_env_var
(
"GEM_HOME"
)
ohai
"Contents of $GEM_PATH Environment Variable:"
,
render_env_var
(
"GEM_PATH"
)
ohai
"Contents of $BUNDLE_PATH Environment Variable:"
,
render_env_var
(
"BUNDLE_PATH"
)
ohai
"Contents of $PATH Environment Variable:"
,
render_env_var
(
"PATH"
)
ohai
"Contents of $SHELL Environment Variable:"
,
render_env_var
(
"SHELL"
)
ohai
"Contents of Locale Environment Variables:"
,
render_with_none
(
locale_variables
)
end
def
self
.
alt_taps
Tap
.
select
{
|
t
|
t
.
cask_dir
&&
t
!=
Hbc
.
default_tap
}
.
map
(
&
:path
)
end
def
self
.
default_cask_count
Hbc
.
default_tap
.
cask_files
.
count
rescue
StandardError
"0
#{
error_string
"Error reading
#{
Hbc
.
default_tap
.
path
}
"
}
"
end
def
self
.
homebrew_origin
homebrew_origin
=
notfound_string
begin
Dir
.
chdir
(
HOMEBREW_REPOSITORY
)
do
homebrew_origin
=
SystemCommand
.
run
(
"/usr/bin/git"
,
args:
%w[config --get remote.origin.url]
,
print_stderr:
false
).
stdout
.
strip
end
if
homebrew_origin
!~
/\S/
homebrew_origin
=
"
#{
none_string
}
#{
error_string
}
"
elsif
homebrew_origin
!~
%r{(mxcl|Homebrew)/(home)?brew(
\.
git)?
\Z
}
homebrew_origin
.
concat
"
#{
error_string
"warning: nonstandard origin"
}
"
end
rescue
StandardError
homebrew_origin
=
error_string
"Not Found - Error running git"
end
homebrew_origin
end
def
self
.
homebrew_cellar
homebrew_constants
(
"cellar"
)
end
def
self
.
homebrew_version
homebrew_constants
(
"version"
)
end
def
self
.
homebrew_taps
Tap
::
TAP_DIRECTORY
end
def
self
.
homebrew_constants
(
name
)
@homebrew_constants
||=
{}
return
@homebrew_constants
[
name
]
if
@homebrew_constants
.
key?
(
name
)
@homebrew_constants
[
name
]
=
notfound_string
begin
@homebrew_constants
[
name
]
=
SystemCommand
.
run!
(
HOMEBREW_BREW_FILE
,
args:
[
"--
#{
name
}
"
],
print_stderr:
false
)
.
stdout
.
strip
if
@homebrew_constants
[
name
]
!~
/\S/
@homebrew_constants
[
name
]
=
"
#{
none_string
}
#{
error_string
}
"
end
path
=
Pathname
.
new
(
@homebrew_constants
[
name
])
@homebrew_constants
[
name
]
=
path
if
path
.
exist?
rescue
StandardError
@homebrew_constants
[
name
]
=
error_string
"Not Found - Error running brew"
end
@homebrew_constants
[
name
]
ohai
"Homebrew-Cask Version"
,
Hbc
.
full_version
ohai
"Homebrew-Cask Install Location"
,
render_install_location
ohai
"Homebrew-Cask Staging Location"
,
render_staging_location
(
Hbc
.
caskroom
)
ohai
"Homebrew-Cask Cached Downloads"
,
render_cached_downloads
ohai
"Homebrew-Cask Taps:"
puts
render_taps
(
Hbc
.
default_tap
,
*
alt_taps
)
ohai
"Contents of $LOAD_PATH"
,
render_load_path
(
$LOAD_PATH
)
ohai
"Environment Variables"
environment_variables
=
[
"RUBYLIB"
,
"RUBYOPT"
,
"RUBYPATH"
,
"RBENV_VERSION"
,
"CHRUBY_VERSION"
,
"GEM_HOME"
,
"GEM_PATH"
,
"BUNDLE_PATH"
,
"PATH"
,
"SHELL"
,
]
(
locale_variables
+
environment_variables
).
sort
.
each
(
&
method
(
:render_env_var
))
end
def
self
.
locale_variables
ENV
.
keys
.
grep
(
/^(?:LC_\S+|LANG|LANGUAGE)\Z/
).
collect
{
|
v
|
%Q(
#{
v
}
="
#{
ENV
[
v
]
}
")
}.
sort
.
join
(
"
\n
"
)
ENV
.
keys
.
grep
(
/^(?:LC_\S+|LANG|LANGUAGE)\Z/
).
sort
end
def
self
.
none_string
"<NONE>"
end
def
self
.
legacy_tap_pattern
/phinze/
end
def
self
.
notfound_string
Formatter
.
error
(
"Not Found - Unknown Error"
)
end
def
self
.
error_string
(
string
=
"Error"
)
Formatter
.
error
(
"(
#{
string
}
)"
)
end
...
...
@@ -121,37 +44,42 @@ module Hbc
none_string
end
def
self
.
render_with_none_as_error
(
string
)
return
string
if
!
string
.
nil?
&&
string
.
respond_to?
(
:to_s
)
&&
!
string
.
to_s
.
empty?
"
#{
none_string
}
#{
error_string
}
"
def
self
.
alt_taps
Tap
.
select
{
|
t
|
t
.
cask_dir
&&
t
!=
Hbc
.
default_tap
}
end
def
self
.
render_tap_paths
(
paths
)
paths
=
[
paths
]
unless
paths
.
respond_to?
(
:each
)
paths
.
collect
do
|
dir
|
if
dir
.
nil?
||
dir
.
to_s
.
empty?
def
self
.
cask_count_for_tap
(
tap
)
count
=
tap
.
cask_files
.
count
"
#{
count
}
#{
count
==
1
?
"cask"
:
"casks"
}
"
rescue
StandardError
"0
#{
error_string
"error reading
#{
tap
.
path
}
"
}
"
end
def
self
.
render_taps
(
*
taps
)
taps
.
collect
do
|
tap
|
if
tap
.
path
.
nil?
||
tap
.
path
.
to_s
.
empty?
none_string
elsif
dir
.
to_s
.
match
(
legacy_tap_pattern
)
dir
.
to_s
.
concat
(
"
#{
error_string
"Warning: legacy tap path"
}
"
)
else
dir
.
to_s
"
#{
tap
.
path
}
(
#{
cask_count_for_tap
(
tap
)
}
)"
end
end
end
def
self
.
render_env_var
(
var
)
if
ENV
.
key?
(
var
)
%Q(
#{
var
}
="
#{
ENV
[
var
]
}
")
else
none_string
end
return
unless
ENV
.
key?
(
var
)
var
=
%Q(
#{
var
}
="
#{
ENV
[
var
]
}
")
puts
user_tilde
(
var
)
end
def
self
.
user_tilde
(
path
)
path
.
gsub
(
ENV
[
"HOME"
],
"~"
)
end
# This could be done by calling into Homebrew, but the situation
# where "doctor" is needed is precisely the situation where such
# things are less dependable.
def
self
.
render_install_location
locations
=
Dir
.
glob
(
Pathname
.
new
(
homebrew_cellar
)
.
join
(
"brew-cask"
,
"*"
)).
reverse
locations
=
Dir
.
glob
(
HOMEBREW_CELLAR
.
join
(
"brew-cask"
,
"*"
)).
reverse
if
locations
.
empty?
none_string
else
...
...
@@ -162,7 +90,7 @@ module Hbc
end
def
self
.
render_staging_location
(
path
)
path
=
Pathname
.
new
(
path
)
path
=
Pathname
.
new
(
user_tilde
(
path
.
to_s
)
)
if
!
path
.
exist?
"
#{
path
}
#{
error_string
"error: path does not exist"
}
}"
elsif
!
path
.
writable?
...
...
@@ -173,19 +101,18 @@ module Hbc
end
def
self
.
render_load_path
(
paths
)
paths
.
map
(
&
method
(
:user_tilde
))
return
"
#{
none_string
}
#{
error_string
}
"
if
[
*
paths
].
empty?
paths
end
def
self
.
render_cached_downloads
cleanup
=
CLI
::
Cleanup
.
default
files
=
cleanup
.
cache_files
count
=
files
.
count
count
=
cleanup
.
cache_files
.
count
size
=
cleanup
.
disk_cleanup_size
size_msg
=
"
#{
number_readable
(
count
)
}
files,
#{
disk_usage_readable
(
size
)
}
"
warn_msg
=
error_string
(
'warning: run "brew cask cleanup"'
)
size_msg
<<
"
#{
warn_msg
}
"
if
count
>
0
[
Hbc
.
cache
,
size_msg
]
msg
=
user_tilde
(
Hbc
.
cache
.
to_s
)
msg
<<
" (
#{
number_readable
(
count
)
}
files,
#{
disk_usage_readable
(
size
)
}
)"
unless
count
.
zero?
msg
end
def
self
.
help
...
...
This diff is collapsed.
Click to expand it.
Library/Homebrew/cask/spec/cask/cli/doctor_spec.rb
+
1
−
1
View file @
917b9f44
...
...
@@ -4,7 +4,7 @@ describe Hbc::CLI::Doctor do
it
"displays some nice info about the environment"
do
expect
{
Hbc
::
CLI
::
Doctor
.
run
}.
to
output
(
/\A==>
macOS Release:
/
).
to_stdout
}.
to
output
(
/\A==>
Homebrew-Cask Version
/
).
to_stdout
end
it
"raises an exception when arguments are given"
do
...
...
This diff is collapsed.
Click to expand it.
Preview
0%
Loading
Try again
or
attach a new file
.
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Save comment
Cancel
Please
register
or
sign in
to comment