[RESOLU] version in registry does not match requirements of min_version

Questions about WAPT Packaging / Requêtes et aides autour des paquets Wapt.
Règles du forum
Règles du forum communautaire
* English support on www.reddit.com/r/wapt
* Le support communautaire en français se fait sur ce forum
* Merci de préfixer le titre du topic par [RESOLU] s'il est résolu.
* Merci de ne pas modifier un topic qui est taggé [RESOLU]. Ouvrez un nouveau topic en référençant l'ancien
* Préciser version de WAPT installée, version complète ET numéro de build (2.2.1.11957 / 2.2.2.12337 / etc.) AINSI QUE l'édition Enterprise / Discovery
* Les versions 1.8.2 et antérieures ne sont plus maintenues. Les seules questions acceptées vis à vis de la version 1.8.2 sont liés à la mise à jour vers une version supportée (2.1, 2.2, etc.)
* Préciser OS du serveur (Linux / Windows) et version (Debian Buster/Bullseye - CentOS 7 - Windows Server 2012/2016/2019)
* Préciser OS de la machine d'administration/création des paquets et de la machine avec l'agent qui pose problème le cas échéant (Windows 7 / 10 / 11 / Debian 11 / etc.)
* Eviter de poser plusieurs questions lors de l'ouverture de topic, sinon il risque d'être ignorer. Si plusieurs sujet, ouvrir plusieurs topic, et de préférence les uns après les autres et pas tous en même temps (ie ne pas spammer le forum).
* Inclure directement les morceaux de code, les captures d'écran et autres images directement dans le post. Les liens vers les pastebin, les bitly et autres sites tierces seront systématiquement supprimés.
* Comme tout forum communautaire, le support est fait bénévolement par les membres. Si vous avez besoin d'un support commercial, vous pouvez contacter le service commercial Tranquil IT au 02.40.97.57.55
cefinformatique
Messages : 21
Inscription : 26 mai 2023 - 14:25

03 janv. 2024 - 13:54

Bonjour,

J'ai créé un paquet pour déployer un logiciel (déjà installé sur les postes clients) en version 23.1.0.4

Voici le setup.py de mon paquet :

Code : Tout sélectionner

def install():
    softname ='AWCLIENTSQL'
    listAW=installed_softwares(softname)
    if listAW == softname:
        print("Mise a jour de DiaClientSQL")
        install_exe_if_needed('DiaClientSQLInstall.exe',
            silentflags='/Silent',
            key='AWCLIENTSQL',
            remove_old_version=True
        )
    else:
        print("Mise a jour de DiaClientSQL")
        install_exe_if_needed('DiaClientSQLInstall.exe',
            silentflags='/Silent',
            key='AWCLIENTSQL'
        )
        filecopyto(r'C:\ProgramData\Microsoft\Windows\Start Menu\Programs\ACDSuite\DiaClient SQL.lnk',r'C:\Users\Public\Desktop')
Une fois le paquet déployé j'obtiens l'erreur suivante lors de la mise dans 80% des cas :
waptutils.EWaptSetupException: Fatal error : Setup DiaClientSQLInstall.exe has been executed and key AWCLIENTSQL has been found in the registry, but version in registry does not match requirements of min_version=23.1.0.4

EWaptSetupException: Fatal error : Setup DiaClientSQLInstall.exe has been executed and key AWCLIENTSQL has been found in the registry, but version in registry does not match requirements of min_version=23.1.0.4
Si je relance manuellement la mise à jour, celle-ci va finir par s'appliquer correctement après plusieurs tentatives.

La version installée avant la mise à jour via WAPT était 23.1.0.2

Que puis-je faire pour éviter ce problème ?
Dernière modification par cefinformatique le 14 févr. 2024 - 14:35, modifié 2 fois.
Avatar de l’utilisateur
sfonteneau
Expert WAPT
Messages : 1788
Inscription : 10 juil. 2014 - 23:52
Contact :

03 janv. 2024 - 15:24

Aucun argument min_version n'est passer a install_exe_if_needed

donc la fonction fait ceci :

Code : Tout sélectionner

if min_version is None:
    min_version = get_product_props(exe)['version']
Et récupère le numéro de version renseigner dans les propertie du fichier.

Dans votre cas ça doit pas être bon

Le mieux serait d'ajouter un argument min_version avec le numéro de version associer a la clé AWCLIENTSQL
cefinformatique
Messages : 21
Inscription : 26 mai 2023 - 14:25

13 févr. 2024 - 13:36

Bonjour,

Je ré-ouvre ce sujet car à l'occasion d'une nouvelle mise à jour du logiciel concerné j'ai bien renseigné le "min_version" mais cela n'a pas résolu le problème.

J'ai trouvé la cause de celui-ci : Lors de l'installation du programme, l'ancienne version n'est pas désinstallée. Comme l'installation donne un code retour 0 avant qu'elle mette à jour le numéro de version dans le registre windows, le paquet WAPT va comparer le numéro de version du paquet avec l'ancien numéro qui est encore indiqué dans le registre.

Il faudrait donc que je fasse attendre (environ 20 secondes) le paquet WAPT à l'étape entre la fin de l'installation et la vérification du numéro de version dans le registre pour résoudre ce problème.

C'est possible ?
cefinformatique
Messages : 21
Inscription : 26 mai 2023 - 14:25

14 févr. 2024 - 14:34

J'ai résolu mon problème en utilisant le module winreg pour supprimer la clé registre du logiciel avant l'installation. C'est un peu barbare mais ça fonctionne !

Code : Tout sélectionner

# -*- coding: utf-8 -*-
from setuphelpers import *
import winreg

r"""
Usable WAPT package functions: install(), uninstall(), session_setup(), audit(), update_package()

"""
# Declaring global variables - Warnings: 1) WAPT context is only available in package functions; 2) Global variables are not persistent between calls
uninstallkey = ['AWCLIENTSQL']

def install():
    killalltasks(control.get_impacted_process_list())
    softname ='AWCLIENTSQL'
    listFULL=installed_softwares(softname)
    listAW=listFULL[0]['key']
    if listAW == softname:
        # Define the registry key path
        key_path = r"SOFTWARE\WOW6432Node\Microsoft\Windows\CurrentVersion\Uninstall"
        # Open the registry key for deletion
        try:
            with winreg.OpenKey(winreg.HKEY_LOCAL_MACHINE, key_path, 0, winreg.KEY_ALL_ACCESS) as registry_key:
                winreg.DeleteKey(registry_key, "AWCLIENTSQL")
                print("Registry key deleted successfully.")
        except FileNotFoundError:
            print("Registry key not found.")
        except PermissionError:
            print("Permission error. Run the script with administrative privileges.")
        except Exception as e:
            print(f"An error occurred: {e}")
        print("Mise a jour de DiaClientSQL")
        install_exe_if_needed('DiaClientSQLInstall.exe',
            silentflags='/Silent',
            key=softname,
            remove_old_version=True,
#            min_version=control.get_version()
        )
    else:
        print("Installation de DiaClientSQL")
        install_exe_if_needed('DiaClientSQLInstall.exe',
            silentflags='/Silent',
            key=softname,
            remove_old_version=True
        )
        filecopyto(r'C:\ProgramData\Microsoft\Windows\Start Menu\Programs\ACDSuite\DiaClient SQL.lnk',r'C:\Users\Public\Desktop')
Avatar de l’utilisateur
dcardon
Expert WAPT
Messages : 1412
Inscription : 18 juin 2014 - 09:58
Localisation : Saint Sébastien sur Loire
Contact :

15 févr. 2024 - 16:25

Bonjour Marc,

merci pour le retour!

Denis
Denis Cardon - Tranquil IT
Communiquez autour de vous sur WAPT! Envoyez nous vos url de blog et d'articles dans la catégorie votre avis du forum, nous les mettrons en avant sur le site WAPT
Verrouillé