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

xpm uninstall --global fails if package version is @latest #202

Open
TommyMurphyTM1234 opened this issue Jul 30, 2024 · 12 comments
Open

xpm uninstall --global fails if package version is @latest #202

TommyMurphyTM1234 opened this issue Jul 30, 2024 · 12 comments
Assignees

Comments

@TommyMurphyTM1234
Copy link

Describe the bug

xpm uninstall --global fails with @latest even when the specified package is installed.

To Reproduce

I did this on Windows 10:

mkdir test
cd test

xpm init

xpm install @xpack-dev-tools/riscv-none-elf-gcc@latest --verbose
...

xpm uninstall @xpack-dev-tools/riscv-none-elf-gcc@latest --verbose
xPack manager - uninstall package(s)

Symlink 'xpacks/@xpack-dev-tools/riscv-none-elf-gcc' removed
package.json devDependencies['@xpack-dev-tools/riscv-none-elf-gcc'] removed

'xpm uninstall' completed in 336 ms.

xpm list --global
- @xpack-dev-tools/riscv-none-elf-gcc
  A binary xPack with the GNU RISC-V Embedded GCC executables
  - 14.1.0-1.1

xpm uninstall @xpack-dev-tools/riscv-none-elf-gcc@latest --verbose --global
xPack manager - uninstall package(s)

error: global package '@xpack-dev-tools/riscv-none-elf-gcc@latest' not installed
exit(2)

xpm uninstall @xpack-dev-tools/[email protected] --verbose --global
xPack manager - uninstall package(s)

Changing permissions to read-write...
'C:\Users\Tommy Murphy\AppData\Roaming\xPacks\@xpack-dev-tools\riscv-none-elf-gcc\14.1.0-1.1' removed

'xpm uninstall' completed in 6.274 sec.

Expected behaviour

I would have expected the xpm uninstall using @latest as the version to work.

Actual behaviour

xpm uninstall with a package version of @latest fails but it works if I give it a specific version number.

Context

  • OS Name: Windows 10
  • the output of npm doctor
npm doctor
Connecting to the registry
Ok

Checking npm version
Not ok
Use npm v10.8.2

Checking node version
Ok
current: v20.16.0, recommended: v20.16.0

