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

Update Installer Script (run postInstall before shortcut creation) #1170

Merged
merged 1 commit into from
Jan 5, 2020

Conversation

Zemogiter
Copy link
Contributor

@Zemogiter Zemogiter commented Jan 5, 2020

Description

Thanks to #1144 we have discovered that scripts will fail if .executable() points to a file that only exist after postInstall step is done. Since @plata mentioned something about Installer Script working this way for a reason (though I was unable to find that reason in closed PRs and issues) this is a WIP draft untill me or someone else test this with other scripts that use postInstall.

What works

Heroes of Might & Magic IV no longer crash due to non-existing .executable()

What was not tested

Other scripts with postInstall

Test

  • Operating system (and linux kernel version): Ubuntu 19.10
  • Hardware (GPU/CPU): GTX 1080 ti, i7-7700K

Ready for review

  • Script tested as a regular phoenicis user and working (if you have a problem -> create as draft and ask for help).
  • json-align and eslint run according to the documentation.
  • Codacy and travis checked.

Sorry, something went wrong.

Verified

This commit was created on GitHub.com and signed with GitHub’s verified signature. The key has expired.
@Zemogiter Zemogiter changed the title Update Installer Script Update Installer Script, switched places with shortcut creation and postInstall Jan 5, 2020
@plata
Copy link
Collaborator

plata commented Jan 5, 2020

@qparis can you remember if there was a reason to use this order?

@madoar
Copy link
Collaborator

madoar commented Jan 5, 2020

I don't see a reason why we should not be able to change the order. We should only face an issue with this if inside postInstall the created shortcut is accessed or the internal values of QuickScript are changed, which should not be the case anyway.

@plata
Copy link
Collaborator

plata commented Jan 5, 2020

For me it's fine to try it. Could you take a look at the postInstall calls to see if there's something which might get broken?

@madoar
Copy link
Collaborator

madoar commented Jan 5, 2020

This is interesting. It seems like some installers use a different order:

setupWizard.message(tr("Download \"{0}\" in Origin and shut it down once \"{0}\" is installed", this._name));
wine.run(tempFile, [], null, false, true);
// wait until Origin and Wine are closed
wine.wait();
// Origin installation has finished
setupWizard.wait(tr("Please wait..."));
this._preInstall(wine, setupWizard);
// back to generic wait (might have been changed in preInstall)
setupWizard.wait(tr("Please wait..."));
this._postInstall(wine, setupWizard);
// create shortcut after installation (if executable is specified, it does not exist earlier)
this._createShortcut(wine.prefix());

@madoar
Copy link
Collaborator

madoar commented Jan 5, 2020

ZipScript as well

@plata
Copy link
Collaborator

plata commented Jan 5, 2020

Ok, then let's merge this.

@plata plata marked this pull request as ready for review January 5, 2020 12:50
@plata plata changed the title Update Installer Script, switched places with shortcut creation and postInstall Update Installer Script (run postInstall before shortcut creation) Jan 5, 2020
@plata plata merged commit 8603dc5 into PhoenicisOrg:master Jan 5, 2020
@Zemogiter Zemogiter deleted the patch-1 branch January 5, 2020 12:53
petermetz pushed a commit to petermetz/scripts that referenced this pull request Jun 7, 2020

Unverified

This commit is not signed, but one or more authors requires that any commit attributed to them is signed.
…hoenicisOrg#1170)

Avoid issues if postInstall() creates the executable which the shortcut refers to.
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

None yet

3 participants