У меня есть проект InstallScript, написанный с нуля в InstallShield 2010. Он содержит, помимо прочего, три собственных объекта InstallShield и четыре объекта-держателя модуля InstallShield Merge, которые обертывают файлы MSM.
Когда я первоначально тестировал проект, он отлично устанавливался в чистой среде, но когда я попытался обновить его до более новой версии, каждый из четырех объектов-держателей модулей слияния выдал сообщение «Ошибка 1706. Не найден действительный источник для продукта XXXX».
Я покопался в сети и обнаружил, что это ошибка установщика Windows, и это происходит потому, что файл MSI должен существовать на компьютере даже после того, как исходный установочный носитель пропал.Рекомендованный способ убедиться в том, что установлен флажок «локально кэшировать MSI-пакет» в диалоговом окне свойств объекта-держателя модуля слияния.
Я установил этот флажок для всех четырех модулей слияния и провел повторное тестирование, но это помоглоне решить проблему.Затем я посмотрел, где эти модули слияния фактически помещаются на жесткий диск.В диалоговом окне свойств указано <DISK1TARGET>
, которое разрешается до C:\Program Files\InstallShield Installation Information\
{GUID продукта} во время выполнения.Глядя на тестовую машину, казалось, что все четыре модуля слияния записывают в одно и то же место, перезаписывая тем самым файлы MSI друг друга.
Чтобы обойти это, я отредактировал каждый модуль слияния, чтобы кэшировать себя в уникальныйпуть, <DISK1TARGET>\
{Имя} .Я скомпилировал и протестировал снова, и я вижу, что каждый модуль слияния теперь действительно сохраняет себя в уникальной подпапке.Однако все четыре сообщения об ошибках 1706 все еще появляются при обновлении.
У кого-нибудь есть какие-нибудь идеи?Я уверен, что упускаю что-то очевидное, но это нигде не документировано.: -)
ОБНОВЛЕНИЕ:
Судя по большому количеству сообщений на форумах InstallShield, InstallShield генерирует новый GUID продукта для каждого встроенного MSI при каждой сборке.проект InstallScript.Во время процесса обновления механизм InstallShield перезаписывает каждый файл MSI, кэшированный на целевом компьютере, более новой версией, но когда дело доходит до их выполнения, установщик Windows говорит: «Эй, это новый продукт, где находится MSI старого продукта, так что яможно удалить? ", отсюда и ошибка.
Можно ли сказать InstallShield, что он не должен заново генерировать GUID продукта для каждого встроенного MSI в каждой сборке?Конечно, это поведение делает насмешкой над всей идеей встраивания модулей слияния в проекты InstallScript?: - (