[wix-devs] WIXBUG5750 and RollbackBoundary

Bob Arnson bob at firegiant.com
Tue Jan 23 09:42:42 PST 2018


And remember the *other* reason Burn registers ARP immediately: So there's *something* if a package triggers a mid-chain reboot. For that, you can't really delay registration (for .NET, e.g.) but make de-registration possible.

-----Original Message-----
From: wix-devs [mailto:wix-devs-bounces at lists.wixtoolset.org] On Behalf Of Sean Hall via wix-devs
Sent: Tuesday, 23 January, 2018 12:31
To: WiX Toolset Developer Mailing List <wix-devs at lists.wixtoolset.org>
Cc: Sean Hall <r.sean.hall at gmail.com>
Subject: Re: [wix-devs] WIXBUG5750 and RollbackBoundary

I don't know how to reconcile what you're seeing with https://github.com/wixtoolset/issues/issues/4822/ (one of the few issues where Rob, Bob, and I have all commented)

On Tue, Jan 23, 2018 at 11:18 AM, Hoover, Jacob <Jacob.Hoover at greenheck.com>
wrote:

> Strange one here...
>
>                 <Chain ParallelCache="no">
>                         <MsiPackage SourceFile="..\SecondPackage\bin\Debug\SecondPackage.msi"
> Name="payload\second\SecondPackage.msi" Compressed="no" Permanent="yes"
> Visible="yes" />
>                         <RollbackBoundary />
>                         <MsiPackage SourceFile="..\FailingPackage\bin\Debug\FailingPackage.msi"
> Name="payload\failing\FailingPackage.msi" Compressed="no" />
>                 </Chain>
>
> This I think is what Rob was speaking of.  When this chain is ran, the 
> permanent package gets installed, then the failure happens, and we do 
> indeed remove ARP. However, I see nothing different if I remove the 
> rollback boundary, that is until I add my logic for cleaning the cache 
> on rollback.
>
> Do we do some magic to the chain to do all permanent packages first?
>
> -----Original Message-----
> From: wix-devs [mailto:wix-devs-bounces at lists.wixtoolset.org] On 
> Behalf Of Sean Hall via wix-devs
> Sent: Tuesday, January 23, 2018 11:00 AM
> To: WiX Toolset Developer Mailing List <wix-devs at lists.wixtoolset.org>
> Cc: Sean Hall <r.sean.hall at gmail.com>
> Subject: Re: [wix-devs] WIXBUG5750 and RollbackBoundary
>
> That's not the default behavior, though. If you set Permanent to yes 
> and your stuff fails, then the bundle stays registered in ARP. I know 
> I've seen multiple people complain about this on Stack Overflow and/or wix-users.
>
> On Tue, Jan 23, 2018 at 10:55 AM, Rob Mensching <rob at firegiant.com> wrote:
>
> > There is (should be) code in there (unless my memory is totally 
> > wrong) that flips the "retain ARP entry" bit after all permanent 
> > packages are installed. Actually, writing that makes me think maybe 
> > that doesn't require a rollback boundary and we just made it the 
> > default behavior (since RollbackBoundaries weren't really discoverable).
> >
> > Regards,
> >
> >   Rob Mensching
> >   CEO
> >   FireGiant
> > _______________________________________________________________
> >  FireGiant  |  Dedicated support for the WiX toolset  | 
> > http://www.firegiant.com/
> >
> > -----Original Message-----
> > From: wix-devs [mailto:wix-devs-bounces at lists.wixtoolset.org] On 
> > Behalf Of Sean Hall via wix-devs
> > Sent: Tuesday, January 23, 2018 8:53 AM
> > To: WiX Toolset Developer Mailing List 
> > <wix-devs at lists.wixtoolset.org>
> > Cc: Sean Hall <r.sean.hall at gmail.com>
> > Subject: Re: [wix-devs] WIXBUG5750 and RollbackBoundary
> >
> > Interesting. I think I've only tried the Permanent=yes for .NET. I 
> > didn't realize that putting a RollbackBoundary between it and "all 
> > my stuff" would allow the bundle to unregister itself if "all my stuff"
> failed.
> >
> > On Tue, Jan 23, 2018 at 10:47 AM, Hoover, Jacob via wix-devs < 
> > wix-devs at lists.wixtoolset.org> wrote:
> >
> > > As for 1), this is not the case for any way I've tried to author it.
> > > As soon as the RollbackBounday is hit it stops rolling back. So 
> > > your bundle stays in ARP, and just .Net remains installed. If you 
> > > wanted to accomplish this, one would have to add @Permanent=yes 
> > > (this is what our .Net packages do), though that then means an 
> > > uninstall won't touch
> > it.
> > >
> > > -----Original Message-----
> > > From: wix-devs [mailto:wix-devs-bounces at lists.wixtoolset.org] On 
> > > Behalf Of Rob Mensching via wix-devs
> > > Sent: Tuesday, January 23, 2018 10:38 AM
> > > To: WiX Toolset Developer Mailing List 
> > > <wix-devs at lists.wixtoolset.org>
> > > Cc: Rob Mensching <rob at firegiant.com>
> > > Subject: Re: [wix-devs] WIXBUG5750 and RollbackBoundary
> > >
> > > Bob's recollection is correct. These are the scenarios to think about:
> > >
> > > 1. .NET Framework + Boundary + All your stuff == this boundary 
> > > prevents the experience of installing then on failure removing 
> > > .NET Framework. No one wants to go through that. The Bundle ARP 
> > > entry is (should be) gone so the cached "All your stuff" packages 
> > > should be removed. This
> > > (unfortunately) was a late scenario (particularly the ARP 
> > > behavior) that made things ugly (as per Sean).
> > >
> > > 2. Your Vital Stuff + Boundary + Your Optional Stuff == this 
> > > boundary is to help get the user to get a working product and not 
> > > have some non-important package force everything back. In this 
> > > case, ARP stays and stuff can stay in the cache. Idea is the user 
> > > wants that stuff and will probably try again. If the user doesn't 
> > > want any of it, well they need to uninstall anyway.
> > >
> > >
> > > Regards,
> > >
> > >   Rob Mensching
> > >   CEO
> > >   FireGiant
> > > _______________________________________________________________
> > >  FireGiant  |  Dedicated support for the WiX toolset  | 
> > > http://www.firegiant.com/
> > >
> > > -----Original Message-----
> > > From: wix-devs [mailto:wix-devs-bounces at lists.wixtoolset.org] On 
> > > Behalf Of Sean Hall via wix-devs
> > > Sent: Tuesday, January 23, 2018 8:28 AM
> > > To: WiX Toolset Developer Mailing List 
> > > <wix-devs at lists.wixtoolset.org>
> > > Cc: Sean Hall <r.sean.hall at gmail.com>
> > > Subject: Re: [wix-devs] WIXBUG5750 and RollbackBoundary
> > >
> > > I think it's easier right now to just say that the behavior is 
> > > undefined for whether a package will still be cached in those 
> > > scenarios. Like Rob has said, at some point we need to redo how 
> > > Burn handles caching and this is one thing that could be addressed.
> > >
> > > On Tue, Jan 23, 2018 at 10:05 AM, Hoover, Jacob < 
> > > Jacob.Hoover at greenheck.com>
> > > wrote:
> > >
> > > > I'm liking the simplification of if it's in ARP, then the cache 
> > > > can stay, however the current plan executes a rollback of a 
> > > > cached package if it fails. Are you saying this behavior should 
> > > > change, or just the concept of cleaning the cache should only 
> > > > happen if ARP =
> > False?
> > ____________________________________________________________________
> > WiX Toolset Developer Mailing List provided by FireGiant 
> > http://www.firegiant.com/
> >
> ____________________________________________________________________
> WiX Toolset Developer Mailing List provided by FireGiant 
> http://www.firegiant.com/
>
____________________________________________________________________
WiX Toolset Developer Mailing List provided by FireGiant http://www.firegiant.com/



More information about the wix-devs mailing list