Оказывается, это ожидаемое поведение.В локальной изолированной программной среде пользователям предлагается ввести адрес электронной почты, и (по умолчанию) для них создается «пользователь», и они автоматически входят в систему.
Из документа App Engine «Обзор Python API пользователя»:
Учетные записи Google и сервер разработки
Сервер разработки имитирует систему учетных записей Google с использованием фиктивного экрана входа.Когда ваше приложение вызывает API пользователей для получения URL-адреса для экрана входа, API возвращает URL-адрес специального сервера разработки, который запрашивает адрес электронной почты, но не вводит пароль.В это приглашение можно ввести любой адрес электронной почты, и приложение будет вести себя так, как будто вы вошли в систему с учетной записью с этим адресом.
Экран входа в систему также содержит флажок, указывающий, является ли учетная запись фиктивнойявляется администратором;то есть, имеет ли учетная запись примитивную роль «Просмотр», «Редактор» или «Владелец», или предопределенную роль администратора приложений App Engine.Если вы установите этот флажок, приложение будет вести себя так, как будто вы вошли в систему с использованием учетной записи администратора.
Аналогично, API-интерфейс пользователя возвращает URL-адрес выхода, который отменяет фиктивный вход.
Уникальный идентификатор объекта User на сервере разработки рассчитывается на основе адреса электронной почты.Два уникальных адреса электронной почты всегда представляют двух уникальных пользователей на сервере разработки.
Лично я считаю, что этот дизайн очень несовершенен.Я не знаю, что Google думает о манифесте «Двенадцать факторов», но такое поведение является вопиющим нарушением статьи 10 (Dev / Prod Parity), которая кратко излагается как «Делайте разработку, постановку и производство как можно более схожими».Я не вижу причин, по которым полный поток авторизации / перенаправления не будет работать в локальной песочнице, и, по крайней мере, пользователи должны иметь возможность выбрать его.(Я хотел бы любить , чтобы выяснить, что это вариант.)
Самая важная часть об этом условном поведении заключается в том, что API объекта пользователя отличается, поэтому я виделошибка, упомянутая в моем вопросе (объект 'GaeDatastoreUser' не имеет атрибута 'user_id').У локального пользователя также нет метода nickname
.