Skip to content
This repository has been archived by the owner on Oct 25, 2022. It is now read-only.

Linux support #234

Closed
5 of 6 tasks
TheCakeIsNaOH opened this issue Jan 28, 2021 · 24 comments
Closed
5 of 6 tasks

Linux support #234

TheCakeIsNaOH opened this issue Jan 28, 2021 · 24 comments

Comments

@TheCakeIsNaOH
Copy link
Contributor

TheCakeIsNaOH commented Jan 28, 2021

So, I'd like to be able to run AU on Linux for a couple of reasons, and it seems like at least a subset of AU features are almost ready to go. Here is a list of current blocking problems that I have found:

  • Many aliases don't work on Linux, because they instead refer to native tools that don't have the same behavior and options. Affected aliases include mkdir, rm, gc, pushd, popd, ls, set, cp, tee, and sort. The solution is fairly simple; replace these (or all) aliases with the full versions. ((GH-234) Expand all aliases #235)
  • The nuspec files element directory separator needs to be changed to a forward slash manually. I have a PR open to make choco do it automatically: (GH-502) Correct path separator in nuspec file element chocolatey/nuget-chocolatey#19
  • On PowerShell 7 on Linux running [enum]::GetValues('Net.SecurityProtocolType') says that ssl3 is supported, but when I actually try to set it, it says that it is not supported. Again should be a simple fix to select tls or higher when running on non-windows. (Don't set SSLv3 on PowerShell 6+ #236)
  • In the AUPackage class definition, NuspecPath is defined with a hardcoded backslash. Needs use [IO.Path]::DirectorySeparatorChar instead. There are probably other spots with a hardcoded backslash that would need to be switched to a platform-independent method, i.e. Join-Path or whatever. Edit: get-remotefiles also needs changes for this, and some of the plugins almost certainly do as well. (Make directory separators platform agnostic #237)
  • Automatic checksumming probably won't work and would be really hard to get working. But always using -ChecksumFor none and Get-RemoteChecksum is pretty easy to do on the maintainer end, so IMO this should be the required way to do it on Linux.
  • Running choco pack fails if the nupkg already exists. choco pack command fails on non-Windows when the nupkg already exists chocolatey/choco#2076

There are probably some things lurking that I missed, but those should get at least a minimum amount of functionality.

@majkinetor
Copy link
Owner

Thanks for detailed report.

How would calls to choco.exe work on linux side (packing and pushing) ?

@overag3
Copy link

overag3 commented Jan 28, 2021

@TheCakeIsNaOH
Copy link
Contributor Author

TheCakeIsNaOH commented Jan 28, 2021

Choco can be installed and run on Mono, and a wrapper script can be put on the $path.

Stick something like this in /usr/local/bin/choco.exe and in /usr/local/bin/choco

#!/bin/bash
mono /opt/chocolatey/console/choco.exe "$@" --allow-unofficial

This will have to be done manually by the person running AU, as will installation of any other dependencies (7z, etc).

@TheCakeIsNaOH
Copy link
Contributor Author

I have a branch here with changes: https://github.com/TheCakeIsNaOH/au/commits/linux-support
It's not PR ready (yet), but it's a start.

TheCakeIsNaOH added a commit to TheCakeIsNaOH/au that referenced this issue Jan 29, 2021
@TheCakeIsNaOH
Copy link
Contributor Author

Additional considerations on the package maintainer end:

  • Update their update_all.ps1 script, and possibly other custom scripts to use a platform-agnostic directory separator.
  • Disable automatic checksumming for all packages, and use Get-RemoteChecksum instead if needed.
  • Make sure that the filename in au_SearchReplace and the filename of the file have the same casing
  • Install mono, pwsh 7, build and install choco, etc. Fortunately, Install-Module AU works no problem, so that should be a viable install method later, and also I probably should develop a linux install script, or make the current one work with linux.
  • Figure out the directory separator thing in the nuspec, although I hope the PR for fixing that will get merged soon.

@majkinetor
Copy link
Owner

I would like it on linux (or everywhere) to not depend on choco (as it depends on mono and it depends on ....) to pack/push. Push could be done easily via API but not sure what could be used as choco pack on linux without choco

Maybe somebody from choco team could help with info in that regard (@ferventcoder @gep13). Maybe something like this? This would allow you to do entire AU stuff on Linux as on Windows. The only thing missing would be local testing but that is not particular downside given that packages are for Windows.

@TheCakeIsNaOH
Copy link
Contributor Author

In the 12 days of Chocolatey, @ferventcoder did say that moving to dotnet core was a major item on the want-to-do list for 2021. https://youtu.be/ren6uzV5ZHc?t=1624

With that, choco.exe should run with dotnet installed. Alternatively, chocolatey.lib should also work, and that is something that could be bundled with AU. This would also allow the pack validation to work, once it is added to choco.

I don't really like the idea of using dotnet pack. It requires creating a .csproj file, it vomits out a bunch of auto-created files, and it complains that a number of things are deprecated, for example, the licenseUrl, and the iconUrl. Though it does work, at least as far as I can tell.

@TheCakeIsNaOH
Copy link
Contributor Author

In regard to deprecating automatic checksumming, even if it was removed completely, it's not like people couldn't use an old version of AU. Both the chocolatey package and the PowerShell gallery module are self-contained, so old versions will work.

Maybe throw on non-windows, and print a warning on Windows. Then in a year or whatever, remove it completely.

The only thing missing would be local testing but that is not particular downside given that packages are for Windows.

Virtualbox and Vagrant are available on Linux, so hopefully, it should not be too hard to get the test environment working there.

@majkinetor
Copy link
Owner

In the 12 days of Chocolatey, @ferventcoder did say that moving to dotnet core was a major item on the want-to-do list for 2021. https://youtu.be/ren6uzV5ZHc?t=1624

Sure, lets wait on that then I guess its not a matter of want but matter of must for choco.

Virtualbox and Vagrant are available on Linux, so hopefully, it should not be too hard to get the test environment working there.

I am thinking on deprecating that too in Test-Package and go with Windows Sandbox as vbox with vagrant is enormous pain in the ass. Not that it would work as is on Linux too.

@majkinetor
Copy link
Owner

Automatic checksumming probably won't work and would be really hard to get working. But always using -ChecksumFor none and Get-RemoteChecksum is pretty easy to do on the maintainer end, so IMO this should be the required way to do it on Linux.

It could also be added in $PROFILE: $au_ChecksumFor = 'none' . It can't override what is in update.ps1 but it wont be default any more.

@TheCakeIsNaOH
Copy link
Contributor Author

I guess its not a matter of want but matter of must for choco.

It's on the must-do eventually, but they seem to get really touchy talking about dates, and I just wanted to head that off at the pass.

vbox with vagrant is enormous pain in the ass.

True.

I am thinking on deprecating that too in Test-Package and go with Windows Sandbox

There are definite merits to that idea. Not having to download and keep a copy of the 4GB vm image would be a plus.

Windows sandbox does conflict with running VirtualBox due to Hyper-V issues.

At some point, I could also work on getting a test environment like thing setup for KVM on linux, probably with one old image (like the current test env), and one up to date one (latest win 10). It's not like it's that much code to write.

It could also be added in $PROFILE: $au_ChecksumFor = 'none'

I'm not really a fan of that for consistency purposes, like running AU in a CI environment or similar. Although, for something like that, that can just be added to the CI build config, or probably in your update_all.ps1 would work fine as well for a CI environment.

@majkinetor
Copy link
Owner

but they seem to get really touchy talking about dates

Yeah, I know. They are very touchy in general: ¯\_(ツ)_/¯

Windows sandbox does conflict with running VirtualBox due to Hyper-V issues.

That was fixed. However, sandbox usually starts in seconds. On the negative side, you can't snapshot state but I guess its not a big problem in our case.

@TheCakeIsNaOH
Copy link
Contributor Author

TheCakeIsNaOH commented Jan 30, 2021

That was fixed.

It has never worked for me. When I have tried that VirtualBox never won't boot windows VMs anymore. They just spin the dots endlessly during boot or bluescreen.

Maybe I should try again, they might have fixed my issues more recently.

@majkinetor
Copy link
Owner

I didn't try it either.

@niks255
Copy link

niks255 commented Mar 5, 2021

It seems to work on Linux now (at least update functionality does), but one issue I have encountered is lack of support for case-sensitive file systems. In my package, au_SearchReplace searches for patterns in chocolateyInstall.ps1, but the actual file name is lowercase. That results in a failure, obviously.

@majkinetor
Copy link
Owner

au_SearchReplace searches for patterns in chocolateyInstall.ps1, but the actual file name is lowercase.

No it doesn't. I uses file names you give it to.

Automatic checksum has hardcoded this kind of name but you shouldn't use it anyway.

@majkinetor
Copy link
Owner

It also looks like this one can be closed, @TheCakeIsNaOH ?

@TheCakeIsNaOH
Copy link
Contributor Author

I'd say it probably could be. Any further things could get their own issue if they come up.

It would be good to document the remaining possible issues and things to be aware of in the wiki, e.g. like the nuspec files element, and not using the automatic check summing.

@TheCakeIsNaOH
Copy link
Contributor Author

With regards to the au_SearchReplace, @niks255 and I where talking and perhaps we could do something like:

$filename = (Get-Childitem -Path $filename).fullname

which I think would allow it to be case-insensitive.

@niks255
Copy link

niks255 commented Mar 5, 2021

No it doesn't. I uses file names you give it to.

That's the point. I pass chocolateyInstall.ps1, but actual file name is chocolateyinstall.ps1, and that is perfectly acceptable on Windows, but not on Linux.

With regards to the au_SearchReplace, @niks255 and I where talking and perhaps we could do something like:

$filename = (Get-Childitem -Path $filename).fullname

which I think would allow it to be case-insensitive.

Yeah, just run Get-ChildItem on a directory that contains a file and then do Where-Object {$_.Name -Like "file name without path"}).BaseName

@majkinetor
Copy link
Owner

The filename problem is not something AU should be concerned with and is trivial to solve in multiple ways.

I will close this then when I add Linux notes in docs.

Thx @TheCakeIsNaOH for making this work.

@TheCakeIsNaOH
Copy link
Contributor Author

TheCakeIsNaOH commented Mar 6, 2021

Here is the list of stuff to put in the Linux notes that I know of;

@hurricanehrndz
Copy link

I am just beginning to use this on Linux and the progress is incredible! @majkinetor @TheCakeIsNaOH Thanks for your efforts!

@majkinetor
Copy link
Owner

Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.
Projects
None yet
Development

No branches or pull requests

5 participants