You have hit on an interesting (read: highly annoying) bug in the App Store validation process, it seems:
For starters, the location to which you copy your apps does not, in fact, come into it, and neither does your status as admin / non-admin user. Despite the fact Apple states this should be possible, on my two machines, I cannot get an app manually copied to run either as a standard user, an admin user, in /Applications
or in ~/Applications
. Neither does chown
ing and chmod
ing the bundle to conform with regular installs help. The App Store login sheet pop ups (once), but the app keeps quitting with exit code 173 after that.
According to Apple’s developer documentation for the validation of App Store receipts, part of the receipt validating the use of an app is a machine specific GUID. When you copy an app to another machine, the GUID does not match anymore, thus invalidating the receipt (conversely, on your own machine, it always matches, whatever the user you install the app for – hence you not having any problem with that). Apps are meant to signal an invalid receipt by exiting with exit code 173, and the App Store’s storeagent
process is meant to take over after that, asking for credentials and generating a new receipt, then re-launching the app on success:
If the system successfully obtains a valid receipt, it relaunches the application. Otherwise, it displays an error message to the user, explaining the problem.
Do not display any error message to the user if validation fails. The system is responsible for trying to obtain a valid receipt or informing the user that the receipt is not valid.
What happen in your (and my test) case is that validation fails quietly – as indicated by the fact the receipt is never updated, but no error message is shown either. The logs show storeagent
returns:
promptResponse: <CKSignInPromptResponse:0x1080c4fb0 returnCode:1>
This code is undocumented by Apple, and all I have found are discussions by developers about this issue in a testing context, where it seems to relate to iTunes Connect data being incomplete (Geoff Pado has a concise summary here).
However that may be, the picture as a whole clearly shows validation is failing en route, which leaves apps copied manually with an invalid receipt even after entering the correct credentials to the App Store. Only those apps that do not check their own validity will still run, as you noted.
Not very helpfully in your case, Apple only recommends deleting and re-downloading from the App Store to remedy the issue.
TL;DR: You cannot manually copy apps bought in the App Store from one computer to another until Apple fixes the receipt validation process needed for it. Install location and user privilege do not come into it.
I have just experienced the same problem. I noticed graphic artefacts on my desktop, but did not worry about it until Transmission failed to start. Couple of iterations later I restarted it from iTerm (thus bypassing launchd), and it worked. I shrugged shoulders and rebooted - now that was a mistake.
Pretty much all apps that use default MacOS windows rendering engine could not start, including Finder. This meant I could not start iTerm or Terminal either. The likes of Chrome, VLC, Sonos and iTunes, which use their own window renderer, worked. I got a very similar stacktrace all the time bar the last call - not strdup, but memmove, also from stdlib. Surprisingly enough, when I tried to log in as another user, everything still worked.
I tried resetting SMC and PRAM to no avail. Then I rebooted in safe mode, in which rendering worked, and rebooted back to the normal mode. This helped. At least I can launch apps now - but Finder crashes and relaunches every now and then occasionally.
Best Answer
This may be another case of Lion being a quiter. And utilizing OS X Lion's Auto Termination and additionally OS X Lions Sudden Termination feature.
A program that is "taking to long to start" seems like a perfect candidate for the OS to kill.
Also it makes perfect sense for when you come back the second time and they start up, since Lion would have saved state on the program.