Модульные тесты Nosegae с gae-session в проекте Python Google App Engine

Я не могу заставить работать gae-sessions при использовании модульных тестов. Я не уверен, что это проблема с файлами cookie или внутренняя проблема gae-сессий (для сохранения используется memcache/хранилище данных). Он отлично работает в реальном приложении при доступе через браузер.

Я использую Python 2.5 в Mac OS 10.6.6, Google App Engine SDK 1.4.2, NoseGAE-0.1.7 и gae-sessions версии 1.06.

Вот мой код:


реализация веб-приложения:

from google.appengine.ext import webapp
from gaesessions import get_current_session

class cookietest(webapp.RequestHandler):
    def get(self):
        s = get_current_session()
        if not 'message' in s:
            self.response.out.write('No session value')
            s['message'] = 'This value is stored in a session'
        else:
            self.response.out.write("Message found: %s" % s['message'])

application = webapp.WSGIApplication([(r'/cookietest', cookietest)])

Реализация модульного теста:

def test_cookietest(self):
    from gaesessions import SessionMiddleware
    app_with_sessions = SessionMiddleware(application, cookie_key=os.urandom(64)) # random key
    self.app = TestApp(app_with_sessions)

    resp = self.app.get('/cookietest')
    cookie = resp.headers['Set-Cookie']
    assert cookie
    resp = self.app.get('/cookietest', headers={'Cookie': cookie})
    print resp
    assert 'This value is stored in a session' in resp

Соответствующий вывод:

FAIL: test_cookietest (tests.test.TestUser)
----------------------------------------------------------------------
Traceback (most recent call last):
  File "/Users/Asad/.../test.py", line 33, in test_cookietest
    assert 'This value is stored in a session' in resp
AssertionError: 
-------------------- >> begin captured stdout << ---------------------
Response: 200 OK
Cache-Control: no-cache
Content-Type: text/html; charset=utf-8
Expires: Fri, 01 Jan 1990 00:00:00 GMT
Set-Cookie:  DgU00="DQjpTdhQsKYYGhvNr/CLm+v835QV5V1jTX9T4wMULhI=1301034363_89b1c1007a6159e85828ab9a7673759cgAJ9cQB9cQFVB21lc3NhZ2VxAlUhVGhpcyB2YWx1ZSBpcyBzdG9yZWQgaW4gYSBzZXNzaW9ucQNzhnEELg=="; expires=Fri, 25-Mar-2011 06:26:03 GMT; Path=/; HttpOnly
No session value

--------------------- >> end captured stdout << ----------------------
-------------------- >> begin captured logging << --------------------
root: WARNING: Could not read datastore data from /var/folders/pt/ptPaW5O7E-eLIrfFhhczbU+++TI/-Tmp-/nosegae.datastore
root: INFO: zipimporter('/Library/Python/2.5/site-packages/NoseGAE-0.1.7-py2.5.egg', '')
root: INFO: zipimporter('/Library/Python/2.5/site-packages/WebTest-1.2.3-py2.5.egg', '')
root: INFO: zipimporter('/Library/Python/2.5/site-packages/WebOb-1.0-py2.5.egg', '')
root: INFO: zipimporter('/Library/Python/2.5/site-packages/mock-0.7.0b4-py2.5.egg', '')
root: DEBUG: Could not import "strop": Disallowed C-extension or built-in module
--------------------- >> end captured logging << ---------------------

----------------------------------------------------------------------
Ran 10 tests in 0.284s

FAILED (failures=1)

person Asad R.    schedule 18.03.2011    source источник


Ответы (1)


Я думаю, вам придется вручную сохранить сеанс в этом тесте.

   if not 'message' in s:
        self.response.out.write('No session value')
        s['message'] = 'This value is stored in a session'
        s.save()

Обновлять:

gae-sessions извлекает файл cookie сеанса из переменной os.environ['HTTP_COOKIE']. Это значение необходимо установить перед запросом self.app.get вместо передачи файла cookie в параметре headers.

person Calvin    schedule 18.03.2011
comment
Gae-sessions извлекает cookie из переменной os.environ['HTTP_COOKIE']. Я не думаю, что передача заголовка Cookie эквивалентна установке этого значения. - person Calvin; 29.03.2011
comment
Спасибо! это сработало. Я просто установил os.environ['HTTP_COOKIE'] перед моим запросом self.app.get(), и он отлично работает. Хотите отредактировать ответ или написать другой, чтобы я мог его принять? - person Asad R.; 30.03.2011