From 85fecaaf744a27058b2c570fecb8cbd05e8fd88a Mon Sep 17 00:00:00 2001 From: jaimergp Date: Mon, 29 Jan 2024 15:27:29 +0100 Subject: [PATCH 1/5] add tips for advanced debugging --- docs/source/debugging.md | 67 ++++++++++++++++++++++++++++++++++++++++ docs/source/index.md | 1 + 2 files changed, 68 insertions(+) create mode 100644 docs/source/debugging.md diff --git a/docs/source/debugging.md b/docs/source/debugging.md new file mode 100644 index 000000000..2eb704860 --- /dev/null +++ b/docs/source/debugging.md @@ -0,0 +1,67 @@ +# Debugging tips + +Sometimes `constructor` fails to build the requested installer. Sometimes the installer builds, but +there are errors when it is run in the target machine. + +In this section we will talk about different techniques you can use to find out was wrong with your installers. + +## Run `constructor` in debug mode + +When you run `constructor`, `conda` is called behind the scenes to solve the requested specs. You can enable advanced logging using the flags `-v` or `--debug`. These will be passed to `conda`. Be prepared for _a lot_ of output! + + +## Verbose `conda` + +Whether it's while running `constructor` to build an installer, or while the installer is running in the target machine, some instance of `conda` will be running behind the scenes. You can request more verbose output via the `CONDA_VERBOSITY` environment variable. It can take values from `1` to `4`. You can also set `CONDA_DEBUG` to `1`. + + +## Verbose shell installers + +The shell installers are "just" a shell script that invokes `conda` in certain events. This means you can enable `bash` verbosity via the `-x` flag: + +```bash +bash -x ./Miniconda.sh +# or with verbose conda: +CONDA_VERBOSITY=3 bash -x ./Miniconda.sh +``` + +## Verbose PKG installers + +PKG installers are usually invoked graphically. You can check the native logs via +L. Note that you will need to choose the detailed view in the dropdown menu you'll find in the top right corner. + +In order to get more verbosity out of conda, you now know you need the `CONDA_VERBOSITY` variable. However, it needs to be set up _before_ running the installer. One way from the command line would be: + +```bash +CONDA_VERBOSITY=3 installer -pkg ./path/to/installer.pkg -target LocalSystem +``` + +See `man installer` for more details. + +## Verbose EXE installers + +Windows installers do not have a verbose mode. By default, the graphical logs are only available in the "progress bar" dialog, by clicking on "Show details". This text box is right-clickable, which will allow you to copy the contents to the clipboard (and then paste them in a text file, presumably). + +If you want `conda` to print more details, then, run it from the CMD prompt like this: + +```batch +set "CONDA_VERBOSITY=3" +start /wait your-installer.exe +``` + +### Building logging-enabled EXE installers + +There's a way of building EXE installers that do write logs to a file. For this, you need a special `nsis` package configured to do so: + +```batch +conda install "nsis=*=*log*" +``` + +Then, you can invoke `constructor` normally, but setting a special environment variable: + +```batch +set "NSIS_USING_LOG_BUILD=1" +constructor . +``` + +The resulting EXE installer will always generate an `install.log` file in the target directory. +It will contain the full logs, as available in the "Show details" dialog. diff --git a/docs/source/index.md b/docs/source/index.md index d3586a53b..9c909768b 100644 --- a/docs/source/index.md +++ b/docs/source/index.md @@ -11,4 +11,5 @@ getting-started howto construct-yaml cli-options +debugging ``` From e90c3bcbe409f99b03dc6b38ebd5b722b9854348 Mon Sep 17 00:00:00 2001 From: jaimergp Date: Mon, 29 Jan 2024 16:42:20 +0100 Subject: [PATCH 2/5] some syntax fixes --- docs/source/cli-options.md | 23 +++++++++++++---------- docs/source/debugging.md | 16 ++++++++-------- 2 files changed, 21 insertions(+), 18 deletions(-) diff --git a/docs/source/cli-options.md b/docs/source/cli-options.md index cc3466518..388197f8d 100644 --- a/docs/source/cli-options.md +++ b/docs/source/cli-options.md @@ -38,16 +38,19 @@ $ bash my_installer.sh -b -p /opt/my_app Windows installers have the following CLI options available: - `/InstallationType=[JustMe|AllUsers]`: This flag sets the installation type. The default is -`JustMe`. `AllUsers` might require elevated privileges. - `/AddToPath=[0|1]`: Whether to add the -installation directory to the `PATH` environment variable. The default is `0`. This is NOT -recommended. - `/CheckPathLength=[0|1]`: Check whether the installation path is too long (>46 -characters). The default depends on how the installer was created. - `/KeepPkgCache=[0|1]`: Whether -to keep the package cache or not. Defaults to `1`. - `/NoRegistry=[0|1]`: Whether to prevent -registry modification or not. Defaults to `0`. - `/NoScripts=[0|1]`: If set to `1`, the installer -will not run any post-install scripts. Defaults to `0`. - `/NoShortcuts=[0|1]`: If set to `1`, the -installer will not create any shortcuts. Defaults to `0`. - `/RegisterPython=[0|1]`: Whether to -register Python as default in the Windows registry. Defaults to `1`. This is preferred to -`AddToPath`. + `JustMe`. `AllUsers` might require elevated privileges. +- `/AddToPath=[0|1]`: Whether to add the installation directory to the `PATH` environment + variable. The default is `0`. This is NOT recommended. +- `/CheckPathLength=[0|1]`: Check whether the installation path is too long (>46 + characters). The default depends on how the installer was created. +- `/KeepPkgCache=[0|1]`: Whether to keep the package cache or not. Defaults to `1`. +- `/NoRegistry=[0|1]`: Whether to prevent registry modification or not. Defaults to `0`. +- `/NoScripts=[0|1]`: If set to `1`, the installer will not run any post-install scripts. Defaults + to `0`. +- `/NoShortcuts=[0|1]`: If set to `1`, the installer will not create any shortcuts. Defaults to + `0`. +- `/RegisterPython=[0|1]`: Whether toregister Python as default in the Windows registry. Defaults + to `1`. This is preferred to `AddToPath`. You can also supply [standard NSIS flags](https://nsis.sourceforge.io/Docs/Chapter3.html#installerusage), but only _after_ the ones mentioned above: diff --git a/docs/source/debugging.md b/docs/source/debugging.md index 2eb704860..b826cf8dd 100644 --- a/docs/source/debugging.md +++ b/docs/source/debugging.md @@ -20,9 +20,9 @@ Whether it's while running `constructor` to build an installer, or while the ins The shell installers are "just" a shell script that invokes `conda` in certain events. This means you can enable `bash` verbosity via the `-x` flag: ```bash -bash -x ./Miniconda.sh +$ bash -x ./Miniconda.sh # or with verbose conda: -CONDA_VERBOSITY=3 bash -x ./Miniconda.sh +$ CONDA_VERBOSITY=3 bash -x ./Miniconda.sh ``` ## Verbose PKG installers @@ -32,7 +32,7 @@ PKG installers are usually invoked graphically. You can check the native logs vi In order to get more verbosity out of conda, you now know you need the `CONDA_VERBOSITY` variable. However, it needs to be set up _before_ running the installer. One way from the command line would be: ```bash -CONDA_VERBOSITY=3 installer -pkg ./path/to/installer.pkg -target LocalSystem +$ CONDA_VERBOSITY=3 installer -pkg ./path/to/installer.pkg -target LocalSystem ``` See `man installer` for more details. @@ -44,8 +44,8 @@ Windows installers do not have a verbose mode. By default, the graphical logs ar If you want `conda` to print more details, then, run it from the CMD prompt like this: ```batch -set "CONDA_VERBOSITY=3" -start /wait your-installer.exe +> set "CONDA_VERBOSITY=3" +> cmd.exe /c start /wait your-installer.exe ``` ### Building logging-enabled EXE installers @@ -53,14 +53,14 @@ start /wait your-installer.exe There's a way of building EXE installers that do write logs to a file. For this, you need a special `nsis` package configured to do so: ```batch -conda install "nsis=*=*log*" +> conda install "nsis=*=*log*" ``` Then, you can invoke `constructor` normally, but setting a special environment variable: ```batch -set "NSIS_USING_LOG_BUILD=1" -constructor . +> set "NSIS_USING_LOG_BUILD=1" +> cmd.exe /c start /wait constructor . ``` The resulting EXE installer will always generate an `install.log` file in the target directory. From 6028bd32dd7b16b49f06a52428405dd76c798ea6 Mon Sep 17 00:00:00 2001 From: jaimergp Date: Mon, 29 Jan 2024 17:10:42 +0100 Subject: [PATCH 3/5] merge with CLI options page --- docs/source/cli-options.md | 49 ++++++++++++++++++++++++++++++++++++++ docs/source/index.md | 1 - news/752-debugging | 19 +++++++++++++++ 3 files changed, 68 insertions(+), 1 deletion(-) create mode 100644 news/752-debugging diff --git a/docs/source/cli-options.md b/docs/source/cli-options.md index 388197f8d..7db0960b4 100644 --- a/docs/source/cli-options.md +++ b/docs/source/cli-options.md @@ -2,6 +2,12 @@ The are the command-line flags available in the installers generated by constructor. +:::{admonition} Configure conda's verbosity +:class: tip + +Whether it's while running `constructor` to build an installer, or while the installer is running in the target machine, some instance of `conda` will be running behind the scenes. You can request more verbose output via the `CONDA_VERBOSITY` environment variable. It can take values from `1` to `4`. You can also set `CONDA_DEBUG` to `1`. +::: + ## Shell-based installers for MacOS and Linux We have the following CLI options available for MacOS and Linux: @@ -32,6 +38,17 @@ Run the installer in batch mode and install to a custom path: $ bash my_installer.sh -b -p /opt/my_app ``` +:::{admonition} Extra verbosity +:class: tip + +Get more verbose outputs by running the installer with `-x` and/or `CONDA_VERBOSITY=3`: + +```bash +$ bash -x my_installer.sh +# or with verbose conda: +$ CONDA_VERBOSITY=3 bash -x my_installer.sh +``` +::: ## Windows installers @@ -84,6 +101,36 @@ Run the uninstaller in silent mode from its original location: > cmd.exe /c start /wait "C:\Program Files\my_app\uninstaller.exe" /S _?=C:\Program Files\my_app ``` +:::{admonition} EXE installers with file logging +:class: tip + +Windows installers do not have a verbose mode. By default, the graphical logs are only available in the "progress bar" dialog, by clicking on "Show details". This text box is right-clickable, which will allow you to copy the contents to the clipboard (and then paste them in a text file, presumably). + +There's a way of building EXE installers that do write logs to a file. For this, you need a special `nsis` package configured to do so: + +```batch +> conda install "nsis=*=*log*" +``` + +Then, you can invoke `constructor` normally, but setting a special environment variable: + +```batch +> set "NSIS_USING_LOG_BUILD=1" +> constructor . +``` + +The resulting EXE installer will always generate an `install.log` file in the target directory. +It will contain the full logs, as available in the "Show details" dialog. + +Combine this with `CONDA_VERBOSITY=3` at install time for maximum details: + + +```batch +> set "CONDA_VERBOSITY=3" +> cmd.exe /c start /wait your-installer.exe +``` +::: + ## PKG installers The PKG installers do not offer any CLI options. Instead, you need to use the `installer` @@ -91,6 +138,8 @@ subcommand: ```bash $ installer -pkg my_installer.pkg -dumplog -target CurrentUserHomeDirectory +# with extra verbosity from conda +$ CONDA_VERBOSITY=3 installer -pkg my_installer.pkg -dumplog -target CurrentUserHomeDirectory ``` Note you can't choose a custom path for the installation. Instead, you can only choose a `target`. diff --git a/docs/source/index.md b/docs/source/index.md index 9c909768b..d3586a53b 100644 --- a/docs/source/index.md +++ b/docs/source/index.md @@ -11,5 +11,4 @@ getting-started howto construct-yaml cli-options -debugging ``` diff --git a/news/752-debugging b/news/752-debugging new file mode 100644 index 000000000..669898a1d --- /dev/null +++ b/news/752-debugging @@ -0,0 +1,19 @@ +### Enhancements + +* + +### Bug fixes + +* + +### Deprecations + +* + +### Docs + +* Add some tips for debugging the creation and execution of `constructor`-made installers. (#752) + +### Other + +* From 62ec2d42eb3890b5b38320f17dde20c716ac75ca Mon Sep 17 00:00:00 2001 From: jaimergp Date: Tue, 6 Feb 2024 14:57:57 +0100 Subject: [PATCH 4/5] Apply suggestions from code review Co-authored-by: Bianca Henderson --- docs/source/cli-options.md | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/docs/source/cli-options.md b/docs/source/cli-options.md index 7db0960b4..804bcf940 100644 --- a/docs/source/cli-options.md +++ b/docs/source/cli-options.md @@ -106,13 +106,13 @@ Run the uninstaller in silent mode from its original location: Windows installers do not have a verbose mode. By default, the graphical logs are only available in the "progress bar" dialog, by clicking on "Show details". This text box is right-clickable, which will allow you to copy the contents to the clipboard (and then paste them in a text file, presumably). -There's a way of building EXE installers that do write logs to a file. For this, you need a special `nsis` package configured to do so: +There's a way of building EXE installers that can write logs to a file; for this, you need a special `nsis` package configured to do so: ```batch > conda install "nsis=*=*log*" ``` -Then, you can invoke `constructor` normally, but setting a special environment variable: +Then, you can invoke `constructor` normally after setting a special environment variable: ```batch > set "NSIS_USING_LOG_BUILD=1" From 1521e2e81637c9ad1d7a5eeeef6a15b1c2c46ec4 Mon Sep 17 00:00:00 2001 From: jaimergp Date: Tue, 6 Feb 2024 15:07:30 +0100 Subject: [PATCH 5/5] Apply suggestions from code review Co-authored-by: Bianca Henderson --- docs/source/cli-options.md | 2 +- docs/source/debugging.md | 8 ++++---- 2 files changed, 5 insertions(+), 5 deletions(-) diff --git a/docs/source/cli-options.md b/docs/source/cli-options.md index 804bcf940..49b466674 100644 --- a/docs/source/cli-options.md +++ b/docs/source/cli-options.md @@ -66,7 +66,7 @@ Windows installers have the following CLI options available: to `0`. - `/NoShortcuts=[0|1]`: If set to `1`, the installer will not create any shortcuts. Defaults to `0`. -- `/RegisterPython=[0|1]`: Whether toregister Python as default in the Windows registry. Defaults +- `/RegisterPython=[0|1]`: Whether to register Python as default in the Windows registry. Defaults to `1`. This is preferred to `AddToPath`. You can also supply [standard NSIS flags](https://nsis.sourceforge.io/Docs/Chapter3.html#installerusage), but only _after_ the ones mentioned above: diff --git a/docs/source/debugging.md b/docs/source/debugging.md index b826cf8dd..c9ad88481 100644 --- a/docs/source/debugging.md +++ b/docs/source/debugging.md @@ -17,7 +17,7 @@ Whether it's while running `constructor` to build an installer, or while the ins ## Verbose shell installers -The shell installers are "just" a shell script that invokes `conda` in certain events. This means you can enable `bash` verbosity via the `-x` flag: +The shell installers are simply shell scripts that invoke `conda` in certain events. This means you can enable `bash` verbosity via the `-x` flag: ```bash $ bash -x ./Miniconda.sh @@ -29,7 +29,7 @@ $ CONDA_VERBOSITY=3 bash -x ./Miniconda.sh PKG installers are usually invoked graphically. You can check the native logs via +L. Note that you will need to choose the detailed view in the dropdown menu you'll find in the top right corner. -In order to get more verbosity out of conda, you now know you need the `CONDA_VERBOSITY` variable. However, it needs to be set up _before_ running the installer. One way from the command line would be: +In order to get more verbosity out of `conda`, you now know you need the `CONDA_VERBOSITY` variable. However, it needs to be set up _before_ running the installer. One way from the command line would be: ```bash $ CONDA_VERBOSITY=3 installer -pkg ./path/to/installer.pkg -target LocalSystem @@ -50,13 +50,13 @@ If you want `conda` to print more details, then, run it from the CMD prompt like ### Building logging-enabled EXE installers -There's a way of building EXE installers that do write logs to a file. For this, you need a special `nsis` package configured to do so: +There's a way of building EXE installers that can write logs to a file; for this, you need a special `nsis` package configured to do so: ```batch > conda install "nsis=*=*log*" ``` -Then, you can invoke `constructor` normally, but setting a special environment variable: +Then, you can invoke `constructor` normally after setting a special environment variable: ```batch > set "NSIS_USING_LOG_BUILD=1"