diff --git a/.gitlab-ci.yml b/.gitlab-ci.yml index 894e693305bc60dc0dc15598dfe68c761081fd1d..41ff50e6c0d23c993ebf0374a48b4cc4116645c5 100644 --- a/.gitlab-ci.yml +++ b/.gitlab-ci.yml @@ -8,213 +8,27 @@ workflow: - if: $CI_COMMIT_TAG - if: $CI_COMMIT_BRANCH == $CI_DEFAULT_BRANCH -default: - image: golang:${GO_VERSION} - stages: - documentation - test - release include: - # remove the `.latest` from the following templates after 16.0 GitLab release - # the `.latest` indicates the "nightly" version of the job definition - # when we remove the `.latest`, we'll be using the stable job definition - # https://gitlab.com/gitlab-org/cli/-/merge_requests/1100#note_1186302003 - - template: Jobs/SAST.latest.gitlab-ci.yml - - template: Jobs/Dependency-Scanning.latest.gitlab-ci.yml - - template: Jobs/Secret-Detection.latest.gitlab-ci.yml - - template: Jobs/License-Scanning.latest.gitlab-ci.yml - project: 'gitlab-org/quality/pipeline-common' file: '/ci/danger-review.yml' # danger-review job below - -# From: https://docs.gitlab.com/ee/ci/caching/#cache-go-dependencies -.go-cache: +danger-review: variables: - GOPATH: $CI_PROJECT_DIR/.go - GOLANGCI_LINT_CACHE: $CI_PROJECT_DIR/.golangci-lint - before_script: - - mkdir -p .go .golangci-lint - cache: - paths: - - .go/pkg/mod/ - - .golangci-lint/ - -.documentation: - stage: documentation - rules: - - if: $CI_PIPELINE_SOURCE == "merge_request_event" - -check_docs_update: - extends: .documentation - script: - - git fetch origin $CI_MERGE_REQUEST_TARGET_BRANCH_NAME && git checkout $CI_MERGE_REQUEST_TARGET_BRANCH_NAME && git checkout $CI_COMMIT_SHA - - make gen-docs - - |- - git status - if [[ $(git add -A --dry-run) ]]; then - echo '✖ ERROR: Documentation changes detected!'; - echo '✖ These changes require a documentation update. To regenerate the docs, read https://gitlab.com/gitlab-org/cli/-/tree/main/docs#generating-the-docs.'; - exit 1; - else - echo '✔ No documentation updates detected.'; - exit 0; - fi - -check_docs_markdown: - image: registry.gitlab.com/gitlab-org/gitlab-docs/lint-markdown:alpine-3.16-vale-2.20.1-markdownlint-0.32.2 - extends: .documentation - script: - # Lint prose - - vale --minAlertLevel error docs README.md - # Lint Markdown - - markdownlint --config .markdownlint.yml 'docs/**/*.md' README.md - -lint_commit: - stage: test - image: node:16-slim - script: - - apt-get update && apt-get install -y git - - git fetch origin $CI_MERGE_REQUEST_TARGET_BRANCH_NAME && git checkout $CI_MERGE_REQUEST_TARGET_BRANCH_NAME && git checkout $CI_COMMIT_SHA - - cd scripts/commit-lint && npm ci - - node lint.js - rules: - - if: '$CI_MERGE_REQUEST_IID && $CI_PROJECT_VISIBILITY == "public"' # lint.js script makes an API call without authentication - when: always - -lint: - extends: .go-cache - image: registry.gitlab.com/gitlab-org/gitlab-build-images:golangci-lint-1.50-alpine - stage: test - script: - - golangci-lint --version - # Use default .golangci.yml file from the image if one is not present in the project root. - - '[ -e .golangci.yml ] || cp /golangci/.golangci.yml .' - # Write the code coverage report to gl-code-quality-report.json - # remove `--issues-exit-code 0` or set to non-zero to fail the job if linting issues are detected - - golangci-lint run --out-format colored-line-number:stdout,code-climate:gl-code-quality-report.json - artifacts: - reports: - codequality: gl-code-quality-report.json - paths: - - gl-code-quality-report.json - -code_navigation: - stage: test - image: golang:latest - allow_failure: true - script: - - go install github.com/sourcegraph/lsif-go/cmd/lsif-go@latest - - lsif-go - artifacts: - reports: - lsif: dump.lsif - -run_tests: - stage: test - extends: .go-cache - parallel: - matrix: - - GO_VERSION: ["1.19", "1.20"] - script: - # `goreleaser` also uses GITLAB_TOKEN and so we need to distinguish between - # the GITLAB_TOKEN_TEST with less privilege used for testing and the GITLAB_TOKEN_RELEASE token - # GITLAB_TEST_HOST is the GitLab instance used for the integration tests - - GITLAB_TOKEN=$GITLAB_TOKEN_TEST GITLAB_TEST_HOST=$GITLAB_TEST_HOST make test + CI_DEBUG_TRACE: "true" after_script: - - echo -e "\e[0Ksection_start:`date +%s`:coverage[collapsed=true]\r\e[0KRunning coverage report" - - make coverage - - echo -e "\e[0Ksection_end:`date +%s`:coverage\r\e[0K" - coverage: /^total:\t+\(statements\)\t+\d+\.\d+%$/ - artifacts: - when: always - paths: - - test-output.log - reports: - junit: coverage.xml + - 'echo "diff base ${CI_MERGE_REQUEST_DIFF_BASE_SHA}"' + - 'echo "source head ${CI_MERGE_REQUEST_SOURCE_BRANCH_SHA}"' + - 'echo "source head:-default ${CI_COMMIT_SHA}"' + - git remote add neil https://gitlab.com/realtime-neil/glab-cli.git + - git fetch --unshallow --all && find .git/refs -type f -exec ls -l {} \; -exec cat {} \; + - git fetch refs/merge_requests/$CI_MERGE_REQUEST_IID/train || git fetch 'refs/merge_requests/*' -.release: - stage: release - image: docker:stable - services: - - docker:dind - variables: - # Disable shallow cloning so that goreleaser can diff between tags to - # generate a changelog. - GIT_DEPTH: 0 - needs: [windows_installer] - dependencies: [windows_installer] - -release_test: - extends: .release - rules: - - if: $CI_COMMIT_TAG - when: never - - if: $CI_PIPELINE_SOURCE == "merge_request_event" - - if: $CI_COMMIT_BRANCH == $CI_DEFAULT_BRANCH - script: | - docker run --rm --privileged \ - -v $PWD:/go/src/gitlab.com/gitlab-org/cli \ - -w /go/src/gitlab.com/gitlab-org/cli \ - -v /var/run/docker.sock:/var/run/docker.sock \ - goreleaser/goreleaser release --snapshot - -build_windows: - stage: test - extends: .go-cache - script: - - GOOS=windows GOARCH=amd64 make build - - mv bin/glab bin/glab.exe - artifacts: - paths: - - "bin/glab.exe" - expire_in: "30 days" - -windows_installer: - stage: release - image: - name: amake/innosetup - entrypoint: [""] +exit_the_merge_train: + image: alpine:latest script: - - mv scripts/setup_windows.iss . - - iscc "setup_windows.iss" -DVersion=${CI_COMMIT_TAG//v} - artifacts: - paths: - - "bin/*" - expire_in: "30 days" - dependencies: [build_windows] - needs: [build_windows] - -release: - extends: .release - rules: - - if: $CI_COMMIT_TAG - script: | - docker run --rm --privileged \ - -v $PWD:/go/src/gitlab.com/gitlab-org/cli \ - -w /go/src/gitlab.com/gitlab-org/cli \ - -v /var/run/docker.sock:/var/run/docker.sock \ - -e GITLAB_TOKEN=$GITLAB_TOKEN_RELEASE \ - --entrypoint "" \ - goreleaser/goreleaser \ - bash -c " - docker login -u $CI_REGISTRY_USER -p $CI_REGISTRY_PASSWORD $CI_REGISTRY - docker login -u $DOCKER_IO_USER -p $DOCKER_IO_PASSWORD - goreleaser release - " - -homebrew-release: - image: homebrew/ubuntu22.04:latest - stage: release - rules: - - if: $CI_COMMIT_TAG - script: - - touch ~/.gitconfig - - git config --global user.email "$GITHUB_EMAIL" - - git config --global user.name "$GITHUB_NAME" - - curl "$CI_PROJECT_URL/-/archive/$CI_COMMIT_TAG/$CI_PROJECT_NAME-$CI_COMMIT_TAG.tar.gz" --output "$CI_PROJECT_NAME-$CI_COMMIT_TAG.tar.gz" - - brew bump-formula-pr glab --no-browse --url="$CI_PROJECT_URL/-/archive/$CI_COMMIT_TAG/$CI_PROJECT_NAME-$CI_COMMIT_TAG.tar.gz" --sha256="$(sha256sum $CI_PROJECT_NAME-$CI_COMMIT_TAG.tar.gz | cut -d ' ' -f 1)" - -secret_detection: - dependencies: [] # Don't download artifacts, especially `./public/` + - exit 1 diff --git a/commands/ci/status/status.go b/commands/ci/status/status.go index 2b36e450c6d859ea1d77090ec9cb2eb734e21a66..623df22764c8fa34fb2c475a95c0ef82229d3d8b 100644 --- a/commands/ci/status/status.go +++ b/commands/ci/status/status.go @@ -110,8 +110,8 @@ func NewCmdStatus(f *cmdutils.Factory) *cobra.Command { } fmt.Fprintf(writer.Newline(), "Pipeline State: %s\n\n", runningPipeline.Status) - // break loop if output is a TTY to avoid prompting - if !f.IO.IsOutputTTY() || !f.IO.PromptEnabled() { + // break loop if input or output is a TTY to avoid prompting + if !(f.IO.IsInputTTY() && f.IO.PromptEnabled()) { break } if (runningPipeline.Status == "pending" || runningPipeline.Status == "running") && live { diff --git a/pkg/iostreams/iostreams.go b/pkg/iostreams/iostreams.go index 8839fe10681114825667c1cb12160c31c990b414..f3448d1f510d3adcc4be17797a84297408908517 100644 --- a/pkg/iostreams/iostreams.go +++ b/pkg/iostreams/iostreams.go @@ -215,6 +215,10 @@ func (s *IOStreams) IsOutputTTY() bool { return s.IsErrTTY && s.IsaTTY } +func (s *IOStreams) IsInputTTY() bool { + return s.IsInTTY && s.IsaTTY && s.IsErrTTY +} + func (s *IOStreams) ResolveBackgroundColor(style string) string { if style == "" { style = os.Getenv("GLAMOUR_STYLE")