IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

C# Discussion :

Gérer des dépendances communes entres plusieurs produits


Sujet :

C#

  1. #1
    Membre confirmé
    Profil pro
    Inscrit en
    Octobre 2007
    Messages
    1 002
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2007
    Messages : 1 002
    Points : 552
    Points
    552
    Par défaut Gérer des dépendances communes entres plusieurs produits
    Bonjour,

    Dans mon entreprise nous avons plusieurs produits. Ces produits utilisent des librairies communes (essentiellement en .Net).
    Il existe 2 types de librairies communes:
    - interne (dont nous avons les sources)
    - externe (librairie payante)

    Aujourd'hui chaque produit/projet a son propre répertoire locale de librairies (donc un répertoire lib pour chaque projet dont on fait pointer la référence, ce répertoire est archivé sur svn comme le reste du projet).

    Le problème vient du fait que chacun utilise sa propre version de lib commune, qu'il appartient au chef de projet de mettre à jour avec la version courante (ce qu'il ne fait pas forcement...).


    1- Ma première idée simple à réaliser: c'est de faire pointer tous les projets sur un répertoire partagé "MyCommonLib\Current" qui sera mis à jour quand la version de la librairie commune sera considérée comme stable.
    Comme ça à la compilation de chaque projet on est certain que tous nos produits utilisent la dernière version stable.
    Le problème: au moment où l'on doit faire un hotfix (revenir sur une version antérieure au produit), l’état de la révision ne sera pas exactement le même qu'il y a un an (c'est la limite de pointer sur des répertoires partagés, c'était l'avantage de livrer un répertoire lib dans chaque projet...). Ca peut avoir quelque fâcheuse incidence (assez limité genre le projet ne compile pu car une librairie commune a changé)



    2- Utiliser un gestionnaire de dépendance, j'avais testé sur java / eclipse, ce genre de bousin, et ça m'avait l'air très laborieux (maven). Et de mémoire ça ne résout pas mon problème de devoir utiliser la dernière lib stable...


    3- faire une espèce de script avant build, qui va mettre le répertoire Lib à jour. Comme ça dans le gestionnaire de Source on a la lib commune réellement utilisée à l’époque !...



    Si vous avez un feetback, je suis preneur !

  2. #2
    Membre éprouvé Avatar de sisqo60
    Homme Profil pro
    Consultant informatique
    Inscrit en
    Février 2006
    Messages
    754
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Indre et Loire (Centre)

    Informations professionnelles :
    Activité : Consultant informatique

    Informations forums :
    Inscription : Février 2006
    Messages : 754
    Points : 1 188
    Points
    1 188
    Par défaut
    Bonjour,

    C'est toujours source de problèmes, mais pour faire des choix, il faut savoir comment vous travaillez, quelle est la taille de l'équipe etc...

  3. #3
    Membre confirmé
    Profil pro
    Inscrit en
    Octobre 2007
    Messages
    1 002
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2007
    Messages : 1 002
    Points : 552
    Points
    552
    Par défaut
    Salut !

    Petit équipe (8 personnes), pour presque autant de produit

    Sous VS2010, SVN tortoise/ankh.

    On utilise des répertoires partagés pour publier les versions.

  4. #4
    Expert confirmé

    Homme Profil pro
    Chef de projet NTIC
    Inscrit en
    Septembre 2006
    Messages
    3 580
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Chef de projet NTIC
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Septembre 2006
    Messages : 3 580
    Points : 5 194
    Points
    5 194
    Par défaut
    salut

    si tu utilises SVN ou autre gestionnaire de version, tu peux "taguer" ta version pour savoir laquelle utiliser...

    Au "pire", tu pourrais meme de faire un "NuPack" pour ne plus te poser de question...

  5. #5
    Membre confirmé
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Mars 2011
    Messages
    269
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mars 2011
    Messages : 269
    Points : 460
    Points
    460
    Par défaut
    Bonjour,

    Je vois pas d'autre solution que celle que tu proposes.
    1) Le probleme de cette solution, c'est bien la reproduction de bug. C'est une fausse bonne idée
    2) Comme le dit theMonz31, NuGet répondra simplement a ce besoin
    3) Ca reviens à 1)

    Mettre à jour des librairie externe n'est pas anodin, de mon expérience dans les 2/3 des cas la nouvelle version est rétro-compatible, mais dans le 1/3 restant c'est pas le cas, et là c'est la galère.

    Toujours de mon expérience la bonne solution c'est de laisser les projets ce mettre a jour.
    Que ça soit totalement manuellement, ou de manière packagé via NuGet.

    Les gestionnaires de dépendances ne mettent à jour les dépendance que sur demande, mais ils fournissent un ensemble cohérent.
    Les gestionnaires de dépendances ne gèrent pas a ma connaissance les versions incompatible

    Bref, laisse les projets ce mettre à jours.
    Et comme le dit theMonz31, toutes version d'une (ou d'un groupe de) librairie doit avoir sont tag SVN. Le numéro de version des librairies doit permettre de retrouver le tag SVN.
    Sans ce type d'information, la reproduction de bug peut devenir un cauchemar.

  6. #6
    Membre confirmé
    Profil pro
    Inscrit en
    Octobre 2007
    Messages
    1 002
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2007
    Messages : 1 002
    Points : 552
    Points
    552
    Par défaut
    OK merci les mecs d'avoir pris le temps de répondre sur cette question pas forcement lié au C# en elle même,

    Conclusion, on fait rien de plus : Ne pas oublier d'envoyer un mail à chaque publication de lib commune, et charge au chef de projet de ne pas oublier de l’intégrer...
    Ça me chiffonne quand même un peu... surtout pour les lib internes, mais bon je vais mis faire

Discussions similaires

  1. Réponses: 0
    Dernier message: 28/03/2011, 16h51
  2. Communication entre plusieurs fenetres
    Par tom42 dans le forum Général JavaScript
    Réponses: 16
    Dernier message: 03/03/2008, 17h49
  3. paramètres communs entre plusieurs html
    Par j.p.mignot dans le forum Général JavaScript
    Réponses: 7
    Dernier message: 13/01/2008, 16h45
  4. Réponses: 1
    Dernier message: 13/03/2007, 09h52
  5. Communication entre plusieurs applications.
    Par granquet dans le forum Linux
    Réponses: 9
    Dernier message: 01/06/2006, 14h42

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo