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

Spring Java Discussion :

getResourceAsStream ne trouve pas le pom.properties en test pour donner la version du projet


Sujet :

Spring Java

  1. #1
    Membre éclairé

    Profil pro
    Inscrit en
    Janvier 2007
    Messages
    605
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2007
    Messages : 605
    Points : 670
    Points
    670
    Par défaut getResourceAsStream ne trouve pas le pom.properties en test pour donner la version du projet
    Bonjour,

    C'est une erreur toute bête qui m'affecte, mais je passe dessus sans parvenir à la résoudre. Elle est certainement enfantine, mais Ah ! Je passe à côté de sa solution depuis des jours !

    J'ai une méthode qui renvoie la version de mon application en allant la chercher dans le pom.properties généré par Maven. Celui qu'il place systématiquement dans META-INF/maven/[...].
    Elle fonctionne très bien déployée, mais lorsqu'elle est exécuté en test d'intégration par failsafe, elle échoue.

    Le jar où le pom.properties doit être trouvé est celui de l'artefact service.base,
    mais j'ai envisagé qu'il puisse ne pas être construit au moment du test, et j'ai placé une deuxième chance dans l'examen du jar des objets métiers, qui est compilé auparavant.

    Mais rien n'y fait. J'ai un NoSuchElementException. L'InputStream vaut null lors des tests.
    Avez-vous une idée de pourquoi ?

    Merci !

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
       /**
        * Renvoie un InputStream sur un des pom.properties. Celui de service.base, normalement, mais celui de objets.metiers pour les tests.
        * @return InputStream vers un pom.properties.
        * @throws NoSuchElementException si le POM ne peut être trouvé pour en extraire la version.
        */
       @SuppressWarnings("resource") 
       private InputStream getResourceAsStream()
       {
          InputStream is = getClass().getClassLoader().getResourceAsStream("/META-INF/maven/com.ardent.checker/service.base/pom.properties"); //$NON-NLS-1$
     
          if (is == null)
          {
             is = Environnement.class.getClassLoader().getResourceAsStream("/META-INF/maven/com.ardent.checker/objets.metiers/pom.properties"); //$NON-NLS-1$
          }
     
          if (is == null)
          {
             Ressources rsc = new Ressources(InstallationService.class);
             String message = rsc.format("excp.pom_manquant"); //$NON-NLS-1$
             throw new NoSuchElementException(message);
          }
     
          return is;
       }

  2. #2
    Expert éminent sénior
    Avatar de tchize_
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Avril 2007
    Messages
    25 481
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : Belgique

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

    Informations forums :
    Inscription : Avril 2007
    Messages : 25 481
    Points : 48 806
    Points
    48 806
    Par défaut
    Ce fichier est créé par maven archiver, qui est utilisé par le pluging jar. Il est intégré directement dans le jar. Le unit test n'utilise pas le jar mais le dossier build, donc le fichier n'y est pas présent. Si tu veux faire ce genre de test, je te suggère de mettre ce fichier dans src/rsc/test/META-INF/ (et de l'exclure lors de la construction du jar, pour éviter les conflits avec le pom autogénéré).

  3. #3
    Membre éclairé

    Profil pro
    Inscrit en
    Janvier 2007
    Messages
    605
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2007
    Messages : 605
    Points : 670
    Points
    670
    Par défaut
    Merci, il est effectivement passé en plaçant META-INF et ses sous-répertoires dans test/resources
    et moyennant cette adaptation supplémentaire :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
       @SuppressWarnings("resource") 
       private InputStream getResourceAsStream()
       {
          InputStream is = getClass().getResourceAsStream("/META-INF/maven/com.ardent.checker/service.base/pom.properties"); //$NON-NLS-1$
          
          if (is == null)
          {
             // Pour le test d'intégration.
             is = Thread.currentThread().getContextClassLoader().getResourceAsStream("/META-INF/maven/com.ardent.checker/service.base/pom.properties"); //$NON-NLS-1$
          }
          
          if (is == null)
          {
             Ressources rsc = new Ressources(InstallationService.class);
             String message = rsc.format("excp.pom_manquant"); //$NON-NLS-1$
             throw new NoSuchElementException(message);
          }
          
          return is;
       }
    Ah les Classloaders ! Faut réapprendre leur fonctionnement régulièrement...

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. [Axis2] Ne trouve pas mon log4j.properties
    Par houpli dans le forum Services Web
    Réponses: 1
    Dernier message: 23/05/2012, 12h03
  2. Je ne trouve pas de rubrique palm ou port pour une solution
    Par barney94 dans le forum Mode d'emploi & aide aux nouveaux
    Réponses: 2
    Dernier message: 07/02/2008, 22h24
  3. Réponses: 4
    Dernier message: 29/12/2007, 11h53
  4. [TP]trouve pas le graph.tpu
    Par kaygee dans le forum Turbo Pascal
    Réponses: 12
    Dernier message: 13/06/2003, 12h49
  5. [Kylix] [cgi] ne trouve pas libsqlmy.so.1 !
    Par Nepomiachty Olivier dans le forum EDI
    Réponses: 3
    Dernier message: 04/07/2002, 15h15

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