Checking configured npm registry
Ok
using default registry (https://registry.npmjs.org/)

Checking for git executable in PATH
Ok
C:\Program Files\Git\cmd\git.EXE

Checking for global bin folder in PATH
Ok
C:\Users\Tommy Murphy\AppData\Roaming\npm

npm error Some problems found. See above for recommendations.
npm error A complete log of this run can be found in: C:\Users\Tommy Murphy\AppData\Local\npm-cache\_logs\2024-07-30T20_44_41_562Z-debug-0.log

Comments

None.

@ilg-ul ilg-ul self-assigned this Jul 30, 2024
@ilg-ul
Copy link
Contributor

ilg-ul commented Jul 30, 2024

Although it seems obvious that the install and uninstall must be consistent, under the bonnet things are a bit more complicated.

xpm has no understanding of what latest means. xpm (as npm does too) asks the server to get the version tagged with latest (or any tag in fact), and the server returns the actual version.

At uninstall time, which may be long after install, this information not only that it is no longer available, but asking the server for the meaning of latest is wrong, since in the mean time a different version may have been tagged as latest.

So, strictly speaking, uninstall @latest cannot be implemented.

What can be done is to cheat and compute latest at uninstall time as the greatest version, according to semver.

For normal npm packages which use a strict semver string, this should work.

Unfortunately binary xpacks use an extended semver, with additional numbers defined as pre-releases. If the package that provides semver services is able to sort such strings, we probably have an acceptable solution.

@TommyMurphyTM1234
Copy link
Author

What can be done is to cheat and compute latest at uninstall time as the greatest version, according to semver.

Wouldn't that make sense given that that seems to be what happens when working within an xPack project directory using xpm uninstall ... @latest without --global?

Or else just make xpm uninstall require an explicit (fully qualified?) version number and reject @latest altogether?

Either way, what happens within a project directory and what happens when using --global should ideally be consistent.

@ilg-ul
Copy link
Contributor

ilg-ul commented Jul 30, 2024

I guess that xpm uninstall in a project completely ignores the version, since there can be no multiple versions of the same package installed in a project.

At the global level, if multiple versions are installed, the version is mandatory. Or should be, I don't know how the code behaves now.

@TommyMurphyTM1234
Copy link
Author

I guess that xpm uninstall in a project completely ignores the version, since there can be no multiple versions of the same package installed in a project.

Ah - I didn't realise that even though it makes sense! :-)

In that case maybe it would make more sense if...

  1. "Local" xpm uninstall errors out if any version, including @latest, is specified?
  2. "Global" xpm uninstall ... --global errors out if a version is not specified or @latest is specified?

@ilg-ul
Copy link
Contributor

ilg-ul commented Jul 30, 2024

It makes sense. I'll improve the validation and error processing.

@TommyMurphyTM1234
Copy link
Author

I also noticed this - is it deliberate?

xpm list --global
- @xpack-dev-tools/riscv-none-elf-gcc
  A binary xPack with the GNU RISC-V Embedded GCC executables
  - 13.3.0-1.1
  - 14.1.0-1.1

mkdir test
cd test

xpm init

# No version specified but works the same as if @latest or @14.1.0-1.1 were specified
xpm install @xpack-dev-tools/riscv-none-elf-gcc --verbose

xpm list

- @xpack-dev-tools/[email protected]
  A binary xPack with the GNU RISC-V Embedded GCC executables
...

@ilg-ul
Copy link
Contributor

ilg-ul commented Jul 30, 2024 via email

@TommyMurphyTM1234
Copy link
Author

On 31 Jul 2024, at 00:46, Tommy Murphy @.***> wrote: # No version specified but works the same as if @latest or @14.1.0-1.1 were specified xpm install @xpack-dev-tools/riscv-none-elf-gcc --verbose
that's correct, the default is @latest.

But not when I do xpm uninstall @xpack-dev-tools/riscv-none-elf-gcc --verbose --global. In that case it removes ALL versions of @xpack-dev-tools/riscv-none-elf-gcc from the central store.

I'm my opinion the handling of version specifiers could/should ideally be more consistent.

@ilg-ul
Copy link
Contributor

ilg-ul commented Jul 30, 2024

You're right. What would be the ideal consistent behaviour for both install and uninstall?

@TommyMurphyTM1234
Copy link
Author

You're right. What would be the ideal consistent behaviour for both install and uninstall?

I need to review the current behaviour of project based and global package installs/uninstalls more systematically and then think about this.

@TommyMurphyTM1234
Copy link
Author

You're right. What would be the ideal consistent behaviour for both install and uninstall?

I need to review the current behaviour of project based and global package installs/uninstalls more systematically and then think about this.

As far as I can see...

(An "xPack enabled project directory" is one in which xpm init was previously run).

Global

  1. xpm install ... --global with no version specifier is equivalent to @latest.
  2. xpm uninstall ... --global with no version specifier uninstalls all versions of the specified package.
  3. xpm uninstall ... --global with @latest gives an error (e.g. error: global package '@xpack-dev-tools/openocd@latest' not installed).
  4. So, xpm uninstall ... --global needs either no version specifier or a specific version specifier but not @latest.

xPack enabled project directory

  1. xpm install without --global in an xPack enabled project directory with no version installs the latest version available in the central store.
  2. xpm uninstall without --global in an xPack enabled project directory ignores any version specifier.

Am I missing anything here?
Are there also version pattern matching options that can be used?

@ilg-ul
Copy link
Contributor

ilg-ul commented Jul 31, 2024

Am I missing anything here?

For completeness you can add the cases with @latest in xPack enabled project, but they are obvious.

Are there also version pattern matching options that can be used?

Not for the moment.

Anyways, the xpm behaviour should be consistent to npm, if possible.

(BTW, you can install xPacks with npm too, but the binary archive is not automatically unpacked in the .content folder, it needs to be done by a separate mechanism).

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Development

No branches or pull requests

2 participants