load test
Find a file
doaortu 83322104b7
feat: add web flag for codespace list & create subcommand (#7288)
* feat: add web flag to cs list subcommand

web flag only works with repo flag, because,
currently there only param for listing with repo_id

* feat: add web flag to cs crate subcommand

web flag used for creating codespace through web UI instead of terminal.
web flag cannot be used with display-name, idle-timeout,
or retention retention-period
because there's no option for that in the Web UI

* refactor: extract mutual excusive logic to PreRunE

- changed web flag mutual exclusive logic, using cmdutil
- extract that logic to PreRunE clause in createCmd
- move web flag up to make it close to PreRunE clause (for clarity)
- add new param to newCreateCmd fn to facilitate test logic
- apply new newCreateCmd fn to root.go

* fix: clarify flag desc and error message

- remove 'yet' from error messages that can cause misunderstanding
- clarify list web flag can only be used with repo flag

* fix: skip machine check when we use web flag ...
(..and no machine flag provided)

+ add test for this new case
+ adjust related test cases for this new change.

* refactor: move flag check logic to PreRunE

why: err on PreRunE or RunE will also print help if error happened

+ move web, repo, org, user mutual exclusive logic to PreRunE clause
+ move repo, org, user mutual exclusive logic to PreRunE
+ move limit check flag to PreRunE
+ modify newListCmd fn to facilitate test logic
+ apply new newListCmd to root.go
+ add test cases to check PreRunE clause
- remove mutual exclusive test cases from Test_AppList

* refactor: remove the opts equality checks

* fix: mutually exclusive misfires
because of wrong logic

+ refine test case too

* cleanup:removing useWeb check in fn getMachineName

because it's no longer needed

+ remove redundant test-case

* refactor: remove redundant ifs

* refactor: clarify test name

* re-clarify web flag desc in list.go

* refactor: break long lines, use more idiomatic err

* add test case for nonexistent/wrong machine
2023-04-13 10:37:16 -05:00
.devcontainer Update to Go 1.19 2022-12-12 15:50:13 +01:00
.github Replace deprecated command with environment file 2023-03-19 00:19:02 +09:00
api Only replace control sequences (#7168) 2023-03-15 08:24:20 +11:00
build/windows Resolve PR feedback 2021-09-18 09:23:43 -07:00
cmd Disallow update checker delaying the gh process (#6978) 2023-02-07 19:52:53 +00:00
context Fix set-default interactive not showing all remotes (#6969) 2023-02-07 23:11:38 +00:00
docs Improve Amazon Linux install instructions 2023-03-30 11:30:12 +02:00
git Autocomplete branch flags (#6031) 2023-03-29 16:09:44 +00:00
internal Properly handle closing files that have been writen to (#7199) 2023-03-23 01:17:47 +00:00
pkg feat: add web flag for codespace list & create subcommand (#7288) 2023-04-13 10:37:16 -05:00
script Remove pubkey as it is no longer necessary (#6208) 2022-09-06 14:31:24 +00:00
test Pass web browser to each individual command 2021-03-19 21:22:37 +01:00
utils Merge remote-tracking branch 'origin' into go-gh-term 2022-10-24 17:07:24 +02:00
.gitattributes Retire copy-release-to-another-repo action 2020-01-29 16:13:07 +01:00
.gitignore Port select portions of Makefile to script/build.go 2021-01-08 22:35:57 +01:00
.golangci.yml Re-enable linters now that golangci-lint has been updated (#5615) 2022-05-11 16:57:57 +02:00
.goreleaser.yml Enable darwin arm64 builds in goreleaser (#4435) 2023-02-17 15:24:51 +01:00
CODEOWNERS Fix CODEOWNERS for codespaces 2021-11-15 20:05:54 +01:00
go.mod Bump github.com/mattn/go-isatty from 0.0.17 to 0.0.18 (#7217) 2023-03-23 07:53:21 +11:00
go.sum Bump github.com/mattn/go-isatty from 0.0.17 to 0.0.18 (#7217) 2023-03-23 07:53:21 +11:00
LICENSE Create LICENSE 2019-11-21 13:22:23 -06:00
Makefile Tweak build scripts to enable cross-compiling 2021-04-09 15:48:12 +02:00
README.md Fix typo in README.md 2023-03-29 17:36:40 +01:00

GitHub CLI

gh is GitHub on the command line. It brings pull requests, issues, and other GitHub concepts to the terminal next to where you are already working with git and your code.

screenshot of gh pr status

GitHub CLI is available for repositories hosted on GitHub.com and GitHub Enterprise Server 2.20+, and to install on macOS, Windows, and Linux.

Documentation

For installation options see below, for usage instructions see the manual.

Contributing

If anything feels off, or if you feel that some functionality is missing, please check out the contributing page. There you will find instructions for sharing your feedback, building the tool locally, and submitting pull requests to the project.

If you are a hubber and are interested in shipping new commands for the CLI, check out our doc on internal contributions.

Installation

macOS

gh is available via Homebrew, MacPorts, Conda, Spack, and as a downloadable binary from the releases page.

Homebrew

Install: Upgrade:
brew install gh brew upgrade gh

MacPorts

Install: Upgrade:
sudo port install gh sudo port selfupdate && sudo port upgrade gh

Conda

Install: Upgrade:
conda install gh --channel conda-forge conda update gh --channel conda-forge

Additional Conda installation options available on the gh-feedstock page.

Spack

Install: Upgrade:
spack install gh spack uninstall gh && spack install gh

Linux & BSD

gh is available via:

For more information, see Linux & BSD installation.

Windows

gh is available via WinGet, scoop, Chocolatey, Conda, and as downloadable MSI.

WinGet

Install: Upgrade:
winget install --id GitHub.cli winget upgrade --id GitHub.cli

Note


The Windows installer modifies your PATH. When using Windows Terminal, you will need to open a new window for the changes to take affect. (Simply opening a new tab will not be sufficient.)

scoop

Install: Upgrade:
scoop install gh scoop update gh

Chocolatey

Install: Upgrade:
choco install gh choco upgrade gh

Signed MSI

MSI installers are available for download on the releases page.

Codespaces

To add GitHub CLI to your codespace, add the following to your devcontainer file:

"features": {
  "ghcr.io/devcontainers/features/github-cli:1": {}
}

GitHub Actions

GitHub CLI comes pre-installed in all GitHub-Hosted Runners.

Other platforms

Download packaged binaries from the releases page.

Build from source

See here on how to build GitHub CLI from source.

Comparison with hub

For many years, hub was the unofficial GitHub CLI tool. gh is a new project that helps us explore what an official GitHub CLI tool can look like with a fundamentally different design. While both tools bring GitHub to the terminal, hub behaves as a proxy to git, and gh is a standalone tool. Check out our more detailed explanation to learn more.