Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

failed to link 'share/terminfo/h/hp70092A' in wsl2 ubuntu when UTF-8 character included in directory #1362

Closed
2 tasks done
IncubatorShokuhou opened this issue May 10, 2024 · 15 comments
Labels
🐞 bug Something isn't working

Comments

@IncubatorShokuhou
Copy link

IncubatorShokuhou commented May 10, 2024

Checks

  • I have checked that this issue has not already been reported.

  • I have confirmed this bug exists on the latest version of pixi, using pixi --version.

Reproducible example

on WSL2 ubuntu 22.04, in a directory include Chinese character:

  1. cd /mnt/d/测试
  2. pixi init test
  3. cd test
  4. pixi add numpy
    and then error:
  × failed to link 'share/terminfo/n/ncr260vt300wpp'
  ├─▶ failed to copy file to destination
  ╰─▶ Symbolic link loop (os error 40)

Issue description

fail to run pixi on wsl ubuntu when directory includes utf-8 characters

Expected behavior

no error happened

@IncubatorShokuhou IncubatorShokuhou added the 🐞 bug Something isn't working label May 10, 2024
@IncubatorShokuhou IncubatorShokuhou changed the title failed to link 'share/terminfo/h/hp70092A' failed to link 'share/terminfo/h/hp70092A' in wsl2 ubuntu when UTF-8 character included in directory May 10, 2024
@IncubatorShokuhou
Copy link
Author

IncubatorShokuhou commented May 10, 2024

BTW, I've encountered utf-8 issues a few times on this project, particularly with directory paths. Would it be possible to include related tests in our automated testing process?

@baszalmstra
Copy link
Contributor

Does this also happen with non-utf8 paths? Are you perhaps storing your environment on a Windows drive? Windows is case insensitive but the package you are trying to install needs a case sensitive file system. Imagine you have the following case:

fileA
filea # symbolic link to `fileA`

On a case insensitive filesystem this will be a single file and the symbolic link will point to itself creating the infinite recursion.

BTW, I've encountered utf-8 issues a few times on this project, particularly with directory paths. Would it be possible to include related tests in our automated testing process?

Yes! Contributions are welcome! :)

@IncubatorShokuhou
Copy link
Author

Does this also happen with non-utf8 paths?

No.

Are you perhaps storing your environment on a Windows drive?

I am using WSL, and it seems that this issue has nothing to do with uppercase and lowercase letters.

@IncubatorShokuhou
Copy link
Author

Yes! Contributions are welcome! :)

I am more than willing to contribute, but I am concerned that adding content related to UTF-8 characters to the CI process may cause many CI to fail in the short term, leading to chaos in the project. I believe it would be better for the maintainers to make the changes yourself, as you have a better grasp of the entire project.

@wolfv
Copy link
Member

wolfv commented May 10, 2024

@IncubatorShokuhou this issue might indeed be best fixed in rattler - if you can add a little test there that would be very helpful (https://github.com/mamba-org/rattler/).

Just to be sure, does this issue also occur on Windows itself? We already fixed a couple of Unicode related issues ... so I would hope that not that much is failing.

@IncubatorShokuhou
Copy link
Author

@IncubatorShokuhou this issue might indeed be best fixed in rattler - if you can add a little test there that would be very helpful (https://github.com/mamba-org/rattler/).

Just to be sure, does this issue also occur on Windows itself? We already fixed a couple of Unicode related issues ... so I would hope that not that much is failing.

I tested the issue where the path contains UTF-8 characters, and the results are as follows:

  1. In PowerShell: No issues occurred.
  2. In the /mnt/d directory under WSL: The problem appeared.
  3. In the ~/ directory under WSL: No issues occurred.
  4. Repeating steps 1-3 on another computer yielded identical results.
  5. In native Ubuntu: No issues occurred.
  6. On an Armbian (running Debian on an arm64 platform): No issues occurred.

@baszalmstra
Copy link
Contributor

In the /mnt/d directory under WSL: The problem appeared.

Yeah that confirms my suspicion. /mnt/d is a case insensitive filesystem under WSL. If you are installing a linux package on that drive and the package contains files with different capitalization issues may occur.

@RaphaelMelanconAtBentley

I'm getting a similar issue which I'm not sure is related:

  ├─▶ failed to link 'share/terminfo/2/2621a'
  ├─▶ unexpected io operation while removing clobbered file
  ╰─▶ No such file or directory (os error 2)

Pixi v0.22.0 in a docker container running ubuntu 22.04

@benmoss
Copy link

benmoss commented Jun 3, 2024

I am running into this too, I managed to create a pretty minimal repro on my machine https://github.com/benmoss/pixi-symbolic-link-bug

➜  pixi-repro git:(main) pixi info
      Pixi version: 0.23.0
          Platform: osx-arm64
  Virtual packages: __unix=0=0
                  : __osx=14.5=0
                  : __archspec=1=m2
         Cache dir: /Users/bmoss40/Library/Caches/rattler/cache
      Auth storage: /Users/bmoss40/.rattler/credentials.json

Project
------------
              Name: pixi-repro
           Version: 0.1.0
     Manifest file: /private/tmp/pixi-repro/pixi.toml
  Config locations:
      Last updated: 03-06-2024 10:48:28

Environments
------------
       Environment: default
          Features: default
          Channels: conda-forge
  Dependency count: 1
      Dependencies: pytest
 PyPI Dependencies: python-git
  Target platforms: osx-arm64, linux-64, linux-aarch64

@ruben-arts
Copy link
Contributor

Thanks @benmoss !! I unfortunately cannot recreate the bug on my linux machine. @nichmor could you give it a try on your mac?

@pavelzw
Copy link
Contributor

pavelzw commented Jun 6, 2024

The conda world if ncurses-linux-64 didn't have share/terminfo/n/ncr260vt300wpp and share/terminfo/N/NCR260VT300WPP in its package

conda-forge/ncurses-feedstock#73

image

@PanTheDev
Copy link

Might it have something to with the locals not set properly? Adding locales to my container fixed it for me.

@garymm
Copy link

garymm commented Jul 5, 2024

I'm seeing this running pixi install using the official ghcr.io/prefix-dev/pixi container image running in a devcontainer on MacOS. It seems by default MacOS filesystems are case-insensitive, and this carries through to the devcontainer :-(

@pavelzw
Copy link
Contributor

pavelzw commented Jul 6, 2024

@garymm #600 (comment)

@baszalmstra
Copy link
Contributor

I'm closing this issue. It has to do with mounted a case-insensitive file system in a case-sensitive environment.

This is the same issue as: #234

The solution is to make sure that your pixi environment is not on case-insensitive filesystem.

Please open a new issue if you feel I closed this issue too soon.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
🐞 bug Something isn't working
Projects
None yet
Development

No branches or pull requests

9 participants