2016-08-21 3 views
2

Я разработал приложение appngine в GO, и теперь я попытался использовать androidpublisher api. Для этого мне нужно много зависимостей, таких как:golang appengine - filename too long

  • github.com/google/google-api-go-client
  • github.com/golang/oauth2
  • google.golang.org/appengine
  • google.golang.org/appengine/urlfetch

Я попытался аутентификации oauth2 настройки для Google-API-Go-клиента в соответствии с примером в https://github.com/golang/oauth2

Все выглядит нормально, но я больше не могу запускать приложение-сервер на моей машине разработки Windows. Он жалуется на слишком длинные имена файлов:

INFO  2016-08-20 22:48:03,786 devappserver2.py:769] Skipping SDK update check. 
INFO  2016-08-20 22:48:03,960 api_server.py:205] Starting API server at: http://localhost:64053 
INFO  2016-08-20 22:48:03,969 dispatcher.py:197] Starting module "default" running at: http://localhost:8080 
INFO  2016-08-20 22:48:03,974 admin_server.py:116] Starting admin server at:http://localhost:8000 

Exception in thread Instance Adjustment: Traceback (most recent call last): 
    File "C:\Python27\lib\threading.py", line 801, in __bootstrap_inner 
     self.run() 
    File "C:\Python27\lib\threading.py", line 754, in run 
     self.__target(*self.__args, **self.__kwargs) 
    File "C:\work\go_appengine\google\appengine\tools\devappserver2\module.py",line 1485, in _loop_adjusting_instances 
     self._adjust_instances() 
    File "C:\work\go_appengine\google\appengine\tools\devappserver2\module.py",line 1460, in _adjust_instances 
     self._add_instance(permit_warmup=True) 
    File "C:\work\go_appengine\google\appengine\tools\devappserver2\module.py",line 1338, in _add_instance 
     expect_ready_request=perform_warmup) 
    File "C:\work\go_appengine\google\appengine\tools\devappserver2\go_runtime.py",line 174, in new_instance 
     if self._go_application.maybe_build(self._modified_since_last_build): 
    File "C:\work\go_appengine\google\appengine\tools\devappserver2\go_application.py",line 304, in maybe_build 
     self._extras_hash, old_extras_hash = (self._get_extras_hash(), 
    File "C:\work\go_appengine\google\appengine\tools\devappserver2\go_application.py",line 247, in _get_extras_hash gab_stdout, 
     _ = self._run_gab(gab_args, env={}) 
    File "C:\work\go_appengine\google\appengine\tools\devappserver2\go_application.py",line 175, in _run_gab 
     gab_extra_args, env) 
    File "C:\work\go_appengine\google\appengine\tools\devappserver2\go_application.py",line 111, in _run_gab 
     env=env) 
    File "C:\work\go_appengine\google\appengine\tools\devappserver2\safe_subprocess.py",line 74, in start_process 
     stdin=subprocess.PIPE, startupinfo=startupinfo) 
    File "C:\Python27\lib\subprocess.py", line710, in __init__ 
     errread, errwrite) 
    File "C:\Python27\lib\subprocess.py", line 958, in _execute_child 
     startupinfo) 
    WindowsError: [Error 206] The filename or extension is too long 

Я думаю, что мой GOPATH настроен неправильно, таким образом, он дает все gofiles в качестве аргумента go-app-builder.exe.

Мой проект под C:\Users\me\project\ это где точки gopath до и были я стою, когда я типа:

goapp.bat serve . 
Can

кто-то помочь решить эту проблему? Спасибо.

EDIT

Моя структура проекта выглядит так: Как я должен установить мой GOPATH?

GOPATH 
    $GOPATH 
     app.yaml 
     cron.yaml 
     pkg 
     src 
      testapp 
       app.go 
     golang.org 
      x 
        oauth2 

Edit 2

Я попытался пошевелить GOPATH проецировать корн-Dir/gopath, но теперь я получаю сообщение об ошибке:

Exception in thread Instance Adjustment: Traceback (most recent call last): File "C:\Python27\lib\threading.py", line 810, in 
__bootstrap_inner 
    self.run() File "C:\Python27\lib\threading.py", line 763, in run 
    self.__target(*self.__args, **self.__kwargs) File "C:\Users\Indra\development\tools\go_appengine\google\appengine\tools\devappserver2\module.py", line 1486, in _loop_adjusting_instances 
    self._adjust_instances() File "C:\Users\Indra\development\tools\go_appengine\google\appengine\tools\devappserver2\module.py", line 1461, in _adjust_instances 
    self._add_instance(permit_warmup=True) File "C:\Users\Indra\development\tools\go_appengine\google\appengine\tools\devappserver2\module.py", line 1339, in _add_instance 
    expect_ready_request=perform_warmup) File "C:\Users\Indra\development\tools\go_appengine\google\appengine\tools\devappserver2\go_runtime.py", line 176, in new_instance 
    if self._go_application.maybe_build(self._modified_since_last_build): File "C:\Users\Indra\development\tools\go_appengine\google\appengine\tools\devappserver2\go_application.py", line 304, in maybe_build 
    self._extras_hash, old_extras_hash = (self._get_extras_hash(), File "C:\Users\Indra\development\tools\go_appengine\google\appengine\tools\devappserver2\go_application.py", line 247, in _get_extras_hash 
    gab_stdout, _ = self._run_gab(gab_args, env={}) File "C:\Users\Indra\development\tools\go_appengine\google\appengine\tools\devappserver2\go_application.py", line 175, in _run_gab 
    gab_extra_args, env) File "C:\Users\Indra\development\tools\go_appengine\google\appengine\tools\devappserver2\go_application.py", line 111, in _run_gab 
    env=env) File "C:\Users\Indra\development\tools\go_appengine\google\appengine\tools\devappserver2\safe_subprocess.py", line 74, in start_process 
    stdin=subprocess.PIPE, startupinfo=startupinfo) File "C:\Python27\lib\subprocess.py", line 710, in __init__ 
    errread, errwrite) File "C:\Python27\lib\subprocess.py", line 958, in _execute_child 
    startupinfo) WindowsError: [Error 87] Falscher Parameter 

для всех не немецких пользователей это жалуется на неправильный параметр

+0

Не пропустите dot '.', просто начните с' goapp serve'. Это исправить? – icza

+0

Используйте команду 'goapp.bat serve <путь к каталогу, содержащему app.yaml>' или cd, в этот каталог и запустите 'goapp.bat serve'. Если это не устранит проблему, посмотрите на http://stackoverflow.com/questions/38711615/appengine-appengine-package-always-fails-with-syscall-or-unsafe-import-fai/38713152#38713152 , У вас может быть GOPATH, указывающий на каталог приложения. –

+0

'goapp serve' не исправил его. Да, мой GOPATH указывает на приложение. Я редактировал свой пост с моей текущей структурой каталогов. – user3603632

ответ

0

Я решил проблему, установив свой GOPATH.

Это теперь ее так:

GOPATH=C:\Users\me\development\appengine\gopath;C:\Users\me\project 

Теперь все работает и найти загруженный файл гораздо меньше, в настоящее время. 2 МБ против 11 МБ.

Спасибо за подсказку.