web-dev-qa-db-fra.com

Comment configurer PYTHONPATH pour un package instantané?

J'essaie de capturer le package d'un projet non-pur python. J'ai utilisé le plug-in python avec des scripts de génération/installation personnalisés.

Ce projet contient 2 python packages requis pour l'application de bureau:

  • alfanous (API)
  • _alfanous-desktop_ (interface graphique Qt PySide)

snapcraft.yaml fichier:

_name: alfanous
version: "0.7.8"
summary: Alfanous
description: GNU hello prints a friendly greeting.
  This is part of the snapcraft tour at http://snapcraft.io/create/
#confinement: strict
confinement: devmode

apps:
  alfanous-gui:
    command: usr/bin/alfanous-desktop
    #desktop: usr/share/applications/my-app.desktop
  alfanous-cli:
    command: usr/bin/alfanous-console

parts:
  alfanous-git:
    build-packages:
      #- python
      - sqlite3
      - pyside-tools
      - qt4-linguist-tools
      - python-babel
      - qt4-qmake
      - python-setuptools
      #- python-pyparsing
      #- Perl
    #plugin: make
    plugin: python
    python-version: python2
    #source: https://github.com/Alfanous-team/alfanous/archive/0.7.8.tar.gz
    source: https://github.com/Alfanous-team/alfanous.git
    source-type: git
    source-depth: 1
    #source-tag: 0.7.8
    build: |
      make build
    install: |
      echo _______#######:$(pwd)
      #make install_api 
      make install_api DESTDIR=$SNAPCRAFT_PART_INSTALL
      make install_desktop DESTDIR=$SNAPCRAFT_PART_INSTALL
    stage-packages:
      - python-pyparsing
      - python-pyside
      #- epydoc
      #- sphinx
      - python-babel
      - python-setuptools
    python-packages:
      - pyparsing
      - pyside
      - babel
_

Le paquet logiciel enfichable est construit et installé sans erreur. Cependant, si j'essaye de l'exécuter:

_$ alfanous.alfanous-cli
Traceback (most recent call last):
  File "/snap/alfanous/x3/usr/bin/alfanous-console", line 5, in <module>
    from pkg_resources import load_entry_point
  File "/snap/alfanous/x3/usr/lib/python2.7/dist-packages/pkg_resources/__init__.py", line 2927, in <module>
    @_call_aside
  File "/snap/alfanous/x3/usr/lib/python2.7/dist-packages/pkg_resources/__init__.py", line 2913, in _call_aside
    f(*args, **kwargs)
  File "/snap/alfanous/x3/usr/lib/python2.7/dist-packages/pkg_resources/__init__.py", line 2940, in _initialize_master_working_set
    working_set = WorkingSet._build_master()
  File "/snap/alfanous/x3/usr/lib/python2.7/dist-packages/pkg_resources/__init__.py", line 635, in _build_master
    ws.require(__requires__)
  File "/snap/alfanous/x3/usr/lib/python2.7/dist-packages/pkg_resources/__init__.py", line 943, in require
    needed = self.resolve(parse_requirements(requirements))
  File "/snap/alfanous/x3/usr/lib/python2.7/dist-packages/pkg_resources/__init__.py", line 829, in resolve
    raise DistributionNotFound(req, requirers)
pkg_resources.DistributionNotFound: The 'alfanous==0.7.29' distribution was not found and is required by the application
_

Mon premier suspect est non complet PYTHONPATH, en essayant de déboguer:

_snap run --Shell alfanous.alfanous-cli
env | grep -i python
_

n'apporte rien.

et les deux paquets sont là:

_$ ls /snap/alfanous/current/usr/lib/python2.7/site-packages/
alfanous                        alfanousDesktop
alfanous-0.7.29-py2.7.Egg-info  alfanousDesktop-0.7.29-py2.7.Egg-info
_

Comment configurer correctement PYTHONPATH? Le plugin python ne devrait-il pas s'en charger?

snapcraft v2.28 Ubuntu 16.04.2 LTS 64Bit

3
user.dz

J'ai modifié alfanous-console pour imprimer sys.path et reconstruire le cliché:

['/snap/alfanous/x4/usr/bin',
 '/snap/alfanous/x4/usr/lib/python2.7',
 '/snap/alfanous/x4/usr/lib/python2.7/plat-x86_64-linux-gnu',
 '/snap/alfanous/x4/usr/lib/python2.7/lib-tk',
 '/snap/alfanous/x4/usr/lib/python2.7/lib-old',
 '/snap/alfanous/x4/usr/lib/python2.7/lib-dynload',
 '/snap/alfanous/x4/usr/lib/python2.7/dist-packages']

Il semble clair que la snap n'inclut pas site-packages à PYTHONPATH où mon paquet cible s'installe.

  • Je dois donc modifier son chemin d'installation
  • Ou signalez-le à l’équipe instantanée pour ajouter usr/lib/python2.7/site-packages

    En relation Rapport de bug n ° 1670749: le confinement classique nécessite le paramétrage manuel de PATH et PYTHONPATH

    La solution suggérée n'a pas fonctionné:

    apps:
      alfanous-gui:
        command: usr/bin/alfanous-desktop
        environment:
          PATH: $SNAP/usr/bin:$SNAP/bin/:$PATH
          PYTHONPATH: $SNAP/usr/lib/python2.7/site-packages:$SNAP/usr/lib/python2.7/dist-packages:$PYTHONPATH
        #desktop: usr/share/applications/my-app.desktop
      alfanous-cli:
        command: usr/bin/alfanous-console
        environment:
          PATH: $SNAP/usr/bin:$SNAP/bin/:$PATH
          PYTHONPATH: $SNAP/usr/lib/python2.7/site-packages:$SNAP/usr/lib/python2.7/dist-packages:$PYTHONPATH
    

    À cause de ce chemin étrange pointant vers le dossier Host /home

    ['/snap/alfanous/x7/usr/bin',
     '/snap/alfanous/x7/usr/lib/python2.7/site-packages',
     '/snap/alfanous/x7/usr/lib/python2.7/dist-packages',
     '/usr/lib/python2.7/site-packages',
     '/usr/lib/python2.7/dist-packages',
     '/home/sneetsher/Desktop/sandbox/alfanous-snap',
     '/snap/alfanous/x7/usr/lib/python2.7',
     '/snap/alfanous/x7/usr/lib/python2.7/plat-x86_64-linux-gnu',
     '/snap/alfanous/x7/usr/lib/python2.7/lib-tk',
     '/snap/alfanous/x7/usr/lib/python2.7/lib-old',
     '/snap/alfanous/x7/usr/lib/python2.7/lib-dynload']
    
1
user.dz