TestAcceptableZipFile fails when executed in /tmp
<!--- Please read this! Before opening a new issue, make sure to search for keywords in the issues filtered by the "bug" label: - https://gitlab.com/gitlab-org/cli/-/issues/?label_name%5B%5D=type%3A%3Abug and verify the issue you're about to submit isn't a duplicate. ---> ### Checklist <!-- Please test the latest versions, that will remove the possibility that you see a bug that is fixed in a newer version. --> Most of these are not applicable, my report is regarding tests. - [ ] I'm using the latest version of the extension (Run `glab --version`) - Extension version: _Put your extension version here_ - [ ] Operating system and version: GNU/Linux 6.12.87 - [ ] Gitlab.com or self-managed instance? _gitlab.com/self-managed instance/both_ - [ ] GitLab version (if self-managed) _GitLab version here_ (Use the `version` endpoint, like this: gitlab.my-company.com/api/v4/version) - [ ] I have performed `glab auth status` to check for authentication issues - [ ] Run the command in debug mode (like `DEBUG=true glab mr list`) and attach any useful output ### Summary When you clone the repository into /tmp, running tests fails with: ``` --- FAIL: TestAcceptableZipFile (0.03s) logic_test.go:101: Error Trace: /tmp/ffff/cli/internal/commands/job/artifact/logic_test.go:101 Error: "../../../../../../TestAcceptableZipFile3772470382/002/file-0.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-1.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-2.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-3.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-4.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-5.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-6.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-7.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-8.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-9.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-10.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-11.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-12.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-13.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-14.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-15.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-16.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-17.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-18.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-19.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-20.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-21.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-22.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-23.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-24.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-25.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-26.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-27.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-28.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-29.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-30.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-31.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-32.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-33.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-34.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-35.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-36.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-37.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-38.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-39.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-40.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-41.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-42.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-43.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-44.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-45.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-46.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-47.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-48.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-49.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-50.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-51.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-52.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-53.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-54.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-55.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-56.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-57.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-58.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-59.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-60.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-61.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-62.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-63.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-64.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-65.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-66.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-67.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-68.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-69.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-70.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-71.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-72.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-73.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-74.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-75.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-76.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-77.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-78.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-79.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-80.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-81.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-82.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-83.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-84.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-85.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-86.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-87.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-88.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-89.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-90.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-91.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-92.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-93.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-94.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-95.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-96.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-97.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-98.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-99.txt\n" does not contain "/tmp/TestAcceptableZipFile3772470382/002/file-0.txt" Test: TestAcceptableZipFile FAIL FAIL gitlab.com/gitlab-org/cli/internal/commands/job/artifact 0.052s FAIL ``` ### Environment bash: line 1: glab: command not found - OS: Linux 6.12.87 x86_64 - SHELL: /gnu/store/vhkg4avy9zf0kj70dcsmfpymnllkjq1y-bash-5.2.37/bin/sh - TERM: dumb - GLAB: ### Steps to reproduce 1. `cd /tmp` 2. `git clone https://gitlab.com/gitlab-org/cli.git` 3. `cd cli` 4. `go test ./internal/commands/job/artifact` ### What is the current _bug_ behavior? Test fails. ### What is the expected _correct_ behavior? Test passes. ### Relevant logs and/or screenshots ``` --- FAIL: TestAcceptableZipFile (0.03s) logic_test.go:101: Error Trace: /tmp/ffff/cli/internal/commands/job/artifact/logic_test.go:101 Error: "../../../../../../TestAcceptableZipFile3772470382/002/file-0.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-1.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-2.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-3.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-4.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-5.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-6.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-7.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-8.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-9.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-10.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-11.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-12.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-13.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-14.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-15.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-16.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-17.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-18.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-19.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-20.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-21.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-22.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-23.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-24.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-25.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-26.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-27.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-28.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-29.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-30.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-31.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-32.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-33.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-34.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-35.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-36.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-37.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-38.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-39.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-40.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-41.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-42.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-43.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-44.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-45.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-46.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-47.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-48.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-49.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-50.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-51.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-52.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-53.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-54.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-55.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-56.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-57.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-58.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-59.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-60.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-61.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-62.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-63.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-64.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-65.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-66.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-67.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-68.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-69.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-70.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-71.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-72.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-73.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-74.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-75.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-76.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-77.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-78.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-79.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-80.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-81.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-82.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-83.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-84.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-85.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-86.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-87.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-88.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-89.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-90.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-91.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-92.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-93.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-94.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-95.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-96.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-97.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-98.txt\n../../../../../../TestAcceptableZipFile3772470382/002/file-99.txt\n" does not contain "/tmp/TestAcceptableZipFile3772470382/002/file-0.txt" Test: TestAcceptableZipFile FAIL FAIL gitlab.com/gitlab-org/cli/internal/commands/job/artifact 0.052s FAIL ``` ### Possible fixes Problem is in https://gitlab.com/gitlab-org/cli/-/blob/v1.95.0/internal/commands/job/artifact/logic.go?ref_type=tags#L121 . The tests expects absolute path, but the code gives relative one. Possible workaround is to set TMPDIR to unrelated hierarchy, e.g. ` TMPDIR=/run/ go test ./internal/commands/job/artifact` makes the test pass, however that is not always an option, for example in build sandboxes, /tmp is often only writable location.
issue